42 lines
1.0 KiB
Rust
42 lines
1.0 KiB
Rust
use actix_web::post;
|
|
use actix_web::web;
|
|
use actix_web::web::Data;
|
|
use actix_web::Responder;
|
|
use openraft::raft::AppendEntriesRequest;
|
|
use openraft::raft::InstallSnapshotRequest;
|
|
use openraft::raft::VoteRequest;
|
|
use web::Json;
|
|
|
|
use crate::app::ExampleApp;
|
|
use crate::ExampleNodeId;
|
|
use crate::ExampleTypeConfig;
|
|
|
|
// --- Raft communication
|
|
|
|
#[post("/raft-vote")]
|
|
pub async fn vote(
|
|
app: Data<ExampleApp>,
|
|
req: Json<VoteRequest<ExampleNodeId>>,
|
|
) -> actix_web::Result<impl Responder> {
|
|
let res = app.raft.vote(req.0).await;
|
|
Ok(Json(res))
|
|
}
|
|
|
|
#[post("/raft-append")]
|
|
pub async fn append(
|
|
app: Data<ExampleApp>,
|
|
req: Json<AppendEntriesRequest<ExampleTypeConfig>>,
|
|
) -> actix_web::Result<impl Responder> {
|
|
let res = app.raft.append_entries(req.0).await;
|
|
Ok(Json(res))
|
|
}
|
|
|
|
#[post("/raft-snapshot")]
|
|
pub async fn snapshot(
|
|
app: Data<ExampleApp>,
|
|
req: Json<InstallSnapshotRequest<ExampleTypeConfig>>,
|
|
) -> actix_web::Result<impl Responder> {
|
|
let res = app.raft.install_snapshot(req.0).await;
|
|
Ok(Json(res))
|
|
}
|