-
Notifications
You must be signed in to change notification settings - Fork 305
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Threshold Custody: Add internal signing protocol
- Loading branch information
1 parent
2762a83
commit 7a4fc12
Showing
3 changed files
with
255 additions
and
0 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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 +1,82 @@ | ||
use anyhow::{anyhow, Result}; | ||
use penumbra_keys::{keys::AddressIndex, Address, FullViewingKey}; | ||
use penumbra_proto::custody::v1alpha1::{self as pb}; | ||
use penumbra_transaction::AuthorizationData; | ||
use tonic::{async_trait, Request, Response, Status}; | ||
|
||
use crate::AuthorizeRequest; | ||
|
||
mod config; | ||
mod sign; | ||
|
||
/// A custody backend using threshold signing. | ||
/// | ||
/// This backend is initialized with a full viewing key, but only a share | ||
/// of the spend key, which is not enough to sign on its own. Instead, | ||
/// other signers with the same type of configuration need to cooperate | ||
/// to help produce a signature. | ||
pub struct Threshold {} | ||
|
||
impl Threshold { | ||
/// Try and create the necessary signatures to authorize the transaction plan. | ||
async fn authorize(&self, _request: AuthorizeRequest) -> Result<AuthorizationData> { | ||
todo!() | ||
} | ||
|
||
/// Return the full viewing key. | ||
fn export_full_viewing_key(&self) -> FullViewingKey { | ||
todo!() | ||
} | ||
|
||
/// Get the address associated with an index. | ||
/// | ||
/// This is just to match the API of the custody trait. | ||
fn confirm_address(&self, _index: AddressIndex) -> Address { | ||
todo!() | ||
} | ||
} | ||
|
||
#[async_trait] | ||
impl pb::custody_protocol_service_server::CustodyProtocolService for Threshold { | ||
async fn authorize( | ||
&self, | ||
request: Request<pb::AuthorizeRequest>, | ||
) -> Result<Response<pb::AuthorizeResponse>, Status> { | ||
let request = request | ||
.into_inner() | ||
.try_into() | ||
.map_err(|e| Status::invalid_argument(format!("{e}")))?; | ||
let data = self.authorize(request).await.map_err(|e| { | ||
Status::internal(format!("Failed to process authorization request: {e}")) | ||
})?; | ||
Ok(Response::new(pb::AuthorizeResponse { | ||
data: Some(data.into()), | ||
})) | ||
} | ||
|
||
async fn export_full_viewing_key( | ||
&self, | ||
_request: Request<pb::ExportFullViewingKeyRequest>, | ||
) -> Result<Response<pb::ExportFullViewingKeyResponse>, Status> { | ||
let fvk = self.export_full_viewing_key(); | ||
Ok(Response::new(pb::ExportFullViewingKeyResponse { | ||
full_viewing_key: Some(fvk.into()), | ||
})) | ||
} | ||
|
||
async fn confirm_address( | ||
&self, | ||
request: Request<pb::ConfirmAddressRequest>, | ||
) -> Result<Response<pb::ConfirmAddressResponse>, Status> { | ||
let index = request | ||
.into_inner() | ||
.address_index | ||
.ok_or(anyhow!("ConfirmAddressRequest missing address_index")) | ||
.and_then(|x| x.try_into()) | ||
.map_err(|e| Status::invalid_argument(format!("{e}")))?; | ||
let address = self.confirm_address(index); | ||
Ok(Response::new(pb::ConfirmAddressResponse { | ||
address: Some(address.into()), | ||
})) | ||
} | ||
} |
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