use openlark_core::{
SDKResult,
api::{ApiRequest, ApiResponseTrait, ResponseFormat},
config::Config,
http::Transport,
validate_required,
};
use serde::{Deserialize, Serialize};
use crate::common::{api_endpoints::DriveApi, api_utils::*};
#[derive(Debug, Clone)]
pub struct AuthPermissionMemberRequest {
config: Config,
pub token: String,
pub file_type: String,
pub action: String,
}
impl AuthPermissionMemberRequest {
pub fn new(
config: Config,
token: impl Into<String>,
file_type: impl Into<String>,
action: impl Into<String>,
) -> Self {
Self {
config,
token: token.into(),
file_type: file_type.into(),
action: action.into(),
}
}
pub async fn execute(self) -> SDKResult<AuthPermissionMemberResponse> {
self.execute_with_options(openlark_core::req_option::RequestOption::default())
.await
}
pub async fn execute_with_options(
self,
option: openlark_core::req_option::RequestOption,
) -> SDKResult<AuthPermissionMemberResponse> {
validate_required!(self.token, "token 不能为空");
validate_required!(self.file_type, "file_type 不能为空");
validate_required!(self.action, "action 不能为空");
match self.action.as_str() {
"view" | "edit" | "share" | "comment" | "export" | "copy" | "print"
| "manage_public" => {}
_ => {
return Err(openlark_core::error::validation_error(
"action",
"action 必须为 view/edit/share/comment/export/copy/print/manage_public",
));
}
}
let api_endpoint = DriveApi::AuthPermissionMember(self.token.clone());
let api_request = ApiRequest::<AuthPermissionMemberResponse>::get(&api_endpoint.to_url())
.query("type", &self.file_type)
.query("action", &self.action);
let response = Transport::request(api_request, &self.config, Some(option)).await?;
extract_response_data(response, "授权")
}
}
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct AuthPermissionMemberResponse {
pub auth_result: bool,
}
impl ApiResponseTrait for AuthPermissionMemberResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[cfg(test)]
mod tests {
use super::*;
use openlark_core::testing::prelude::test_runtime;
#[test]
fn test_auth_permission_member_request_builder() {
let config = Config::default();
let request = AuthPermissionMemberRequest::new(config, "file_token", "docx", "view");
assert_eq!(request.token, "file_token");
assert_eq!(request.file_type, "docx");
assert_eq!(request.action, "view");
}
#[test]
fn test_response_trait() {
assert_eq!(
AuthPermissionMemberResponse::data_format(),
ResponseFormat::Data
);
}
#[test]
fn test_empty_token_validation() {
let config = Config::default();
let request = AuthPermissionMemberRequest::new(config, "", "docx", "view");
let result = std::thread::spawn(move || {
let rt = test_runtime();
rt.block_on(async move {
let _ = request.execute().await;
})
})
.join();
assert!(result.is_ok());
}
#[test]
fn test_action_validation() {
let config = Config::default();
let request = AuthPermissionMemberRequest::new(config, "token", "docx", "invalid");
let result = std::thread::spawn(move || {
let rt = test_runtime();
rt.block_on(async move {
let _ = request.execute().await;
})
})
.join();
assert!(result.is_ok());
}
#[test]
fn test_supported_actions() {
let config = Config::default();
for action in [
"view",
"edit",
"share",
"comment",
"export",
"copy",
"print",
"manage_public",
] {
let request = AuthPermissionMemberRequest::new(
config.clone(),
"token",
"docx",
action.to_string(),
);
assert_eq!(request.action, action);
}
}
#[test]
fn test_response_structure() {
let response = AuthPermissionMemberResponse { auth_result: true };
assert!(response.auth_result);
let response2 = AuthPermissionMemberResponse { auth_result: false };
assert!(!response2.auth_result);
}
}