{-# 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.DMS.ImportCertificate -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Uploads the specified certificate. module Amazonka.DMS.ImportCertificate ( -- * Creating a Request ImportCertificate (..), newImportCertificate, -- * Request Lenses importCertificate_certificatePem, importCertificate_certificateWallet, importCertificate_tags, importCertificate_certificateIdentifier, -- * Destructuring the Response ImportCertificateResponse (..), newImportCertificateResponse, -- * Response Lenses importCertificateResponse_certificate, importCertificateResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import Amazonka.DMS.Types import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newImportCertificate' smart constructor. data ImportCertificate = ImportCertificate' { -- | The contents of a @.pem@ file, which contains an X.509 certificate. certificatePem :: Prelude.Maybe (Data.Sensitive Prelude.Text), -- | The location of an imported Oracle Wallet certificate for use with SSL. -- Provide the name of a @.sso@ file using the @fileb:\/\/@ prefix. You -- can\'t provide the certificate inline. -- -- Example: @filebase64(\"${path.root}\/rds-ca-2019-root.sso\")@ certificateWallet :: Prelude.Maybe Data.Base64, -- | The tags associated with the certificate. tags :: Prelude.Maybe [Tag], -- | A customer-assigned name for the certificate. Identifiers must begin -- with a letter and must contain only ASCII letters, digits, and hyphens. -- They can\'t end with a hyphen or contain two consecutive hyphens. certificateIdentifier :: Prelude.Text } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ImportCertificate' 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: -- -- 'certificatePem', 'importCertificate_certificatePem' - The contents of a @.pem@ file, which contains an X.509 certificate. -- -- 'certificateWallet', 'importCertificate_certificateWallet' - The location of an imported Oracle Wallet certificate for use with SSL. -- Provide the name of a @.sso@ file using the @fileb:\/\/@ prefix. You -- can\'t provide the certificate inline. -- -- Example: @filebase64(\"${path.root}\/rds-ca-2019-root.sso\")@-- -- -- /Note:/ This 'Lens' automatically encodes and decodes Base64 data. -- -- The underlying isomorphism will encode to Base64 representation during -- -- serialisation, and decode from Base64 representation during deserialisation. -- -- This 'Lens' accepts and returns only raw unencoded data. -- -- 'tags', 'importCertificate_tags' - The tags associated with the certificate. -- -- 'certificateIdentifier', 'importCertificate_certificateIdentifier' - A customer-assigned name for the certificate. Identifiers must begin -- with a letter and must contain only ASCII letters, digits, and hyphens. -- They can\'t end with a hyphen or contain two consecutive hyphens. newImportCertificate :: -- | 'certificateIdentifier' Prelude.Text -> ImportCertificate newImportCertificate pCertificateIdentifier_ = ImportCertificate' { certificatePem = Prelude.Nothing, certificateWallet = Prelude.Nothing, tags = Prelude.Nothing, certificateIdentifier = pCertificateIdentifier_ } -- | The contents of a @.pem@ file, which contains an X.509 certificate. importCertificate_certificatePem :: Lens.Lens' ImportCertificate (Prelude.Maybe Prelude.Text) importCertificate_certificatePem = Lens.lens (\ImportCertificate' {certificatePem} -> certificatePem) (\s@ImportCertificate' {} a -> s {certificatePem = a} :: ImportCertificate) Prelude.. Lens.mapping Data._Sensitive -- | The location of an imported Oracle Wallet certificate for use with SSL. -- Provide the name of a @.sso@ file using the @fileb:\/\/@ prefix. You -- can\'t provide the certificate inline. -- -- Example: @filebase64(\"${path.root}\/rds-ca-2019-root.sso\")@-- -- -- /Note:/ This 'Lens' automatically encodes and decodes Base64 data. -- -- The underlying isomorphism will encode to Base64 representation during -- -- serialisation, and decode from Base64 representation during deserialisation. -- -- This 'Lens' accepts and returns only raw unencoded data. importCertificate_certificateWallet :: Lens.Lens' ImportCertificate (Prelude.Maybe Prelude.ByteString) importCertificate_certificateWallet = Lens.lens (\ImportCertificate' {certificateWallet} -> certificateWallet) (\s@ImportCertificate' {} a -> s {certificateWallet = a} :: ImportCertificate) Prelude.. Lens.mapping Data._Base64 -- | The tags associated with the certificate. importCertificate_tags :: Lens.Lens' ImportCertificate (Prelude.Maybe [Tag]) importCertificate_tags = Lens.lens (\ImportCertificate' {tags} -> tags) (\s@ImportCertificate' {} a -> s {tags = a} :: ImportCertificate) Prelude.. Lens.mapping Lens.coerced -- | A customer-assigned name for the certificate. Identifiers must begin -- with a letter and must contain only ASCII letters, digits, and hyphens. -- They can\'t end with a hyphen or contain two consecutive hyphens. importCertificate_certificateIdentifier :: Lens.Lens' ImportCertificate Prelude.Text importCertificate_certificateIdentifier = Lens.lens (\ImportCertificate' {certificateIdentifier} -> certificateIdentifier) (\s@ImportCertificate' {} a -> s {certificateIdentifier = a} :: ImportCertificate) instance Core.AWSRequest ImportCertificate where type AWSResponse ImportCertificate = ImportCertificateResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> ImportCertificateResponse' Prelude.<$> (x Data..?> "Certificate") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ImportCertificate where hashWithSalt _salt ImportCertificate' {..} = _salt `Prelude.hashWithSalt` certificatePem `Prelude.hashWithSalt` certificateWallet `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` certificateIdentifier instance Prelude.NFData ImportCertificate where rnf ImportCertificate' {..} = Prelude.rnf certificatePem `Prelude.seq` Prelude.rnf certificateWallet `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf certificateIdentifier instance Data.ToHeaders ImportCertificate where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonDMSv20160101.ImportCertificate" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON ImportCertificate where toJSON ImportCertificate' {..} = Data.object ( Prelude.catMaybes [ ("CertificatePem" Data..=) Prelude.<$> certificatePem, ("CertificateWallet" Data..=) Prelude.<$> certificateWallet, ("Tags" Data..=) Prelude.<$> tags, Prelude.Just ( "CertificateIdentifier" Data..= certificateIdentifier ) ] ) instance Data.ToPath ImportCertificate where toPath = Prelude.const "/" instance Data.ToQuery ImportCertificate where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newImportCertificateResponse' smart constructor. data ImportCertificateResponse = ImportCertificateResponse' { -- | The certificate to be uploaded. certificate :: Prelude.Maybe Certificate, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ImportCertificateResponse' 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: -- -- 'certificate', 'importCertificateResponse_certificate' - The certificate to be uploaded. -- -- 'httpStatus', 'importCertificateResponse_httpStatus' - The response's http status code. newImportCertificateResponse :: -- | 'httpStatus' Prelude.Int -> ImportCertificateResponse newImportCertificateResponse pHttpStatus_ = ImportCertificateResponse' { certificate = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The certificate to be uploaded. importCertificateResponse_certificate :: Lens.Lens' ImportCertificateResponse (Prelude.Maybe Certificate) importCertificateResponse_certificate = Lens.lens (\ImportCertificateResponse' {certificate} -> certificate) (\s@ImportCertificateResponse' {} a -> s {certificate = a} :: ImportCertificateResponse) -- | The response's http status code. importCertificateResponse_httpStatus :: Lens.Lens' ImportCertificateResponse Prelude.Int importCertificateResponse_httpStatus = Lens.lens (\ImportCertificateResponse' {httpStatus} -> httpStatus) (\s@ImportCertificateResponse' {} a -> s {httpStatus = a} :: ImportCertificateResponse) instance Prelude.NFData ImportCertificateResponse where rnf ImportCertificateResponse' {..} = Prelude.rnf certificate `Prelude.seq` Prelude.rnf httpStatus