aws_sdk_ssooidc/config/
auth.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Auth scheme resolver trait specific to AWS SSO OIDC
3pub trait ResolveAuthScheme: ::std::marker::Send + ::std::marker::Sync + ::std::fmt::Debug {
4    /// Resolve a priority list of auth scheme options with the given parameters
5    fn resolve_auth_scheme<'a>(
6        &'a self,
7        params: &'a crate::config::auth::Params,
8        cfg: &'a ::aws_smithy_types::config_bag::ConfigBag,
9        runtime_components: &'a ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponents,
10    ) -> ::aws_smithy_runtime_api::client::auth::AuthSchemeOptionsFuture<'a>;
11
12    /// Convert this service-specific resolver into a `SharedAuthSchemeOptionResolver`
13    fn into_shared_resolver(self) -> ::aws_smithy_runtime_api::client::auth::SharedAuthSchemeOptionResolver
14    where
15        Self: ::std::marker::Sized + 'static,
16    {
17        ::aws_smithy_runtime_api::client::auth::SharedAuthSchemeOptionResolver::new(DowncastParams(self))
18    }
19}
20
21#[derive(Debug)]
22struct DowncastParams<T>(T);
23impl<T> ::aws_smithy_runtime_api::client::auth::ResolveAuthSchemeOptions for DowncastParams<T>
24where
25    T: ResolveAuthScheme,
26{
27    fn resolve_auth_scheme_options_v2<'a>(
28        &'a self,
29        params: &'a ::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams,
30        cfg: &'a ::aws_smithy_types::config_bag::ConfigBag,
31        runtime_components: &'a ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponents,
32    ) -> ::aws_smithy_runtime_api::client::auth::AuthSchemeOptionsFuture<'a> {
33        match params.get::<crate::config::auth::Params>() {
34            ::std::option::Option::Some(concrete_params) => self.0.resolve_auth_scheme(concrete_params, cfg, runtime_components),
35            ::std::option::Option::None => ::aws_smithy_runtime_api::client::auth::AuthSchemeOptionsFuture::ready(::std::result::Result::Err(
36                "params of expected type was not present".into(),
37            )),
38        }
39    }
40}
41
42/// The default auth scheme resolver
43#[derive(Debug)]
44#[allow(dead_code)]
45pub struct DefaultAuthSchemeResolver {
46    service_defaults: Vec<::aws_smithy_runtime_api::client::auth::AuthSchemeOption>,
47    operation_overrides: ::std::collections::HashMap<&'static str, Vec<::aws_smithy_runtime_api::client::auth::AuthSchemeOption>>,
48}
49
50// TODO(https://github.com/smithy-lang/smithy-rs/issues/4177): Remove `allow(...)` once the issue is addressed.
51// When generating code for tests (e.g., `codegen-client-test`), this manual implementation
52// of the `Default` trait may appear as if it could be derived automatically.
53// However, that is not the case in production.
54#[allow(clippy::derivable_impls)]
55impl Default for DefaultAuthSchemeResolver {
56    fn default() -> Self {
57        Self {
58            service_defaults: vec![::aws_smithy_runtime_api::client::auth::AuthSchemeOption::builder()
59                .scheme_id(::aws_runtime::auth::sigv4::SCHEME_ID)
60                .build()
61                .expect("required fields set")],
62            operation_overrides: [
63                (
64                    "CreateToken",
65                    vec![::aws_smithy_runtime_api::client::auth::AuthSchemeOption::from(
66                        ::aws_smithy_runtime::client::auth::no_auth::NO_AUTH_SCHEME_ID,
67                    )],
68                ),
69                (
70                    "RegisterClient",
71                    vec![::aws_smithy_runtime_api::client::auth::AuthSchemeOption::from(
72                        ::aws_smithy_runtime::client::auth::no_auth::NO_AUTH_SCHEME_ID,
73                    )],
74                ),
75                (
76                    "StartDeviceAuthorization",
77                    vec![::aws_smithy_runtime_api::client::auth::AuthSchemeOption::from(
78                        ::aws_smithy_runtime::client::auth::no_auth::NO_AUTH_SCHEME_ID,
79                    )],
80                ),
81            ]
82            .into(),
83        }
84    }
85}
86
87impl crate::config::auth::ResolveAuthScheme for DefaultAuthSchemeResolver {
88    fn resolve_auth_scheme<'a>(
89        &'a self,
90        params: &'a crate::config::auth::Params,
91        _cfg: &'a ::aws_smithy_types::config_bag::ConfigBag,
92        _runtime_components: &'a ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponents,
93    ) -> ::aws_smithy_runtime_api::client::auth::AuthSchemeOptionsFuture<'a> {
94        let operation_name = params.operation_name();
95
96        let modeled_auth_options = match self.operation_overrides.get(operation_name) {
97            Some(overrides) => overrides,
98            None => &self.service_defaults,
99        };
100
101        let _fut = ::aws_smithy_runtime_api::client::auth::AuthSchemeOptionsFuture::ready(Ok(modeled_auth_options.clone()));
102
103        _fut
104    }
105}
106
107/// Configuration parameters for resolving the correct auth scheme
108#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
109pub struct Params {
110    operation_name: ::std::borrow::Cow<'static, str>,
111}
112impl Params {
113    /// Create a builder for [`Params`]
114    pub fn builder() -> crate::config::auth::ParamsBuilder {
115        crate::config::auth::ParamsBuilder::default()
116    }
117
118    /// Return the operation name for [`Params`]
119    pub fn operation_name(&self) -> &str {
120        self.operation_name.as_ref()
121    }
122}
123
124#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
125/// Builder for [`Params`]
126pub struct ParamsBuilder {
127    operation_name: ::std::option::Option<::std::borrow::Cow<'static, str>>,
128}
129impl ParamsBuilder {
130    /// Set the operation name for the builder
131    pub fn operation_name(self, operation_name: impl Into<::std::borrow::Cow<'static, str>>) -> Self {
132        self.set_operation_name(::std::option::Option::Some(operation_name.into()))
133    }
134
135    /// Set the operation name for the builder
136    pub fn set_operation_name(mut self, operation_name: ::std::option::Option<::std::borrow::Cow<'static, str>>) -> Self {
137        self.operation_name = operation_name;
138        self
139    }
140    /// Consume this builder, create [`Params`]."
141    ///
142    /// Return [`BuildError`] if any of the required fields are unset.
143    ///
144    pub fn build(self) -> ::std::result::Result<crate::config::auth::Params, crate::config::auth::BuildError> {
145        ::std::result::Result::Ok(crate::config::auth::Params {
146            operation_name: self.operation_name.ok_or_else(|| BuildError::missing("operation_name"))?,
147        })
148    }
149}
150
151/// An error that occurred while constructing `config::auth::Params`
152#[derive(Debug)]
153pub struct BuildError {
154    field: ::std::borrow::Cow<'static, str>,
155}
156
157impl BuildError {
158    fn missing(field: &'static str) -> Self {
159        Self { field: field.into() }
160    }
161}
162
163impl std::fmt::Display for BuildError {
164    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
165        write!(f, "a required field was missing: `{}`", self.field)
166    }
167}
168
169impl std::error::Error for BuildError {}