// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
    /// Constructs a fluent builder for the [`CreateApp`](crate::operation::create_app::builders::CreateAppFluentBuilder) operation.
    ///
    /// - The fluent builder is configurable:
    ///   - [`name(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::name) / [`set_name(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_name): <p> The name for an Amplify app. </p>
    ///   - [`description(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::description) / [`set_description(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_description): <p> The description for an Amplify app. </p>
    ///   - [`repository(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::repository) / [`set_repository(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_repository): <p> The repository for an Amplify app. </p>
    ///   - [`platform(Platform)`](crate::operation::create_app::builders::CreateAppFluentBuilder::platform) / [`set_platform(Option<Platform>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_platform): <p> The platform for the Amplify app. For a static app, set the platform type to <code>WEB</code>. For a dynamic server-side rendered (SSR) app, set the platform type to <code>WEB_COMPUTE</code>. For an app requiring Amplify Hosting's original SSR support only, set the platform type to <code>WEB_DYNAMIC</code>.</p>
    ///   - [`iam_service_role_arn(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::iam_service_role_arn) / [`set_iam_service_role_arn(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_iam_service_role_arn): <p> The AWS Identity and Access Management (IAM) service role for an Amplify app. </p>
    ///   - [`oauth_token(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::oauth_token) / [`set_oauth_token(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_oauth_token): <p>The OAuth token for a third-party source control system for an Amplify app. The OAuth token is used to create a webhook and a read-only deploy key using SSH cloning. The OAuth token is not stored.</p>  <p>Use <code>oauthToken</code> for repository providers other than GitHub, such as Bitbucket or CodeCommit. To authorize access to GitHub as your repository provider, use <code>accessToken</code>.</p>  <p>You must specify either <code>oauthToken</code> or <code>accessToken</code> when you create a new app.</p>  <p>Existing Amplify apps deployed from a GitHub repository using OAuth continue to work with CI/CD. However, we strongly recommend that you migrate these apps to use the GitHub App. For more information, see <a href="https://docs.aws.amazon.com/amplify/latest/UserGuide/setting-up-GitHub-access.html#migrating-to-github-app-auth">Migrating an existing OAuth app to the Amplify GitHub App</a> in the <i>Amplify User Guide</i> .</p>
    ///   - [`access_token(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::access_token) / [`set_access_token(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_access_token): <p>The personal access token for a GitHub repository for an Amplify app. The personal access token is used to authorize access to a GitHub repository using the Amplify GitHub App. The token is not stored.</p>  <p>Use <code>accessToken</code> for GitHub repositories only. To authorize access to a repository provider such as Bitbucket or CodeCommit, use <code>oauthToken</code>.</p>  <p>You must specify either <code>accessToken</code> or <code>oauthToken</code> when you create a new app.</p>  <p>Existing Amplify apps deployed from a GitHub repository using OAuth continue to work with CI/CD. However, we strongly recommend that you migrate these apps to use the GitHub App. For more information, see <a href="https://docs.aws.amazon.com/amplify/latest/UserGuide/setting-up-GitHub-access.html#migrating-to-github-app-auth">Migrating an existing OAuth app to the Amplify GitHub App</a> in the <i>Amplify User Guide</i> .</p>
    ///   - [`environment_variables(impl Into<String>, impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::environment_variables) / [`set_environment_variables(Option<HashMap<String, String>>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_environment_variables): <p> The environment variables map for an Amplify app. </p>
    ///   - [`enable_branch_auto_build(bool)`](crate::operation::create_app::builders::CreateAppFluentBuilder::enable_branch_auto_build) / [`set_enable_branch_auto_build(Option<bool>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_enable_branch_auto_build): <p> Enables the auto building of branches for an Amplify app. </p>
    ///   - [`enable_branch_auto_deletion(bool)`](crate::operation::create_app::builders::CreateAppFluentBuilder::enable_branch_auto_deletion) / [`set_enable_branch_auto_deletion(Option<bool>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_enable_branch_auto_deletion): <p> Automatically disconnects a branch in the Amplify Console when you delete a branch from your Git repository. </p>
    ///   - [`enable_basic_auth(bool)`](crate::operation::create_app::builders::CreateAppFluentBuilder::enable_basic_auth) / [`set_enable_basic_auth(Option<bool>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_enable_basic_auth): <p> Enables basic authorization for an Amplify app. This will apply to all branches that are part of this app. </p>
    ///   - [`basic_auth_credentials(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::basic_auth_credentials) / [`set_basic_auth_credentials(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_basic_auth_credentials): <p> The credentials for basic authorization for an Amplify app. You must base64-encode the authorization credentials and provide them in the format <code>user:password</code>.</p>
    ///   - [`custom_rules(CustomRule)`](crate::operation::create_app::builders::CreateAppFluentBuilder::custom_rules) / [`set_custom_rules(Option<Vec<CustomRule>>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_custom_rules): <p> The custom rewrite and redirect rules for an Amplify app. </p>
    ///   - [`tags(impl Into<String>, impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::tags) / [`set_tags(Option<HashMap<String, String>>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_tags): <p> The tag for an Amplify app. </p>
    ///   - [`build_spec(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::build_spec) / [`set_build_spec(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_build_spec): <p> The build specification (build spec) for an Amplify app. </p>
    ///   - [`custom_headers(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::custom_headers) / [`set_custom_headers(Option<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_custom_headers): <p>The custom HTTP headers for an Amplify app.</p>
    ///   - [`enable_auto_branch_creation(bool)`](crate::operation::create_app::builders::CreateAppFluentBuilder::enable_auto_branch_creation) / [`set_enable_auto_branch_creation(Option<bool>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_enable_auto_branch_creation): <p> Enables automated branch creation for an Amplify app. </p>
    ///   - [`auto_branch_creation_patterns(impl Into<String>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::auto_branch_creation_patterns) / [`set_auto_branch_creation_patterns(Option<Vec<String>>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_auto_branch_creation_patterns): <p> The automated branch creation glob patterns for an Amplify app. </p>
    ///   - [`auto_branch_creation_config(AutoBranchCreationConfig)`](crate::operation::create_app::builders::CreateAppFluentBuilder::auto_branch_creation_config) / [`set_auto_branch_creation_config(Option<AutoBranchCreationConfig>)`](crate::operation::create_app::builders::CreateAppFluentBuilder::set_auto_branch_creation_config): <p> The automated branch creation configuration for an Amplify app. </p>
    /// - On success, responds with [`CreateAppOutput`](crate::operation::create_app::CreateAppOutput) with field(s):
    ///   - [`app(Option<App>)`](crate::operation::create_app::CreateAppOutput::app): <p> Represents the different branches of a repository for building, deploying, and hosting an Amplify app. </p>
    /// - On failure, responds with [`SdkError<CreateAppError>`](crate::operation::create_app::CreateAppError)
    pub fn create_app(&self) -> crate::operation::create_app::builders::CreateAppFluentBuilder {
        crate::operation::create_app::builders::CreateAppFluentBuilder::new(self.handle.clone())
    }
}