{-# 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.Redshift.ModifySnapshotCopyRetentionPeriod -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Modifies the number of days to retain snapshots in the destination -- Amazon Web Services Region after they are copied from the source Amazon -- Web Services Region. By default, this operation only changes the -- retention period of copied automated snapshots. The retention periods -- for both new and existing copied automated snapshots are updated with -- the new retention period. You can set the manual option to change only -- the retention periods of copied manual snapshots. If you set this -- option, only newly copied manual snapshots have the new retention -- period. module Amazonka.Redshift.ModifySnapshotCopyRetentionPeriod ( -- * Creating a Request ModifySnapshotCopyRetentionPeriod (..), newModifySnapshotCopyRetentionPeriod, -- * Request Lenses modifySnapshotCopyRetentionPeriod_manual, modifySnapshotCopyRetentionPeriod_clusterIdentifier, modifySnapshotCopyRetentionPeriod_retentionPeriod, -- * Destructuring the Response ModifySnapshotCopyRetentionPeriodResponse (..), newModifySnapshotCopyRetentionPeriodResponse, -- * Response Lenses modifySnapshotCopyRetentionPeriodResponse_cluster, modifySnapshotCopyRetentionPeriodResponse_httpStatus, ) where 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 Amazonka.Redshift.Types import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | -- -- /See:/ 'newModifySnapshotCopyRetentionPeriod' smart constructor. data ModifySnapshotCopyRetentionPeriod = ModifySnapshotCopyRetentionPeriod' { -- | Indicates whether to apply the snapshot retention period to newly copied -- manual snapshots instead of automated snapshots. manual :: Prelude.Maybe Prelude.Bool, -- | The unique identifier of the cluster for which you want to change the -- retention period for either automated or manual snapshots that are -- copied to a destination Amazon Web Services Region. -- -- Constraints: Must be the valid name of an existing cluster that has -- cross-region snapshot copy enabled. clusterIdentifier :: Prelude.Text, -- | The number of days to retain automated snapshots in the destination -- Amazon Web Services Region after they are copied from the source Amazon -- Web Services Region. -- -- By default, this only changes the retention period of copied automated -- snapshots. -- -- If you decrease the retention period for automated snapshots that are -- copied to a destination Amazon Web Services Region, Amazon Redshift -- deletes any existing automated snapshots that were copied to the -- destination Amazon Web Services Region and that fall outside of the new -- retention period. -- -- Constraints: Must be at least 1 and no more than 35 for automated -- snapshots. -- -- If you specify the @manual@ option, only newly copied manual snapshots -- will have the new retention period. -- -- If you specify the value of -1 newly copied manual snapshots are -- retained indefinitely. -- -- Constraints: The number of days must be either -1 or an integer between -- 1 and 3,653 for manual snapshots. retentionPeriod :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ModifySnapshotCopyRetentionPeriod' 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: -- -- 'manual', 'modifySnapshotCopyRetentionPeriod_manual' - Indicates whether to apply the snapshot retention period to newly copied -- manual snapshots instead of automated snapshots. -- -- 'clusterIdentifier', 'modifySnapshotCopyRetentionPeriod_clusterIdentifier' - The unique identifier of the cluster for which you want to change the -- retention period for either automated or manual snapshots that are -- copied to a destination Amazon Web Services Region. -- -- Constraints: Must be the valid name of an existing cluster that has -- cross-region snapshot copy enabled. -- -- 'retentionPeriod', 'modifySnapshotCopyRetentionPeriod_retentionPeriod' - The number of days to retain automated snapshots in the destination -- Amazon Web Services Region after they are copied from the source Amazon -- Web Services Region. -- -- By default, this only changes the retention period of copied automated -- snapshots. -- -- If you decrease the retention period for automated snapshots that are -- copied to a destination Amazon Web Services Region, Amazon Redshift -- deletes any existing automated snapshots that were copied to the -- destination Amazon Web Services Region and that fall outside of the new -- retention period. -- -- Constraints: Must be at least 1 and no more than 35 for automated -- snapshots. -- -- If you specify the @manual@ option, only newly copied manual snapshots -- will have the new retention period. -- -- If you specify the value of -1 newly copied manual snapshots are -- retained indefinitely. -- -- Constraints: The number of days must be either -1 or an integer between -- 1 and 3,653 for manual snapshots. newModifySnapshotCopyRetentionPeriod :: -- | 'clusterIdentifier' Prelude.Text -> -- | 'retentionPeriod' Prelude.Int -> ModifySnapshotCopyRetentionPeriod newModifySnapshotCopyRetentionPeriod pClusterIdentifier_ pRetentionPeriod_ = ModifySnapshotCopyRetentionPeriod' { manual = Prelude.Nothing, clusterIdentifier = pClusterIdentifier_, retentionPeriod = pRetentionPeriod_ } -- | Indicates whether to apply the snapshot retention period to newly copied -- manual snapshots instead of automated snapshots. modifySnapshotCopyRetentionPeriod_manual :: Lens.Lens' ModifySnapshotCopyRetentionPeriod (Prelude.Maybe Prelude.Bool) modifySnapshotCopyRetentionPeriod_manual = Lens.lens (\ModifySnapshotCopyRetentionPeriod' {manual} -> manual) (\s@ModifySnapshotCopyRetentionPeriod' {} a -> s {manual = a} :: ModifySnapshotCopyRetentionPeriod) -- | The unique identifier of the cluster for which you want to change the -- retention period for either automated or manual snapshots that are -- copied to a destination Amazon Web Services Region. -- -- Constraints: Must be the valid name of an existing cluster that has -- cross-region snapshot copy enabled. modifySnapshotCopyRetentionPeriod_clusterIdentifier :: Lens.Lens' ModifySnapshotCopyRetentionPeriod Prelude.Text modifySnapshotCopyRetentionPeriod_clusterIdentifier = Lens.lens (\ModifySnapshotCopyRetentionPeriod' {clusterIdentifier} -> clusterIdentifier) (\s@ModifySnapshotCopyRetentionPeriod' {} a -> s {clusterIdentifier = a} :: ModifySnapshotCopyRetentionPeriod) -- | The number of days to retain automated snapshots in the destination -- Amazon Web Services Region after they are copied from the source Amazon -- Web Services Region. -- -- By default, this only changes the retention period of copied automated -- snapshots. -- -- If you decrease the retention period for automated snapshots that are -- copied to a destination Amazon Web Services Region, Amazon Redshift -- deletes any existing automated snapshots that were copied to the -- destination Amazon Web Services Region and that fall outside of the new -- retention period. -- -- Constraints: Must be at least 1 and no more than 35 for automated -- snapshots. -- -- If you specify the @manual@ option, only newly copied manual snapshots -- will have the new retention period. -- -- If you specify the value of -1 newly copied manual snapshots are -- retained indefinitely. -- -- Constraints: The number of days must be either -1 or an integer between -- 1 and 3,653 for manual snapshots. modifySnapshotCopyRetentionPeriod_retentionPeriod :: Lens.Lens' ModifySnapshotCopyRetentionPeriod Prelude.Int modifySnapshotCopyRetentionPeriod_retentionPeriod = Lens.lens (\ModifySnapshotCopyRetentionPeriod' {retentionPeriod} -> retentionPeriod) (\s@ModifySnapshotCopyRetentionPeriod' {} a -> s {retentionPeriod = a} :: ModifySnapshotCopyRetentionPeriod) instance Core.AWSRequest ModifySnapshotCopyRetentionPeriod where type AWSResponse ModifySnapshotCopyRetentionPeriod = ModifySnapshotCopyRetentionPeriodResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "ModifySnapshotCopyRetentionPeriodResult" ( \s h x -> ModifySnapshotCopyRetentionPeriodResponse' Prelude.<$> (x Data..@? "Cluster") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable ModifySnapshotCopyRetentionPeriod where hashWithSalt _salt ModifySnapshotCopyRetentionPeriod' {..} = _salt `Prelude.hashWithSalt` manual `Prelude.hashWithSalt` clusterIdentifier `Prelude.hashWithSalt` retentionPeriod instance Prelude.NFData ModifySnapshotCopyRetentionPeriod where rnf ModifySnapshotCopyRetentionPeriod' {..} = Prelude.rnf manual `Prelude.seq` Prelude.rnf clusterIdentifier `Prelude.seq` Prelude.rnf retentionPeriod instance Data.ToHeaders ModifySnapshotCopyRetentionPeriod where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath ModifySnapshotCopyRetentionPeriod where toPath = Prelude.const "/" instance Data.ToQuery ModifySnapshotCopyRetentionPeriod where toQuery ModifySnapshotCopyRetentionPeriod' {..} = Prelude.mconcat [ "Action" Data.=: ( "ModifySnapshotCopyRetentionPeriod" :: Prelude.ByteString ), "Version" Data.=: ("2012-12-01" :: Prelude.ByteString), "Manual" Data.=: manual, "ClusterIdentifier" Data.=: clusterIdentifier, "RetentionPeriod" Data.=: retentionPeriod ] -- | /See:/ 'newModifySnapshotCopyRetentionPeriodResponse' smart constructor. data ModifySnapshotCopyRetentionPeriodResponse = ModifySnapshotCopyRetentionPeriodResponse' { cluster :: Prelude.Maybe Cluster, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'ModifySnapshotCopyRetentionPeriodResponse' 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: -- -- 'cluster', 'modifySnapshotCopyRetentionPeriodResponse_cluster' - Undocumented member. -- -- 'httpStatus', 'modifySnapshotCopyRetentionPeriodResponse_httpStatus' - The response's http status code. newModifySnapshotCopyRetentionPeriodResponse :: -- | 'httpStatus' Prelude.Int -> ModifySnapshotCopyRetentionPeriodResponse newModifySnapshotCopyRetentionPeriodResponse pHttpStatus_ = ModifySnapshotCopyRetentionPeriodResponse' { cluster = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Undocumented member. modifySnapshotCopyRetentionPeriodResponse_cluster :: Lens.Lens' ModifySnapshotCopyRetentionPeriodResponse (Prelude.Maybe Cluster) modifySnapshotCopyRetentionPeriodResponse_cluster = Lens.lens (\ModifySnapshotCopyRetentionPeriodResponse' {cluster} -> cluster) (\s@ModifySnapshotCopyRetentionPeriodResponse' {} a -> s {cluster = a} :: ModifySnapshotCopyRetentionPeriodResponse) -- | The response's http status code. modifySnapshotCopyRetentionPeriodResponse_httpStatus :: Lens.Lens' ModifySnapshotCopyRetentionPeriodResponse Prelude.Int modifySnapshotCopyRetentionPeriodResponse_httpStatus = Lens.lens (\ModifySnapshotCopyRetentionPeriodResponse' {httpStatus} -> httpStatus) (\s@ModifySnapshotCopyRetentionPeriodResponse' {} a -> s {httpStatus = a} :: ModifySnapshotCopyRetentionPeriodResponse) instance Prelude.NFData ModifySnapshotCopyRetentionPeriodResponse where rnf ModifySnapshotCopyRetentionPeriodResponse' {..} = Prelude.rnf cluster `Prelude.seq` Prelude.rnf httpStatus