open_lark/service/cloud_docs/bitable/v1/app_table/
batch_delete.rs

1use reqwest::Method;
2use serde::{Deserialize, Serialize};
3
4use crate::{
5    core::{
6        api_req::ApiRequest,
7        api_resp::{ApiResponseTrait, BaseResponse, ResponseFormat},
8        constants::AccessTokenType,
9        http::Transport,
10        req_option::RequestOption,
11        SDKResult,
12    },
13    impl_executable_builder_owned,
14};
15
16use super::AppTableService;
17
18impl AppTableService {
19    /// 删除多个数据表
20    pub async fn batch_delete(
21        &self,
22        request: BatchDeleteTablesRequest,
23        option: Option<RequestOption>,
24    ) -> SDKResult<BaseResponse<BatchDeleteTablesResponse>> {
25        let mut api_req = request.api_request;
26        api_req.http_method = Method::POST;
27        api_req.api_path = format!(
28            "/open-apis/bitable/v1/apps/{}/tables/batch_delete",
29            request.app_token
30        );
31        api_req.supported_access_token_types = vec![AccessTokenType::Tenant, AccessTokenType::User];
32        api_req.body = serde_json::to_vec(&BatchDeleteTablesRequestBody {
33            table_ids: request.table_ids,
34        })?;
35
36        let api_resp = Transport::request(api_req, &self.config, option).await?;
37        Ok(api_resp)
38    }
39}
40
41/// 批量删除数据表请求
42#[derive(Debug, Default)]
43pub struct BatchDeleteTablesRequest {
44    api_request: ApiRequest,
45    /// 多维表格的 app_token
46    app_token: String,
47    /// 要删除的数据表 ID 列表
48    table_ids: Vec<String>,
49}
50
51impl BatchDeleteTablesRequest {
52    pub fn builder() -> BatchDeleteTablesRequestBuilder {
53        BatchDeleteTablesRequestBuilder::default()
54    }
55
56    /// 创建批量删除数据表请求
57    pub fn new(app_token: impl ToString, table_ids: Vec<String>) -> Self {
58        Self {
59            api_request: ApiRequest::default(),
60            app_token: app_token.to_string(),
61            table_ids,
62        }
63    }
64}
65
66#[derive(Default)]
67pub struct BatchDeleteTablesRequestBuilder {
68    request: BatchDeleteTablesRequest,
69}
70
71impl BatchDeleteTablesRequestBuilder {
72    /// 多维表格的 app_token
73    pub fn app_token(mut self, app_token: impl ToString) -> Self {
74        self.request.app_token = app_token.to_string();
75        self
76    }
77
78    /// 要删除的数据表 ID 列表
79    pub fn table_ids(mut self, table_ids: Vec<String>) -> Self {
80        self.request.table_ids = table_ids;
81        self
82    }
83
84    /// 添加单个数据表 ID
85    pub fn add_table_id(mut self, table_id: impl ToString) -> Self {
86        self.request.table_ids.push(table_id.to_string());
87        self
88    }
89
90    pub fn build(self) -> BatchDeleteTablesRequest {
91        self.request
92    }
93}
94
95impl_executable_builder_owned!(
96    BatchDeleteTablesRequestBuilder,
97    AppTableService,
98    BatchDeleteTablesRequest,
99    BaseResponse<BatchDeleteTablesResponse>,
100    batch_delete
101);
102
103#[derive(Serialize)]
104struct BatchDeleteTablesRequestBody {
105    table_ids: Vec<String>,
106}
107
108#[derive(Deserialize, Debug)]
109pub struct BatchDeleteTablesResponse {
110    /// 删除结果列表
111    pub deleted: bool,
112}
113
114impl ApiResponseTrait for BatchDeleteTablesResponse {
115    fn data_format() -> ResponseFormat {
116        ResponseFormat::Data
117    }
118}
119
120#[cfg(test)]
121mod tests {
122    use super::*;
123    use serde_json::json;
124
125    #[test]
126    fn test_batch_delete_tables_request() {
127        let table_ids = vec![
128            "tblsRc9GRRXKqhvW".to_string(),
129            "tbl1234567890abc".to_string(),
130        ];
131
132        let request = BatchDeleteTablesRequest::builder()
133            .app_token("bascnmBA*****yGehy8")
134            .table_ids(table_ids.clone())
135            .build();
136
137        assert_eq!(request.app_token, "bascnmBA*****yGehy8");
138        assert_eq!(request.table_ids, table_ids);
139    }
140
141    #[test]
142    fn test_batch_delete_tables_with_builder() {
143        let request = BatchDeleteTablesRequest::builder()
144            .app_token("bascnmBA*****yGehy8")
145            .add_table_id("tblsRc9GRRXKqhvW")
146            .add_table_id("tbl1234567890abc")
147            .add_table_id("tblabcdefghijklm")
148            .build();
149
150        assert_eq!(request.table_ids.len(), 3);
151        assert_eq!(request.table_ids[0], "tblsRc9GRRXKqhvW");
152        assert_eq!(request.table_ids[1], "tbl1234567890abc");
153        assert_eq!(request.table_ids[2], "tblabcdefghijklm");
154    }
155
156    #[test]
157    fn test_batch_delete_tables_request_new() {
158        let table_ids = vec!["table1".to_string(), "table2".to_string()];
159        let request = BatchDeleteTablesRequest::new("bascnmBA*****yGehy8", table_ids.clone());
160
161        assert_eq!(request.app_token, "bascnmBA*****yGehy8");
162        assert_eq!(request.table_ids, table_ids);
163    }
164
165    #[test]
166    fn test_batch_delete_tables_request_body_serialization() {
167        let body = BatchDeleteTablesRequestBody {
168            table_ids: vec!["table1".to_string(), "table2".to_string()],
169        };
170
171        let serialized = serde_json::to_value(&body).unwrap();
172        let expected = json!({
173            "table_ids": ["table1", "table2"]
174        });
175
176        assert_eq!(serialized, expected);
177    }
178}