bitwarden_sm/secrets/
get_by_ids.rs1use bitwarden_api_api::models::GetSecretsRequestModel;
2use schemars::JsonSchema;
3use serde::{Deserialize, Serialize};
4use uuid::Uuid;
5
6use crate::{SecretsManagerClient, error::SecretsManagerError, secrets::SecretsResponse};
7
8#[allow(missing_docs)]
9#[derive(Serialize, Deserialize, Debug, JsonSchema)]
10#[serde(rename_all = "camelCase", deny_unknown_fields)]
11pub struct SecretsGetRequest {
12 pub ids: Vec<Uuid>,
14}
15
16pub(crate) async fn get_secrets_by_ids(
17 client: &SecretsManagerClient,
18 input: SecretsGetRequest,
19) -> Result<SecretsResponse, SecretsManagerError> {
20 let client = client.client();
21 let request = Some(GetSecretsRequestModel { ids: input.ids });
22
23 let config = client.internal.get_api_configurations();
24
25 let res = config
26 .api_client
27 .secrets_api()
28 .get_secrets_by_ids(request)
29 .await?;
30
31 let key_store = client.internal.get_key_store();
32
33 SecretsResponse::process_response(res, &mut key_store.context())
34}