Skip to content

Commit

Permalink
feat(mpc): add readme/fixup sql
Browse files Browse the repository at this point in the history
  • Loading branch information
hussein-aitlahcen committed Sep 2, 2024
1 parent 512ff0d commit 2e2c90b
Show file tree
Hide file tree
Showing 3 changed files with 63 additions and 4 deletions.
58 changes: 58 additions & 0 deletions mpc/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
# Introduction

This project contains the client and coordinator to conduct Groth16 multi-party computation for the circuit SRS.
Three components are in play:
- Supabase : host the state machine in postgresql and exposes api and storage services to upload contributions.
- Coordinator: contact Supabase and verify contribution to step the state machine.
- Client: pure function that accepts the current contributor id and generate then upload a contribution payload.

## Supabase

Hosts the database, storage services and state machine of the MPC round. Provides instant API on top of them.

## Coordinator

The coordinator is in charge of verifying contributions. When a contribution is deemed valid, it dispatches the value to Supabase (insert an entry), effectively stepping the MPC state machine.

## Client

Exposes an API to contribute at `localhost:4919`:
- `OPTIONS /contribute`
- `POST /contribute` a `Contribute` object in body. Returns :
- a `202 Accepted` if the contribution started.
- a `503 Unavailable` if the client is busy (likely already contributing).
- `GET /contribute` returns :
- a `200 Ok` if everything is ok and the contribution is going or the client is idle with the body containing an encoded `Status` representing the client status.
- a `500 InternalServerError` if the contribution failed unexpectedly.

### Structures

#### Contribute
```json
{
"supabase_project": "<supabase_project_url>",
"bucket": "<supabase_bucket_to_push_contribution>",
"jwt": "<supabase_logged_in_user_jwt>",
"api_key": "<supabase_anon_api_key>",
"contributor_id": "<logged_in_user_uuid>",
"payload_id": "<logged_in_user_payload_uuid>"
}
```

#### Status
```rust
#[serde(rename_all = "camelCase")]
pub enum Status {
Idle,
Initializing,
DownloadStarted(String),
Downloading(String, u8),
DownloadEnded(String),
ContributionStarted,
ContributionEnded,
UploadStarted(String),
UploadEnded(String),
Failed(String),
Successful,
}
```
7 changes: 4 additions & 3 deletions mpc/client/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -38,12 +38,12 @@ use tokio::{
use tokio_util::sync::CancellationToken;
use types::Status;

const SUPABASE_PROJECT: &str = "https://wwqpylbrcpriyaqugzsi.supabase.co";
const ENDPOINT: &str = "/contribute";

#[derive(PartialEq, Eq, Debug, Clone, Deserialize)]
#[serde(rename_all = "camelCase")]
struct Contribute {
supabase_project: String,
bucket: String,
jwt: String,
api_key: String,
Expand Down Expand Up @@ -74,14 +74,15 @@ type DynError = Box<dyn std::error::Error + Send + Sync>;
async fn contribute(
tx_status: Sender<Status>,
Contribute {
supabase_project,
bucket,
jwt,
api_key,
contributor_id,
payload_id,
}: Contribute,
) -> Result<(), DynError> {
let client = SupabaseMPCApi::new(SUPABASE_PROJECT.into(), api_key, jwt);
let client = SupabaseMPCApi::new(&supabase_project, api_key, jwt);
let current_contributor = client
.current_contributor()
.await?
Expand Down Expand Up @@ -183,7 +184,7 @@ async fn contribute(
// https://tus.io/protocols/resumable-upload#creation ==
// =====================================================
let response = upload_client
.post(format!("{SUPABASE_PROJECT}/storage/v1/upload/resumable"))
.post(format!("{supabase_project}/storage/v1/upload/resumable"))
.header("Tus-Resumable", "1.0.0")
.header("Upload-Length", CONTRIBUTION_SIZE.to_string())
.header(
Expand Down
2 changes: 1 addition & 1 deletion mpc/coordinator/database.sql
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,8 @@ CREATE TABLE queue (
ALTER TABLE queue ENABLE ROW LEVEL SECURITY;
ALTER TABLE queue ADD FOREIGN KEY (id) REFERENCES auth.users(id);
CREATE UNIQUE INDEX idx_queue_score_id ON queue(score, id);
CREATE UNIQUE INDEX idx_queue_score ON queue(score);
CREATE UNIQUE INDEX idx_queue_id_payload ON queue(id, payload_id);
CREATE INDEX idx_queue_score ON queue(score);

CREATE POLICY view_all
ON queue
Expand Down

0 comments on commit 2e2c90b

Please sign in to comment.