Skip to main content

bitwarden_sm/secrets/
get_by_ids.rs

1use 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    /// IDs of the secrets to retrieve
13    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}