Governor Compatibility Bravo

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

function BALLOT_TYPEHASH() external view returns (bytes32)

Returns

NameTypeDescription

_0

bytes32

undefined

COUNTING_MODE

function COUNTING_MODE() external pure returns (string)

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

NameTypeDescription

_0

string

undefined

cancel

function cancel(uint256 proposalId) external nonpayable

Cancels a proposal only if sender is the proposer, or proposer delegates dropped below proposal threshold.

Parameters

NameTypeDescription

proposalId

uint256

undefined

castVote

function castVote(uint256 proposalId, uint8 support) external nonpayable returns (uint256)

See {IGovernor-castVote}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

support

uint8

undefined

Returns

NameTypeDescription

_0

uint256

undefined

castVoteBySig

function castVoteBySig(uint256 proposalId, uint8 support, uint8 v, bytes32 r, bytes32 s) external nonpayable returns (uint256)

See {IGovernor-castVoteBySig}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

support

uint8

undefined

v

uint8

undefined

r

bytes32

undefined

s

bytes32

undefined

Returns

NameTypeDescription

_0

uint256

undefined

castVoteWithReason

function castVoteWithReason(uint256 proposalId, uint8 support, string reason) external nonpayable returns (uint256)

See {IGovernor-castVoteWithReason}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

support

uint8

undefined

reason

string

undefined

Returns

NameTypeDescription

_0

uint256

undefined

execute

function execute(address[] targets, uint256[] values, bytes[] calldatas, bytes32 descriptionHash) external payable returns (uint256)

See {IGovernor-execute}.

Parameters

NameTypeDescription

targets

address[]

undefined

values

uint256[]

undefined

calldatas

bytes[]

undefined

descriptionHash

bytes32

undefined

Returns

NameTypeDescription

_0

uint256

undefined

execute

function execute(uint256 proposalId) external payable

See {IGovernorCompatibilityBravo-execute}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

getActions

function getActions(uint256 proposalId) external view returns (address[] targets, uint256[] values, string[] signatures, bytes[] calldatas)

See {IGovernorCompatibilityBravo-getActions}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

Returns

NameTypeDescription

targets

address[]

undefined

values

uint256[]

undefined

signatures

string[]

undefined

calldatas

bytes[]

undefined

getReceipt

function getReceipt(uint256 proposalId, address voter) external view returns (struct IGovernorCompatibilityBravo.Receipt)

See {IGovernorCompatibilityBravo-getReceipt}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

voter

address

undefined

Returns

NameTypeDescription

_0

IGovernorCompatibilityBravo.Receipt

undefined

getVotes

function getVotes(address account, uint256 blockNumber) external view returns (uint256)

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

NameTypeDescription

account

address

undefined

blockNumber

uint256

undefined

Returns

NameTypeDescription

_0

uint256

undefined

hasVoted

function hasVoted(uint256 proposalId, address account) external view returns (bool)

See {IGovernor-hasVoted}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

account

address

undefined

Returns

NameTypeDescription

_0

bool

undefined

hashProposal

function hashProposal(address[] targets, uint256[] values, bytes[] calldatas, bytes32 descriptionHash) external pure returns (uint256)

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

NameTypeDescription

targets

address[]

undefined

values

uint256[]

undefined

calldatas

bytes[]

undefined

descriptionHash

bytes32

undefined

Returns

NameTypeDescription

_0

uint256

undefined

name

function name() external view returns (string)

See {IGovernor-name}.

Returns

NameTypeDescription

_0

string

undefined

proposalDeadline

function proposalDeadline(uint256 proposalId) external view returns (uint256)

See {IGovernor-proposalDeadline}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

Returns

NameTypeDescription

_0

uint256

undefined

proposalEta

function proposalEta(uint256 proposalId) external view returns (uint256)

Parameters

NameTypeDescription

proposalId

uint256

undefined

Returns

NameTypeDescription

_0

uint256

undefined

proposalSnapshot

function proposalSnapshot(uint256 proposalId) external view returns (uint256)

See {IGovernor-proposalSnapshot}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

Returns

NameTypeDescription

_0

uint256

undefined

proposalThreshold

function proposalThreshold() external view returns (uint256)

