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