133 137 | ::std::borrow::Cow::Owned(rcb)
|
134 138 | }
|
135 139 | }
|
136 140 |
|
137 141 | #[derive(Debug)]
|
138 142 | struct HttpEmptyPrefixHeadersResponseDeserializer;
|
139 143 | impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for HttpEmptyPrefixHeadersResponseDeserializer {
|
140 144 | fn deserialize_nonstreaming(
|
141 145 | &self,
|
142 146 | response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
|
147 + | _cfg: &::aws_smithy_types::config_bag::ConfigBag,
|
143 148 | ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
|
144 149 | let (success, status) = (response.status().is_success(), response.status().as_u16());
|
150 + | #[allow(unused_mut)]
|
151 + | let mut force_error = false;
|
152 + |
|
153 + | if !success && status != 200 || force_error {
|
145 154 | let headers = response.headers();
|
146 155 | let body = response.body().bytes().expect("body loaded");
|
147 156 | #[allow(unused_mut)]
|
148 - | let mut force_error = false;
|
157 + | let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(status, headers, body).map_err(|e| {
|
158 + | ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
|
159 + | })?;
|
149 160 |
|
150 - | let parse_result = if !success && status != 200 || force_error {
|
151 - | crate::protocol_serde::shape_http_empty_prefix_headers::de_http_empty_prefix_headers_http_error(status, headers, body)
|
161 + | let generic = generic_builder.build();
|
162 + | ::std::result::Result::Err(::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::operation(
|
163 + | ::aws_smithy_runtime_api::client::interceptors::context::Error::erase(
|
164 + | crate::operation::http_empty_prefix_headers::HttpEmptyPrefixHeadersError::generic(generic),
|
165 + | ),
|
166 + | ))
|
152 167 | } else {
|
153 - | crate::protocol_serde::shape_http_empty_prefix_headers::de_http_empty_prefix_headers_http_response(status, headers, body)
|
154 - | };
|
155 - | crate::protocol_serde::type_erase_result(parse_result)
|
168 + | let protocol = _cfg
|
169 + | .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
|
170 + | .expect("a SharedClientProtocol is required");
|
171 + | let mut deser = protocol
|
172 + | .deserialize_response(response, HttpEmptyPrefixHeaders::OUTPUT_SCHEMA, _cfg)
|
173 + | .map_err(|e| {
|
174 + | ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
|
175 + | })?;
|
176 + | let body = response.body().bytes().expect("body loaded");
|
177 + | let output = crate::operation::http_empty_prefix_headers::HttpEmptyPrefixHeadersOutput::deserialize_with_response(
|
178 + | &mut *deser,
|
179 + | response.headers(),
|
180 + | response.status().into(),
|
181 + | body,
|
182 + | )
|
183 + | .map_err(|e| {
|
184 + | ::aws_smithy_runtime_api::client::orchestrator::OrchestratorError::other(::aws_smithy_runtime_api::box_error::BoxError::from(e))
|
185 + | })?;
|
186 + | ::std::result::Result::Ok(::aws_smithy_runtime_api::client::interceptors::context::Output::erase(output))
|
187 + | }
|
156 188 | }
|
157 189 | }
|
158 190 | #[derive(Debug)]
|
159 191 | struct HttpEmptyPrefixHeadersRequestSerializer;
|
160 192 | impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for HttpEmptyPrefixHeadersRequestSerializer {
|
161 193 | #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
|
162 194 | fn serialize_input(
|
163 195 | &self,
|
164 196 | input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
|
165 197 | _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
|
166 198 | ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
|
167 199 | let input = input
|
168 200 | .downcast::<crate::operation::http_empty_prefix_headers::HttpEmptyPrefixHeadersInput>()
|
169 201 | .expect("correct type");
|
170 - | let _header_serialization_settings = _cfg
|
171 - | .load::<crate::serialization_settings::HeaderSerializationSettings>()
|
172 - | .cloned()
|
173 - | .unwrap_or_default();
|
174 - | let mut request_builder = {
|
175 - | #[allow(clippy::uninlined_format_args)]
|
176 - | fn uri_base(
|
177 - | _input: &crate::operation::http_empty_prefix_headers::HttpEmptyPrefixHeadersInput,
|
178 - | output: &mut ::std::string::String,
|
179 - | ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
|
180 - | use ::std::fmt::Write as _;
|
181 - | ::std::write!(output, "/HttpEmptyPrefixHeaders").expect("formatting should succeed");
|
182 - | ::std::result::Result::Ok(())
|
202 + | let protocol = _cfg
|
203 + | .load::<::aws_smithy_schema::protocol::SharedClientProtocol>()
|
204 + | .expect("a SharedClientProtocol is required");
|
205 + | if protocol.supports_http_bindings() {
|
206 + | let mut request = protocol
|
207 + | .serialize_body(&input, HttpEmptyPrefixHeaders::INPUT_SCHEMA, "", _cfg)
|
208 + | .map_err(::aws_smithy_runtime_api::box_error::BoxError::from)?;
|
209 + | {
|
210 + | let mut uri = "/HttpEmptyPrefixHeaders".to_string();
|
211 + | let mut query_params: Vec<(String, String)> = Vec::new();
|
212 + | if let Some(ref map) = input.prefix_headers {
|
213 + | for (k, v) in map {
|
214 + | request.headers_mut().insert(k.to_string(), v.to_string());
|
215 + | }
|
216 + | }
|
217 + | if let Some(ref val) = input.specific_header {
|
218 + | request.headers_mut().insert("hello", val.to_string());
|
219 + | }
|
220 + | if !query_params.is_empty() {
|
221 + | uri.push(if uri.contains('?') { '&' } else { '?' });
|
222 + | let pairs: Vec<String> = query_params
|
223 + | .iter()
|
224 + | .map(|(k, v)| {
|
225 + | format!(
|
226 + | "{}={}",
|
227 + | ::aws_smithy_schema::http_protocol::percent_encode(k),
|
228 + | ::aws_smithy_schema::http_protocol::percent_encode(v)
|
229 + | )
|
230 + | })
|
231 + | .collect();
|
232 + | uri.push_str(&pairs.join("&"));
|
233 + | }
|
234 + | request.set_uri(uri.as_str()).expect("valid URI");
|
183 235 | }
|
184 - | #[allow(clippy::unnecessary_wraps)]
|
185 - | fn update_http_builder(
|
186 - | input: &crate::operation::http_empty_prefix_headers::HttpEmptyPrefixHeadersInput,
|
187 - | builder: ::http_1x::request::Builder,
|
188 - | ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
|
189 - | let mut uri = ::std::string::String::new();
|
190 - | uri_base(input, &mut uri)?;
|
191 - | let builder = crate::protocol_serde::shape_http_empty_prefix_headers::ser_http_empty_prefix_headers_headers(input, builder)?;
|
192 - | ::std::result::Result::Ok(builder.method("GET").uri(uri))
|
193 - | }
|
194 - | let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
|
195 - | builder
|
196 - | };
|
197 - | let body = ::aws_smithy_types::body::SdkBody::from("");
|
198 236 |
|
199 - | ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
|
237 + | return ::std::result::Result::Ok(request);
|
238 + | } else {
|
239 + | let mut request = protocol
|
240 + | .serialize_request(&input, HttpEmptyPrefixHeaders::INPUT_SCHEMA, "", _cfg)
|
241 + | .map_err(::aws_smithy_runtime_api::box_error::BoxError::from)?;
|
242 + |
|
243 + | return ::std::result::Result::Ok(request);
|
244 + | }
|
200 245 | }
|
201 246 | }
|
202 247 | #[derive(Debug)]
|
203 248 | struct HttpEmptyPrefixHeadersEndpointParamsInterceptor;
|
204 249 |
|
205 250 | impl ::aws_smithy_runtime_api::client::interceptors::Intercept for HttpEmptyPrefixHeadersEndpointParamsInterceptor {
|
206 251 | fn name(&self) -> &'static str {
|
207 252 | "HttpEmptyPrefixHeadersEndpointParamsInterceptor"
|
208 253 | }
|
209 254 |
|
210 255 | fn read_before_execution(
|
211 256 | &self,
|
212 257 | context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
|
213 258 | '_,
|
214 259 | ::aws_smithy_runtime_api::client::interceptors::context::Input,
|
215 260 | ::aws_smithy_runtime_api::client::interceptors::context::Output,
|
216 261 | ::aws_smithy_runtime_api::client::interceptors::context::Error,
|
217 262 | >,
|
218 263 | cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
|
219 264 | ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
|
220 265 | let _input = context
|
221 266 | .input()
|
222 267 | .downcast_ref::<HttpEmptyPrefixHeadersInput>()
|
223 268 | .ok_or("failed to downcast to HttpEmptyPrefixHeadersInput")?;
|
224 269 |
|
225 270 | let params = crate::config::endpoint::Params::builder().build().map_err(|err| {
|
226 271 | ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
|
227 272 | })?;
|
228 273 | cfg.interceptor_state()
|
229 274 | .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
|
230 275 | ::std::result::Result::Ok(())
|
231 276 | }
|
232 277 | }
|
233 278 |
|
234 279 | // The get_* functions below are generated from JMESPath expressions in the
|
235 280 | // operationContextParams trait. They target the operation's input shape.
|
236 281 |
|
237 282 | #[allow(unreachable_code, unused_variables)]
|
238 283 | #[cfg(test)]
|
239 284 | mod http_empty_prefix_headers_test {
|
240 285 |
|
241 286 | /// Serializes all request headers, using specific when present
|
242 287 | /// Test ID: RestJsonHttpEmptyPrefixHeadersRequestClient
|
243 288 | #[::tokio::test]
|
244 289 | #[::tracing_test::traced_test]
|
245 - | #[should_panic]
|
246 290 | async fn rest_json_http_empty_prefix_headers_request_client_request() {
|
247 291 | let (http_client, request_receiver) = ::aws_smithy_http_client::test_util::capture_request(None);
|
248 292 | let config_builder = crate::config::Config::builder()
|
249 293 | .with_test_defaults()
|
250 294 | // TODO(https://github.com/smithy-lang/smithy-rs/issues/4177):
|
251 295 | // Until the incorrect separation is addressed, we need to rely on this workaround.
|
252 296 | .allow_no_auth()
|
253 297 | .endpoint_url("https://example.com");
|
254 298 |
|
255 299 | let client = crate::Client::from_conf(config_builder.http_client(http_client).build());
|