MACI
A contract which allows users to sign up, and deploy new polls
stateTreeDepth
uint8 stateTreeDepth
The state tree depth is fixed. As such it should be as large as feasible so that there can be as many users as possible. i.e. 2 ** 23 = 8388608 this should also match the parameter of the circom circuits. IMPORTANT: remember to change the ballot tree depth in contracts/ts/genEmptyBallotRootsContract.ts file if we change the state tree depth!
maxSignups
uint256 maxSignups
TREE_ARITY
uint8 TREE_ARITY
BLANK_STATE_LEAF_HASH
uint256 BLANK_STATE_LEAF_HASH
The hash of a blank state leaf
emptyBallotRoots
uint256[5] emptyBallotRoots
The roots of the empty ballot trees
nextPollId
uint256 nextPollId
Each poll has an incrementing ID
polls
mapping(uint256 => struct MACI.PollContracts) polls
A mapping of poll IDs to Poll contracts.
pollFactory
contract IPollFactory pollFactory
Factory contract that deploy a Poll contract
messageProcessorFactory
contract IMessageProcessorFactory messageProcessorFactory
Factory contract that deploy a MessageProcessor contract
tallyFactory
contract ITallyFactory tallyFactory
Factory contract that deploy a Tally contract
lazyIMTData
struct LazyIMTData lazyIMTData
The state tree. Represents a mapping between each user's public key and their voice credit balance.
signUpGatekeeper
contract SignUpGatekeeper signUpGatekeeper
Address of the SignUpGatekeeper, a contract which determines whether a user may sign up to vote
initialVoiceCreditProxy
contract InitialVoiceCreditProxy initialVoiceCreditProxy
The contract which provides the values of the initial voice credit balance per user
PollContracts
A struct holding the addresses of poll, mp and tally
struct PollContracts {
address poll;
address messageProcessor;
address tally;
}
SignUp
event SignUp(uint256 _stateIndex, uint256 _userPubKeyX, uint256 _userPubKeyY, uint256 _voiceCreditBalance, uint256 _timestamp)
DeployPoll
event DeployPoll(uint256 _pollId, uint256 _coordinatorPubKeyX, uint256 _coordinatorPubKeyY, enum DomainObjs.Mode _mode)
PoseidonHashLibrariesNotLinked
error PoseidonHashLibrariesNotLinked()
custom errors
TooManySignups
error TooManySignups()
InvalidPubKey
error InvalidPubKey()
PollDoesNotExist
error PollDoesNotExist(uint256 pollId)
constructor
constructor(contract IPollFactory _pollFactory, contract IMessageProcessorFactory _messageProcessorFactory, contract ITallyFactory _tallyFactory, contract SignUpGatekeeper _signUpGatekeeper, contract InitialVoiceCreditProxy _initialVoiceCreditProxy, uint8 _stateTreeDepth, uint256[5] _emptyBallotRoots) public payable
Create a new instance of the MACI contract.
Parameters
Name | Type | Description |
---|---|---|
_pollFactory | contract IPollFactory | The PollFactory contract |
_messageProcessorFactory | contract IMessageProcessorFactory | The MessageProcessorFactory contract |
_tallyFactory | contract ITallyFactory | The TallyFactory contract |
_signUpGatekeeper | contract SignUpGatekeeper | The SignUpGatekeeper contract |
_initialVoiceCreditProxy | contract InitialVoiceCreditProxy | The InitialVoiceCreditProxy contract |
_stateTreeDepth | uint8 | The depth of the state tree |
_emptyBallotRoots | uint256[5] | The roots of the empty ballot trees |
signUp
function signUp(struct DomainObjs.PubKey _pubKey, bytes _signUpGatekeeperData, bytes _initialVoiceCreditProxyData) public virtual
Allows any eligible user sign up. The sign-up gatekeeper should prevent double sign-ups or ineligible users from doing so. This function will only succeed if the sign-up deadline has not passed. It also enqueues a fresh state leaf into the state AccQueue.
Parameters
Name | Type | Description |
---|---|---|
_pubKey | struct DomainObjs.PubKey | The user's desired public key. |
_signUpGatekeeperData | bytes | Data to pass to the sign-up gatekeeper's register() function. For instance, the POAPGatekeeper or SignUpTokenGatekeeper requires this value to be the ABI-encoded token ID. |
_initialVoiceCreditProxyData | bytes | Data to pass to the InitialVoiceCreditProxy, which allows it to determine how many voice credits this user should have. |
deployPoll
function deployPoll(uint256 _duration, struct Params.TreeDepths _treeDepths, struct DomainObjs.PubKey _coordinatorPubKey, address _verifier, address _vkRegistry, enum DomainObjs.Mode _mode) public virtual
Deploy a new Poll contract.
Parameters
Name | Type | Description |
---|---|---|
_duration | uint256 | How long should the Poll last for |
_treeDepths | struct Params.TreeDepths | The depth of the Merkle trees |
_coordinatorPubKey | struct DomainObjs.PubKey | The coordinator's public key |
_verifier | address | The Verifier Contract |
_vkRegistry | address | The VkRegistry Contract |
_mode | enum DomainObjs.Mode | Voting mode |
getStateTreeRoot
function getStateTreeRoot() public view returns (uint256 root)
Return the main root of the StateAq contract
Return Values
Name | Type | Description |
---|---|---|
root | uint256 | The Merkle root |
getPoll
function getPoll(uint256 _pollId) public view returns (struct MACI.PollContracts pollContracts)
Get the Poll details
Parameters
Name | Type | Description |
---|---|---|
_pollId | uint256 | The identifier of the Poll to retrieve |
Return Values
Name | Type | Description |
---|---|---|
pollContracts | struct MACI.PollContracts | The Poll contract object |
numSignUps
function numSignUps() public view returns (uint256 signUps)
Get the number of signups
Return Values
Name | Type | Description |
---|---|---|
signUps | uint256 | numsignUps The number of signups |