cycles-quartz/enclaves/quartz/src/server.rs

102 lines
3 KiB
Rust
Raw Normal View History

2024-02-27 23:59:25 +00:00
use std::sync::{Arc, Mutex};
use k256::ecdsa::SigningKey;
2024-02-27 23:29:06 +00:00
use quartz_cw::{
2024-02-27 23:59:25 +00:00
msg::{
execute::{session_create::SessionCreate, session_set_pub_key::SessionSetPubKey},
instantiate::CoreInstantiate,
},
2024-02-27 23:29:06 +00:00
state::{Config, Nonce},
};
2024-02-22 20:09:44 +00:00
use quartz_proto::quartz::{
2024-02-23 20:51:55 +00:00
core_server::Core, InstantiateRequest as RawInstantiateRequest,
2024-02-27 23:29:06 +00:00
InstantiateResponse as RawInstantiateResponse, SessionCreateRequest as RawSessionCreateRequest,
SessionCreateResponse as RawSessionCreateResponse,
2024-02-27 23:59:25 +00:00
SessionSetPubKeyRequest as RawSessionSetPubKeyRequest,
SessionSetPubKeyResponse as RawSessionSetPubKeyResponse,
2024-02-22 20:09:44 +00:00
};
2024-02-27 23:59:25 +00:00
use quartz_relayer::types::{InstantiateResponse, SessionCreateResponse, SessionSetPubKeyResponse};
2024-02-27 23:29:06 +00:00
use rand::Rng;
2024-02-20 11:27:10 +00:00
use tonic::{Request, Response, Status};
2024-02-26 10:56:55 +00:00
use crate::attestor::Attestor;
2024-02-23 20:51:55 +00:00
type TonicResult<T> = Result<T, Status>;
2024-02-27 23:59:25 +00:00
#[derive(Clone, Debug)]
2024-02-26 10:56:55 +00:00
pub struct CoreService<A> {
2024-02-23 20:51:20 +00:00
config: Config,
2024-02-27 23:59:25 +00:00
nonce: Arc<Mutex<Nonce>>,
2024-02-26 10:56:55 +00:00
attestor: A,
2024-02-23 20:51:20 +00:00
}
2024-02-26 10:56:55 +00:00
impl<A> CoreService<A>
where
A: Attestor,
{
pub fn new(config: Config, attestor: A) -> Self {
2024-02-27 23:59:25 +00:00
Self {
config,
nonce: Arc::new(Mutex::new([0u8; 32])),
attestor,
}
2024-02-23 20:51:20 +00:00
}
}
2024-02-20 11:27:10 +00:00
#[tonic::async_trait]
2024-02-26 10:56:55 +00:00
impl<A> Core for CoreService<A>
where
A: Attestor + Send + Sync + 'static,
{
2024-02-22 20:09:44 +00:00
async fn instantiate(
&self,
2024-02-23 20:51:55 +00:00
_request: Request<RawInstantiateRequest>,
) -> TonicResult<Response<RawInstantiateResponse>> {
2024-02-26 10:56:55 +00:00
let core_instantiate_msg = CoreInstantiate::new(self.config.clone());
2024-02-27 23:29:06 +00:00
2024-02-26 10:56:55 +00:00
let quote = self
.attestor
.quote(core_instantiate_msg)
.map_err(|e| Status::internal(e.to_string()))?;
2024-02-22 20:09:44 +00:00
2024-02-23 20:51:55 +00:00
let response = InstantiateResponse::new(self.config.clone(), quote);
Ok(Response::new(response.into()))
2024-02-22 20:09:44 +00:00
}
2024-02-20 11:27:10 +00:00
async fn session_create(
&self,
2024-02-27 23:29:06 +00:00
_request: Request<RawSessionCreateRequest>,
) -> TonicResult<Response<RawSessionCreateResponse>> {
2024-02-27 23:59:25 +00:00
let mut nonce = self.nonce.lock().unwrap();
*nonce = rand::thread_rng().gen::<Nonce>();
let session_create_msg = SessionCreate::new(*nonce);
2024-02-20 11:27:10 +00:00
2024-02-27 23:29:06 +00:00
let quote = self
.attestor
.quote(session_create_msg)
.map_err(|e| Status::internal(e.to_string()))?;
2024-02-20 11:27:10 +00:00
2024-02-27 23:59:25 +00:00
let response = SessionCreateResponse::new(*nonce, quote);
Ok(Response::new(response.into()))
}
async fn session_set_pub_key(
&self,
_request: Request<RawSessionSetPubKeyRequest>,
) -> TonicResult<Response<RawSessionSetPubKeyResponse>> {
let nonce = self.nonce.lock().unwrap();
let sk = SigningKey::random(&mut rand::thread_rng());
let pk = sk.verifying_key();
let session_set_pub_key_msg = SessionSetPubKey::new(*nonce, *pk);
let quote = self
.attestor
.quote(session_set_pub_key_msg)
.map_err(|e| Status::internal(e.to_string()))?;
let response = SessionSetPubKeyResponse::new(*nonce, *pk, quote);
2024-02-27 23:29:06 +00:00
Ok(Response::new(response.into()))
2024-02-20 11:27:10 +00:00
}
}