termii_rust/async_impl/rest/switch/campaign.rs
1//! Send and manage campaigns sent to your organization's phonebook.
2//!
3//! Create, view & manage phonebooks using these APIs.
4//!
5//! Each phonebook can be identified by a unique ID, which makes it easier to edit or delete a phonebook.
6
7use std::{collections::HashMap, sync::Arc};
8
9use async_trait::async_trait;
10
11use crate::{
12 async_impl::http::client,
13 common::{
14 errors, pagination,
15 switch::campaign::{
16 PhoneBookCreateUpdateDeleteResponse, PhoneBookCreateUpdateRequest, PhoneBookItem,
17 PhoneBookListResponse,
18 },
19 },
20};
21
22#[derive(Debug)]
23pub struct Campaign<'a> {
24 api_key: &'a str,
25 client: Arc<client::HttpClient>,
26}
27
28impl<'a> Campaign<'a> {
29 pub(crate) fn new(api_key: &'a str, client: Arc<client::HttpClient>) -> Campaign<'a> {
30 Campaign { api_key, client }
31 }
32
33 pub(crate) async fn _get(&self, page: &str) -> Result<Vec<PhoneBookItem>, errors::HttpError> {
34 let mut params = HashMap::new();
35 params.insert("api_key", self.api_key);
36 params.insert("page", page);
37
38 let response = self.client.get("phonebooks", Some(params), None).await?;
39
40 let campaign_item = response_or_error_text_async!(response, PhoneBookListResponse);
41
42 Ok(campaign_item.data)
43 }
44
45 /// Fetch Phonebooks.
46 ///
47 /// ## Examples
48 ///
49 /// ```rust
50 /// use termii_rust::{async_impl::rest::termii, common::switch::campaign::PhoneBookItem};
51 ///
52 /// let client = termii::Termii::new("Your API key");
53 ///
54 /// let phonebooks: Vec<PhoneBookItem> = client.switch.campaign.get(Some(1)).await.unwrap();
55 ///
56 /// println!("{:?}", phonebooks);
57 /// ```
58 /// ### The above code is limited by termii's pagination. You can get all your phonebooks with the **all** function like such
59 ///
60 /// ```rust
61 /// let phonebooks: Vec<PhoneBookItem> = client.switch.campaign.all().await.unwrap();
62 /// ```
63 pub async fn get(&self, page: Option<&str>) -> Result<Vec<PhoneBookItem>, errors::HttpError> {
64 let page = page.unwrap_or("1");
65 let campaign_items = self._get(page).await?;
66 Ok(campaign_items)
67 }
68
69 /// Fetch Phonebooks.
70 ///
71 /// ## Examples
72 ///
73 /// ```rust
74 /// use termii_rust::{
75 /// async_impl::rest::termii,
76 /// common::switch::campaign::{
77 /// PhoneBookCreateUpdateDeleteResponse, PhoneBookCreateUpdateRequest,
78 /// },
79 /// };
80 ///
81 /// let client = termii::Termii::new("Your API key");
82 ///
83 /// let phonebook_create_request = PhoneBookCreateUpdateRequest {
84 /// phonebook_name: "My Phonebook".to_string(),
85 /// description: "My Phonebook".to_string(),
86 /// };
87 ///
88 /// let phonebook_create_response: PhoneBookCreateUpdateDeleteResponse = client
89 /// .switch
90 /// .campaign
91 /// .create(phonebook_create_request)
92 /// .await
93 /// .unwrap();
94 ///
95 /// println!("{:?}", phonebook_create_response);
96 /// ```
97 pub async fn create(
98 &self,
99 mut payload: PhoneBookCreateUpdateRequest,
100 ) -> Result<PhoneBookCreateUpdateDeleteResponse, errors::HttpError> {
101 payload.set_api_key(self.api_key);
102
103 let response = self
104 .client
105 .post("phonebooks", None, None, Some(payload))
106 .await?;
107
108 let campaign_create_response =
109 response_or_error_text_async!(response, PhoneBookCreateUpdateDeleteResponse);
110
111 Ok(campaign_create_response)
112 }
113
114 /// Update Phonebook.
115 ///
116 /// ## Examples
117 ///
118 /// ```rust
119 /// use termii_rust::{
120 /// async_impl::rest::termii,
121 /// common::switch::campaign::{
122 /// PhoneBookCreateUpdateDeleteResponse, PhoneBookCreateUpdateRequest,
123 /// },
124 /// };
125 ///
126 /// let client = termii::Termii::new("Your API key");
127 ///
128 /// let phonebook_update_request = PhoneBookCreateUpdateRequest {
129 /// phonebook_name: "My Phonebook".to_string(),
130 /// description: "My Phonebook".to_string(),
131 /// };
132 ///
133 /// let phonebook_update_response: PhoneBookCreateUpdateDeleteResponse = client
134 /// .switch
135 /// .campaign
136 /// .update(
137 /// "f9c28de9-ab5a-4513-9c9f-338be8e1c390",
138 /// phonebook_update_request,
139 /// )
140 /// .await
141 /// .unwrap();
142 ///
143 /// println!("{:?}", phonebook_update_response);
144 /// ```
145 pub async fn update(
146 &self,
147 phonebook_id: &str,
148 mut payload: PhoneBookCreateUpdateRequest,
149 ) -> Result<PhoneBookCreateUpdateDeleteResponse, errors::HttpError> {
150 payload.set_api_key(self.api_key);
151
152 let response = self
153 .client
154 .patch(
155 format!("phonebooks/{}", phonebook_id).as_str(),
156 None,
157 None,
158 Some(payload),
159 )
160 .await?;
161
162 let campaign_update_response =
163 response_or_error_text_async!(response, PhoneBookCreateUpdateDeleteResponse);
164
165 Ok(campaign_update_response)
166 }
167
168 /// Delete Phonebook.
169 ///
170 /// ## Examples
171 ///
172 /// ```rust
173 /// use termii_rust::{
174 /// async_impl::rest::termii, common::switch::campaign::PhoneBookCreateUpdateDeleteResponse,
175 /// };
176 ///
177 /// let client = termii::Termii::new("Your API key");
178 ///
179 /// let phonebook_delete_response: PhoneBookCreateUpdateDeleteResponse = client
180 /// .switch
181 /// .campaign
182 /// .delete("f9c28de9-ab5a-4513-9c9f-338be8e1c390")
183 /// .await
184 /// .unwrap();
185 ///
186 /// println!("{:?}", phonebook_delete_response);
187 /// ```
188 pub async fn delete(
189 &self,
190 phonebook_id: &str,
191 ) -> Result<PhoneBookCreateUpdateDeleteResponse, errors::HttpError> {
192 let response = self
193 .client
194 .delete(format!("phonebooks/{}", phonebook_id).as_str(), None, None)
195 .await?;
196
197 let campaign_delete_response =
198 response_or_error_text_async!(response, PhoneBookCreateUpdateDeleteResponse);
199
200 Ok(campaign_delete_response)
201 }
202}
203
204#[async_trait]
205impl pagination::PaginatedResourceAsync for Campaign<'_> {
206 type Item = PhoneBookItem;
207
208 async fn _get(&self, page: &str) -> Result<Vec<Self::Item>, errors::HttpError> {
209 Campaign::_get(self, page).await
210 }
211}