{-# 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.MemoryDb.UpdateCluster -- 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 settings for a cluster. You can use this operation to -- change one or more cluster configuration settings by specifying the -- settings and the new values. module Amazonka.MemoryDb.UpdateCluster ( -- * Creating a Request UpdateCluster (..), newUpdateCluster, -- * Request Lenses updateCluster_aCLName, updateCluster_description, updateCluster_engineVersion, updateCluster_maintenanceWindow, updateCluster_nodeType, updateCluster_parameterGroupName, updateCluster_replicaConfiguration, updateCluster_securityGroupIds, updateCluster_shardConfiguration, updateCluster_snapshotRetentionLimit, updateCluster_snapshotWindow, updateCluster_snsTopicArn, updateCluster_snsTopicStatus, updateCluster_clusterName, -- * Destructuring the Response UpdateClusterResponse (..), newUpdateClusterResponse, -- * Response Lenses updateClusterResponse_cluster, updateClusterResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.MemoryDb.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newUpdateCluster' smart constructor. data UpdateCluster = UpdateCluster' { -- | The Access Control List that is associated with the cluster aCLName :: Prelude.Maybe Prelude.Text, -- | The description of the cluster to update description :: Prelude.Maybe Prelude.Text, -- | The upgraded version of the engine to be run on the nodes. You can -- upgrade to a newer engine version, but you cannot downgrade to an -- earlier engine version. If you want to use an earlier engine version, -- you must delete the existing cluster and create it anew with the earlier -- engine version. engineVersion :: Prelude.Maybe Prelude.Text, -- | Specifies the weekly time range during which maintenance on the cluster -- is performed. It is specified as a range in the format -- ddd:hh24:mi-ddd:hh24:mi (24H Clock UTC). The minimum maintenance window -- is a 60 minute period. -- -- Valid values for @ddd@ are: -- -- - @sun@ -- -- - @mon@ -- -- - @tue@ -- -- - @wed@ -- -- - @thu@ -- -- - @fri@ -- -- - @sat@ -- -- Example: @sun:23:00-mon:01:30@ maintenanceWindow :: Prelude.Maybe Prelude.Text, -- | A valid node type that you want to scale this cluster up or down to. nodeType :: Prelude.Maybe Prelude.Text, -- | The name of the parameter group to update parameterGroupName :: Prelude.Maybe Prelude.Text, -- | The number of replicas that will reside in each shard replicaConfiguration :: Prelude.Maybe ReplicaConfigurationRequest, -- | The SecurityGroupIds to update securityGroupIds :: Prelude.Maybe [Prelude.Text], -- | The number of shards in the cluster shardConfiguration :: Prelude.Maybe ShardConfigurationRequest, -- | The number of days for which MemoryDB retains automatic cluster -- snapshots before deleting them. For example, if you set -- SnapshotRetentionLimit to 5, a snapshot that was taken today is retained -- for 5 days before being deleted. snapshotRetentionLimit :: Prelude.Maybe Prelude.Int, -- | The daily time range (in UTC) during which MemoryDB begins taking a -- daily snapshot of your cluster. snapshotWindow :: Prelude.Maybe Prelude.Text, -- | The SNS topic ARN to update snsTopicArn :: Prelude.Maybe Prelude.Text, -- | The status of the Amazon SNS notification topic. Notifications are sent -- only if the status is active. snsTopicStatus :: Prelude.Maybe Prelude.Text, -- | The name of the cluster to update clusterName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'UpdateCluster' 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: -- -- 'aCLName', 'updateCluster_aCLName' - The Access Control List that is associated with the cluster -- -- 'description', 'updateCluster_description' - The description of the cluster to update -- -- 'engineVersion', 'updateCluster_engineVersion' - The upgraded version of the engine to be run on the nodes. You can -- upgrade to a newer engine version, but you cannot downgrade to an -- earlier engine version. If you want to use an earlier engine version, -- you must delete the existing cluster and create it anew with the earlier -- engine version. -- -- 'maintenanceWindow', 'updateCluster_maintenanceWindow' - Specifies the weekly time range during which maintenance on the cluster -- is performed. It is specified as a range in the format -- ddd:hh24:mi-ddd:hh24:mi (24H Clock UTC). The minimum maintenance window -- is a 60 minute period. -- -- Valid values for @ddd@ are: -- -- - @sun@ -- -- - @mon@ -- -- - @tue@ -- -- - @wed@ -- -- - @thu@ -- -- - @fri@ -- -- - @sat@ -- -- Example: @sun:23:00-mon:01:30@ -- -- 'nodeType', 'updateCluster_nodeType' - A valid node type that you want to scale this cluster up or down to. -- -- 'parameterGroupName', 'updateCluster_parameterGroupName' - The name of the parameter group to update -- -- 'replicaConfiguration', 'updateCluster_replicaConfiguration' - The number of replicas that will reside in each shard -- -- 'securityGroupIds', 'updateCluster_securityGroupIds' - The SecurityGroupIds to update -- -- 'shardConfiguration', 'updateCluster_shardConfiguration' - The number of shards in the cluster -- -- 'snapshotRetentionLimit', 'updateCluster_snapshotRetentionLimit' - The number of days for which MemoryDB retains automatic cluster -- snapshots before deleting them. For example, if you set -- SnapshotRetentionLimit to 5, a snapshot that was taken today is retained -- for 5 days before being deleted. -- -- 'snapshotWindow', 'updateCluster_snapshotWindow' - The daily time range (in UTC) during which MemoryDB begins taking a -- daily snapshot of your cluster. -- -- 'snsTopicArn', 'updateCluster_snsTopicArn' - The SNS topic ARN to update -- -- 'snsTopicStatus', 'updateCluster_snsTopicStatus' - The status of the Amazon SNS notification topic. Notifications are sent -- only if the status is active. -- -- 'clusterName', 'updateCluster_clusterName' - The name of the cluster to update newUpdateCluster :: -- | 'clusterName' Prelude.Text -> UpdateCluster newUpdateCluster pClusterName_ = UpdateCluster' { aCLName = Prelude.Nothing, description = Prelude.Nothing, engineVersion = Prelude.Nothing, maintenanceWindow = Prelude.Nothing, nodeType = Prelude.Nothing, parameterGroupName = Prelude.Nothing, replicaConfiguration = Prelude.Nothing, securityGroupIds = Prelude.Nothing, shardConfiguration = Prelude.Nothing, snapshotRetentionLimit = Prelude.Nothing, snapshotWindow = Prelude.Nothing, snsTopicArn = Prelude.Nothing, snsTopicStatus = Prelude.Nothing, clusterName = pClusterName_ } -- | The Access Control List that is associated with the cluster updateCluster_aCLName :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_aCLName = Lens.lens (\UpdateCluster' {aCLName} -> aCLName) (\s@UpdateCluster' {} a -> s {aCLName = a} :: UpdateCluster) -- | The description of the cluster to update updateCluster_description :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_description = Lens.lens (\UpdateCluster' {description} -> description) (\s@UpdateCluster' {} a -> s {description = a} :: UpdateCluster) -- | The upgraded version of the engine to be run on the nodes. You can -- upgrade to a newer engine version, but you cannot downgrade to an -- earlier engine version. If you want to use an earlier engine version, -- you must delete the existing cluster and create it anew with the earlier -- engine version. updateCluster_engineVersion :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_engineVersion = Lens.lens (\UpdateCluster' {engineVersion} -> engineVersion) (\s@UpdateCluster' {} a -> s {engineVersion = a} :: UpdateCluster) -- | Specifies the weekly time range during which maintenance on the cluster -- is performed. It is specified as a range in the format -- ddd:hh24:mi-ddd:hh24:mi (24H Clock UTC). The minimum maintenance window -- is a 60 minute period. -- -- Valid values for @ddd@ are: -- -- - @sun@ -- -- - @mon@ -- -- - @tue@ -- -- - @wed@ -- -- - @thu@ -- -- - @fri@ -- -- - @sat@ -- -- Example: @sun:23:00-mon:01:30@ updateCluster_maintenanceWindow :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_maintenanceWindow = Lens.lens (\UpdateCluster' {maintenanceWindow} -> maintenanceWindow) (\s@UpdateCluster' {} a -> s {maintenanceWindow = a} :: UpdateCluster) -- | A valid node type that you want to scale this cluster up or down to. updateCluster_nodeType :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_nodeType = Lens.lens (\UpdateCluster' {nodeType} -> nodeType) (\s@UpdateCluster' {} a -> s {nodeType = a} :: UpdateCluster) -- | The name of the parameter group to update updateCluster_parameterGroupName :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_parameterGroupName = Lens.lens (\UpdateCluster' {parameterGroupName} -> parameterGroupName) (\s@UpdateCluster' {} a -> s {parameterGroupName = a} :: UpdateCluster) -- | The number of replicas that will reside in each shard updateCluster_replicaConfiguration :: Lens.Lens' UpdateCluster (Prelude.Maybe ReplicaConfigurationRequest) updateCluster_replicaConfiguration = Lens.lens (\UpdateCluster' {replicaConfiguration} -> replicaConfiguration) (\s@UpdateCluster' {} a -> s {replicaConfiguration = a} :: UpdateCluster) -- | The SecurityGroupIds to update updateCluster_securityGroupIds :: Lens.Lens' UpdateCluster (Prelude.Maybe [Prelude.Text]) updateCluster_securityGroupIds = Lens.lens (\UpdateCluster' {securityGroupIds} -> securityGroupIds) (\s@UpdateCluster' {} a -> s {securityGroupIds = a} :: UpdateCluster) Prelude.. Lens.mapping Lens.coerced -- | The number of shards in the cluster updateCluster_shardConfiguration :: Lens.Lens' UpdateCluster (Prelude.Maybe ShardConfigurationRequest) updateCluster_shardConfiguration = Lens.lens (\UpdateCluster' {shardConfiguration} -> shardConfiguration) (\s@UpdateCluster' {} a -> s {shardConfiguration = a} :: UpdateCluster) -- | The number of days for which MemoryDB retains automatic cluster -- snapshots before deleting them. For example, if you set -- SnapshotRetentionLimit to 5, a snapshot that was taken today is retained -- for 5 days before being deleted. updateCluster_snapshotRetentionLimit :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Int) updateCluster_snapshotRetentionLimit = Lens.lens (\UpdateCluster' {snapshotRetentionLimit} -> snapshotRetentionLimit) (\s@UpdateCluster' {} a -> s {snapshotRetentionLimit = a} :: UpdateCluster) -- | The daily time range (in UTC) during which MemoryDB begins taking a -- daily snapshot of your cluster. updateCluster_snapshotWindow :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_snapshotWindow = Lens.lens (\UpdateCluster' {snapshotWindow} -> snapshotWindow) (\s@UpdateCluster' {} a -> s {snapshotWindow = a} :: UpdateCluster) -- | The SNS topic ARN to update updateCluster_snsTopicArn :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_snsTopicArn = Lens.lens (\UpdateCluster' {snsTopicArn} -> snsTopicArn) (\s@UpdateCluster' {} a -> s {snsTopicArn = a} :: UpdateCluster) -- | The status of the Amazon SNS notification topic. Notifications are sent -- only if the status is active. updateCluster_snsTopicStatus :: Lens.Lens' UpdateCluster (Prelude.Maybe Prelude.Text) updateCluster_snsTopicStatus = Lens.lens (\UpdateCluster' {snsTopicStatus} -> snsTopicStatus) (\s@UpdateCluster' {} a -> s {snsTopicStatus = a} :: UpdateCluster) -- | The name of the cluster to update updateCluster_clusterName :: Lens.Lens' UpdateCluster Prelude.Text updateCluster_clusterName = Lens.lens (\UpdateCluster' {clusterName} -> clusterName) (\s@UpdateCluster' {} a -> s {clusterName = a} :: UpdateCluster) instance Core.AWSRequest UpdateCluster where type AWSResponse UpdateCluster = UpdateClusterResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> UpdateClusterResponse' Prelude.<$> (x Data..?> "Cluster") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable UpdateCluster where hashWithSalt _salt UpdateCluster' {..} = _salt `Prelude.hashWithSalt` aCLName `Prelude.hashWithSalt` description `Prelude.hashWithSalt` engineVersion `Prelude.hashWithSalt` maintenanceWindow `Prelude.hashWithSalt` nodeType `Prelude.hashWithSalt` parameterGroupName `Prelude.hashWithSalt` replicaConfiguration `Prelude.hashWithSalt` securityGroupIds `Prelude.hashWithSalt` shardConfiguration `Prelude.hashWithSalt` snapshotRetentionLimit `Prelude.hashWithSalt` snapshotWindow `Prelude.hashWithSalt` snsTopicArn `Prelude.hashWithSalt` snsTopicStatus `Prelude.hashWithSalt` clusterName instance Prelude.NFData UpdateCluster where rnf UpdateCluster' {..} = Prelude.rnf aCLName `Prelude.seq` Prelude.rnf description `Prelude.seq` Prelude.rnf engineVersion `Prelude.seq` Prelude.rnf maintenanceWindow `Prelude.seq` Prelude.rnf nodeType `Prelude.seq` Prelude.rnf parameterGroupName `Prelude.seq` Prelude.rnf replicaConfiguration `Prelude.seq` Prelude.rnf securityGroupIds `Prelude.seq` Prelude.rnf shardConfiguration `Prelude.seq` Prelude.rnf snapshotRetentionLimit `Prelude.seq` Prelude.rnf snapshotWindow `Prelude.seq` Prelude.rnf snsTopicArn `Prelude.seq` Prelude.rnf snsTopicStatus `Prelude.seq` Prelude.rnf clusterName instance Data.ToHeaders UpdateCluster where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonMemoryDB.UpdateCluster" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON UpdateCluster where toJSON UpdateCluster' {..} = Data.object ( Prelude.catMaybes [ ("ACLName" Data..=) Prelude.<$> aCLName, ("Description" Data..=) Prelude.<$> description, ("EngineVersion" Data..=) Prelude.<$> engineVersion, ("MaintenanceWindow" Data..=) Prelude.<$> maintenanceWindow, ("NodeType" Data..=) Prelude.<$> nodeType, ("ParameterGroupName" Data..=) Prelude.<$> parameterGroupName, ("ReplicaConfiguration" Data..=) Prelude.<$> replicaConfiguration, ("SecurityGroupIds" Data..=) Prelude.<$> securityGroupIds, ("ShardConfiguration" Data..=) Prelude.<$> shardConfiguration, ("SnapshotRetentionLimit" Data..=) Prelude.<$> snapshotRetentionLimit, ("SnapshotWindow" Data..=) Prelude.<$> snapshotWindow, ("SnsTopicArn" Data..=) Prelude.<$> snsTopicArn, ("SnsTopicStatus" Data..=) Prelude.<$> snsTopicStatus, Prelude.Just ("ClusterName" Data..= clusterName) ] ) instance Data.ToPath UpdateCluster where toPath = Prelude.const "/" instance Data.ToQuery UpdateCluster where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newUpdateClusterResponse' smart constructor. data UpdateClusterResponse = UpdateClusterResponse' { -- | The updated cluster 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 'UpdateClusterResponse' 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', 'updateClusterResponse_cluster' - The updated cluster -- -- 'httpStatus', 'updateClusterResponse_httpStatus' - The response's http status code. newUpdateClusterResponse :: -- | 'httpStatus' Prelude.Int -> UpdateClusterResponse newUpdateClusterResponse pHttpStatus_ = UpdateClusterResponse' { cluster = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The updated cluster updateClusterResponse_cluster :: Lens.Lens' UpdateClusterResponse (Prelude.Maybe Cluster) updateClusterResponse_cluster = Lens.lens (\UpdateClusterResponse' {cluster} -> cluster) (\s@UpdateClusterResponse' {} a -> s {cluster = a} :: UpdateClusterResponse) -- | The response's http status code. updateClusterResponse_httpStatus :: Lens.Lens' UpdateClusterResponse Prelude.Int updateClusterResponse_httpStatus = Lens.lens (\UpdateClusterResponse' {httpStatus} -> httpStatus) (\s@UpdateClusterResponse' {} a -> s {httpStatus = a} :: UpdateClusterResponse) instance Prelude.NFData UpdateClusterResponse where rnf UpdateClusterResponse' {..} = Prelude.rnf cluster `Prelude.seq` Prelude.rnf httpStatus