bitwarden_core/auth/api/request/
api_token_request.rs1use 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}