{-# 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.CertificateManagerPCA.RestoreCertificateAuthority -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Restores a certificate authority (CA) that is in the @DELETED@ state. -- You can restore a CA during the period that you defined in the -- __PermanentDeletionTimeInDays__ parameter of the -- -- action. Currently, you can specify 7 to 30 days. If you did not specify -- a __PermanentDeletionTimeInDays__ value, by default you can restore the -- CA at any time in a 30 day period. You can check the time remaining in -- the restoration period of a private CA in the @DELETED@ state by calling -- the -- -- or -- -- actions. The status of a restored CA is set to its pre-deletion status -- when the __RestoreCertificateAuthority__ action returns. To change its -- status to @ACTIVE@, call the -- -- action. If the private CA was in the @PENDING_CERTIFICATE@ state at -- deletion, you must use the -- -- action to import a certificate authority into the private CA before it -- can be activated. You cannot restore a CA after the restoration period -- has ended. module Amazonka.CertificateManagerPCA.RestoreCertificateAuthority ( -- * Creating a Request RestoreCertificateAuthority (..), newRestoreCertificateAuthority, -- * Request Lenses restoreCertificateAuthority_certificateAuthorityArn, -- * Destructuring the Response RestoreCertificateAuthorityResponse (..), newRestoreCertificateAuthorityResponse, ) where import Amazonka.CertificateManagerPCA.Types import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens 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:/ 'newRestoreCertificateAuthority' smart constructor. data RestoreCertificateAuthority = RestoreCertificateAuthority' { -- | The Amazon Resource Name (ARN) that was returned when you called the -- -- action. This must be of the form: -- -- @arn:aws:acm-pca:@/@region@/@:@/@account@/@:certificate-authority\/@/@12345678-1234-1234-1234-123456789012@/@ @ certificateAuthorityArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RestoreCertificateAuthority' 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: -- -- 'certificateAuthorityArn', 'restoreCertificateAuthority_certificateAuthorityArn' - The Amazon Resource Name (ARN) that was returned when you called the -- -- action. This must be of the form: -- -- @arn:aws:acm-pca:@/@region@/@:@/@account@/@:certificate-authority\/@/@12345678-1234-1234-1234-123456789012@/@ @ newRestoreCertificateAuthority :: -- | 'certificateAuthorityArn' Prelude.Text -> RestoreCertificateAuthority newRestoreCertificateAuthority pCertificateAuthorityArn_ = RestoreCertificateAuthority' { certificateAuthorityArn = pCertificateAuthorityArn_ } -- | The Amazon Resource Name (ARN) that was returned when you called the -- -- action. This must be of the form: -- -- @arn:aws:acm-pca:@/@region@/@:@/@account@/@:certificate-authority\/@/@12345678-1234-1234-1234-123456789012@/@ @ restoreCertificateAuthority_certificateAuthorityArn :: Lens.Lens' RestoreCertificateAuthority Prelude.Text restoreCertificateAuthority_certificateAuthorityArn = Lens.lens (\RestoreCertificateAuthority' {certificateAuthorityArn} -> certificateAuthorityArn) (\s@RestoreCertificateAuthority' {} a -> s {certificateAuthorityArn = a} :: RestoreCertificateAuthority) instance Core.AWSRequest RestoreCertificateAuthority where type AWSResponse RestoreCertificateAuthority = RestoreCertificateAuthorityResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull RestoreCertificateAuthorityResponse' instance Prelude.Hashable RestoreCertificateAuthority where hashWithSalt _salt RestoreCertificateAuthority' {..} = _salt `Prelude.hashWithSalt` certificateAuthorityArn instance Prelude.NFData RestoreCertificateAuthority where rnf RestoreCertificateAuthority' {..} = Prelude.rnf certificateAuthorityArn instance Data.ToHeaders RestoreCertificateAuthority where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "ACMPrivateCA.RestoreCertificateAuthority" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON RestoreCertificateAuthority where toJSON RestoreCertificateAuthority' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ( "CertificateAuthorityArn" Data..= certificateAuthorityArn ) ] ) instance Data.ToPath RestoreCertificateAuthority where toPath = Prelude.const "/" instance Data.ToQuery RestoreCertificateAuthority where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newRestoreCertificateAuthorityResponse' smart constructor. data RestoreCertificateAuthorityResponse = RestoreCertificateAuthorityResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'RestoreCertificateAuthorityResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newRestoreCertificateAuthorityResponse :: RestoreCertificateAuthorityResponse newRestoreCertificateAuthorityResponse = RestoreCertificateAuthorityResponse' instance Prelude.NFData RestoreCertificateAuthorityResponse where rnf _ = ()