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