artifacts/apis/
events_api.rs1use super::{configuration, Error};
2use crate::{apis::ResponseContent, models};
3use reqwest::StatusCode;
4use serde::{de, Deserialize, Deserializer, Serialize};
5
6#[derive(Clone, Debug)]
8pub struct GetAllActiveEventsParams {
9 pub page: Option<u32>,
11 pub size: Option<u32>,
13}
14
15impl GetAllActiveEventsParams {
16 pub fn new(page: Option<u32>, size: Option<u32>) -> Self {
17 Self { page, size }
18 }
19}
20
21#[derive(Clone, Debug)]
23pub struct GetAllEventsParams {
24 pub r#type: Option<models::MapContentType>,
26 pub page: Option<u32>,
28 pub size: Option<u32>,
30}
31
32impl GetAllEventsParams {
33 pub fn new(
34 r#type: Option<models::MapContentType>,
35 page: Option<u32>,
36 size: Option<u32>,
37 ) -> Self {
38 Self { r#type, page, size }
39 }
40}
41
42#[derive(Clone, Debug)]
44pub struct SpawnEventParams {
45 pub spawn_event_request: models::SpawnEventRequest,
46}
47
48impl SpawnEventParams {
49 pub fn new(spawn_event_request: models::SpawnEventRequest) -> Self {
50 Self {
51 spawn_event_request,
52 }
53 }
54}
55
56#[derive(Debug, Clone, Serialize)]
58#[serde(untagged)]
59pub enum GetAllActiveEventsError {}
60
61impl<'de> Deserialize<'de> for GetAllActiveEventsError {
62 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
63 where
64 D: Deserializer<'de>,
65 {
66 let raw = models::ErrorResponseSchema::deserialize(deserializer)?;
67 Err(de::Error::custom(format!(
68 "Unexpected error code: {}",
69 raw.error.code
70 )))
71 }
72}
73
74#[derive(Debug, Clone, Serialize)]
76#[serde(untagged)]
77pub enum GetAllEventsError {}
78
79impl<'de> Deserialize<'de> for GetAllEventsError {
80 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
81 where
82 D: Deserializer<'de>,
83 {
84 let raw = models::ErrorResponseSchema::deserialize(deserializer)?;
85 Err(de::Error::custom(format!(
86 "Unexpected error code: {}",
87 raw.error.code
88 )))
89 }
90}
91
92#[derive(Debug, Clone, Serialize)]
94#[serde(untagged)]
95pub enum SpawnEventError {
96 Status563(models::ErrorResponseSchema),
98 Status564(models::ErrorResponseSchema),
100 Status422(models::ErrorResponseSchema),
102}
103
104impl<'de> Deserialize<'de> for SpawnEventError {
105 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
106 where
107 D: Deserializer<'de>,
108 {
109 let raw = models::ErrorResponseSchema::deserialize(deserializer)?;
110 match raw.error.code {
111 563 => Ok(Self::Status563(raw)),
112 564 => Ok(Self::Status564(raw)),
113 422 => Ok(Self::Status422(raw)),
114 _ => Err(de::Error::custom(format!(
115 "Unexpected error code: {}",
116 raw.error.code
117 ))),
118 }
119 }
120}
121
122pub async fn get_all_active_events(
124 configuration: &configuration::Configuration,
125 params: GetAllActiveEventsParams,
126) -> Result<models::DataPageActiveEventSchema, Error<GetAllActiveEventsError>> {
127 let local_var_configuration = configuration;
128
129 let page = params.page;
131 let size = params.size;
133
134 let local_var_client = &local_var_configuration.client;
135
136 let local_var_uri_str = format!("{}/events/active", local_var_configuration.base_path);
137 let mut local_var_req_builder =
138 local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
139
140 if let Some(ref local_var_str) = page {
141 local_var_req_builder =
142 local_var_req_builder.query(&[("page", &local_var_str.to_string())]);
143 }
144 if let Some(ref local_var_str) = size {
145 local_var_req_builder =
146 local_var_req_builder.query(&[("size", &local_var_str.to_string())]);
147 }
148 if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
149 local_var_req_builder =
150 local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
151 }
152
153 let local_var_req = local_var_req_builder.build()?;
154 let local_var_resp = local_var_client.execute(local_var_req).await?;
155
156 let local_var_status = local_var_resp.status();
157 let local_var_content = local_var_resp.text().await?;
158
159 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
160 serde_json::from_str(&local_var_content).map_err(Error::from)
161 } else {
162 let local_var_entity: Option<GetAllActiveEventsError> =
163 serde_json::from_str(&local_var_content).ok();
164 let local_var_error = ResponseContent {
165 status: local_var_status,
166 content: local_var_content,
167 entity: local_var_entity,
168 };
169 Err(Error::ResponseError(local_var_error))
170 }
171}
172
173pub async fn get_all_events(
175 configuration: &configuration::Configuration,
176 params: GetAllEventsParams,
177) -> Result<models::DataPageEventSchema, Error<GetAllEventsError>> {
178 let local_var_configuration = configuration;
179
180 let r#type = params.r#type;
182 let page = params.page;
184 let size = params.size;
186
187 let local_var_client = &local_var_configuration.client;
188
189 let local_var_uri_str = format!("{}/events", local_var_configuration.base_path);
190 let mut local_var_req_builder =
191 local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
192
193 if let Some(ref local_var_str) = r#type {
194 local_var_req_builder =
195 local_var_req_builder.query(&[("type", &local_var_str.to_string())]);
196 }
197 if let Some(ref local_var_str) = page {
198 local_var_req_builder =
199 local_var_req_builder.query(&[("page", &local_var_str.to_string())]);
200 }
201 if let Some(ref local_var_str) = size {
202 local_var_req_builder =
203 local_var_req_builder.query(&[("size", &local_var_str.to_string())]);
204 }
205 if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
206 local_var_req_builder =
207 local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
208 }
209
210 let local_var_req = local_var_req_builder.build()?;
211 let local_var_resp = local_var_client.execute(local_var_req).await?;
212
213 let local_var_status = local_var_resp.status();
214 let local_var_content = local_var_resp.text().await?;
215
216 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
217 serde_json::from_str(&local_var_content).map_err(Error::from)
218 } else {
219 let local_var_entity: Option<GetAllEventsError> =
220 serde_json::from_str(&local_var_content).ok();
221 let local_var_error = ResponseContent {
222 status: local_var_status,
223 content: local_var_content,
224 entity: local_var_entity,
225 };
226 Err(Error::ResponseError(local_var_error))
227 }
228}
229
230pub async fn spawn_event(
232 configuration: &configuration::Configuration,
233 params: SpawnEventParams,
234) -> Result<models::ActiveEventResponseSchema, Error<SpawnEventError>> {
235 let local_var_configuration = configuration;
236
237 let spawn_event_request = params.spawn_event_request;
239
240 let local_var_client = &local_var_configuration.client;
241
242 let local_var_uri_str = format!("{}/events/spawn", local_var_configuration.base_path);
243 let mut local_var_req_builder =
244 local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
245
246 if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
247 local_var_req_builder =
248 local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
249 }
250 if let Some(ref local_var_token) = local_var_configuration.bearer_access_token {
251 local_var_req_builder = local_var_req_builder.bearer_auth(local_var_token.to_owned());
252 };
253 local_var_req_builder = local_var_req_builder.json(&spawn_event_request);
254
255 let local_var_req = local_var_req_builder.build()?;
256 let local_var_resp = local_var_client.execute(local_var_req).await?;
257
258 let local_var_status = local_var_resp.status();
259 let local_var_content = local_var_resp.text().await?;
260
261 if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
262 serde_json::from_str(&local_var_content).map_err(Error::from)
263 } else {
264 let local_var_entity: Option<SpawnEventError> =
265 serde_json::from_str(&local_var_content).ok();
266 let local_var_error = ResponseContent {
267 status: local_var_status,
268 content: local_var_content,
269 entity: local_var_entity,
270 };
271 Err(Error::ResponseError(local_var_error))
272 }
273}