Skip to main content

openlark_workflow/v2/task/
add_members.rs

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