openlark_workflow/v2/tasklist/
update.rs1use crate::common::{api_endpoints::TaskApiV2, api_utils::*};
6use crate::v2::tasklist::models::{TasklistIcon, UpdateTasklistBody, UpdateTasklistResponse};
7use openlark_core::{
8 SDKResult,
9 api::{ApiRequest, ApiResponseTrait, ResponseFormat},
10 config::Config,
11 validate_required,
12};
13use std::sync::Arc;
14
15#[derive(Debug, Clone)]
17pub struct UpdateTasklistRequest {
18 config: Arc<Config>,
20 tasklist_guid: String,
22 body: UpdateTasklistBody,
24}
25
26impl UpdateTasklistRequest {
27 pub fn new(config: Arc<Config>, tasklist_guid: String) -> Self {
29 Self {
30 config,
31 tasklist_guid,
32 body: UpdateTasklistBody::default(),
33 }
34 }
35
36 pub fn summary(mut self, summary: impl Into<String>) -> Self {
38 self.body.summary = Some(summary.into());
39 self
40 }
41
42 pub fn description(mut self, description: impl Into<String>) -> Self {
44 self.body.description = Some(description.into());
45 self
46 }
47
48 pub fn icon(mut self, icon: TasklistIcon) -> Self {
50 self.body.icon = Some(icon);
51 self
52 }
53
54 pub async fn execute(self) -> SDKResult<UpdateTasklistResponse> {
56 self.execute_with_options(openlark_core::req_option::RequestOption::default())
57 .await
58 }
59
60 pub async fn execute_with_options(
62 self,
63 option: openlark_core::req_option::RequestOption,
64 ) -> SDKResult<UpdateTasklistResponse> {
65 validate_required!(self.tasklist_guid.trim(), "任务清单GUID不能为空");
67
68 let api_endpoint = TaskApiV2::TasklistUpdate(self.tasklist_guid.clone());
69 let mut request = ApiRequest::<UpdateTasklistResponse>::put(api_endpoint.to_url());
70
71 let request_body = &self.body;
72 request = request.body(serialize_params(request_body, "更新任务清单")?);
73
74 let response =
75 openlark_core::http::Transport::request(request, &self.config, Some(option)).await?;
76 extract_response_data(response, "更新任务清单")
77 }
78}
79
80impl ApiResponseTrait for UpdateTasklistResponse {
81 fn data_format() -> ResponseFormat {
82 ResponseFormat::Data
83 }
84}
85
86#[cfg(test)]
87#[allow(unused_imports)]
88mod tests {
89 use std::sync::Arc;
90
91 use super::*;
92
93 #[test]
94 fn test_update_tasklist_builder() {
95 let config = Arc::new(
96 openlark_core::config::Config::builder()
97 .app_id("test")
98 .app_secret("test")
99 .build(),
100 );
101
102 let request =
103 UpdateTasklistRequest::new(config, "tasklist_123".to_string()).summary("更新的标题");
104
105 assert_eq!(request.tasklist_guid, "tasklist_123");
106 assert_eq!(request.body.summary, Some("更新的标题".to_string()));
107 }
108}