{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.IoT.CreateDomainConfiguration -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Creates a domain configuration. -- -- Requires permission to access the -- -- action. module Amazonka.IoT.CreateDomainConfiguration ( -- * Creating a Request CreateDomainConfiguration (..), newCreateDomainConfiguration, -- * Request Lenses createDomainConfiguration_authorizerConfig, createDomainConfiguration_domainName, createDomainConfiguration_serverCertificateArns, createDomainConfiguration_serviceType, createDomainConfiguration_tags, createDomainConfiguration_validationCertificateArn, createDomainConfiguration_domainConfigurationName, -- * Destructuring the Response CreateDomainConfigurationResponse (..), newCreateDomainConfigurationResponse, -- * Response Lenses createDomainConfigurationResponse_domainConfigurationArn, createDomainConfigurationResponse_domainConfigurationName, createDomainConfigurationResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoT.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newCreateDomainConfiguration' smart constructor. data CreateDomainConfiguration = CreateDomainConfiguration' { -- | An object that specifies the authorization service for a domain. authorizerConfig :: Prelude.Maybe AuthorizerConfig, -- | The name of the domain. domainName :: Prelude.Maybe Prelude.Text, -- | The ARNs of the certificates that IoT passes to the device during the -- TLS handshake. Currently you can specify only one certificate ARN. This -- value is not required for Amazon Web Services-managed domains. serverCertificateArns :: Prelude.Maybe [Prelude.Text], -- | The type of service delivered by the endpoint. -- -- Amazon Web Services IoT Core currently supports only the @DATA@ service -- type. serviceType :: Prelude.Maybe ServiceType, -- | Metadata which can be used to manage the domain configuration. -- -- For URI Request parameters use format: ...key1=value1&key2=value2... -- -- For the CLI command-line parameter use format: &&tags -- \"key1=value1&key2=value2...\" -- -- For the cli-input-json file use format: \"tags\": -- \"key1=value1&key2=value2...\" tags :: Prelude.Maybe [Tag], -- | The certificate used to validate the server certificate and prove domain -- name ownership. This certificate must be signed by a public certificate -- authority. This value is not required for Amazon Web Services-managed -- domains. validationCertificateArn :: Prelude.Maybe Prelude.Text, -- | The name of the domain configuration. This value must be unique to a -- region. domainConfigurationName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateDomainConfiguration' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'authorizerConfig', 'createDomainConfiguration_authorizerConfig' - An object that specifies the authorization service for a domain. -- -- 'domainName', 'createDomainConfiguration_domainName' - The name of the domain. -- -- 'serverCertificateArns', 'createDomainConfiguration_serverCertificateArns' - The ARNs of the certificates that IoT passes to the device during the -- TLS handshake. Currently you can specify only one certificate ARN. This -- value is not required for Amazon Web Services-managed domains. -- -- 'serviceType', 'createDomainConfiguration_serviceType' - The type of service delivered by the endpoint. -- -- Amazon Web Services IoT Core currently supports only the @DATA@ service -- type. -- -- 'tags', 'createDomainConfiguration_tags' - Metadata which can be used to manage the domain configuration. -- -- For URI Request parameters use format: ...key1=value1&key2=value2... -- -- For the CLI command-line parameter use format: &&tags -- \"key1=value1&key2=value2...\" -- -- For the cli-input-json file use format: \"tags\": -- \"key1=value1&key2=value2...\" -- -- 'validationCertificateArn', 'createDomainConfiguration_validationCertificateArn' - The certificate used to validate the server certificate and prove domain -- name ownership. This certificate must be signed by a public certificate -- authority. This value is not required for Amazon Web Services-managed -- domains. -- -- 'domainConfigurationName', 'createDomainConfiguration_domainConfigurationName' - The name of the domain configuration. This value must be unique to a -- region. newCreateDomainConfiguration :: -- | 'domainConfigurationName' Prelude.Text -> CreateDomainConfiguration newCreateDomainConfiguration pDomainConfigurationName_ = CreateDomainConfiguration' { authorizerConfig = Prelude.Nothing, domainName = Prelude.Nothing, serverCertificateArns = Prelude.Nothing, serviceType = Prelude.Nothing, tags = Prelude.Nothing, validationCertificateArn = Prelude.Nothing, domainConfigurationName = pDomainConfigurationName_ } -- | An object that specifies the authorization service for a domain. createDomainConfiguration_authorizerConfig :: Lens.Lens' CreateDomainConfiguration (Prelude.Maybe AuthorizerConfig) createDomainConfiguration_authorizerConfig = Lens.lens (\CreateDomainConfiguration' {authorizerConfig} -> authorizerConfig) (\s@CreateDomainConfiguration' {} a -> s {authorizerConfig = a} :: CreateDomainConfiguration) -- | The name of the domain. createDomainConfiguration_domainName :: Lens.Lens' CreateDomainConfiguration (Prelude.Maybe Prelude.Text) createDomainConfiguration_domainName = Lens.lens (\CreateDomainConfiguration' {domainName} -> domainName) (\s@CreateDomainConfiguration' {} a -> s {domainName = a} :: CreateDomainConfiguration) -- | The ARNs of the certificates that IoT passes to the device during the -- TLS handshake. Currently you can specify only one certificate ARN. This -- value is not required for Amazon Web Services-managed domains. createDomainConfiguration_serverCertificateArns :: Lens.Lens' CreateDomainConfiguration (Prelude.Maybe [Prelude.Text]) createDomainConfiguration_serverCertificateArns = Lens.lens (\CreateDomainConfiguration' {serverCertificateArns} -> serverCertificateArns) (\s@CreateDomainConfiguration' {} a -> s {serverCertificateArns = a} :: CreateDomainConfiguration) Prelude.. Lens.mapping Lens.coerced -- | The type of service delivered by the endpoint. -- -- Amazon Web Services IoT Core currently supports only the @DATA@ service -- type. createDomainConfiguration_serviceType :: Lens.Lens' CreateDomainConfiguration (Prelude.Maybe ServiceType) createDomainConfiguration_serviceType = Lens.lens (\CreateDomainConfiguration' {serviceType} -> serviceType) (\s@CreateDomainConfiguration' {} a -> s {serviceType = a} :: CreateDomainConfiguration) -- | Metadata which can be used to manage the domain configuration. -- -- For URI Request parameters use format: ...key1=value1&key2=value2... -- -- For the CLI command-line parameter use format: &&tags -- \"key1=value1&key2=value2...\" -- -- For the cli-input-json file use format: \"tags\": -- \"key1=value1&key2=value2...\" createDomainConfiguration_tags :: Lens.Lens' CreateDomainConfiguration (Prelude.Maybe [Tag]) createDomainConfiguration_tags = Lens.lens (\CreateDomainConfiguration' {tags} -> tags) (\s@CreateDomainConfiguration' {} a -> s {tags = a} :: CreateDomainConfiguration) Prelude.. Lens.mapping Lens.coerced -- | The certificate used to validate the server certificate and prove domain -- name ownership. This certificate must be signed by a public certificate -- authority. This value is not required for Amazon Web Services-managed -- domains. createDomainConfiguration_validationCertificateArn :: Lens.Lens' CreateDomainConfiguration (Prelude.Maybe Prelude.Text) createDomainConfiguration_validationCertificateArn = Lens.lens (\CreateDomainConfiguration' {validationCertificateArn} -> validationCertificateArn) (\s@CreateDomainConfiguration' {} a -> s {validationCertificateArn = a} :: CreateDomainConfiguration) -- | The name of the domain configuration. This value must be unique to a -- region. createDomainConfiguration_domainConfigurationName :: Lens.Lens' CreateDomainConfiguration Prelude.Text createDomainConfiguration_domainConfigurationName = Lens.lens (\CreateDomainConfiguration' {domainConfigurationName} -> domainConfigurationName) (\s@CreateDomainConfiguration' {} a -> s {domainConfigurationName = a} :: CreateDomainConfiguration) instance Core.AWSRequest CreateDomainConfiguration where type AWSResponse CreateDomainConfiguration = CreateDomainConfigurationResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateDomainConfigurationResponse' Prelude.<$> (x Data..?> "domainConfigurationArn") Prelude.<*> (x Data..?> "domainConfigurationName") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateDomainConfiguration where hashWithSalt _salt CreateDomainConfiguration' {..} = _salt `Prelude.hashWithSalt` authorizerConfig `Prelude.hashWithSalt` domainName `Prelude.hashWithSalt` serverCertificateArns `Prelude.hashWithSalt` serviceType `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` validationCertificateArn `Prelude.hashWithSalt` domainConfigurationName instance Prelude.NFData CreateDomainConfiguration where rnf CreateDomainConfiguration' {..} = Prelude.rnf authorizerConfig `Prelude.seq` Prelude.rnf domainName `Prelude.seq` Prelude.rnf serverCertificateArns `Prelude.seq` Prelude.rnf serviceType `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf validationCertificateArn `Prelude.seq` Prelude.rnf domainConfigurationName instance Data.ToHeaders CreateDomainConfiguration where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON CreateDomainConfiguration where toJSON CreateDomainConfiguration' {..} = Data.object ( Prelude.catMaybes [ ("authorizerConfig" Data..=) Prelude.<$> authorizerConfig, ("domainName" Data..=) Prelude.<$> domainName, ("serverCertificateArns" Data..=) Prelude.<$> serverCertificateArns, ("serviceType" Data..=) Prelude.<$> serviceType, ("tags" Data..=) Prelude.<$> tags, ("validationCertificateArn" Data..=) Prelude.<$> validationCertificateArn ] ) instance Data.ToPath CreateDomainConfiguration where toPath CreateDomainConfiguration' {..} = Prelude.mconcat [ "/domainConfigurations/", Data.toBS domainConfigurationName ] instance Data.ToQuery CreateDomainConfiguration where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateDomainConfigurationResponse' smart constructor. data CreateDomainConfigurationResponse = CreateDomainConfigurationResponse' { -- | The ARN of the domain configuration. domainConfigurationArn :: Prelude.Maybe Prelude.Text, -- | The name of the domain configuration. domainConfigurationName :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateDomainConfigurationResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'domainConfigurationArn', 'createDomainConfigurationResponse_domainConfigurationArn' - The ARN of the domain configuration. -- -- 'domainConfigurationName', 'createDomainConfigurationResponse_domainConfigurationName' - The name of the domain configuration. -- -- 'httpStatus', 'createDomainConfigurationResponse_httpStatus' - The response's http status code. newCreateDomainConfigurationResponse :: -- | 'httpStatus' Prelude.Int -> CreateDomainConfigurationResponse newCreateDomainConfigurationResponse pHttpStatus_ = CreateDomainConfigurationResponse' { domainConfigurationArn = Prelude.Nothing, domainConfigurationName = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The ARN of the domain configuration. createDomainConfigurationResponse_domainConfigurationArn :: Lens.Lens' CreateDomainConfigurationResponse (Prelude.Maybe Prelude.Text) createDomainConfigurationResponse_domainConfigurationArn = Lens.lens (\CreateDomainConfigurationResponse' {domainConfigurationArn} -> domainConfigurationArn) (\s@CreateDomainConfigurationResponse' {} a -> s {domainConfigurationArn = a} :: CreateDomainConfigurationResponse) -- | The name of the domain configuration. createDomainConfigurationResponse_domainConfigurationName :: Lens.Lens' CreateDomainConfigurationResponse (Prelude.Maybe Prelude.Text) createDomainConfigurationResponse_domainConfigurationName = Lens.lens (\CreateDomainConfigurationResponse' {domainConfigurationName} -> domainConfigurationName) (\s@CreateDomainConfigurationResponse' {} a -> s {domainConfigurationName = a} :: CreateDomainConfigurationResponse) -- | The response's http status code. createDomainConfigurationResponse_httpStatus :: Lens.Lens' CreateDomainConfigurationResponse Prelude.Int createDomainConfigurationResponse_httpStatus = Lens.lens (\CreateDomainConfigurationResponse' {httpStatus} -> httpStatus) (\s@CreateDomainConfigurationResponse' {} a -> s {httpStatus = a} :: CreateDomainConfigurationResponse) instance Prelude.NFData CreateDomainConfigurationResponse where rnf CreateDomainConfigurationResponse' {..} = Prelude.rnf domainConfigurationArn `Prelude.seq` Prelude.rnf domainConfigurationName `Prelude.seq` Prelude.rnf httpStatus