openstack_sdk_load_balancer/v2/loadbalancer/
delete.rs1use derive_builder::Builder;
27use http::{HeaderMap, HeaderName, HeaderValue};
28
29use openstack_sdk_core::api::rest_endpoint_prelude::*;
30
31use std::borrow::Cow;
32
33#[derive(Builder, Debug, Clone)]
34#[builder(setter(strip_option))]
35pub struct Request<'a> {
36 #[builder(default)]
38 cascade: Option<bool>,
39
40 #[builder(default, setter(into))]
43 id: Cow<'a, str>,
44
45 #[builder(setter(name = "_headers"), default, private)]
46 _headers: Option<HeaderMap>,
47}
48impl<'a> Request<'a> {
49 pub fn builder() -> RequestBuilder<'a> {
51 RequestBuilder::default()
52 }
53}
54
55impl<'a> RequestBuilder<'a> {
56 pub fn header<K, V>(&mut self, header_name: K, header_value: V) -> &mut Self
58 where
59 K: Into<HeaderName>,
60 V: Into<HeaderValue>,
61 {
62 self._headers
63 .get_or_insert(None)
64 .get_or_insert_with(HeaderMap::new)
65 .insert(header_name.into(), header_value.into());
66 self
67 }
68
69 pub fn headers<I, T>(&mut self, iter: I) -> &mut Self
71 where
72 I: Iterator<Item = T>,
73 T: Into<(Option<HeaderName>, HeaderValue)>,
74 {
75 self._headers
76 .get_or_insert(None)
77 .get_or_insert_with(HeaderMap::new)
78 .extend(iter.map(Into::into));
79 self
80 }
81}
82
83impl RestEndpoint for Request<'_> {
84 fn method(&self) -> http::Method {
85 http::Method::DELETE
86 }
87
88 fn endpoint(&self) -> Cow<'static, str> {
89 format!("lbaas/loadbalancers/{id}", id = self.id.as_ref(),).into()
90 }
91
92 fn parameters(&self) -> QueryParams<'_> {
93 let mut params = QueryParams::default();
94 params.push_opt("cascade", self.cascade);
95
96 params
97 }
98
99 fn service_type(&self) -> ServiceType {
100 ServiceType::LoadBalancer
101 }
102
103 fn response_key(&self) -> Option<Cow<'static, str>> {
104 None
105 }
106
107 fn request_headers(&self) -> Option<&HeaderMap> {
109 self._headers.as_ref()
110 }
111
112 fn api_version(&self) -> Option<ApiVersion> {
114 Some(ApiVersion::new(2, 0))
115 }
116}
117
118#[cfg(test)]
119mod tests {
120 use super::*;
121 use http::{HeaderName, HeaderValue};
122 use httpmock::MockServer;
123 #[cfg(feature = "sync")]
124 use openstack_sdk_core::api::Query;
125 use openstack_sdk_core::test::client::FakeOpenStackClient;
126 use openstack_sdk_core::types::ServiceType;
127 use serde_json::json;
128
129 #[test]
130 fn test_service_type() {
131 assert_eq!(
132 Request::builder().build().unwrap().service_type(),
133 ServiceType::LoadBalancer
134 );
135 }
136
137 #[test]
138 fn test_response_key() {
139 assert!(Request::builder().build().unwrap().response_key().is_none())
140 }
141
142 #[cfg(feature = "sync")]
143 #[test]
144 fn endpoint() {
145 let server = MockServer::start();
146 let client = FakeOpenStackClient::new(server.base_url());
147 let mock = server.mock(|when, then| {
148 when.method(httpmock::Method::DELETE)
149 .path(format!("/lbaas/loadbalancers/{id}", id = "id",));
150
151 then.status(200)
152 .header("content-type", "application/json")
153 .json_body(json!({ "dummy": {} }));
154 });
155
156 let endpoint = Request::builder().id("id").build().unwrap();
157 let _: serde_json::Value = endpoint.query(&client).unwrap();
158 mock.assert();
159 }
160
161 #[cfg(feature = "sync")]
162 #[test]
163 fn endpoint_headers() {
164 let server = MockServer::start();
165 let client = FakeOpenStackClient::new(server.base_url());
166 let mock = server.mock(|when, then| {
167 when.method(httpmock::Method::DELETE)
168 .path(format!("/lbaas/loadbalancers/{id}", id = "id",))
169 .header("foo", "bar")
170 .header("not_foo", "not_bar");
171 then.status(200)
172 .header("content-type", "application/json")
173 .json_body(json!({ "dummy": {} }));
174 });
175
176 let endpoint = Request::builder()
177 .id("id")
178 .headers(
179 [(
180 Some(HeaderName::from_static("foo")),
181 HeaderValue::from_static("bar"),
182 )]
183 .into_iter(),
184 )
185 .header(
186 HeaderName::from_static("not_foo"),
187 HeaderValue::from_static("not_bar"),
188 )
189 .build()
190 .unwrap();
191 let _: serde_json::Value = endpoint.query(&client).unwrap();
192 mock.assert();
193 }
194}