use reqwest::Method;
use serde::{Deserialize, Serialize};
use crate::{
core::{
api_req::ApiRequest,
api_resp::{ApiResponseTrait, BaseResponse, ResponseFormat},
config::Config,
constants::AccessTokenType,
http::Transport,
req_option::RequestOption,
SDKResult,
},
service::acs::models::{
AccessMethod, AccessRecord, AccessResult, AccessType, FaceImage, PageResponse,
},
};
pub struct AccessRecordService {
pub config: Config,
}
impl AccessRecordService {
pub fn new(config: Config) -> Self {
Self { config }
}
pub async fn list_access_records(
&self,
request: AccessRecordListRequest,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<AccessRecordListResponse>> {
let mut api_req = ApiRequest {
http_method: Method::GET,
api_path: "/open-apis/acs/v1/access_records".to_string(),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: vec![],
..Default::default()
};
if let Some(page_token) = request.page_token {
api_req
.query_params
.insert("page_token".to_string(), page_token);
}
if let Some(page_size) = request.page_size {
api_req
.query_params
.insert("page_size".to_string(), page_size.to_string());
}
if let Some(user_id) = request.user_id {
api_req.query_params.insert("user_id".to_string(), user_id);
}
if let Some(device_id) = request.device_id {
api_req
.query_params
.insert("device_id".to_string(), device_id);
}
if let Some(access_type) = request.access_type {
api_req.query_params.insert(
"access_type".to_string(),
serde_json::to_string(&access_type)?,
);
}
if let Some(access_method) = request.access_method {
api_req.query_params.insert(
"access_method".to_string(),
serde_json::to_string(&access_method)?,
);
}
if let Some(result) = request.result {
api_req
.query_params
.insert("result".to_string(), serde_json::to_string(&result)?);
}
if let Some(start_time) = request.start_time {
api_req
.query_params
.insert("start_time".to_string(), start_time.to_string());
}
if let Some(end_time) = request.end_time {
api_req
.query_params
.insert("end_time".to_string(), end_time.to_string());
}
Transport::request(api_req, &self.config, option).await
}
pub async fn download_face_image(
&self,
record_id: &str,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<AccessRecordFaceImageResponse>> {
let api_req = ApiRequest {
http_method: Method::GET,
api_path: format!("/open-apis/acs/v1/access_records/{record_id}/face_image"),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: vec![],
..Default::default()
};
Transport::request(api_req, &self.config, option).await
}
}
#[derive(Debug, Clone, Serialize, Deserialize, Default)]
pub struct AccessRecordListRequest {
#[serde(skip_serializing_if = "Option::is_none")]
pub page_token: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub page_size: Option<i32>,
#[serde(skip_serializing_if = "Option::is_none")]
pub user_id: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub device_id: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub access_type: Option<AccessType>,
#[serde(skip_serializing_if = "Option::is_none")]
pub access_method: Option<AccessMethod>,
#[serde(skip_serializing_if = "Option::is_none")]
pub result: Option<AccessResult>,
#[serde(skip_serializing_if = "Option::is_none")]
pub start_time: Option<i64>,
#[serde(skip_serializing_if = "Option::is_none")]
pub end_time: Option<i64>,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct AccessRecordListResponse {
#[serde(flatten)]
pub access_records: PageResponse<AccessRecord>,
}
impl ApiResponseTrait for AccessRecordListResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[derive(Debug, Serialize, Deserialize)]
pub struct AccessRecordFaceImageResponse {
pub face_image: FaceImage,
}
impl ApiResponseTrait for AccessRecordFaceImageResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}