Governor Compatibility Bravo Upgradeable
Compatibility layer that implements GovernorBravo compatibility on to of {Governor}. This compatibility layer includes a voting system and requires a {IGovernorTimelock} compatible module to be added through inheritance. It does not include token bindings, not does it include any variable upgrade patterns. Available since v4.3.
Methods
BALLOT_TYPEHASH
Returns
_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
_0
string
undefined
cancel
Cancels a proposal only if sender is the proposer, or proposer delegates dropped below proposal threshold.
Parameters
proposalId
uint256
undefined
castVote
See {IGovernor-castVote}.
Parameters
proposalId
uint256
undefined
support
uint8
undefined
Returns
_0
uint256
undefined
castVoteBySig
See {IGovernor-castVoteBySig}.
Parameters
proposalId
uint256
undefined
support
uint8
undefined
v
uint8
undefined
r
bytes32
undefined
s
bytes32
undefined
Returns
_0
uint256
undefined
castVoteWithReason
See {IGovernor-castVoteWithReason}.
Parameters
proposalId
uint256
undefined
support
uint8
undefined
reason
string
undefined
Returns
_0
uint256
undefined
execute
See {IGovernor-execute}.
Parameters
targets
address[]
undefined
values
uint256[]
undefined
calldatas
bytes[]
undefined
descriptionHash
bytes32
undefined
Returns
_0
uint256
undefined
execute
See {IGovernorCompatibilityBravo-execute}.
Parameters
proposalId
uint256
undefined
getActions
See {IGovernorCompatibilityBravo-getActions}.
Parameters
proposalId
uint256
undefined
Returns
targets
address[]
undefined
values
uint256[]
undefined
signatures
string[]
undefined
calldatas
bytes[]
undefined
getReceipt
See {IGovernorCompatibilityBravo-getReceipt}.
Parameters
proposalId
uint256
undefined
voter
address
undefined
Returns
_0
IGovernorCompatibilityBravoUpgradeable.Receipt
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
account
address
undefined
blockNumber
uint256
undefined
Returns
_0
uint256
undefined
hasVoted
See {IGovernor-hasVoted}.
Parameters
proposalId
uint256
undefined
account
address
undefined
Returns
_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
targets
address[]
undefined
values
uint256[]
undefined
calldatas
bytes[]
undefined
descriptionHash
bytes32
undefined
Returns
_0
uint256
undefined
name
See {IGovernor-name}.
Returns
_0
string
undefined
proposalDeadline
See {IGovernor-proposalDeadline}.
Parameters
proposalId
uint256
undefined
Returns
_0
uint256
undefined
proposalEta
Parameters
proposalId
uint256
undefined
Returns
_0
uint256
undefined
proposalSnapshot
See {IGovernor-proposalSnapshot}.
Parameters
proposalId
uint256
undefined
Returns
_0
uint256
undefined
proposalThreshold
Part of the Governor Bravo's interface: "The number of votes required in order for a voter to become a proposer".
Returns
_0
uint256
undefined
proposals
See {IGovernorCompatibilityBravo-proposals}.
Parameters
proposalId
uint256
undefined
Returns
id
uint256
undefined
proposer
address
undefined
eta
uint256
undefined
startBlock
uint256
undefined
endBlock
uint256
undefined
forVotes
uint256
undefined
againstVotes
uint256
undefined
abstainVotes
uint256
undefined
canceled
bool
undefined
executed
bool
undefined
propose
See {IGovernor-propose}.
Parameters
targets
address[]
undefined
values
uint256[]
undefined
calldatas
bytes[]
undefined
description
string
undefined
Returns
_0
uint256
undefined
propose
See {IGovernorCompatibilityBravo-propose}.
Parameters
targets
address[]
undefined
values
uint256[]
undefined
signatures
string[]
undefined
calldatas
bytes[]
undefined
description
string
undefined
Returns
_0
uint256
undefined
queue
Parameters
targets
address[]
undefined
values
uint256[]
undefined
calldatas
bytes[]
undefined
descriptionHash
bytes32
undefined
Returns
proposalId
uint256
undefined
queue
See {IGovernorCompatibilityBravo-queue}.
Parameters
proposalId
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
blockNumber
uint256
undefined
Returns
_0
uint256
undefined
quorumVotes
See {IGovernorCompatibilityBravo-quorumVotes}.
Returns
_0
uint256
undefined
state
See {IGovernor-state}.
Parameters
proposalId
uint256
undefined
Returns
_0
enum IGovernorUpgradeable.ProposalState
undefined
supportsInterface
See {IERC165-supportsInterface}.
Parameters
interfaceId
bytes4
undefined
Returns
_0
bool
undefined
timelock
Returns
_0
address
undefined
version
See {IGovernor-version}.
Returns
_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
_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
_0
uint256
undefined
Events
ProposalCanceled
Parameters
proposalId
uint256
undefined
ProposalCreated
Parameters
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
proposalId
uint256
undefined
ProposalQueued
Parameters
proposalId
uint256
undefined
eta
uint256
undefined
VoteCast
Parameters
voter indexed
address
undefined
proposalId
uint256
undefined
support
uint8
undefined
weight
uint256
undefined
reason
string
undefined
Last updated