Skip to content

Commit

Permalink
cdh/kms: add aliyun KMS support for GetPublicKey
Browse files Browse the repository at this point in the history
Signed-off-by: Xynnn007 <[email protected]>
  • Loading branch information
Xynnn007 committed Dec 6, 2023
1 parent 949b7d5 commit 4415e7a
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 4 deletions.
40 changes: 38 additions & 2 deletions confidential-data-hub/kms/src/plugins/aliyun/client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,11 @@ use serde_json::Value;
use sha2::{Digest, Sha256};
use tokio::fs;

use crate::plugins::aliyun::client::dkms_api::{DecryptRequest, EncryptRequest};
use crate::plugins::aliyun::client::dkms_api::{
DecryptRequest, EncryptRequest, GetPublicKeyRequest,
};
use crate::plugins::_IN_GUEST_DEFAULT_KEY_PATH;
use crate::{Annotations, Decrypter, Encrypter, ProviderSettings};
use crate::{Annotations, Decrypter, Encrypter, ProviderSettings, PubkeyProvider};
use crate::{Error, Result};

use super::annotations::{AliAnnotations, AliProviderSettings};
Expand Down Expand Up @@ -223,6 +225,40 @@ impl Decrypter for AliyunKmsClient {
}
}

#[async_trait]
impl PubkeyProvider for AliyunKmsClient {
/// a typical key id of aliyun KMS is like
/// `key-shh65012xxxmpi4oxtxxx`
async fn get_public_key(&mut self, key_id: &str) -> Result<Vec<u8>> {
let get_public_key_request = GetPublicKeyRequest {
key_id: key_id.into(),
};
let mut body = Vec::new();
get_public_key_request.encode(&mut body).map_err(|e| {
Error::AliyunKmsError(format!(
"encode get public key request using protobuf failed: {e}"
))
})?;
let headers = self.build_headers("GetPublicKey", &body).map_err(|e| {
Error::AliyunKmsError(format!(
"build get public key request http header failed: {e}"
))
})?;

let res = self
.do_request(body, headers)
.await
.map_err(|e| Error::AliyunKmsError(format!("do request to kms server failed: {e}")))?;

let decrypt_response = dkms_api::GetPublicKeyResponse::decode(&res[..]).map_err(|e| {
Error::AliyunKmsError(format!(
"decode decrypt response using protobuf failed: {e}"
))
})?;
Ok(decrypt_response.public_key.into())
}
}

impl AliyunKmsClient {
const API_VERSION: &'static str = "dkms-gcs-0.2";
const SIGNATURE_METHOD: &'static str = "RSA_PKCS1_SHA_256";
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,16 @@ message DecryptResponse {
string PaddingMode = 5;
}

message GetPublicKeyRequest {
string KeyId = 1;
}

message GetPublicKeyResponse {
string KeyId = 1;
string PublicKey = 2;
string RequestId = 3;
}

message Error {
int32 StatusCode = 1;
string ErrorCode = 2;
Expand Down
12 changes: 10 additions & 2 deletions confidential-data-hub/kms/src/plugins/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,9 @@ pub enum PublicKeyProvider {
#[cfg(feature = "kbs")]
#[strum(ascii_case_insensitive)]
Kbs,
#[cfg(feature = "aliyun")]
#[strum(ascii_case_insensitive)]
Aliyun,
}

/// Create a new [`PubkeyProvider`] by given provider name
Expand All @@ -81,13 +84,18 @@ async fn new_public_key_provider(provider_name: &str) -> Result<Box<dyn PubkeyPr
PublicKeyProvider::Kbs => {
Ok(Box::new(kbs::KbcClient::new().await?) as Box<dyn PubkeyProvider>)
}
#[cfg(feature = "aliyun")]
PublicKeyProvider::Aliyun => Ok(Box::new(
aliyun::AliyunKmsClient::from_provider_settings(&ProviderSettings::default()).await?,
) as Box<dyn PubkeyProvider>),
}
}

/// Get the public key due to the given `key_id`.
/// For example:
/// For example `key_id`:
///
/// public key from KBS: `kbs:///default/key/1`
/// - KBS: `kbs:///default/key/1`
/// - Aliyun KMS: `aliyun://key-shh65012626mpi4oxxxxx`
pub async fn get_public_key(key_id: &str) -> Result<Vec<u8>> {
let (provider, keyid) = key_id
.split_once("://")
Expand Down

0 comments on commit 4415e7a

Please sign in to comment.