1pub use ::aws_smithy_runtime_api::client::endpoint::EndpointFuture;
3pub use ::aws_smithy_runtime_api::client::endpoint::SharedEndpointResolver;
4pub use ::aws_smithy_types::endpoint::Endpoint;
5
6#[derive(Debug, Default)]
8pub(crate) struct EndpointOverrideFeatureTrackerInterceptor;
9
10#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
11impl ::aws_smithy_runtime_api::client::interceptors::Intercept for EndpointOverrideFeatureTrackerInterceptor {
12 fn name(&self) -> &'static str {
13 "EndpointOverrideFeatureTrackerInterceptor"
14 }
15
16 fn read_before_execution(
17 &self,
18 _context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<'_>,
19 cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
20 ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
21 if cfg.load::<::aws_types::endpoint_config::EndpointUrl>().is_some() {
22 cfg.interceptor_state()
23 .store_append(::aws_runtime::sdk_feature::AwsSdkFeature::EndpointOverride);
24 }
25 ::std::result::Result::Ok(())
26 }
27}
28
29#[cfg(test)]
30mod test {
31
32 #[test]
34 fn test_1() {
35 let params = crate::config::endpoint::Params::builder()
36 .region("us-east-1".to_string())
37 .use_fips(true)
38 .use_dual_stack(true)
39 .build()
40 .expect("invalid params");
41 let resolver = crate::config::endpoint::DefaultResolver::new();
42 let endpoint = resolver.resolve_endpoint(¶ms);
43 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography-fips.us-east-1.api.aws");
44 assert_eq!(
45 endpoint,
46 ::aws_smithy_types::endpoint::Endpoint::builder()
47 .url("https://dataplane.payment-cryptography-fips.us-east-1.api.aws")
48 .build()
49 );
50 }
51
52 #[test]
54 fn test_2() {
55 let params = crate::config::endpoint::Params::builder()
56 .region("us-east-1".to_string())
57 .use_fips(true)
58 .use_dual_stack(false)
59 .build()
60 .expect("invalid params");
61 let resolver = crate::config::endpoint::DefaultResolver::new();
62 let endpoint = resolver.resolve_endpoint(¶ms);
63 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography-fips.us-east-1.amazonaws.com");
64 assert_eq!(
65 endpoint,
66 ::aws_smithy_types::endpoint::Endpoint::builder()
67 .url("https://dataplane.payment-cryptography-fips.us-east-1.amazonaws.com")
68 .build()
69 );
70 }
71
72 #[test]
74 fn test_3() {
75 let params = crate::config::endpoint::Params::builder()
76 .region("us-east-1".to_string())
77 .use_fips(false)
78 .use_dual_stack(true)
79 .build()
80 .expect("invalid params");
81 let resolver = crate::config::endpoint::DefaultResolver::new();
82 let endpoint = resolver.resolve_endpoint(¶ms);
83 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography.us-east-1.api.aws");
84 assert_eq!(
85 endpoint,
86 ::aws_smithy_types::endpoint::Endpoint::builder()
87 .url("https://dataplane.payment-cryptography.us-east-1.api.aws")
88 .build()
89 );
90 }
91
92 #[test]
94 fn test_4() {
95 let params = crate::config::endpoint::Params::builder()
96 .region("us-east-1".to_string())
97 .use_fips(false)
98 .use_dual_stack(false)
99 .build()
100 .expect("invalid params");
101 let resolver = crate::config::endpoint::DefaultResolver::new();
102 let endpoint = resolver.resolve_endpoint(¶ms);
103 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography.us-east-1.amazonaws.com");
104 assert_eq!(
105 endpoint,
106 ::aws_smithy_types::endpoint::Endpoint::builder()
107 .url("https://dataplane.payment-cryptography.us-east-1.amazonaws.com")
108 .build()
109 );
110 }
111
112 #[test]
114 fn test_5() {
115 let params = crate::config::endpoint::Params::builder()
116 .region("cn-north-1".to_string())
117 .use_fips(true)
118 .use_dual_stack(true)
119 .build()
120 .expect("invalid params");
121 let resolver = crate::config::endpoint::DefaultResolver::new();
122 let endpoint = resolver.resolve_endpoint(¶ms);
123 let endpoint =
124 endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography-fips.cn-north-1.api.amazonwebservices.com.cn");
125 assert_eq!(
126 endpoint,
127 ::aws_smithy_types::endpoint::Endpoint::builder()
128 .url("https://dataplane.payment-cryptography-fips.cn-north-1.api.amazonwebservices.com.cn")
129 .build()
130 );
131 }
132
133 #[test]
135 fn test_6() {
136 let params = crate::config::endpoint::Params::builder()
137 .region("cn-north-1".to_string())
138 .use_fips(true)
139 .use_dual_stack(false)
140 .build()
141 .expect("invalid params");
142 let resolver = crate::config::endpoint::DefaultResolver::new();
143 let endpoint = resolver.resolve_endpoint(¶ms);
144 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography-fips.cn-north-1.amazonaws.com.cn");
145 assert_eq!(
146 endpoint,
147 ::aws_smithy_types::endpoint::Endpoint::builder()
148 .url("https://dataplane.payment-cryptography-fips.cn-north-1.amazonaws.com.cn")
149 .build()
150 );
151 }
152
153 #[test]
155 fn test_7() {
156 let params = crate::config::endpoint::Params::builder()
157 .region("cn-north-1".to_string())
158 .use_fips(false)
159 .use_dual_stack(true)
160 .build()
161 .expect("invalid params");
162 let resolver = crate::config::endpoint::DefaultResolver::new();
163 let endpoint = resolver.resolve_endpoint(¶ms);
164 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography.cn-north-1.api.amazonwebservices.com.cn");
165 assert_eq!(
166 endpoint,
167 ::aws_smithy_types::endpoint::Endpoint::builder()
168 .url("https://dataplane.payment-cryptography.cn-north-1.api.amazonwebservices.com.cn")
169 .build()
170 );
171 }
172
173 #[test]
175 fn test_8() {
176 let params = crate::config::endpoint::Params::builder()
177 .region("cn-north-1".to_string())
178 .use_fips(false)
179 .use_dual_stack(false)
180 .build()
181 .expect("invalid params");
182 let resolver = crate::config::endpoint::DefaultResolver::new();
183 let endpoint = resolver.resolve_endpoint(¶ms);
184 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography.cn-north-1.amazonaws.com.cn");
185 assert_eq!(
186 endpoint,
187 ::aws_smithy_types::endpoint::Endpoint::builder()
188 .url("https://dataplane.payment-cryptography.cn-north-1.amazonaws.com.cn")
189 .build()
190 );
191 }
192
193 #[test]
195 fn test_9() {
196 let params = crate::config::endpoint::Params::builder()
197 .region("us-gov-east-1".to_string())
198 .use_fips(true)
199 .use_dual_stack(true)
200 .build()
201 .expect("invalid params");
202 let resolver = crate::config::endpoint::DefaultResolver::new();
203 let endpoint = resolver.resolve_endpoint(¶ms);
204 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography-fips.us-gov-east-1.api.aws");
205 assert_eq!(
206 endpoint,
207 ::aws_smithy_types::endpoint::Endpoint::builder()
208 .url("https://dataplane.payment-cryptography-fips.us-gov-east-1.api.aws")
209 .build()
210 );
211 }
212
213 #[test]
215 fn test_10() {
216 let params = crate::config::endpoint::Params::builder()
217 .region("us-gov-east-1".to_string())
218 .use_fips(true)
219 .use_dual_stack(false)
220 .build()
221 .expect("invalid params");
222 let resolver = crate::config::endpoint::DefaultResolver::new();
223 let endpoint = resolver.resolve_endpoint(¶ms);
224 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography-fips.us-gov-east-1.amazonaws.com");
225 assert_eq!(
226 endpoint,
227 ::aws_smithy_types::endpoint::Endpoint::builder()
228 .url("https://dataplane.payment-cryptography-fips.us-gov-east-1.amazonaws.com")
229 .build()
230 );
231 }
232
233 #[test]
235 fn test_11() {
236 let params = crate::config::endpoint::Params::builder()
237 .region("us-gov-east-1".to_string())
238 .use_fips(false)
239 .use_dual_stack(true)
240 .build()
241 .expect("invalid params");
242 let resolver = crate::config::endpoint::DefaultResolver::new();
243 let endpoint = resolver.resolve_endpoint(¶ms);
244 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography.us-gov-east-1.api.aws");
245 assert_eq!(
246 endpoint,
247 ::aws_smithy_types::endpoint::Endpoint::builder()
248 .url("https://dataplane.payment-cryptography.us-gov-east-1.api.aws")
249 .build()
250 );
251 }
252
253 #[test]
255 fn test_12() {
256 let params = crate::config::endpoint::Params::builder()
257 .region("us-gov-east-1".to_string())
258 .use_fips(false)
259 .use_dual_stack(false)
260 .build()
261 .expect("invalid params");
262 let resolver = crate::config::endpoint::DefaultResolver::new();
263 let endpoint = resolver.resolve_endpoint(¶ms);
264 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography.us-gov-east-1.amazonaws.com");
265 assert_eq!(
266 endpoint,
267 ::aws_smithy_types::endpoint::Endpoint::builder()
268 .url("https://dataplane.payment-cryptography.us-gov-east-1.amazonaws.com")
269 .build()
270 );
271 }
272
273 #[test]
275 fn test_13() {
276 let params = crate::config::endpoint::Params::builder()
277 .region("us-iso-east-1".to_string())
278 .use_fips(true)
279 .use_dual_stack(false)
280 .build()
281 .expect("invalid params");
282 let resolver = crate::config::endpoint::DefaultResolver::new();
283 let endpoint = resolver.resolve_endpoint(¶ms);
284 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography-fips.us-iso-east-1.c2s.ic.gov");
285 assert_eq!(
286 endpoint,
287 ::aws_smithy_types::endpoint::Endpoint::builder()
288 .url("https://dataplane.payment-cryptography-fips.us-iso-east-1.c2s.ic.gov")
289 .build()
290 );
291 }
292
293 #[test]
295 fn test_14() {
296 let params = crate::config::endpoint::Params::builder()
297 .region("us-iso-east-1".to_string())
298 .use_fips(false)
299 .use_dual_stack(false)
300 .build()
301 .expect("invalid params");
302 let resolver = crate::config::endpoint::DefaultResolver::new();
303 let endpoint = resolver.resolve_endpoint(¶ms);
304 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography.us-iso-east-1.c2s.ic.gov");
305 assert_eq!(
306 endpoint,
307 ::aws_smithy_types::endpoint::Endpoint::builder()
308 .url("https://dataplane.payment-cryptography.us-iso-east-1.c2s.ic.gov")
309 .build()
310 );
311 }
312
313 #[test]
315 fn test_15() {
316 let params = crate::config::endpoint::Params::builder()
317 .region("us-isob-east-1".to_string())
318 .use_fips(true)
319 .use_dual_stack(false)
320 .build()
321 .expect("invalid params");
322 let resolver = crate::config::endpoint::DefaultResolver::new();
323 let endpoint = resolver.resolve_endpoint(¶ms);
324 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography-fips.us-isob-east-1.sc2s.sgov.gov");
325 assert_eq!(
326 endpoint,
327 ::aws_smithy_types::endpoint::Endpoint::builder()
328 .url("https://dataplane.payment-cryptography-fips.us-isob-east-1.sc2s.sgov.gov")
329 .build()
330 );
331 }
332
333 #[test]
335 fn test_16() {
336 let params = crate::config::endpoint::Params::builder()
337 .region("us-isob-east-1".to_string())
338 .use_fips(false)
339 .use_dual_stack(false)
340 .build()
341 .expect("invalid params");
342 let resolver = crate::config::endpoint::DefaultResolver::new();
343 let endpoint = resolver.resolve_endpoint(¶ms);
344 let endpoint = endpoint.expect("Expected valid endpoint: https://dataplane.payment-cryptography.us-isob-east-1.sc2s.sgov.gov");
345 assert_eq!(
346 endpoint,
347 ::aws_smithy_types::endpoint::Endpoint::builder()
348 .url("https://dataplane.payment-cryptography.us-isob-east-1.sc2s.sgov.gov")
349 .build()
350 );
351 }
352
353 #[test]
355 fn test_17() {
356 let params = crate::config::endpoint::Params::builder()
357 .region("us-east-1".to_string())
358 .use_fips(false)
359 .use_dual_stack(false)
360 .endpoint("https://example.com".to_string())
361 .build()
362 .expect("invalid params");
363 let resolver = crate::config::endpoint::DefaultResolver::new();
364 let endpoint = resolver.resolve_endpoint(¶ms);
365 let endpoint = endpoint.expect("Expected valid endpoint: https://example.com");
366 assert_eq!(
367 endpoint,
368 ::aws_smithy_types::endpoint::Endpoint::builder().url("https://example.com").build()
369 );
370 }
371
372 #[test]
374 fn test_18() {
375 let params = crate::config::endpoint::Params::builder()
376 .use_fips(false)
377 .use_dual_stack(false)
378 .endpoint("https://example.com".to_string())
379 .build()
380 .expect("invalid params");
381 let resolver = crate::config::endpoint::DefaultResolver::new();
382 let endpoint = resolver.resolve_endpoint(¶ms);
383 let endpoint = endpoint.expect("Expected valid endpoint: https://example.com");
384 assert_eq!(
385 endpoint,
386 ::aws_smithy_types::endpoint::Endpoint::builder().url("https://example.com").build()
387 );
388 }
389
390 #[test]
392 fn test_19() {
393 let params = crate::config::endpoint::Params::builder()
394 .region("us-east-1".to_string())
395 .use_fips(true)
396 .use_dual_stack(false)
397 .endpoint("https://example.com".to_string())
398 .build()
399 .expect("invalid params");
400 let resolver = crate::config::endpoint::DefaultResolver::new();
401 let endpoint = resolver.resolve_endpoint(¶ms);
402 let error = endpoint.expect_err("expected error: Invalid Configuration: FIPS and custom endpoint are not supported [For custom endpoint with fips enabled and dualstack disabled]");
403 assert_eq!(format!("{}", error), "Invalid Configuration: FIPS and custom endpoint are not supported")
404 }
405
406 #[test]
408 fn test_20() {
409 let params = crate::config::endpoint::Params::builder()
410 .region("us-east-1".to_string())
411 .use_fips(false)
412 .use_dual_stack(true)
413 .endpoint("https://example.com".to_string())
414 .build()
415 .expect("invalid params");
416 let resolver = crate::config::endpoint::DefaultResolver::new();
417 let endpoint = resolver.resolve_endpoint(¶ms);
418 let error = endpoint.expect_err("expected error: Invalid Configuration: Dualstack and custom endpoint are not supported [For custom endpoint with fips disabled and dualstack enabled]");
419 assert_eq!(
420 format!("{}", error),
421 "Invalid Configuration: Dualstack and custom endpoint are not supported"
422 )
423 }
424
425 #[test]
427 fn test_21() {
428 let params = crate::config::endpoint::Params::builder().build().expect("invalid params");
429 let resolver = crate::config::endpoint::DefaultResolver::new();
430 let endpoint = resolver.resolve_endpoint(¶ms);
431 let error = endpoint.expect_err("expected error: Invalid Configuration: Missing Region [Missing region]");
432 assert_eq!(format!("{}", error), "Invalid Configuration: Missing Region")
433 }
434}
435
436pub trait ResolveEndpoint: ::std::marker::Send + ::std::marker::Sync + ::std::fmt::Debug {
438 fn resolve_endpoint<'a>(&'a self, params: &'a crate::config::endpoint::Params) -> ::aws_smithy_runtime_api::client::endpoint::EndpointFuture<'a>;
440
441 fn into_shared_resolver(self) -> ::aws_smithy_runtime_api::client::endpoint::SharedEndpointResolver
445 where
446 Self: Sized + 'static,
447 {
448 ::aws_smithy_runtime_api::client::endpoint::SharedEndpointResolver::new(DowncastParams(self))
449 }
450}
451
452#[derive(Debug)]
453struct DowncastParams<T>(T);
454impl<T> ::aws_smithy_runtime_api::client::endpoint::ResolveEndpoint for DowncastParams<T>
455where
456 T: ResolveEndpoint,
457{
458 fn resolve_endpoint<'a>(
459 &'a self,
460 params: &'a ::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams,
461 ) -> ::aws_smithy_runtime_api::client::endpoint::EndpointFuture<'a> {
462 let ep = match params.get::<crate::config::endpoint::Params>() {
463 Some(params) => self.0.resolve_endpoint(params),
464 None => ::aws_smithy_runtime_api::client::endpoint::EndpointFuture::ready(Err("params of expected type was not present".into())),
465 };
466 ep
467 }
468}
469
470#[derive(Debug)]
471pub struct DefaultResolver {
473 partition_resolver: &'static crate::endpoint_lib::partition::PartitionResolver,
474 endpoint_cache: ::arc_swap::ArcSwap<::std::option::Option<(Params, ::aws_smithy_types::endpoint::Endpoint)>>,
475}
476
477impl Default for DefaultResolver {
478 fn default() -> Self {
479 Self::new()
480 }
481}
482
483impl DefaultResolver {
484 pub fn new() -> Self {
486 Self {
487 partition_resolver: &crate::endpoint_lib::DEFAULT_PARTITION_RESOLVER,
488 endpoint_cache: ::arc_swap::ArcSwap::from_pointee(None),
489 }
490 }
491
492 #[allow(
493 unused_variables,
494 unused_parens,
495 clippy::double_parens,
496 clippy::useless_conversion,
497 clippy::bool_comparison,
498 clippy::comparison_to_empty,
499 clippy::needless_borrow,
500 clippy::useless_asref,
501 clippy::redundant_closure_call,
502 clippy::clone_on_copy
503 )]
504 fn resolve_endpoint<'a>(
505 &'a self,
506 params: &'a crate::config::endpoint::Params,
507 ) -> ::std::result::Result<::aws_smithy_types::endpoint::Endpoint, ::aws_smithy_runtime_api::box_error::BoxError> {
508 let mut _diagnostic_collector = crate::endpoint_lib::diagnostic::DiagnosticCollector::new();
509 #[allow(unused_mut)]
510 let mut context = ConditionContext::default();
511
512 let region = ¶ms.region;
514 let use_dual_stack = ¶ms.use_dual_stack;
515 let use_fips = ¶ms.use_fips;
516 let endpoint = ¶ms.endpoint;
517
518 let mut current_ref: i32 = 2;
519 loop {
520 match current_ref {
521 ref_val if ref_val >= 100_000_000 => {
522 return match (ref_val - 100_000_000) as usize {
523 0 => ::std::result::Result::Err(Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message(
524 "No endpoint rule matched",
525 )) as ::aws_smithy_runtime_api::box_error::BoxError),
526 1 => ::std::result::Result::Err(Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message(
527 "Invalid Configuration: FIPS and custom endpoint are not supported".to_string(),
528 )) as ::aws_smithy_runtime_api::box_error::BoxError),
529 2 => ::std::result::Result::Err(Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message(
530 "Invalid Configuration: Dualstack and custom endpoint are not supported".to_string(),
531 )) as ::aws_smithy_runtime_api::box_error::BoxError),
532 3 => {
533 let endpoint = params.endpoint.as_deref().unwrap_or_default();
534 ::std::result::Result::Ok(::aws_smithy_types::endpoint::Endpoint::builder().url(endpoint.to_owned()).build())
535 }
536 4 => {
537 let region = params.region.as_deref().unwrap_or_default();
538 let partition_result = context.partition_result.as_ref().expect("Guaranteed to have a value by earlier checks.");
539 ::std::result::Result::Ok(
540 ::aws_smithy_types::endpoint::Endpoint::builder()
541 .url({
542 let mut out = String::new();
543 out.push_str("https://dataplane.payment-cryptography-fips.");
544 #[allow(clippy::needless_borrow)]
545 out.push_str(®ion.as_ref());
546 out.push('.');
547 #[allow(clippy::needless_borrow)]
548 out.push_str(&partition_result.dual_stack_dns_suffix());
549 out
550 })
551 .build(),
552 )
553 }
554 5 => ::std::result::Result::Err(Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message(
555 "FIPS and DualStack are enabled, but this partition does not support one or both".to_string(),
556 )) as ::aws_smithy_runtime_api::box_error::BoxError),
557 6 => {
558 let region = params.region.as_deref().unwrap_or_default();
559 let partition_result = context.partition_result.as_ref().expect("Guaranteed to have a value by earlier checks.");
560 ::std::result::Result::Ok(
561 ::aws_smithy_types::endpoint::Endpoint::builder()
562 .url({
563 let mut out = String::new();
564 out.push_str("https://dataplane.payment-cryptography-fips.");
565 #[allow(clippy::needless_borrow)]
566 out.push_str(®ion.as_ref());
567 out.push('.');
568 #[allow(clippy::needless_borrow)]
569 out.push_str(&partition_result.dns_suffix());
570 out
571 })
572 .build(),
573 )
574 }
575 7 => ::std::result::Result::Err(Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message(
576 "FIPS is enabled but this partition does not support FIPS".to_string(),
577 )) as ::aws_smithy_runtime_api::box_error::BoxError),
578 8 => {
579 let region = params.region.as_deref().unwrap_or_default();
580 let partition_result = context.partition_result.as_ref().expect("Guaranteed to have a value by earlier checks.");
581 ::std::result::Result::Ok(
582 ::aws_smithy_types::endpoint::Endpoint::builder()
583 .url({
584 let mut out = String::new();
585 out.push_str("https://dataplane.payment-cryptography.");
586 #[allow(clippy::needless_borrow)]
587 out.push_str(®ion.as_ref());
588 out.push('.');
589 #[allow(clippy::needless_borrow)]
590 out.push_str(&partition_result.dual_stack_dns_suffix());
591 out
592 })
593 .build(),
594 )
595 }
596 9 => ::std::result::Result::Err(Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message(
597 "DualStack is enabled but this partition does not support DualStack".to_string(),
598 )) as ::aws_smithy_runtime_api::box_error::BoxError),
599 10 => {
600 let region = params.region.as_deref().unwrap_or_default();
601 let partition_result = context.partition_result.as_ref().expect("Guaranteed to have a value by earlier checks.");
602 ::std::result::Result::Ok(
603 ::aws_smithy_types::endpoint::Endpoint::builder()
604 .url({
605 let mut out = String::new();
606 out.push_str("https://dataplane.payment-cryptography.");
607 #[allow(clippy::needless_borrow)]
608 out.push_str(®ion.as_ref());
609 out.push('.');
610 #[allow(clippy::needless_borrow)]
611 out.push_str(&partition_result.dns_suffix());
612 out
613 })
614 .build(),
615 )
616 }
617 11 => ::std::result::Result::Err(Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message(
618 "Invalid Configuration: Missing Region".to_string(),
619 )) as ::aws_smithy_runtime_api::box_error::BoxError),
620 _ => ::std::result::Result::Err(Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message(
621 "No endpoint rule matched",
622 )) as ::aws_smithy_runtime_api::box_error::BoxError),
623 };
624 }
625 1 | -1 => {
626 return ::std::result::Result::Err(
627 Box::new(::aws_smithy_http::endpoint::ResolveEndpointError::message("No endpoint rule matched"))
628 as ::aws_smithy_runtime_api::box_error::BoxError,
629 )
630 }
631 ref_val => {
632 let is_complement = ref_val < 0;
633 let node = &NODES[(ref_val.unsigned_abs() as usize) - 1];
634 let condition_result = match node.condition_index {
635 0 => endpoint.is_some(),
636 1 => region.is_some(),
637 2 => (|_diagnostic_collector: &mut crate::endpoint_lib::diagnostic::DiagnosticCollector| -> bool {
638 let partition_result = &mut context.partition_result;
639 let partition_resolver = &self.partition_resolver;
640 {
641 *partition_result = partition_resolver
642 .resolve_partition(if let Some(param) = region { param } else { return false }, _diagnostic_collector)
643 .map(|inner| inner.into());
644 partition_result.is_some()
645 }
646 })(&mut _diagnostic_collector),
647 3 => (use_fips) == (&true),
648 4 => (use_dual_stack) == (&true),
649 5 => (|_diagnostic_collector: &mut crate::endpoint_lib::diagnostic::DiagnosticCollector| -> bool {
650 let partition_result = &context.partition_result;
651 let partition_resolver = &self.partition_resolver;
652 (if let Some(inner) = partition_result {
653 inner.supports_dual_stack()
654 } else {
655 return false;
656 }) == (true)
657 })(&mut _diagnostic_collector),
658 6 => (|_diagnostic_collector: &mut crate::endpoint_lib::diagnostic::DiagnosticCollector| -> bool {
659 let partition_result = &context.partition_result;
660 let partition_resolver = &self.partition_resolver;
661 (if let Some(inner) = partition_result {
662 inner.supports_fips()
663 } else {
664 return false;
665 }) == (true)
666 })(&mut _diagnostic_collector),
667 _ => unreachable!("Invalid condition index"),
668 };
669 current_ref = if is_complement ^ condition_result { node.high_ref } else { node.low_ref };
670 }
671 }
672 }
673 }
674}
675
676impl crate::config::endpoint::ResolveEndpoint for DefaultResolver {
677 fn resolve_endpoint<'a>(&'a self, params: &'a crate::config::endpoint::Params) -> ::aws_smithy_runtime_api::client::endpoint::EndpointFuture<'a> {
678 let cached = self.endpoint_cache.load();
680 if let Some((cached_params, cached_endpoint)) = cached.as_ref() {
681 if cached_params == params {
682 return ::aws_smithy_runtime_api::client::endpoint::EndpointFuture::ready(::std::result::Result::Ok(cached_endpoint.clone()));
683 }
684 }
685 drop(cached);
686 let result = self.resolve_endpoint(params);
687 if let ::std::result::Result::Ok(ref endpoint) = result {
688 self.endpoint_cache.store(::std::sync::Arc::new(Some((params.clone(), endpoint.clone()))));
689 }
690 ::aws_smithy_runtime_api::client::endpoint::EndpointFuture::ready(result)
691 }
692}
693const NODES: [crate::endpoint_lib::bdd_interpreter::BddNode; 13] = [
694 crate::endpoint_lib::bdd_interpreter::BddNode {
695 condition_index: -1,
696 high_ref: 1,
697 low_ref: -1,
698 },
699 crate::endpoint_lib::bdd_interpreter::BddNode {
700 condition_index: 0,
701 high_ref: 12,
702 low_ref: 3,
703 },
704 crate::endpoint_lib::bdd_interpreter::BddNode {
705 condition_index: 1,
706 high_ref: 4,
707 low_ref: 100000011,
708 },
709 crate::endpoint_lib::bdd_interpreter::BddNode {
710 condition_index: 2,
711 high_ref: 5,
712 low_ref: 100000011,
713 },
714 crate::endpoint_lib::bdd_interpreter::BddNode {
715 condition_index: 3,
716 high_ref: 8,
717 low_ref: 6,
718 },
719 crate::endpoint_lib::bdd_interpreter::BddNode {
720 condition_index: 4,
721 high_ref: 7,
722 low_ref: 100000010,
723 },
724 crate::endpoint_lib::bdd_interpreter::BddNode {
725 condition_index: 5,
726 high_ref: 100000008,
727 low_ref: 100000009,
728 },
729 crate::endpoint_lib::bdd_interpreter::BddNode {
730 condition_index: 4,
731 high_ref: 10,
732 low_ref: 9,
733 },
734 crate::endpoint_lib::bdd_interpreter::BddNode {
735 condition_index: 6,
736 high_ref: 100000006,
737 low_ref: 100000007,
738 },
739 crate::endpoint_lib::bdd_interpreter::BddNode {
740 condition_index: 5,
741 high_ref: 11,
742 low_ref: 100000005,
743 },
744 crate::endpoint_lib::bdd_interpreter::BddNode {
745 condition_index: 6,
746 high_ref: 100000004,
747 low_ref: 100000005,
748 },
749 crate::endpoint_lib::bdd_interpreter::BddNode {
750 condition_index: 3,
751 high_ref: 100000001,
752 low_ref: 13,
753 },
754 crate::endpoint_lib::bdd_interpreter::BddNode {
755 condition_index: 4,
756 high_ref: 100000002,
757 low_ref: 100000003,
758 },
759];
760#[derive(Default)]
763#[allow(unused_lifetimes)]
764pub(crate) struct ConditionContext<'a> {
765 pub(crate) partition_result: Option<crate::endpoint_lib::partition::Partition<'a>>,
766 phantom: std::marker::PhantomData<&'a ()>,
768}
769
770#[non_exhaustive]
771#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
772pub struct Params {
774 pub(crate) region: ::std::option::Option<::std::string::String>,
776 pub(crate) use_dual_stack: bool,
778 pub(crate) use_fips: bool,
780 pub(crate) endpoint: ::std::option::Option<::std::string::String>,
782}
783impl Params {
784 pub fn builder() -> crate::config::endpoint::ParamsBuilder {
786 crate::config::endpoint::ParamsBuilder::default()
787 }
788 pub fn region(&self) -> ::std::option::Option<&str> {
790 self.region.as_deref()
791 }
792 pub fn use_dual_stack(&self) -> ::std::option::Option<bool> {
794 Some(self.use_dual_stack)
795 }
796 pub fn use_fips(&self) -> ::std::option::Option<bool> {
798 Some(self.use_fips)
799 }
800 pub fn endpoint(&self) -> ::std::option::Option<&str> {
802 self.endpoint.as_deref()
803 }
804}
805
806#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
808pub struct ParamsBuilder {
809 region: ::std::option::Option<::std::string::String>,
810 use_dual_stack: ::std::option::Option<bool>,
811 use_fips: ::std::option::Option<bool>,
812 endpoint: ::std::option::Option<::std::string::String>,
813}
814impl ParamsBuilder {
815 pub fn build(self) -> ::std::result::Result<crate::config::endpoint::Params, crate::config::endpoint::InvalidParams> {
817 if let Some(region) = &self.region {
818 if !crate::endpoint_lib::host::is_valid_host_label(
819 region.as_ref() as &str,
820 true,
821 &mut crate::endpoint_lib::diagnostic::DiagnosticCollector::new(),
822 ) {
823 return Err(crate::config::endpoint::InvalidParams::invalid_value(
824 "region",
825 "must be a valid host label",
826 ));
827 }
828 };
829 Ok(
830 #[allow(clippy::unnecessary_lazy_evaluations)]
831 crate::config::endpoint::Params {
832 region: self.region,
833 use_dual_stack: self
834 .use_dual_stack
835 .or_else(|| Some(false))
836 .ok_or_else(|| crate::config::endpoint::InvalidParams::missing("use_dual_stack"))?,
837 use_fips: self
838 .use_fips
839 .or_else(|| Some(false))
840 .ok_or_else(|| crate::config::endpoint::InvalidParams::missing("use_fips"))?,
841 endpoint: self.endpoint,
842 },
843 )
844 }
845 pub fn region(mut self, value: impl Into<::std::string::String>) -> Self {
849 self.region = Some(value.into());
850 self
851 }
852
853 pub fn set_region(mut self, param: Option<::std::string::String>) -> Self {
857 self.region = param;
858 self
859 }
860 pub fn use_dual_stack(mut self, value: impl Into<bool>) -> Self {
865 self.use_dual_stack = Some(value.into());
866 self
867 }
868
869 pub fn set_use_dual_stack(mut self, param: Option<bool>) -> Self {
874 self.use_dual_stack = param;
875 self
876 }
877 pub fn use_fips(mut self, value: impl Into<bool>) -> Self {
882 self.use_fips = Some(value.into());
883 self
884 }
885
886 pub fn set_use_fips(mut self, param: Option<bool>) -> Self {
891 self.use_fips = param;
892 self
893 }
894 pub fn endpoint(mut self, value: impl Into<::std::string::String>) -> Self {
898 self.endpoint = Some(value.into());
899 self
900 }
901
902 pub fn set_endpoint(mut self, param: Option<::std::string::String>) -> Self {
906 self.endpoint = param;
907 self
908 }
909}
910
911#[derive(Debug)]
913pub struct InvalidParams {
914 field: std::borrow::Cow<'static, str>,
915 kind: InvalidParamsErrorKind,
916}
917
918#[derive(Debug)]
920enum InvalidParamsErrorKind {
921 MissingField,
922 InvalidValue { message: &'static str },
923}
924
925impl InvalidParams {
926 #[allow(dead_code)]
927 fn missing(field: &'static str) -> Self {
928 Self {
929 field: field.into(),
930 kind: InvalidParamsErrorKind::MissingField,
931 }
932 }
933
934 #[allow(dead_code)]
935 fn invalid_value(field: &'static str, message: &'static str) -> Self {
936 Self {
937 field: field.into(),
938 kind: InvalidParamsErrorKind::InvalidValue { message },
939 }
940 }
941}
942
943impl std::fmt::Display for InvalidParams {
944 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
945 match self.kind {
946 InvalidParamsErrorKind::MissingField => write!(f, "a required field was missing: `{}`", self.field),
947 InvalidParamsErrorKind::InvalidValue { message } => write!(f, "invalid value for field: `{}` - {}", self.field, message),
948 }
949 }
950}
951
952impl std::error::Error for InvalidParams {}