Skip to content

Commit

Permalink
async-signature: remove mandatory Send + Sync bounds
Browse files Browse the repository at this point in the history
See: #1373
  • Loading branch information
QuinnWilton committed Nov 8, 2023
1 parent 128d4e6 commit 003c5bf
Showing 1 changed file with 9 additions and 17 deletions.
26 changes: 9 additions & 17 deletions signature/async/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,8 @@ use async_trait::async_trait;
/// (e.g. client for a Cloud KMS or HSM), returning a digital signature.
///
/// This trait is an async equivalent of the [`signature::Signer`] trait.
#[async_trait]
pub trait AsyncSigner<S>
where
Self: Send + Sync,
S: Send + 'static,
{
#[async_trait(?Send)]
pub trait AsyncSigner<S> {
/// Attempt to sign the given message, returning a digital signature on
/// success, or an error if something went wrong.
///
Expand All @@ -32,11 +28,10 @@ where
async fn sign_async(&self, msg: &[u8]) -> Result<S, Error>;
}

#[async_trait]
#[async_trait(?Send)]
impl<S, T> AsyncSigner<S> for T
where
S: Send + 'static,
T: signature::Signer<S> + Send + Sync,
T: signature::Signer<S>,
{
async fn sign_async(&self, msg: &[u8]) -> Result<S, Error> {
self.try_sign(msg)
Expand All @@ -47,25 +42,22 @@ where
///
/// This trait is an async equivalent of the [`signature::DigestSigner`] trait.
#[cfg(feature = "digest")]
#[async_trait]
#[async_trait(?Send)]
pub trait AsyncDigestSigner<D, S>
where
Self: Send + Sync,
D: Digest + Send + 'static,
S: 'static,
D: Digest + 'static,
{
/// Attempt to sign the given prehashed message [`Digest`], returning a
/// digital signature on success, or an error if something went wrong.
async fn sign_digest_async(&self, digest: D) -> Result<S, Error>;
}

#[cfg(feature = "digest")]
#[async_trait]
#[async_trait(?Send)]
impl<D, S, T> AsyncDigestSigner<D, S> for T
where
D: Digest + Send + 'static,
S: Send + 'static,
T: signature::DigestSigner<D, S> + Send + Sync,
D: Digest + 'static,
T: signature::DigestSigner<D, S>,
{
async fn sign_digest_async(&self, digest: D) -> Result<S, Error> {
self.try_sign_digest(digest)
Expand Down

0 comments on commit 003c5bf

Please sign in to comment.