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, Serialize, Deserialize)]
pub struct DeleteSubscribeRequest {
#[serde(skip)]
config: Config,
pub file_token: String,
pub file_type: String,
pub event_type: Option<String>,
}
impl DeleteSubscribeRequest {
pub fn new(
config: Config,
file_token: impl Into<String>,
file_type: impl Into<String>,
) -> Self {
Self {
config,
file_token: file_token.into(),
file_type: file_type.into(),
event_type: None,
}
}
pub fn event_type(mut self, event_type: impl Into<String>) -> Self {
self.event_type = Some(event_type.into());
self
}
pub async fn execute(self) -> SDKResult<DeleteSubscribeResponse> {
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<DeleteSubscribeResponse> {
validate_required!(self.file_token, "file_token 不能为空");
validate_required!(self.file_type, "file_type 不能为空");
match self.file_type.as_str() {
"doc" | "docx" | "sheet" | "bitable" | "file" | "folder" | "slides" => {}
_ => {
return Err(openlark_core::error::validation_error(
"file_type",
"file_type 仅支持 doc/docx/sheet/bitable/file/folder/slides",
));
}
}
if self.file_type == "folder" {
match self.event_type.as_deref() {
Some("file.created_in_folder_v1") => {}
Some(_) => {
return Err(openlark_core::error::validation_error(
"event_type",
"当 file_type=folder 时,event_type 必须为 file.created_in_folder_v1",
));
}
None => {
return Err(openlark_core::error::validation_error(
"event_type",
"当 file_type=folder 时,event_type 不能为空(必须为 file.created_in_folder_v1)",
));
}
}
} else if self.event_type.is_some() {
return Err(openlark_core::error::validation_error(
"event_type",
"当 file_type 不为 folder 时,请勿传入 event_type",
));
}
let api_endpoint = DriveApi::DeleteFileSubscribe(self.file_token.clone());
let mut request = ApiRequest::<DeleteSubscribeResponse>::delete(&api_endpoint.to_url());
request = request.query("file_type", &self.file_type);
if let Some(event_type) = &self.event_type {
request = request.query("event_type", event_type);
}
let response = Transport::request(request, &self.config, Some(option)).await?;
extract_response_data(response, "订阅文件")
}
}
#[derive(Debug, Clone, Serialize, Deserialize, Default)]
pub struct DeleteSubscribeResponse {}
impl ApiResponseTrait for DeleteSubscribeResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_delete_subscribe_request_builder() {
let config = Config::default();
let request = DeleteSubscribeRequest::new(config, "file_token", "docx");
assert_eq!(request.file_token, "file_token");
assert_eq!(request.file_type, "docx");
}
#[test]
fn test_response_trait() {
assert_eq!(DeleteSubscribeResponse::data_format(), ResponseFormat::Data);
}
#[test]
fn test_delete_subscribe_with_event_type() {
let config = Config::default();
let request = DeleteSubscribeRequest::new(config, "folder_token", "folder")
.event_type("file.created_in_folder_v1");
assert_eq!(
request.event_type,
Some("file.created_in_folder_v1".to_string())
);
}
#[test]
fn test_delete_subscribe_response() {
let response = DeleteSubscribeResponse::default();
let _ = response;
}
#[test]
fn test_delete_subscribe_bitable_type() {
let config = Config::default();
let request = DeleteSubscribeRequest::new(config, "bitable_token", "bitable");
assert_eq!(request.file_type, "bitable");
}
#[test]
fn test_delete_subscribe_without_event_type() {
let config = Config::default();
let request = DeleteSubscribeRequest::new(config, "docx_token", "docx");
assert!(request.event_type.is_none());
}
}