{-# 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.DocumentDB.DescribeDBSubnetGroups -- 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 a list of @DBSubnetGroup@ descriptions. If a @DBSubnetGroupName@ -- is specified, the list will contain only the descriptions of the -- specified @DBSubnetGroup@. -- -- This operation returns paginated results. module Amazonka.DocumentDB.DescribeDBSubnetGroups ( -- * Creating a Request DescribeDBSubnetGroups (..), newDescribeDBSubnetGroups, -- * Request Lenses describeDBSubnetGroups_dbSubnetGroupName, describeDBSubnetGroups_filters, describeDBSubnetGroups_marker, describeDBSubnetGroups_maxRecords, -- * Destructuring the Response DescribeDBSubnetGroupsResponse (..), newDescribeDBSubnetGroupsResponse, -- * Response Lenses describeDBSubnetGroupsResponse_dbSubnetGroups, describeDBSubnetGroupsResponse_marker, describeDBSubnetGroupsResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.DocumentDB.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | Represents the input to DescribeDBSubnetGroups. -- -- /See:/ 'newDescribeDBSubnetGroups' smart constructor. data DescribeDBSubnetGroups = DescribeDBSubnetGroups' { -- | The name of the subnet group to return details for. dbSubnetGroupName :: Prelude.Maybe Prelude.Text, -- | This parameter is not currently supported. filters :: Prelude.Maybe [Filter], -- | An optional pagination token provided by a previous 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 -- (marker) is included in the response so that the remaining results can -- be retrieved. -- -- 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 'DescribeDBSubnetGroups' 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: -- -- 'dbSubnetGroupName', 'describeDBSubnetGroups_dbSubnetGroupName' - The name of the subnet group to return details for. -- -- 'filters', 'describeDBSubnetGroups_filters' - This parameter is not currently supported. -- -- 'marker', 'describeDBSubnetGroups_marker' - An optional pagination token provided by a previous request. If this -- parameter is specified, the response includes only records beyond the -- marker, up to the value specified by @MaxRecords@. -- -- 'maxRecords', 'describeDBSubnetGroups_maxRecords' - The maximum number of records to include in the response. If more -- records exist than the specified @MaxRecords@ value, a pagination token -- (marker) is included in the response so that the remaining results can -- be retrieved. -- -- Default: 100 -- -- Constraints: Minimum 20, maximum 100. newDescribeDBSubnetGroups :: DescribeDBSubnetGroups newDescribeDBSubnetGroups = DescribeDBSubnetGroups' { dbSubnetGroupName = Prelude.Nothing, filters = Prelude.Nothing, marker = Prelude.Nothing, maxRecords = Prelude.Nothing } -- | The name of the subnet group to return details for. describeDBSubnetGroups_dbSubnetGroupName :: Lens.Lens' DescribeDBSubnetGroups (Prelude.Maybe Prelude.Text) describeDBSubnetGroups_dbSubnetGroupName = Lens.lens (\DescribeDBSubnetGroups' {dbSubnetGroupName} -> dbSubnetGroupName) (\s@DescribeDBSubnetGroups' {} a -> s {dbSubnetGroupName = a} :: DescribeDBSubnetGroups) -- | This parameter is not currently supported. describeDBSubnetGroups_filters :: Lens.Lens' DescribeDBSubnetGroups (Prelude.Maybe [Filter]) describeDBSubnetGroups_filters = Lens.lens (\DescribeDBSubnetGroups' {filters} -> filters) (\s@DescribeDBSubnetGroups' {} a -> s {filters = a} :: DescribeDBSubnetGroups) Prelude.. Lens.mapping Lens.coerced -- | An optional pagination token provided by a previous request. If this -- parameter is specified, the response includes only records beyond the -- marker, up to the value specified by @MaxRecords@. describeDBSubnetGroups_marker :: Lens.Lens' DescribeDBSubnetGroups (Prelude.Maybe Prelude.Text) describeDBSubnetGroups_marker = Lens.lens (\DescribeDBSubnetGroups' {marker} -> marker) (\s@DescribeDBSubnetGroups' {} a -> s {marker = a} :: DescribeDBSubnetGroups) -- | The maximum number of records to include in the response. If more -- records exist than the specified @MaxRecords@ value, a pagination token -- (marker) is included in the response so that the remaining results can -- be retrieved. -- -- Default: 100 -- -- Constraints: Minimum 20, maximum 100. describeDBSubnetGroups_maxRecords :: Lens.Lens' DescribeDBSubnetGroups (Prelude.Maybe Prelude.Int) describeDBSubnetGroups_maxRecords = Lens.lens (\DescribeDBSubnetGroups' {maxRecords} -> maxRecords) (\s@DescribeDBSubnetGroups' {} a -> s {maxRecords = a} :: DescribeDBSubnetGroups) instance Core.AWSPager DescribeDBSubnetGroups where page rq rs | Core.stop ( rs Lens.^? describeDBSubnetGroupsResponse_marker Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeDBSubnetGroupsResponse_dbSubnetGroups Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeDBSubnetGroups_marker Lens..~ rs Lens.^? describeDBSubnetGroupsResponse_marker Prelude.. Lens._Just instance Core.AWSRequest DescribeDBSubnetGroups where type AWSResponse DescribeDBSubnetGroups = DescribeDBSubnetGroupsResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "DescribeDBSubnetGroupsResult" ( \s h x -> DescribeDBSubnetGroupsResponse' Prelude.<$> ( x Data..@? "DBSubnetGroups" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "DBSubnetGroup") ) Prelude.<*> (x Data..@? "Marker") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeDBSubnetGroups where hashWithSalt _salt DescribeDBSubnetGroups' {..} = _salt `Prelude.hashWithSalt` dbSubnetGroupName `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` marker `Prelude.hashWithSalt` maxRecords instance Prelude.NFData DescribeDBSubnetGroups where rnf DescribeDBSubnetGroups' {..} = Prelude.rnf dbSubnetGroupName `Prelude.seq` Prelude.rnf filters `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf maxRecords instance Data.ToHeaders DescribeDBSubnetGroups where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DescribeDBSubnetGroups where toPath = Prelude.const "/" instance Data.ToQuery DescribeDBSubnetGroups where toQuery DescribeDBSubnetGroups' {..} = Prelude.mconcat [ "Action" Data.=: ("DescribeDBSubnetGroups" :: Prelude.ByteString), "Version" Data.=: ("2014-10-31" :: Prelude.ByteString), "DBSubnetGroupName" Data.=: dbSubnetGroupName, "Filters" Data.=: Data.toQuery (Data.toQueryList "Filter" Prelude.<$> filters), "Marker" Data.=: marker, "MaxRecords" Data.=: maxRecords ] -- | Represents the output of DescribeDBSubnetGroups. -- -- /See:/ 'newDescribeDBSubnetGroupsResponse' smart constructor. data DescribeDBSubnetGroupsResponse = DescribeDBSubnetGroupsResponse' { -- | Detailed information about one or more subnet groups. dbSubnetGroups :: Prelude.Maybe [DBSubnetGroup], -- | An optional pagination token provided by a previous 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 'DescribeDBSubnetGroupsResponse' 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: -- -- 'dbSubnetGroups', 'describeDBSubnetGroupsResponse_dbSubnetGroups' - Detailed information about one or more subnet groups. -- -- 'marker', 'describeDBSubnetGroupsResponse_marker' - An optional pagination token provided by a previous request. If this -- parameter is specified, the response includes only records beyond the -- marker, up to the value specified by @MaxRecords@. -- -- 'httpStatus', 'describeDBSubnetGroupsResponse_httpStatus' - The response's http status code. newDescribeDBSubnetGroupsResponse :: -- | 'httpStatus' Prelude.Int -> DescribeDBSubnetGroupsResponse newDescribeDBSubnetGroupsResponse pHttpStatus_ = DescribeDBSubnetGroupsResponse' { dbSubnetGroups = Prelude.Nothing, marker = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Detailed information about one or more subnet groups. describeDBSubnetGroupsResponse_dbSubnetGroups :: Lens.Lens' DescribeDBSubnetGroupsResponse (Prelude.Maybe [DBSubnetGroup]) describeDBSubnetGroupsResponse_dbSubnetGroups = Lens.lens (\DescribeDBSubnetGroupsResponse' {dbSubnetGroups} -> dbSubnetGroups) (\s@DescribeDBSubnetGroupsResponse' {} a -> s {dbSubnetGroups = a} :: DescribeDBSubnetGroupsResponse) Prelude.. Lens.mapping Lens.coerced -- | An optional pagination token provided by a previous request. If this -- parameter is specified, the response includes only records beyond the -- marker, up to the value specified by @MaxRecords@. describeDBSubnetGroupsResponse_marker :: Lens.Lens' DescribeDBSubnetGroupsResponse (Prelude.Maybe Prelude.Text) describeDBSubnetGroupsResponse_marker = Lens.lens (\DescribeDBSubnetGroupsResponse' {marker} -> marker) (\s@DescribeDBSubnetGroupsResponse' {} a -> s {marker = a} :: DescribeDBSubnetGroupsResponse) -- | The response's http status code. describeDBSubnetGroupsResponse_httpStatus :: Lens.Lens' DescribeDBSubnetGroupsResponse Prelude.Int describeDBSubnetGroupsResponse_httpStatus = Lens.lens (\DescribeDBSubnetGroupsResponse' {httpStatus} -> httpStatus) (\s@DescribeDBSubnetGroupsResponse' {} a -> s {httpStatus = a} :: DescribeDBSubnetGroupsResponse) instance Prelude.NFData DescribeDBSubnetGroupsResponse where rnf DescribeDBSubnetGroupsResponse' {..} = Prelude.rnf dbSubnetGroups `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf httpStatus