{-# 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.RDS.DescribeGlobalClusters -- 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 information about Aurora global database clusters. This API -- supports pagination. -- -- For more information on Amazon Aurora, see -- -- in the /Amazon Aurora User Guide/. -- -- This action only applies to Aurora DB clusters. -- -- This operation returns paginated results. module Amazonka.RDS.DescribeGlobalClusters ( -- * Creating a Request DescribeGlobalClusters (..), newDescribeGlobalClusters, -- * Request Lenses describeGlobalClusters_filters, describeGlobalClusters_globalClusterIdentifier, describeGlobalClusters_marker, describeGlobalClusters_maxRecords, -- * Destructuring the Response DescribeGlobalClustersResponse (..), newDescribeGlobalClustersResponse, -- * Response Lenses describeGlobalClustersResponse_globalClusters, describeGlobalClustersResponse_marker, describeGlobalClustersResponse_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.RDS.Types import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDescribeGlobalClusters' smart constructor. data DescribeGlobalClusters = DescribeGlobalClusters' { -- | This parameter isn\'t currently supported. filters :: Prelude.Maybe [Filter], -- | The user-supplied DB cluster identifier. If this parameter is specified, -- information from only the specific DB cluster is returned. This -- parameter isn\'t case-sensitive. -- -- Constraints: -- -- - If supplied, must match an existing DBClusterIdentifier. globalClusterIdentifier :: Prelude.Maybe Prelude.Text, -- | An optional pagination token provided by a previous -- @DescribeGlobalClusters@ request. If this parameter is specified, the -- response includes only records beyond the marker, up to the value -- specified by @MaxRecords@. marker :: Prelude.Maybe Prelude.Text, -- | The maximum number of records to include in the response. If more -- records exist than the specified @MaxRecords@ value, a pagination token -- called a marker is included in the response so that you can retrieve the -- remaining results. -- -- 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 'DescribeGlobalClusters' 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: -- -- 'filters', 'describeGlobalClusters_filters' - This parameter isn\'t currently supported. -- -- 'globalClusterIdentifier', 'describeGlobalClusters_globalClusterIdentifier' - The user-supplied DB cluster identifier. If this parameter is specified, -- information from only the specific DB cluster is returned. This -- parameter isn\'t case-sensitive. -- -- Constraints: -- -- - If supplied, must match an existing DBClusterIdentifier. -- -- 'marker', 'describeGlobalClusters_marker' - An optional pagination token provided by a previous -- @DescribeGlobalClusters@ request. If this parameter is specified, the -- response includes only records beyond the marker, up to the value -- specified by @MaxRecords@. -- -- 'maxRecords', 'describeGlobalClusters_maxRecords' - The maximum number of records to include in the response. If more -- records exist than the specified @MaxRecords@ value, a pagination token -- called a marker is included in the response so that you can retrieve the -- remaining results. -- -- Default: 100 -- -- Constraints: Minimum 20, maximum 100. newDescribeGlobalClusters :: DescribeGlobalClusters newDescribeGlobalClusters = DescribeGlobalClusters' { filters = Prelude.Nothing, globalClusterIdentifier = Prelude.Nothing, marker = Prelude.Nothing, maxRecords = Prelude.Nothing } -- | This parameter isn\'t currently supported. describeGlobalClusters_filters :: Lens.Lens' DescribeGlobalClusters (Prelude.Maybe [Filter]) describeGlobalClusters_filters = Lens.lens (\DescribeGlobalClusters' {filters} -> filters) (\s@DescribeGlobalClusters' {} a -> s {filters = a} :: DescribeGlobalClusters) Prelude.. Lens.mapping Lens.coerced -- | The user-supplied DB cluster identifier. If this parameter is specified, -- information from only the specific DB cluster is returned. This -- parameter isn\'t case-sensitive. -- -- Constraints: -- -- - If supplied, must match an existing DBClusterIdentifier. describeGlobalClusters_globalClusterIdentifier :: Lens.Lens' DescribeGlobalClusters (Prelude.Maybe Prelude.Text) describeGlobalClusters_globalClusterIdentifier = Lens.lens (\DescribeGlobalClusters' {globalClusterIdentifier} -> globalClusterIdentifier) (\s@DescribeGlobalClusters' {} a -> s {globalClusterIdentifier = a} :: DescribeGlobalClusters) -- | An optional pagination token provided by a previous -- @DescribeGlobalClusters@ request. If this parameter is specified, the -- response includes only records beyond the marker, up to the value -- specified by @MaxRecords@. describeGlobalClusters_marker :: Lens.Lens' DescribeGlobalClusters (Prelude.Maybe Prelude.Text) describeGlobalClusters_marker = Lens.lens (\DescribeGlobalClusters' {marker} -> marker) (\s@DescribeGlobalClusters' {} a -> s {marker = a} :: DescribeGlobalClusters) -- | The maximum number of records to include in the response. If more -- records exist than the specified @MaxRecords@ value, a pagination token -- called a marker is included in the response so that you can retrieve the -- remaining results. -- -- Default: 100 -- -- Constraints: Minimum 20, maximum 100. describeGlobalClusters_maxRecords :: Lens.Lens' DescribeGlobalClusters (Prelude.Maybe Prelude.Int) describeGlobalClusters_maxRecords = Lens.lens (\DescribeGlobalClusters' {maxRecords} -> maxRecords) (\s@DescribeGlobalClusters' {} a -> s {maxRecords = a} :: DescribeGlobalClusters) instance Core.AWSPager DescribeGlobalClusters where page rq rs | Core.stop ( rs Lens.^? describeGlobalClustersResponse_marker Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeGlobalClustersResponse_globalClusters Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeGlobalClusters_marker Lens..~ rs Lens.^? describeGlobalClustersResponse_marker Prelude.. Lens._Just instance Core.AWSRequest DescribeGlobalClusters where type AWSResponse DescribeGlobalClusters = DescribeGlobalClustersResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "DescribeGlobalClustersResult" ( \s h x -> DescribeGlobalClustersResponse' Prelude.<$> ( x Data..@? "GlobalClusters" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "GlobalClusterMember") ) Prelude.<*> (x Data..@? "Marker") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeGlobalClusters where hashWithSalt _salt DescribeGlobalClusters' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` globalClusterIdentifier `Prelude.hashWithSalt` marker `Prelude.hashWithSalt` maxRecords instance Prelude.NFData DescribeGlobalClusters where rnf DescribeGlobalClusters' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf globalClusterIdentifier `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf maxRecords instance Data.ToHeaders DescribeGlobalClusters where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DescribeGlobalClusters where toPath = Prelude.const "/" instance Data.ToQuery DescribeGlobalClusters where toQuery DescribeGlobalClusters' {..} = Prelude.mconcat [ "Action" Data.=: ("DescribeGlobalClusters" :: Prelude.ByteString), "Version" Data.=: ("2014-10-31" :: Prelude.ByteString), "Filters" Data.=: Data.toQuery (Data.toQueryList "Filter" Prelude.<$> filters), "GlobalClusterIdentifier" Data.=: globalClusterIdentifier, "Marker" Data.=: marker, "MaxRecords" Data.=: maxRecords ] -- | /See:/ 'newDescribeGlobalClustersResponse' smart constructor. data DescribeGlobalClustersResponse = DescribeGlobalClustersResponse' { -- | The list of global clusters returned by this request. globalClusters :: Prelude.Maybe [GlobalCluster], -- | An optional pagination token provided by a previous -- @DescribeGlobalClusters@ request. If this parameter is specified, the -- response includes only records beyond the marker, up to the value -- specified by @MaxRecords@. 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 'DescribeGlobalClustersResponse' 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: -- -- 'globalClusters', 'describeGlobalClustersResponse_globalClusters' - The list of global clusters returned by this request. -- -- 'marker', 'describeGlobalClustersResponse_marker' - An optional pagination token provided by a previous -- @DescribeGlobalClusters@ request. If this parameter is specified, the -- response includes only records beyond the marker, up to the value -- specified by @MaxRecords@. -- -- 'httpStatus', 'describeGlobalClustersResponse_httpStatus' - The response's http status code. newDescribeGlobalClustersResponse :: -- | 'httpStatus' Prelude.Int -> DescribeGlobalClustersResponse newDescribeGlobalClustersResponse pHttpStatus_ = DescribeGlobalClustersResponse' { globalClusters = Prelude.Nothing, marker = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The list of global clusters returned by this request. describeGlobalClustersResponse_globalClusters :: Lens.Lens' DescribeGlobalClustersResponse (Prelude.Maybe [GlobalCluster]) describeGlobalClustersResponse_globalClusters = Lens.lens (\DescribeGlobalClustersResponse' {globalClusters} -> globalClusters) (\s@DescribeGlobalClustersResponse' {} a -> s {globalClusters = a} :: DescribeGlobalClustersResponse) Prelude.. Lens.mapping Lens.coerced -- | An optional pagination token provided by a previous -- @DescribeGlobalClusters@ request. If this parameter is specified, the -- response includes only records beyond the marker, up to the value -- specified by @MaxRecords@. describeGlobalClustersResponse_marker :: Lens.Lens' DescribeGlobalClustersResponse (Prelude.Maybe Prelude.Text) describeGlobalClustersResponse_marker = Lens.lens (\DescribeGlobalClustersResponse' {marker} -> marker) (\s@DescribeGlobalClustersResponse' {} a -> s {marker = a} :: DescribeGlobalClustersResponse) -- | The response's http status code. describeGlobalClustersResponse_httpStatus :: Lens.Lens' DescribeGlobalClustersResponse Prelude.Int describeGlobalClustersResponse_httpStatus = Lens.lens (\DescribeGlobalClustersResponse' {httpStatus} -> httpStatus) (\s@DescribeGlobalClustersResponse' {} a -> s {httpStatus = a} :: DescribeGlobalClustersResponse) instance Prelude.NFData DescribeGlobalClustersResponse where rnf DescribeGlobalClustersResponse' {..} = Prelude.rnf globalClusters `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf httpStatus