Skip to main content

aws_sdk_paymentcryptographydata/config/
endpoint.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub 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/// Interceptor that tracks endpoint override business metric.
7#[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    /// For region us-east-1 with FIPS enabled and DualStack enabled
33    #[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(&params);
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    /// For region us-east-1 with FIPS enabled and DualStack disabled
53    #[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(&params);
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    /// For region us-east-1 with FIPS disabled and DualStack enabled
73    #[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(&params);
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    /// For region us-east-1 with FIPS disabled and DualStack disabled
93    #[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(&params);
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    /// For region cn-north-1 with FIPS enabled and DualStack enabled
113    #[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(&params);
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    /// For region cn-north-1 with FIPS enabled and DualStack disabled
134    #[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(&params);
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    /// For region cn-north-1 with FIPS disabled and DualStack enabled
154    #[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(&params);
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    /// For region cn-north-1 with FIPS disabled and DualStack disabled
174    #[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(&params);
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    /// For region us-gov-east-1 with FIPS enabled and DualStack enabled
194    #[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(&params);
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    /// For region us-gov-east-1 with FIPS enabled and DualStack disabled
214    #[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(&params);
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    /// For region us-gov-east-1 with FIPS disabled and DualStack enabled
234    #[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(&params);
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    /// For region us-gov-east-1 with FIPS disabled and DualStack disabled
254    #[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(&params);
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    /// For region us-iso-east-1 with FIPS enabled and DualStack disabled
274    #[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(&params);
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    /// For region us-iso-east-1 with FIPS disabled and DualStack disabled
294    #[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(&params);
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    /// For region us-isob-east-1 with FIPS enabled and DualStack disabled
314    #[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(&params);
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    /// For region us-isob-east-1 with FIPS disabled and DualStack disabled
334    #[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(&params);
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    /// For custom endpoint with region set and fips disabled and dualstack disabled
354    #[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(&params);
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    /// For custom endpoint with region not set and fips disabled and dualstack disabled
373    #[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(&params);
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    /// For custom endpoint with fips enabled and dualstack disabled
391    #[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(&params);
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    /// For custom endpoint with fips disabled and dualstack enabled
407    #[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(&params);
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    /// Missing region
426    #[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(&params);
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
436/// Endpoint resolver trait specific to Payment Cryptography Data Plane
437pub trait ResolveEndpoint: ::std::marker::Send + ::std::marker::Sync + ::std::fmt::Debug {
438    /// Resolve an endpoint with the given parameters
439    fn resolve_endpoint<'a>(&'a self, params: &'a crate::config::endpoint::Params) -> ::aws_smithy_runtime_api::client::endpoint::EndpointFuture<'a>;
440
441    /// Convert this service-specific resolver into a `SharedEndpointResolver`
442    ///
443    /// The resulting resolver will downcast `EndpointResolverParams` into `crate::config::endpoint::Params`.
444    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)]
471/// The default endpoint resolver.
472pub 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    /// Create a new DefaultResolver
485    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        // Param bindings
513        let region = &params.region;
514        let use_dual_stack = &params.use_dual_stack;
515        let use_fips = &params.use_fips;
516        let endpoint = &params.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(&region.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(&region.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(&region.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(&region.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        // Check single-entry cache (lock-free read via ArcSwap)
679        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// These are all optional since they are set by conditions and will
761// all be unset when we start evaluation
762#[derive(Default)]
763#[allow(unused_lifetimes)]
764pub(crate) struct ConditionContext<'a> {
765    pub(crate) partition_result: Option<crate::endpoint_lib::partition::Partition<'a>>,
766    // Sometimes none of the members reference the lifetime, this makes it still valid
767    phantom: std::marker::PhantomData<&'a ()>,
768}
769
770#[non_exhaustive]
771#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
772/// Configuration parameters for resolving the correct endpoint
773pub struct Params {
774    /// The AWS region used to dispatch the request.
775    pub(crate) region: ::std::option::Option<::std::string::String>,
776    /// When true, use the dual-stack endpoint. If the configured endpoint does not support dual-stack, dispatching the request MAY return an error.
777    pub(crate) use_dual_stack: bool,
778    /// When true, send this request to the FIPS-compliant regional endpoint. If the configured endpoint does not have a FIPS compliant endpoint, dispatching the request will return an error.
779    pub(crate) use_fips: bool,
780    /// Override the endpoint used to send this request
781    pub(crate) endpoint: ::std::option::Option<::std::string::String>,
782}
783impl Params {
784    /// Create a builder for [`Params`]
785    pub fn builder() -> crate::config::endpoint::ParamsBuilder {
786        crate::config::endpoint::ParamsBuilder::default()
787    }
788    /// The AWS region used to dispatch the request.
789    pub fn region(&self) -> ::std::option::Option<&str> {
790        self.region.as_deref()
791    }
792    /// When true, use the dual-stack endpoint. If the configured endpoint does not support dual-stack, dispatching the request MAY return an error.
793    pub fn use_dual_stack(&self) -> ::std::option::Option<bool> {
794        Some(self.use_dual_stack)
795    }
796    /// When true, send this request to the FIPS-compliant regional endpoint. If the configured endpoint does not have a FIPS compliant endpoint, dispatching the request will return an error.
797    pub fn use_fips(&self) -> ::std::option::Option<bool> {
798        Some(self.use_fips)
799    }
800    /// Override the endpoint used to send this request
801    pub fn endpoint(&self) -> ::std::option::Option<&str> {
802        self.endpoint.as_deref()
803    }
804}
805
806/// Builder for [`Params`]
807#[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    /// Consume this builder, creating [`Params`].
816    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    /// Sets the value for region
846    ///
847    /// The AWS region used to dispatch the request.
848    pub fn region(mut self, value: impl Into<::std::string::String>) -> Self {
849        self.region = Some(value.into());
850        self
851    }
852
853    /// Sets the value for region
854    ///
855    /// The AWS region used to dispatch the request.
856    pub fn set_region(mut self, param: Option<::std::string::String>) -> Self {
857        self.region = param;
858        self
859    }
860    /// Sets the value for use_dual_stack
861    ///
862    /// When unset, this parameter has a default value of `false`.
863    /// When true, use the dual-stack endpoint. If the configured endpoint does not support dual-stack, dispatching the request MAY return an error.
864    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    /// Sets the value for use_dual_stack
870    ///
871    /// When unset, this parameter has a default value of `false`.
872    /// When true, use the dual-stack endpoint. If the configured endpoint does not support dual-stack, dispatching the request MAY return an error.
873    pub fn set_use_dual_stack(mut self, param: Option<bool>) -> Self {
874        self.use_dual_stack = param;
875        self
876    }
877    /// Sets the value for use_fips
878    ///
879    /// When unset, this parameter has a default value of `false`.
880    /// When true, send this request to the FIPS-compliant regional endpoint. If the configured endpoint does not have a FIPS compliant endpoint, dispatching the request will return an error.
881    pub fn use_fips(mut self, value: impl Into<bool>) -> Self {
882        self.use_fips = Some(value.into());
883        self
884    }
885
886    /// Sets the value for use_fips
887    ///
888    /// When unset, this parameter has a default value of `false`.
889    /// When true, send this request to the FIPS-compliant regional endpoint. If the configured endpoint does not have a FIPS compliant endpoint, dispatching the request will return an error.
890    pub fn set_use_fips(mut self, param: Option<bool>) -> Self {
891        self.use_fips = param;
892        self
893    }
894    /// Sets the value for endpoint
895    ///
896    /// Override the endpoint used to send this request
897    pub fn endpoint(mut self, value: impl Into<::std::string::String>) -> Self {
898        self.endpoint = Some(value.into());
899        self
900    }
901
902    /// Sets the value for endpoint
903    ///
904    /// Override the endpoint used to send this request
905    pub fn set_endpoint(mut self, param: Option<::std::string::String>) -> Self {
906        self.endpoint = param;
907        self
908    }
909}
910
911/// An error that occurred during endpoint resolution
912#[derive(Debug)]
913pub struct InvalidParams {
914    field: std::borrow::Cow<'static, str>,
915    kind: InvalidParamsErrorKind,
916}
917
918/// The kind of invalid parameter error
919#[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 {}