-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
docs(contracts): add draft docs for contracts #328
Merged
+1,129
−67
Merged
Changes from all commits
Commits
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,3 @@ | ||
docs | ||
.env | ||
deploy-config.json | ||
deployed-contracts.json | ||
|
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,189 @@ | ||
# Smart Contracts Documentation | ||
|
||
## Overview | ||
|
||
This documentation provides details on the smart contracts used in the system, including their properties and methods. It also includes integration notes for connecting these contracts with other components like `maci-subgraph`. | ||
|
||
## Contracts | ||
|
||
### Contract: `EASRegistryManager` | ||
|
||
The `EASRegistryManager` contract handles requests for registry management. Users send requests to this contract, and a coordinator approves or rejects these requests. | ||
|
||
#### Properties | ||
|
||
- **contractId**: `uint256` - Unique identifier for the contract. | ||
- **owner**: `address` - The address of the contract owner. | ||
|
||
#### Methods | ||
|
||
- **getOwner()**: `address` - Returns the address of the owner. | ||
- **setOwner(newOwner: address): void** - Sets a new owner for the contract. | ||
|
||
### Contract: `EASRegistry` | ||
|
||
The `EASRegistry` contract allows public access to information about projects. It is designed for reading project data, but if a subgraph is integrated, this contract may not be necessary for frontend use. | ||
|
||
#### Properties | ||
|
||
- **easId**: `uint256` - Unique identifier for the EAS. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. is this a certain EAS schema id? maybe it's better that we provide example of how should it be like here? |
||
- **projects**: `mapping(uint256 => Project)` - Mapping of project IDs to project details. | ||
|
||
#### Methods | ||
|
||
- **addEAS(eas: IEAS): void** - Adds a new EAS to the registry. | ||
- **getEAS(): IEAS** - Retrieves an EAS from the registry. | ||
|
||
### Contract: `Poll` | ||
|
||
The `Poll` contract is used to manage polling information. | ||
|
||
#### Properties | ||
|
||
- **pollName**: `string` - Name of the poll. | ||
- **pollDescription**: `string` - Description of the poll. | ||
|
||
#### Methods | ||
|
||
- **createPoll(name: string, description: string): void** - Creates a new poll with the given name and description. | ||
- **getPoll(): (string, string)** - Retrieves the name and description of the poll. | ||
|
||
### Contract: `MACI` | ||
|
||
The `MACI` contract is used to process and manage MACI data. | ||
|
||
#### Properties | ||
|
||
- **maciData**: `string` - Data associated with MACI. | ||
|
||
#### Methods | ||
|
||
- **processMaciData(data: string): void** - Processes the provided MACI data. | ||
- **getMaciData(): string** - Retrieves the MACI data. | ||
|
||
### Contract: `IRegistryManager` | ||
|
||
The `IRegistryManager` contract handles requests and maintains request-related data. | ||
|
||
#### Properties | ||
|
||
- **requestCount**: `uint256` - The number of requests. | ||
- **requests**: `mapping(uint256 => Request)` - Mapping of request IDs to request details. | ||
|
||
#### Methods | ||
|
||
- **createRequest(request: Request): void** - Creates a new request. | ||
- **getRequest(id: uint256): Request** - Retrieves a request by its ID. | ||
|
||
### Contract: `Request` | ||
|
||
The `Request` contract represents a request for registry management. | ||
|
||
#### Properties | ||
|
||
- **requestId**: `uint256` - Unique identifier for the request. | ||
- **requestData**: `string` - Data associated with the request. | ||
|
||
#### Methods | ||
|
||
- **processRequest(): void** - Processes the request. | ||
- **getRequestData(): string** - Retrieves the request data. | ||
|
||
### Contract: `Recipient` | ||
|
||
The `Recipient` contract represents a recipient entity in the registry. | ||
|
||
#### Properties | ||
|
||
- **recipientAddress**: `address` - Address of the recipient. | ||
- **recipientName**: `string` - Name of the recipient. | ||
|
||
#### Methods | ||
|
||
- **getRecipientInfo(): (address, string)** - Retrieves the address and name of the recipient. | ||
|
||
## Registry and RegistryManager | ||
|
||
Below is the UML diagram representing the relationships and interactions between the contracts: | ||
|
||
![UML Diagram](./diagram.svg) | ||
|
||
## Contract Interaction Overview | ||
|
||
This document provides a brief explanation of the interactions between the `MACI`, `PollFactory`, `Poll`, `IRegistryManager`, and `EASRegistry` contracts. | ||
|
||
### MACI and PollFactory | ||
|
||
- **Role**: The `MACI` contract uses the `PollFactory` to deploy new `Poll` contracts. | ||
- **Details**: | ||
- `MACI` holds a reference to the `PollFactory` contract. | ||
- `MACI` invokes the `deploy` method of the `PollFactory` to create new `Poll` instances. | ||
- The `PollFactory` is responsible for deploying polls with the necessary parameters such as duration, tree depths, and coordinator's public key. | ||
|
||
### MACI and IRegistryManager | ||
|
||
- **Role**: The `MACI` contract interacts with the `IRegistryManager` to manage and maintain registry-related data. | ||
- **Details**: | ||
- `MACI` holds a reference to the `IRegistryManager` contract. | ||
- `MACI` can set or query the `IRegistryManager` for managing requests and registry information. | ||
|
||
### Poll and IRegistryManager | ||
|
||
- **Role**: The `Poll` contract uses the `IRegistryManager` for handling registry-related actions specific to the poll. | ||
- **Details**: | ||
- The `Poll` contract has an address for the `IRegistryManager`. | ||
- `Poll` may call methods on the `IRegistryManager` to update or retrieve registry-related information. | ||
|
||
### Poll and EASRegistry | ||
|
||
- **Role**: The `Poll` contract interacts with the `EASRegistry` to access or update information about projects or entities. | ||
- **Details**: | ||
- `Poll` has a `registry` property that holds the address of the `EASRegistry` contract. | ||
- `Poll` uses this address to perform operations related to project data. | ||
|
||
### EASRegistryManager and EASRegistry | ||
|
||
- **Role**: The `EASRegistryManager` manages and interacts with the `EASRegistry`. | ||
- **Details**: | ||
- `EASRegistryManager` handles requests and maintains control over the operations of the `EASRegistry`. | ||
- `EASRegistryManager` may call methods on `EASRegistry` to add or retrieve EAS (External Authentication Service) entries. | ||
|
||
### Interaction summary | ||
|
||
- **`MACI`**: | ||
|
||
- Contains a `PollFactory` to deploy `Poll` contracts. | ||
- Contains an `IRegistryManager` to manage registry data. | ||
|
||
- **`PollFactory`**: | ||
|
||
- Deploys `Poll` contracts as directed by the `MACI` contract. | ||
|
||
- **`Poll`**: | ||
|
||
- Uses `EASRegistry` to access project information. | ||
- Interacts with `IRegistryManager` for registry-related actions. | ||
|
||
- **`IRegistryManager`**: | ||
|
||
- Manages requests and registry data, interacting with `Poll` and potentially `EASRegistry`. | ||
|
||
- **`EASRegistry`**: | ||
- Provides information about projects, used by `Poll`. | ||
|
||
This interaction structure ensures modularity and clear responsibilities for each contract, facilitating effective coordination and functionality within the system. | ||
|
||
## Integration with `maci-subgraph` | ||
|
||
The integration with `maci-subgraph` is similar to the integration with the EAS contracts. However, additional entities are involved: | ||
|
||
- **Request**: Represents requests to the `RegistryManager` for approval or rejection. | ||
- **Recipient**: Represents entities (projects) in the registry. | ||
- **Registry**: Stores recipient information and manages access. | ||
|
||
## Interaction with Frontend | ||
|
||
- **EASRegistryManager**: This contract is used for submitting requests and handling approvals/rejections. It provides access control and management functionality. | ||
- **EASRegistry**: Allows reading of project information. If integrated with a subgraph, this contract's data may be accessed directly from the subgraph for frontend purposes. | ||
|
||
Ensure that the frontend integration leverages the subgraph where applicable to reduce direct interactions with the `EASRegistry` contract, improving efficiency and performance. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
import childProcess from "child_process"; | ||
import fs from "fs"; | ||
import path from "path"; | ||
|
||
const FLATTEN_PATH = path.resolve(__dirname, "../build/flatten.sol"); | ||
|
||
async function generateUml(): Promise<void> { | ||
const { promisify } = await import("util"); | ||
const execFile = promisify(childProcess.execFile); | ||
await execFile("pnpm", [ | ||
"exec", | ||
"hardhat", | ||
"flatten", | ||
"./contracts/registryManager/EASRegistryManager.sol", | ||
"./contracts/registry/EASRegistry.sol", | ||
]).then(({ stdout }) => fs.promises.writeFile(FLATTEN_PATH, stdout)); | ||
|
||
await execFile("pnpm", [ | ||
"exec", | ||
"sol2uml", | ||
"class", | ||
FLATTEN_PATH, | ||
"-o", | ||
path.resolve(__dirname, "../docs/diagram.svg"), | ||
]).then(() => fs.promises.rm(FLATTEN_PATH)); | ||
} | ||
|
||
generateUml(); |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this should be the address of the EAS Registry contract, right? then I think we could specify it instead of just say it's a unique identifier for the contract?