Part of the Governor Bravo's interface: "The number of votes required in order for a voter to become a proposer".

Returns

NameTypeDescription

_0

uint256

undefined

proposals

function proposals(uint256 proposalId) external view returns (uint256 id, address proposer, uint256 eta, uint256 startBlock, uint256 endBlock, uint256 forVotes, uint256 againstVotes, uint256 abstainVotes, bool canceled, bool executed)

See {IGovernorCompatibilityBravo-proposals}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

Returns

NameTypeDescription

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

function propose(address[] targets, uint256[] values, bytes[] calldatas, string description) external nonpayable returns (uint256)

See {IGovernor-propose}.

Parameters

NameTypeDescription

targets

address[]

undefined

values

uint256[]

undefined

calldatas

bytes[]

undefined

description

string

undefined

Returns

NameTypeDescription

_0

uint256

undefined

propose

function propose(address[] targets, uint256[] values, string[] signatures, bytes[] calldatas, string description) external nonpayable returns (uint256)

See {IGovernorCompatibilityBravo-propose}.

Parameters

NameTypeDescription

targets

address[]

undefined

values

uint256[]

undefined

signatures

string[]

undefined

calldatas

bytes[]

undefined

description

string

undefined

Returns

NameTypeDescription

_0

uint256

undefined

queue

function queue(address[] targets, uint256[] values, bytes[] calldatas, bytes32 descriptionHash) external nonpayable returns (uint256 proposalId)

Parameters

NameTypeDescription

targets

address[]

undefined

values

uint256[]

undefined

calldatas

bytes[]

undefined

descriptionHash

bytes32

undefined

Returns

NameTypeDescription

proposalId

uint256

undefined

queue

function queue(uint256 proposalId) external nonpayable

See {IGovernorCompatibilityBravo-queue}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

quorum

function quorum(uint256 blockNumber) external view returns (uint256)

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

NameTypeDescription

blockNumber

uint256

undefined

Returns

NameTypeDescription

_0

uint256

undefined

quorumVotes

function quorumVotes() external view returns (uint256)

See {IGovernorCompatibilityBravo-quorumVotes}.

Returns

NameTypeDescription

_0

uint256

undefined

state

function state(uint256 proposalId) external view returns (enum IGovernor.ProposalState)

See {IGovernor-state}.

Parameters

NameTypeDescription

proposalId

uint256

undefined

Returns

NameTypeDescription

_0

enum IGovernor.ProposalState

undefined

supportsInterface

function supportsInterface(bytes4 interfaceId) external view returns (bool)

See {IERC165-supportsInterface}.

Parameters

NameTypeDescription

interfaceId

bytes4

undefined

Returns

NameTypeDescription

_0

bool

undefined

timelock

function timelock() external view returns (address)

Returns

NameTypeDescription

_0

address

undefined

version

function version() external view returns (string)

See {IGovernor-version}.

Returns

NameTypeDescription

_0

string

undefined

votingDelay

function votingDelay() external view returns (uint256)

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

NameTypeDescription

_0

uint256

undefined

votingPeriod

function votingPeriod() external view returns (uint256)

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

NameTypeDescription

_0

uint256

undefined

Events

ProposalCanceled

event ProposalCanceled(uint256 proposalId)

Parameters

NameTypeDescription

proposalId

uint256

undefined

ProposalCreated

event ProposalCreated(uint256 proposalId, address proposer, address[] targets, uint256[] values, string[] signatures, bytes[] calldatas, uint256 startBlock, uint256 endBlock, string description)

Parameters

NameTypeDescription

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

event ProposalExecuted(uint256 proposalId)

Parameters

NameTypeDescription

proposalId

uint256

undefined

ProposalQueued

event ProposalQueued(uint256 proposalId, uint256 eta)

Parameters

NameTypeDescription

proposalId

uint256

undefined

eta

uint256

undefined

VoteCast

event VoteCast(address indexed voter, uint256 proposalId, uint8 support, uint256 weight, string reason)

Parameters

NameTypeDescription

voter indexed

address

undefined

proposalId

uint256

undefined

support

uint8

undefined

weight

uint256

undefined

reason

string

undefined

Last updated