Governor Timelock Compound
Extension of {Governor} that binds the execution process to a Compound Timelock. This adds a delay, enforced by the external timelock to all successful proposal (in addition to the voting duration). The {Governor} needs to be the admin of the timelock for any operation to be performed. A public, unrestricted, {GovernorTimelockCompound-__acceptAdmin} is available to accept ownership of the timelock. Using this model means the proposal will be operated by the {TimelockController} and not by the {Governor}. Thus, the assets and permissions must be attached to the {TimelockController}. Any asset sent to the {Governor} will be inaccessible. Available since v4.3.
Methods
BALLOT_TYPEHASH
Returns
Name | Type | Description |
---|---|---|
_0 | bytes32 | undefined |
COUNTING_MODE
module:voting
A description of the possible support
values for {castVote} and the way these votes are counted, meant to be consumed by UIs to show correct vote options and interpret the results. The string is a URL-encoded sequence of key-value pairs that each describe one aspect, for example support=bravo&quorum=for,abstain
. There are 2 standard keys: support
and quorum
. - support=bravo
refers to the vote options 0 = For, 1 = Against, 2 = Abstain, as in GovernorBravo
. - quorum=bravo
means that only For votes are counted towards quorum. - quorum=for,abstain
means that both For and Abstain votes are counted towards quorum. NOTE: The string can be decoded by the standard https://developer.mozilla.org/en-US/docs/Web/API/URLSearchParams[URLSearchParams
] JavaScript class.
Returns
Name | Type | Description |
---|---|---|
_0 | string | undefined |
__acceptAdmin
Accept admin right over the timelock.
castVote
See {IGovernor-castVote}.
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
support | uint8 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
castVoteBySig
See {IGovernor-castVoteBySig}.
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
support | uint8 | undefined |
v | uint8 | undefined |
r | bytes32 | undefined |
s | bytes32 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
castVoteWithReason
See {IGovernor-castVoteWithReason}.
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
support | uint8 | undefined |
reason | string | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
execute
See {IGovernor-execute}.
Parameters
Name | Type | Description |
---|---|---|
targets | address[] | undefined |
values | uint256[] | undefined |
calldatas | bytes[] | undefined |
descriptionHash | bytes32 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
getVotes
module:reputation
Voting power of an account
at a specific blockNumber
. Note: this can be implemented in a number of ways, for example by reading the delegated balance from one (or multiple), {ERC20Votes} tokens.
Parameters
Name | Type | Description |
---|---|---|
account | address | undefined |
blockNumber | uint256 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
hasVoted
module:voting
Returns weither account
has cast a vote on proposalId
.
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
account | address | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | bool | undefined |
hashProposal
See {IGovernor-hashProposal}. The proposal id is produced by hashing the RLC encoded targets
array, the values
array, the calldatas
array and the descriptionHash (bytes32 which itself is the keccak256 hash of the description string). This proposal id can be produced from the proposal data which is part of the {ProposalCreated} event. It can even be computed in advance, before the proposal is submitted. Note that the chainId and the governor address are not part of the proposal id computation. Consequently, the same proposal (with same operation and same description) will have the same id if submitted on multiple governors accross multiple networks. This also means that in order to execute the same operation twice (on the same governor) the proposer will have to change the description in order to avoid proposal id conflicts.
Parameters
Name | Type | Description |
---|---|---|
targets | address[] | undefined |
values | uint256[] | undefined |
calldatas | bytes[] | undefined |
descriptionHash | bytes32 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
name
See {IGovernor-name}.
Returns
Name | Type | Description |
---|---|---|
_0 | string | undefined |
proposalDeadline
See {IGovernor-proposalDeadline}.
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
proposalEta
Public accessor to check the eta of a queued proposal
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
proposalSnapshot
See {IGovernor-proposalSnapshot}.
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
propose
See {IGovernor-propose}.
Parameters
Name | Type | Description |
---|---|---|
targets | address[] | undefined |
values | uint256[] | undefined |
calldatas | bytes[] | undefined |
description | string | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
queue
Function to queue a proposal to the timelock.
Parameters
Name | Type | Description |
---|---|---|
targets | address[] | undefined |
values | uint256[] | undefined |
calldatas | bytes[] | undefined |
descriptionHash | bytes32 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
quorum
module:user-config
Minimum number of cast voted required for a proposal to be successful. Note: The blockNumber
parameter corresponds to the snaphot used for counting vote. This allows to scale the quroum depending on values such as the totalSupply of a token at this block (see {ERC20Votes}).
Parameters
Name | Type | Description |
---|---|---|
blockNumber | uint256 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
state
Overriden version of the {Governor-state} function with added support for the Queued
and Expired
status.
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | enum IGovernor.ProposalState | undefined |
supportsInterface
See {IERC165-supportsInterface}.
Parameters
Name | Type | Description |
---|---|---|
interfaceId | bytes4 | undefined |
Returns
Name | Type | Description |
---|---|---|
_0 | bool | undefined |
timelock
Public accessor to check the address of the timelock
Returns
Name | Type | Description |
---|---|---|
_0 | address | undefined |
updateTimelock
Public endpoint to update the underlying timelock instance. Restricted to the timelock itself, so updates must be proposed, scheduled and executed using the {Governor} workflow. For security reason, the timelock must be handed over to another admin before setting up a new one. The two operations (hand over the timelock) and do the update can be batched in a single proposal. Note that if the timelock admin has been handed over in a previous operation, we refuse updates made through the timelock if admin of the timelock has already been accepted and the operation is executed outside the scope of governance.
Parameters
Name | Type | Description |
---|---|---|
newTimelock | contract ICompoundTimelock | undefined |
version
See {IGovernor-version}.
Returns
Name | Type | Description |
---|---|---|
_0 | string | undefined |
votingDelay
module:user-config
delay, in number of block, between the proposal is created and the vote starts. This can be increassed to leave time for users to buy voting power, of delegate it, before the voting of a proposal starts.
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
votingPeriod
module:user-config
delay, in number of blocks, between the vote start and vote ends. Note: the {votingDelay} can delay the start of the vote. This must be considered when setting the voting duration compared to the voting delay.
Returns
Name | Type | Description |
---|---|---|
_0 | uint256 | undefined |
Events
ProposalCanceled
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
ProposalCreated
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
proposer | address | undefined |
targets | address[] | undefined |
values | uint256[] | undefined |
signatures | string[] | undefined |
calldatas | bytes[] | undefined |
startBlock | uint256 | undefined |
endBlock | uint256 | undefined |
description | string | undefined |
ProposalExecuted
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
ProposalQueued
Parameters
Name | Type | Description |
---|---|---|
proposalId | uint256 | undefined |
eta | uint256 | undefined |
TimelockChange
Emitted when the timelock controller used for proposal execution is modified.
Parameters
Name | Type | Description |
---|---|---|
oldTimelock | address | undefined |
newTimelock | address | undefined |
VoteCast
Parameters
Name | Type | Description |
---|---|---|
voter | address | undefined |
proposalId | uint256 | undefined |
support | uint8 | undefined |
weight | uint256 | undefined |
reason | string | undefined |
Last updated