{-# 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.DescribeCertificates -- 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 certificate authority (CA) certificates provided by -- Amazon DocumentDB for this Amazon Web Services account. -- -- This operation returns paginated results. module Amazonka.DocumentDB.DescribeCertificates ( -- * Creating a Request DescribeCertificates (..), newDescribeCertificates, -- * Request Lenses describeCertificates_certificateIdentifier, describeCertificates_filters, describeCertificates_marker, describeCertificates_maxRecords, -- * Destructuring the Response DescribeCertificatesResponse (..), newDescribeCertificatesResponse, -- * Response Lenses describeCertificatesResponse_certificates, describeCertificatesResponse_marker, describeCertificatesResponse_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 -- | /See:/ 'newDescribeCertificates' smart constructor. data DescribeCertificates = DescribeCertificates' { -- | The user-supplied certificate identifier. If this parameter is -- specified, information for only the specified certificate is returned. -- If this parameter is omitted, a list of up to @MaxRecords@ certificates -- is returned. This parameter is not case sensitive. -- -- Constraints -- -- - Must match an existing @CertificateIdentifier@. certificateIdentifier :: Prelude.Maybe Prelude.Text, -- | This parameter is not currently supported. filters :: Prelude.Maybe [Filter], -- | An optional pagination token provided by a previous -- @DescribeCertificates@ 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 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 'DescribeCertificates' 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: -- -- 'certificateIdentifier', 'describeCertificates_certificateIdentifier' - The user-supplied certificate identifier. If this parameter is -- specified, information for only the specified certificate is returned. -- If this parameter is omitted, a list of up to @MaxRecords@ certificates -- is returned. This parameter is not case sensitive. -- -- Constraints -- -- - Must match an existing @CertificateIdentifier@. -- -- 'filters', 'describeCertificates_filters' - This parameter is not currently supported. -- -- 'marker', 'describeCertificates_marker' - An optional pagination token provided by a previous -- @DescribeCertificates@ request. If this parameter is specified, the -- response includes only records beyond the marker, up to the value -- specified by @MaxRecords@. -- -- 'maxRecords', 'describeCertificates_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 the remaining -- results can be retrieved. -- -- Default: 100 -- -- Constraints: -- -- - Minimum: 20 -- -- - Maximum: 100 newDescribeCertificates :: DescribeCertificates newDescribeCertificates = DescribeCertificates' { certificateIdentifier = Prelude.Nothing, filters = Prelude.Nothing, marker = Prelude.Nothing, maxRecords = Prelude.Nothing } -- | The user-supplied certificate identifier. If this parameter is -- specified, information for only the specified certificate is returned. -- If this parameter is omitted, a list of up to @MaxRecords@ certificates -- is returned. This parameter is not case sensitive. -- -- Constraints -- -- - Must match an existing @CertificateIdentifier@. describeCertificates_certificateIdentifier :: Lens.Lens' DescribeCertificates (Prelude.Maybe Prelude.Text) describeCertificates_certificateIdentifier = Lens.lens (\DescribeCertificates' {certificateIdentifier} -> certificateIdentifier) (\s@DescribeCertificates' {} a -> s {certificateIdentifier = a} :: DescribeCertificates) -- | This parameter is not currently supported. describeCertificates_filters :: Lens.Lens' DescribeCertificates (Prelude.Maybe [Filter]) describeCertificates_filters = Lens.lens (\DescribeCertificates' {filters} -> filters) (\s@DescribeCertificates' {} a -> s {filters = a} :: DescribeCertificates) Prelude.. Lens.mapping Lens.coerced -- | An optional pagination token provided by a previous -- @DescribeCertificates@ request. If this parameter is specified, the -- response includes only records beyond the marker, up to the value -- specified by @MaxRecords@. describeCertificates_marker :: Lens.Lens' DescribeCertificates (Prelude.Maybe Prelude.Text) describeCertificates_marker = Lens.lens (\DescribeCertificates' {marker} -> marker) (\s@DescribeCertificates' {} a -> s {marker = a} :: DescribeCertificates) -- | 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 the remaining -- results can be retrieved. -- -- Default: 100 -- -- Constraints: -- -- - Minimum: 20 -- -- - Maximum: 100 describeCertificates_maxRecords :: Lens.Lens' DescribeCertificates (Prelude.Maybe Prelude.Int) describeCertificates_maxRecords = Lens.lens (\DescribeCertificates' {maxRecords} -> maxRecords) (\s@DescribeCertificates' {} a -> s {maxRecords = a} :: DescribeCertificates) instance Core.AWSPager DescribeCertificates where page rq rs | Core.stop ( rs Lens.^? describeCertificatesResponse_marker Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeCertificatesResponse_certificates Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeCertificates_marker Lens..~ rs Lens.^? describeCertificatesResponse_marker Prelude.. Lens._Just instance Core.AWSRequest DescribeCertificates where type AWSResponse DescribeCertificates = DescribeCertificatesResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "DescribeCertificatesResult" ( \s h x -> DescribeCertificatesResponse' Prelude.<$> ( x Data..@? "Certificates" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "Certificate") ) Prelude.<*> (x Data..@? "Marker") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeCertificates where hashWithSalt _salt DescribeCertificates' {..} = _salt `Prelude.hashWithSalt` certificateIdentifier `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` marker `Prelude.hashWithSalt` maxRecords instance Prelude.NFData DescribeCertificates where rnf DescribeCertificates' {..} = Prelude.rnf certificateIdentifier `Prelude.seq` Prelude.rnf filters `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf maxRecords instance Data.ToHeaders DescribeCertificates where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath DescribeCertificates where toPath = Prelude.const "/" instance Data.ToQuery DescribeCertificates where toQuery DescribeCertificates' {..} = Prelude.mconcat [ "Action" Data.=: ("DescribeCertificates" :: Prelude.ByteString), "Version" Data.=: ("2014-10-31" :: Prelude.ByteString), "CertificateIdentifier" Data.=: certificateIdentifier, "Filters" Data.=: Data.toQuery (Data.toQueryList "Filter" Prelude.<$> filters), "Marker" Data.=: marker, "MaxRecords" Data.=: maxRecords ] -- | /See:/ 'newDescribeCertificatesResponse' smart constructor. data DescribeCertificatesResponse = DescribeCertificatesResponse' { -- | A list of certificates for this Amazon Web Services account. certificates :: Prelude.Maybe [Certificate], -- | An optional pagination token provided if the number of records retrieved -- is greater than @MaxRecords@. If this parameter is specified, the marker -- specifies the next record in the list. Including the value of @Marker@ -- in the next call to @DescribeCertificates@ results in the next page of -- certificates. 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 'DescribeCertificatesResponse' 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: -- -- 'certificates', 'describeCertificatesResponse_certificates' - A list of certificates for this Amazon Web Services account. -- -- 'marker', 'describeCertificatesResponse_marker' - An optional pagination token provided if the number of records retrieved -- is greater than @MaxRecords@. If this parameter is specified, the marker -- specifies the next record in the list. Including the value of @Marker@ -- in the next call to @DescribeCertificates@ results in the next page of -- certificates. -- -- 'httpStatus', 'describeCertificatesResponse_httpStatus' - The response's http status code. newDescribeCertificatesResponse :: -- | 'httpStatus' Prelude.Int -> DescribeCertificatesResponse newDescribeCertificatesResponse pHttpStatus_ = DescribeCertificatesResponse' { certificates = Prelude.Nothing, marker = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | A list of certificates for this Amazon Web Services account. describeCertificatesResponse_certificates :: Lens.Lens' DescribeCertificatesResponse (Prelude.Maybe [Certificate]) describeCertificatesResponse_certificates = Lens.lens (\DescribeCertificatesResponse' {certificates} -> certificates) (\s@DescribeCertificatesResponse' {} a -> s {certificates = a} :: DescribeCertificatesResponse) Prelude.. Lens.mapping Lens.coerced -- | An optional pagination token provided if the number of records retrieved -- is greater than @MaxRecords@. If this parameter is specified, the marker -- specifies the next record in the list. Including the value of @Marker@ -- in the next call to @DescribeCertificates@ results in the next page of -- certificates. describeCertificatesResponse_marker :: Lens.Lens' DescribeCertificatesResponse (Prelude.Maybe Prelude.Text) describeCertificatesResponse_marker = Lens.lens (\DescribeCertificatesResponse' {marker} -> marker) (\s@DescribeCertificatesResponse' {} a -> s {marker = a} :: DescribeCertificatesResponse) -- | The response's http status code. describeCertificatesResponse_httpStatus :: Lens.Lens' DescribeCertificatesResponse Prelude.Int describeCertificatesResponse_httpStatus = Lens.lens (\DescribeCertificatesResponse' {httpStatus} -> httpStatus) (\s@DescribeCertificatesResponse' {} a -> s {httpStatus = a} :: DescribeCertificatesResponse) instance Prelude.NFData DescribeCertificatesResponse where rnf DescribeCertificatesResponse' {..} = Prelude.rnf certificates `Prelude.seq` Prelude.rnf marker `Prelude.seq` Prelude.rnf httpStatus