{-# 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.DescribeClusterVersions -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns descriptions of the available Amazon Redshift cluster versions. -- You can call this operation even before creating any clusters to learn -- more about the Amazon Redshift versions. For more information about -- managing clusters, go to -- -- in the /Amazon Redshift Cluster Management Guide/. -- -- This operation returns paginated results. module Amazonka.Redshift.DescribeClusterVersions ( -- * Creating a Request DescribeClusterVersions (..), newDescribeClusterVersions, -- * Request Lenses describeClusterVersions_clusterParameterGroupFamily, describeClusterVersions_clusterVersion, describeClusterVersions_marker, describeClusterVersions_maxRecords, -- * Destructuring the Response DescribeClusterVersionsResponse (..), newDescribeClusterVersionsResponse, -- * Response Lenses describeClusterVersionsResponse_clusterVersions, describeClusterVersionsResponse_marker, describeClusterVersionsResponse_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:/ 'newDescribeClusterVersions' smart constructor. data DescribeClusterVersions = DescribeClusterVersions' { -- | The name of a specific cluster parameter group family to return details -- for. -- -- Constraints: -- -- - Must be 1 to 255 alphanumeric characters -- -- - First character must be a letter -- -- - Cannot end with a hyphen or contain two consecutive hyphens clusterParameterGroupFamily :: Prelude.Maybe Prelude.Text, -- | The specific cluster version to return. -- -- Example: @1.0@ clusterVersion :: Prelude.Maybe Prelude.Text, -- | An optional parameter that specifies the starting point to return a set -- of response records. When the results of a DescribeClusterVersions -- request exceed the value specified in @MaxRecords@, Amazon Web Services -- returns a value in the @Marker@ field of the response. You can retrieve -- the next set of response records by providing the returned marker value -- in the @Marker@ parameter and retrying the request. marker :: Prelude.Maybe Prelude.Text, -- | The maximum number of response records to return in each call. If the -- number of remaining response records exceeds the specified @MaxRecords@ -- value, a value is returned in a @marker@ field of the response. You can -- retrieve the next set of records by retrying the command with the -- returned marker value. -- -- Default: @100@ -- -- Constraints: minimum 20, maximum 100. maxRecords :: Prelude.Maybe Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeClusterVersions' 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: -- -- 'clusterParameterGroupFamily', 'describeClusterVersions_clusterParameterGroupFamily' - The name of a specific cluster parameter group family to return details -- for. -- -- Constraints: -- -- - Must be 1 to 255 alphanumeric characters -- -- - First character must be a letter -- -- - Cannot end with a hyphen or contain two consecutive hyphens -- -- 'clusterVersion', 'describeClusterVersions_clusterVersion' - The specific cluster version to return. -- -- Example: @1.0@ -- -- 'marker', 'describeClusterVersions_marker' - An optional parameter that specifies the starting point to return a set -- of response records. When the results of a DescribeClusterVersions -- request exceed the value specified in @MaxRecords@, Amazon Web Services -- returns a value in the @Marker@ field of the response. You can retrieve -- the next set of response records by providing the returned marker value -- in the @Marker@ parameter and retrying the request. -- -- 'maxRecords', 'describeClusterVersions_maxRecords' - The maximum number of response records to return in each call. If the -- number of remaining response records exceeds the specified @MaxRecords@ -- value, a value is returned in a @marker@ field of the response. You can -- retrieve the next set of records by retrying the command with the -- returned marker value. -- -- Default: @100@ -- -- Constraints: minimum 20, maximum 100. newDescribeClusterVersions :: DescribeClusterVersions newDescribeClusterVersions = DescribeClusterVersions' { clusterParameterGroupFamily = Prelude.Nothing, clusterVersion = Prelude.Nothing, marker = Prelude.Nothing, maxRecords = Prelude.Nothing } -- | The name of a specific cluster parameter group family to return details -- for. -- -- Constraints: -- -- - Must be 1 to 255 alphanumeric characters -- -- - First character must be a letter -- -- - Cannot end with a hyphen or contain two consecutive hyphens describeClusterVersions_clusterParameterGroupFamily :: Lens.Lens' DescribeClusterVersions (Prelude.Maybe Prelude.Text) describeClusterVersions_clusterParameterGroupFamily = Lens.lens (\DescribeClusterVersions' {clusterParameterGroupFamily} -> clusterParameterGroupFamily) (\s@DescribeClusterVersions' {} a -> s {clusterParameterGroupFamily = a} :: DescribeClusterVersions) -- | The specific cluster version to return. -- -- Example: @1.0@ describeClusterVersions_clusterVersion :: Lens.Lens' DescribeClusterVersions (Prelude.Maybe Prelude.Text) describeClusterVersions_clusterVersion = Lens.lens (\DescribeClusterVersions' {clusterVersion} -> clusterVersion) (\s@DescribeClusterVersions' {} a -> s {clusterVersion = a} :: DescribeClusterVersions) -- | An optional parameter that specifies the starting point to return a set -- of response records. When the results of a DescribeClusterVersions -- request exceed the value specified in @MaxRecords@, Amazon Web Services -- returns a value in the @Marker@ field of the response. You can retrieve -- the next set of response records by providing the returned marker value -- in the @Marker@ parameter and retrying the request. describeClusterVersions_marker :: Lens.Lens' DescribeClusterVersions (Prelude.Maybe Prelude.Text) describeClusterVersions_marker = Lens.lens (\DescribeClusterVersions' {marker} -> marker) (\s@DescribeClusterVersions' {} a -> s {marker = a} :: DescribeClusterVersions) -- | The maximum number of response records to return in each call. If the -- number of remaining response records exceeds the specified @MaxRecords@ -- value, a value is returned in a @marker@ field of the response. You can -- retrieve the next set of records by retrying the command with the -- returned marker value. -- -- Default: @100@ -- -- Constraints: minimum 20, maximum 100. describeClusterVersions_maxRecords :: Lens.Lens' DescribeClusterVersions (Prelude.Maybe Prelude.Int) describeClusterVersions_maxRecords = Lens.lens (\DescribeClusterVersions' {maxRecords} -> maxRecords) (\s@DescribeClusterVersions' {} a -> s {maxRecords = a} :: DescribeClusterVersions) instance Core.AWSPager DescribeClusterVersions where page rq rs | Core.stop ( rs Lens.^? describeClusterVersionsResponse_marker Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeClusterVersionsResponse_clusterVersions Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeClusterVersions_marker Lens..~ rs Lens.^? describeClusterVersionsResponse_marker Prelude.. Lens._Just instance Core.AWSRequest DescribeClusterVersions where type AWSResponse DescribeClusterVersions = DescribeClusterVersionsResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "DescribeClusterVersionsResult" ( \s h x -> DescribeClusterVersionsResponse' Prelude.<$> ( x Data..@? "ClusterVersions" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "ClusterVersion") ) Prelude.<*> (x Data..@? "Marker") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeClusterVersions where hashWithSalt _salt DescribeClusterVersions' {..} = _salt `Prelude.hashWithSalt` clusterParameterGroupFamily `Prelude.hashWithSalt` clusterVersion `Prelude.hashWithSalt` marker `Prelude.hashWithSalt` maxRecords instance Prelude.NFData DescribeClusterVersions where rnf DescribeClusterVersions' {..} = Prelude.rnf clusterParameterGroupFamily `Prelude.seq` Prelude.rnf clusterVersion `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf maxRecords instance Data.ToHeaders DescribeClusterVersions where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DescribeClusterVersions where toPath = Prelude.const "/" instance Data.ToQuery DescribeClusterVersions where toQuery DescribeClusterVersions' {..} = Prelude.mconcat [ "Action" Data.=: ("DescribeClusterVersions" :: Prelude.ByteString), "Version" Data.=: ("2012-12-01" :: Prelude.ByteString), "ClusterParameterGroupFamily" Data.=: clusterParameterGroupFamily, "ClusterVersion" Data.=: clusterVersion, "Marker" Data.=: marker, "MaxRecords" Data.=: maxRecords ] -- | Contains the output from the DescribeClusterVersions action. -- -- /See:/ 'newDescribeClusterVersionsResponse' smart constructor. data DescribeClusterVersionsResponse = DescribeClusterVersionsResponse' { -- | A list of @Version@ elements. clusterVersions :: Prelude.Maybe [ClusterVersion], -- | A value that indicates the starting point for the next set of response -- records in a subsequent request. If a value is returned in a response, -- you can retrieve the next set of records by providing this returned -- marker value in the @Marker@ parameter and retrying the command. If the -- @Marker@ field is empty, all response records have been retrieved for -- the request. marker :: 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 'DescribeClusterVersionsResponse' 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: -- -- 'clusterVersions', 'describeClusterVersionsResponse_clusterVersions' - A list of @Version@ elements. -- -- 'marker', 'describeClusterVersionsResponse_marker' - A value that indicates the starting point for the next set of response -- records in a subsequent request. If a value is returned in a response, -- you can retrieve the next set of records by providing this returned -- marker value in the @Marker@ parameter and retrying the command. If the -- @Marker@ field is empty, all response records have been retrieved for -- the request. -- -- 'httpStatus', 'describeClusterVersionsResponse_httpStatus' - The response's http status code. newDescribeClusterVersionsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeClusterVersionsResponse newDescribeClusterVersionsResponse pHttpStatus_ = DescribeClusterVersionsResponse' { clusterVersions = Prelude.Nothing, marker = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of @Version@ elements. describeClusterVersionsResponse_clusterVersions :: Lens.Lens' DescribeClusterVersionsResponse (Prelude.Maybe [ClusterVersion]) describeClusterVersionsResponse_clusterVersions = Lens.lens (\DescribeClusterVersionsResponse' {clusterVersions} -> clusterVersions) (\s@DescribeClusterVersionsResponse' {} a -> s {clusterVersions = a} :: DescribeClusterVersionsResponse) Prelude.. Lens.mapping Lens.coerced -- | A value that indicates the starting point for the next set of response -- records in a subsequent request. If a value is returned in a response, -- you can retrieve the next set of records by providing this returned -- marker value in the @Marker@ parameter and retrying the command. If the -- @Marker@ field is empty, all response records have been retrieved for -- the request. describeClusterVersionsResponse_marker :: Lens.Lens' DescribeClusterVersionsResponse (Prelude.Maybe Prelude.Text) describeClusterVersionsResponse_marker = Lens.lens (\DescribeClusterVersionsResponse' {marker} -> marker) (\s@DescribeClusterVersionsResponse' {} a -> s {marker = a} :: DescribeClusterVersionsResponse) -- | The response's http status code. describeClusterVersionsResponse_httpStatus :: Lens.Lens' DescribeClusterVersionsResponse Prelude.Int describeClusterVersionsResponse_httpStatus = Lens.lens (\DescribeClusterVersionsResponse' {httpStatus} -> httpStatus) (\s@DescribeClusterVersionsResponse' {} a -> s {httpStatus = a} :: DescribeClusterVersionsResponse) instance Prelude.NFData DescribeClusterVersionsResponse where rnf DescribeClusterVersionsResponse' {..} = Prelude.rnf clusterVersions `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf httpStatus