ISecureUpgradeable
Author: Quantillon Labs - Nicolas Bellengé - @chewbaccoin
Interface for the SecureUpgradeable base contract
Note: security-contact: team@quantillon.money
Functions
initialize
Initializes the secure upgradeable contract
Sets up the secure upgradeable with initial configuration and assigns roles to admin
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to initializer modifier 
- 
oracle: No oracle dependencies 
function initialize(address admin) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| admin | address | Address that receives admin roles | 
setTimelock
Set the timelock contract
Configures the timelock contract for secure upgrade management
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function setTimelock(address _timelock) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| _timelock | address | Address of the timelock contract | 
toggleSecureUpgrades
Toggle secure upgrades
Enables or disables the secure upgrade mechanism
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function toggleSecureUpgrades(bool enabled) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| enabled | bool | Whether to enable secure upgrades | 
proposeUpgrade
Propose an upgrade through the timelock
Initiates a secure upgrade proposal with timelock delay
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function proposeUpgrade(address newImplementation, string calldata description, uint256 customDelay) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newImplementation | address | Address of the new implementation | 
| description | string | Description of the upgrade | 
| customDelay | uint256 | Optional custom delay | 
executeUpgrade
Execute an upgrade through the timelock
Executes a previously proposed upgrade after timelock delay
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function executeUpgrade(address newImplementation) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newImplementation | address | Address of the new implementation | 
emergencyUpgrade
Emergency upgrade (bypasses timelock, requires emergency mode)
Performs immediate upgrade in emergency situations
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function emergencyUpgrade(address newImplementation, string calldata description) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newImplementation | address | Address of the new implementation | 
| description | string | Description of the emergency upgrade | 
isUpgradePending
Check if an upgrade is pending
Checks if there's a pending upgrade for the given implementation
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function isUpgradePending(address implementation) external view returns (bool isPending);
Parameters
| Name | Type | Description | 
|---|---|---|
| implementation | address | Address of the implementation | 
Returns
| Name | Type | Description | 
|---|---|---|
| isPending | bool | Whether the upgrade is pending | 
getPendingUpgrade
Get pending upgrade details
Returns detailed information about a pending upgrade
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function getPendingUpgrade(address implementation)
    external
    view
    returns (ITimelockUpgradeable.PendingUpgrade memory upgrade);
Parameters
| Name | Type | Description | 
|---|---|---|
| implementation | address | Address of the implementation | 
Returns
| Name | Type | Description | 
|---|---|---|
| upgrade | ITimelockUpgradeable.PendingUpgrade | Pending upgrade details | 
canExecuteUpgrade
Check if an upgrade can be executed
Checks if the timelock delay has passed and upgrade can be executed
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function canExecuteUpgrade(address implementation) external view returns (bool canExecute);
Parameters
| Name | Type | Description | 
|---|---|---|
| implementation | address | Address of the implementation | 
Returns
| Name | Type | Description | 
|---|---|---|
| canExecute | bool | Whether the upgrade can be executed | 
getUpgradeSecurityStatus
Get upgrade security status
Returns current security configuration for upgrades
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function getUpgradeSecurityStatus()
    external
    view
    returns (address timelockAddress, bool secureUpgradesEnabled_, bool hasTimelock);
Returns
| Name | Type | Description | 
|---|---|---|
| timelockAddress | address | Address of the timelock contract | 
| secureUpgradesEnabled_ | bool | Whether secure upgrades are enabled | 
| hasTimelock | bool | Whether timelock is set | 
emergencyDisableSecureUpgrades
Disable secure upgrades in emergency
Emergency function to disable secure upgrade mechanism
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function emergencyDisableSecureUpgrades() external;
enableSecureUpgrades
Enable secure upgrades after emergency
Re-enables secure upgrade mechanism after emergency
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function enableSecureUpgrades() external;
timelock
Returns the timelock contract address
Returns the ITimelockUpgradeable contract instance
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function timelock() external view returns (ITimelockUpgradeable);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | ITimelockUpgradeable | The timelock contract | 
secureUpgradesEnabled
Returns whether secure upgrades are enabled
Indicates if the secure upgrade mechanism is active
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function secureUpgradesEnabled() external view returns (bool);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | True if secure upgrades are enabled | 
UPGRADER_ROLE
Returns the upgrader role identifier
Role that can perform upgrades
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function UPGRADER_ROLE() external view returns (bytes32);
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | The upgrader role bytes32 identifier | 
hasRole
Checks if an account has a specific role
Returns true if the account has been granted the role
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function hasRole(bytes32 role, address account) external view returns (bool);
Parameters
| Name | Type | Description | 
|---|---|---|
| role | bytes32 | The role to check | 
| account | address | The account to check | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bool | True if the account has the role | 
getRoleAdmin
Gets the admin role for a given role
Returns the role that is the admin of the given role
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function getRoleAdmin(bytes32 role) external view returns (bytes32);
Parameters
| Name | Type | Description | 
|---|---|---|
| role | bytes32 | The role to get admin for | 
Returns
| Name | Type | Description | 
|---|---|---|
| <none> | bytes32 | The admin role | 
grantRole
Grants a role to an account
Can only be called by an account with the admin role
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function grantRole(bytes32 role, address account) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| role | bytes32 | The role to grant | 
| account | address | The account to grant the role to | 
revokeRole
Revokes a role from an account
Can only be called by an account with the admin role
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function revokeRole(bytes32 role, address account) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| role | bytes32 | The role to revoke | 
| account | address | The account to revoke the role from | 
renounceRole
Renounces a role from the caller
The caller gives up their own role
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function renounceRole(bytes32 role, address callerConfirmation) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| role | bytes32 | The role to renounce | 
| callerConfirmation | address | Confirmation that the caller is renouncing their own role | 
upgradeTo
Upgrades the contract to a new implementation
Can only be called by accounts with UPGRADER_ROLE
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function upgradeTo(address newImplementation) external;
Parameters
| Name | Type | Description | 
|---|---|---|
| newImplementation | address | Address of the new implementation contract | 
upgradeToAndCall
Upgrades the contract to a new implementation and calls a function
Can only be called by accounts with UPGRADER_ROLE
Notes:
- 
security: Validates input parameters and enforces security checks 
- 
validation: Validates input parameters and business logic constraints 
- 
state-changes: Updates contract state variables 
- 
events: Emits relevant events for state changes 
- 
errors: Throws custom errors for invalid conditions 
- 
reentrancy: Protected by reentrancy guard 
- 
access: Restricted to authorized roles 
- 
oracle: Requires fresh oracle price data 
function upgradeToAndCall(address newImplementation, bytes memory data) external payable;
Parameters
| Name | Type | Description | 
|---|---|---|
| newImplementation | address | Address of the new implementation contract | 
| data | bytes | Encoded function call data | 
