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
|
|
|
}
|
|
|
|
}
|