Skip to main content

bitwarden_core/auth/api/request/
api_token_request.rs

1use bitwarden_api_api::Configuration;
2use serde::{Deserialize, Serialize};
3use tracing::debug;
4
5use crate::auth::{api::response::IdentityTokenResponse, login::LoginError};
6
7#[derive(Serialize, Deserialize, Debug)]
8pub(crate) struct ApiTokenRequest {
9    scope: String,
10    client_id: String,
11    client_secret: String,
12    #[serde(rename = "deviceType")]
13    device_type: u8,
14    #[serde(rename = "deviceIdentifier")]
15    device_identifier: String,
16    #[serde(rename = "deviceName")]
17    device_name: String,
18    grant_type: String,
19}
20
21impl ApiTokenRequest {
22    pub(crate) fn new(client_id: &String, client_secret: &String) -> Self {
23        let obj = Self {
24            scope: "api".to_string(),
25            client_id: client_id.to_string(),
26            client_secret: client_secret.to_string(),
27            device_type: 10,
28            device_identifier: "b86dd6ab-4265-4ddf-a7f1-eb28d5677f33".to_string(),
29            device_name: "firefox".to_string(),
30            grant_type: "client_credentials".to_string(),
31        };
32        debug!(?obj, "initializing");
33        obj
34    }
35
36    pub(crate) async fn send(
37        &self,
38        identity_config: &Configuration,
39    ) -> Result<IdentityTokenResponse, LoginError> {
40        super::send_identity_connect_request(identity_config, &self).await
41    }
42}