Skip to main content

openlark_workflow/v2/tasklist/
remove_members.rs

1//! 移除清单成员
2//!
3//! docPath: https://open.feishu.cn/document/server-docs/docs/task-v2/tasklist-remove_members/create
4
5use crate::common::{api_endpoints::TaskApiV2, api_utils::*};
6use openlark_core::{
7    api::{ApiRequest, ApiResponseTrait, ResponseFormat},
8    config::Config,
9    validate_required, SDKResult,
10};
11use serde::{Deserialize, Serialize};
12use std::sync::Arc;
13
14/// 移除清单成员请求体
15#[derive(Debug, Clone, Serialize, Default)]
16pub struct RemoveTasklistMembersBody {
17    /// 成员 ID 列表
18    pub members: Vec<String>,
19}
20
21/// 移除清单成员响应
22#[derive(Debug, Clone, Deserialize)]
23pub struct RemoveTasklistMembersResponse {
24    /// 任务清单 GUID
25    pub tasklist_guid: String,
26    /// 移除的成员 ID 列表
27    #[serde(default)]
28    pub removed_members: Vec<String>,
29}
30
31/// 移除清单成员请求
32#[derive(Debug, Clone)]
33pub struct RemoveTasklistMembersRequest {
34    /// 配置信息
35    config: Arc<Config>,
36    /// 任务清单 GUID
37    tasklist_guid: String,
38    /// 请求体
39    body: RemoveTasklistMembersBody,
40}
41
42impl RemoveTasklistMembersRequest {
43    pub fn new(config: Arc<Config>, tasklist_guid: impl Into<String>) -> Self {
44        Self {
45            config,
46            tasklist_guid: tasklist_guid.into(),
47            body: RemoveTasklistMembersBody::default(),
48        }
49    }
50
51    /// 设置成员 ID 列表
52    pub fn members(mut self, members: Vec<String>) -> Self {
53        self.body.members = members;
54        self
55    }
56
57    /// 移除单个成员
58    pub fn remove_member(mut self, member: impl Into<String>) -> Self {
59        self.body.members.push(member.into());
60        self
61    }
62
63    /// 执行请求
64    pub async fn execute(self) -> SDKResult<RemoveTasklistMembersResponse> {
65        self.execute_with_options(openlark_core::req_option::RequestOption::default())
66            .await
67    }
68
69    /// 执行请求(带选项)
70    pub async fn execute_with_options(
71        self,
72        option: openlark_core::req_option::RequestOption,
73    ) -> SDKResult<RemoveTasklistMembersResponse> {
74        // 验证必填字段
75        validate_required!(self.tasklist_guid.trim(), "任务清单GUID不能为空");
76        validate_required!(self.body.members, "成员列表不能为空");
77
78        let api_endpoint = TaskApiV2::TasklistRemoveMembers(self.tasklist_guid.clone());
79        let mut request = ApiRequest::<RemoveTasklistMembersResponse>::post(api_endpoint.to_url());
80
81        let request_body = &self.body;
82        request = request.body(serialize_params(request_body, "移除清单成员")?);
83
84        let response =
85            openlark_core::http::Transport::request(request, &self.config, Some(option)).await?;
86        extract_response_data(response, "移除清单成员")
87    }
88}
89
90impl ApiResponseTrait for RemoveTasklistMembersResponse {
91    fn data_format() -> ResponseFormat {
92        ResponseFormat::Data
93    }
94}
95
96#[cfg(test)]
97#[allow(unused_imports)]
98mod tests {
99    use std::sync::Arc;
100
101    use super::*;
102
103    #[test]
104    fn test_remove_tasklist_members_builder() {
105        let config = Arc::new(
106            openlark_core::config::Config::builder()
107                .app_id("test")
108                .app_secret("test")
109                .build(),
110        );
111
112        let request = RemoveTasklistMembersRequest::new(config, "tasklist_123")
113            .members(vec!["user_1".to_string(), "user_2".to_string()]);
114
115        assert_eq!(request.tasklist_guid, "tasklist_123");
116        assert_eq!(request.body.members, vec!["user_1", "user_2"]);
117    }
118
119    #[test]
120    fn test_remove_tasklist_member_single() {
121        let config = Arc::new(
122            openlark_core::config::Config::builder()
123                .app_id("test")
124                .app_secret("test")
125                .build(),
126        );
127
128        let request = RemoveTasklistMembersRequest::new(config, "tasklist_123")
129            .remove_member("user_1")
130            .remove_member("user_2");
131
132        assert_eq!(request.body.members, vec!["user_1", "user_2"]);
133    }
134
135    #[test]
136    fn test_tasklist_remove_members_api_v2_url() {
137        let endpoint = TaskApiV2::TasklistRemoveMembers("tasklist_123".to_string());
138        assert_eq!(
139            endpoint.to_url(),
140            "/open-apis/task/v2/tasklists/tasklist_123/remove_members"
141        );
142    }
143}