aws_sdk_ec2/client/
create_verified_access_trust_provider.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2impl super::Client {
3    /// Constructs a fluent builder for the [`CreateVerifiedAccessTrustProvider`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder) operation.
4    ///
5    /// - The fluent builder is configurable:
6    ///   - [`trust_provider_type(TrustProviderType)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::trust_provider_type) / [`set_trust_provider_type(Option<TrustProviderType>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_trust_provider_type):<br>required: **true**<br><p>The type of trust provider.</p><br>
7    ///   - [`user_trust_provider_type(UserTrustProviderType)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::user_trust_provider_type) / [`set_user_trust_provider_type(Option<UserTrustProviderType>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_user_trust_provider_type):<br>required: **false**<br><p>The type of user-based trust provider. This parameter is required when the provider type is <code>user</code>.</p><br>
8    ///   - [`device_trust_provider_type(DeviceTrustProviderType)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::device_trust_provider_type) / [`set_device_trust_provider_type(Option<DeviceTrustProviderType>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_device_trust_provider_type):<br>required: **false**<br><p>The type of device-based trust provider. This parameter is required when the provider type is <code>device</code>.</p><br>
9    ///   - [`oidc_options(CreateVerifiedAccessTrustProviderOidcOptions)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::oidc_options) / [`set_oidc_options(Option<CreateVerifiedAccessTrustProviderOidcOptions>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_oidc_options):<br>required: **false**<br><p>The options for a OpenID Connect-compatible user-identity trust provider. This parameter is required when the provider type is <code>user</code>.</p><br>
10    ///   - [`device_options(CreateVerifiedAccessTrustProviderDeviceOptions)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::device_options) / [`set_device_options(Option<CreateVerifiedAccessTrustProviderDeviceOptions>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_device_options):<br>required: **false**<br><p>The options for a device-based trust provider. This parameter is required when the provider type is <code>device</code>.</p><br>
11    ///   - [`policy_reference_name(impl Into<String>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::policy_reference_name) / [`set_policy_reference_name(Option<String>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_policy_reference_name):<br>required: **true**<br><p>The identifier to be used when working with policy rules.</p><br>
12    ///   - [`description(impl Into<String>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::description) / [`set_description(Option<String>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_description):<br>required: **false**<br><p>A description for the Verified Access trust provider.</p><br>
13    ///   - [`tag_specifications(TagSpecification)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::tag_specifications) / [`set_tag_specifications(Option<Vec::<TagSpecification>>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_tag_specifications):<br>required: **false**<br><p>The tags to assign to the Verified Access trust provider.</p><br>
14    ///   - [`client_token(impl Into<String>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::client_token) / [`set_client_token(Option<String>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_client_token):<br>required: **false**<br><p>A unique, case-sensitive token that you provide to ensure idempotency of your modification request. For more information, see <a href="https://docs.aws.amazon.com/ec2/latest/devguide/ec2-api-idempotency.html">Ensuring idempotency</a>.</p><br>
15    ///   - [`dry_run(bool)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::dry_run) / [`set_dry_run(Option<bool>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_dry_run):<br>required: **false**<br><p>Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is <code>DryRunOperation</code>. Otherwise, it is <code>UnauthorizedOperation</code>.</p><br>
16    ///   - [`sse_specification(VerifiedAccessSseSpecificationRequest)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::sse_specification) / [`set_sse_specification(Option<VerifiedAccessSseSpecificationRequest>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_sse_specification):<br>required: **false**<br><p>The options for server side encryption.</p><br>
17    ///   - [`native_application_oidc_options(CreateVerifiedAccessNativeApplicationOidcOptions)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::native_application_oidc_options) / [`set_native_application_oidc_options(Option<CreateVerifiedAccessNativeApplicationOidcOptions>)`](crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::set_native_application_oidc_options):<br>required: **false**<br><p>The OpenID Connect (OIDC) options.</p><br>
18    /// - On success, responds with [`CreateVerifiedAccessTrustProviderOutput`](crate::operation::create_verified_access_trust_provider::CreateVerifiedAccessTrustProviderOutput) with field(s):
19    ///   - [`verified_access_trust_provider(Option<VerifiedAccessTrustProvider>)`](crate::operation::create_verified_access_trust_provider::CreateVerifiedAccessTrustProviderOutput::verified_access_trust_provider): <p>Details about the Verified Access trust provider.</p>
20    /// - On failure, responds with [`SdkError<CreateVerifiedAccessTrustProviderError>`](crate::operation::create_verified_access_trust_provider::CreateVerifiedAccessTrustProviderError)
21    pub fn create_verified_access_trust_provider(
22        &self,
23    ) -> crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder {
24        crate::operation::create_verified_access_trust_provider::builders::CreateVerifiedAccessTrustProviderFluentBuilder::new(self.handle.clone())
25    }
26}