{-# 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.CreateCertificateFromCsr -- 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 an X.509 certificate using the specified certificate signing -- request. -- -- __Note:__ The CSR must include a public key that is either an RSA key -- with a length of at least 2048 bits or an ECC key from NIST P-256, NIST -- P-384, or NIST P-512 curves. For supported certificates, consult -- . -- -- __Note:__ Reusing the same certificate signing request (CSR) results in -- a distinct certificate. -- -- Requires permission to access the -- -- action. -- -- You can create multiple certificates in a batch by creating a directory, -- copying multiple .csr files into that directory, and then specifying -- that directory on the command line. The following commands show how to -- create a batch of certificates given a batch of CSRs. -- -- Assuming a set of CSRs are located inside of the directory -- my-csr-directory: -- -- On Linux and OS X, the command is: -- -- \$ ls my-csr-directory\/ | xargs -I {} aws iot -- create-certificate-from-csr --certificate-signing-request -- file:\/\/my-csr-directory\/{} -- -- This command lists all of the CSRs in my-csr-directory and pipes each -- CSR file name to the aws iot create-certificate-from-csr Amazon Web -- Services CLI command to create a certificate for the corresponding CSR. -- -- The aws iot create-certificate-from-csr part of the command can also be -- run in parallel to speed up the certificate creation process: -- -- \$ ls my-csr-directory\/ | xargs -P 10 -I {} aws iot -- create-certificate-from-csr --certificate-signing-request -- file:\/\/my-csr-directory\/{} -- -- On Windows PowerShell, the command to create certificates for all CSRs -- in my-csr-directory is: -- -- > ls -Name my-csr-directory | %{aws iot create-certificate-from-csr -- --certificate-signing-request file:\/\/my-csr-directory\/$_} -- -- On a Windows command prompt, the command to create certificates for all -- CSRs in my-csr-directory is: -- -- > forfiles \/p my-csr-directory \/c \"cmd \/c aws iot -- create-certificate-from-csr --certificate-signing-request -- file:\/\/\@path\" module Amazonka.IoT.CreateCertificateFromCsr ( -- * Creating a Request CreateCertificateFromCsr (..), newCreateCertificateFromCsr, -- * Request Lenses createCertificateFromCsr_setAsActive, createCertificateFromCsr_certificateSigningRequest, -- * Destructuring the Response CreateCertificateFromCsrResponse (..), newCreateCertificateFromCsrResponse, -- * Response Lenses createCertificateFromCsrResponse_certificateArn, createCertificateFromCsrResponse_certificateId, createCertificateFromCsrResponse_certificatePem, createCertificateFromCsrResponse_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 -- | The input for the CreateCertificateFromCsr operation. -- -- /See:/ 'newCreateCertificateFromCsr' smart constructor. data CreateCertificateFromCsr = CreateCertificateFromCsr' { -- | Specifies whether the certificate is active. setAsActive :: Prelude.Maybe Prelude.Bool, -- | The certificate signing request (CSR). certificateSigningRequest :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateCertificateFromCsr' 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: -- -- 'setAsActive', 'createCertificateFromCsr_setAsActive' - Specifies whether the certificate is active. -- -- 'certificateSigningRequest', 'createCertificateFromCsr_certificateSigningRequest' - The certificate signing request (CSR). newCreateCertificateFromCsr :: -- | 'certificateSigningRequest' Prelude.Text -> CreateCertificateFromCsr newCreateCertificateFromCsr pCertificateSigningRequest_ = CreateCertificateFromCsr' { setAsActive = Prelude.Nothing, certificateSigningRequest = pCertificateSigningRequest_ } -- | Specifies whether the certificate is active. createCertificateFromCsr_setAsActive :: Lens.Lens' CreateCertificateFromCsr (Prelude.Maybe Prelude.Bool) createCertificateFromCsr_setAsActive = Lens.lens (\CreateCertificateFromCsr' {setAsActive} -> setAsActive) (\s@CreateCertificateFromCsr' {} a -> s {setAsActive = a} :: CreateCertificateFromCsr) -- | The certificate signing request (CSR). createCertificateFromCsr_certificateSigningRequest :: Lens.Lens' CreateCertificateFromCsr Prelude.Text createCertificateFromCsr_certificateSigningRequest = Lens.lens (\CreateCertificateFromCsr' {certificateSigningRequest} -> certificateSigningRequest) (\s@CreateCertificateFromCsr' {} a -> s {certificateSigningRequest = a} :: CreateCertificateFromCsr) instance Core.AWSRequest CreateCertificateFromCsr where type AWSResponse CreateCertificateFromCsr = CreateCertificateFromCsrResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateCertificateFromCsrResponse' Prelude.<$> (x Data..?> "certificateArn") Prelude.<*> (x Data..?> "certificateId") Prelude.<*> (x Data..?> "certificatePem") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateCertificateFromCsr where hashWithSalt _salt CreateCertificateFromCsr' {..} = _salt `Prelude.hashWithSalt` setAsActive `Prelude.hashWithSalt` certificateSigningRequest instance Prelude.NFData CreateCertificateFromCsr where rnf CreateCertificateFromCsr' {..} = Prelude.rnf setAsActive `Prelude.seq` Prelude.rnf certificateSigningRequest instance Data.ToHeaders CreateCertificateFromCsr where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON CreateCertificateFromCsr where toJSON CreateCertificateFromCsr' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ( "certificateSigningRequest" Data..= certificateSigningRequest ) ] ) instance Data.ToPath CreateCertificateFromCsr where toPath = Prelude.const "/certificates" instance Data.ToQuery CreateCertificateFromCsr where toQuery CreateCertificateFromCsr' {..} = Prelude.mconcat ["setAsActive" Data.=: setAsActive] -- | The output from the CreateCertificateFromCsr operation. -- -- /See:/ 'newCreateCertificateFromCsrResponse' smart constructor. data CreateCertificateFromCsrResponse = CreateCertificateFromCsrResponse' { -- | The Amazon Resource Name (ARN) of the certificate. You can use the ARN -- as a principal for policy operations. certificateArn :: Prelude.Maybe Prelude.Text, -- | The ID of the certificate. Certificate management operations only take a -- certificateId. certificateId :: Prelude.Maybe Prelude.Text, -- | The certificate data, in PEM format. certificatePem :: 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 'CreateCertificateFromCsrResponse' 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: -- -- 'certificateArn', 'createCertificateFromCsrResponse_certificateArn' - The Amazon Resource Name (ARN) of the certificate. You can use the ARN -- as a principal for policy operations. -- -- 'certificateId', 'createCertificateFromCsrResponse_certificateId' - The ID of the certificate. Certificate management operations only take a -- certificateId. -- -- 'certificatePem', 'createCertificateFromCsrResponse_certificatePem' - The certificate data, in PEM format. -- -- 'httpStatus', 'createCertificateFromCsrResponse_httpStatus' - The response's http status code. newCreateCertificateFromCsrResponse :: -- | 'httpStatus' Prelude.Int -> CreateCertificateFromCsrResponse newCreateCertificateFromCsrResponse pHttpStatus_ = CreateCertificateFromCsrResponse' { certificateArn = Prelude.Nothing, certificateId = Prelude.Nothing, certificatePem = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The Amazon Resource Name (ARN) of the certificate. You can use the ARN -- as a principal for policy operations. createCertificateFromCsrResponse_certificateArn :: Lens.Lens' CreateCertificateFromCsrResponse (Prelude.Maybe Prelude.Text) createCertificateFromCsrResponse_certificateArn = Lens.lens (\CreateCertificateFromCsrResponse' {certificateArn} -> certificateArn) (\s@CreateCertificateFromCsrResponse' {} a -> s {certificateArn = a} :: CreateCertificateFromCsrResponse) -- | The ID of the certificate. Certificate management operations only take a -- certificateId. createCertificateFromCsrResponse_certificateId :: Lens.Lens' CreateCertificateFromCsrResponse (Prelude.Maybe Prelude.Text) createCertificateFromCsrResponse_certificateId = Lens.lens (\CreateCertificateFromCsrResponse' {certificateId} -> certificateId) (\s@CreateCertificateFromCsrResponse' {} a -> s {certificateId = a} :: CreateCertificateFromCsrResponse) -- | The certificate data, in PEM format. createCertificateFromCsrResponse_certificatePem :: Lens.Lens' CreateCertificateFromCsrResponse (Prelude.Maybe Prelude.Text) createCertificateFromCsrResponse_certificatePem = Lens.lens (\CreateCertificateFromCsrResponse' {certificatePem} -> certificatePem) (\s@CreateCertificateFromCsrResponse' {} a -> s {certificatePem = a} :: CreateCertificateFromCsrResponse) -- | The response's http status code. createCertificateFromCsrResponse_httpStatus :: Lens.Lens' CreateCertificateFromCsrResponse Prelude.Int createCertificateFromCsrResponse_httpStatus = Lens.lens (\CreateCertificateFromCsrResponse' {httpStatus} -> httpStatus) (\s@CreateCertificateFromCsrResponse' {} a -> s {httpStatus = a} :: CreateCertificateFromCsrResponse) instance Prelude.NFData CreateCertificateFromCsrResponse where rnf CreateCertificateFromCsrResponse' {..} = Prelude.rnf certificateArn `Prelude.seq` Prelude.rnf certificateId `Prelude.seq` Prelude.rnf certificatePem `Prelude.seq` Prelude.rnf httpStatus