{-# 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.SSM.DescribeParameters -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Get information about a parameter. -- -- Request results are returned on a best-effort basis. If you specify -- @MaxResults@ in the request, the response includes information up to the -- limit specified. The number of items returned, however, can be between -- zero and the value of @MaxResults@. If the service reaches an internal -- limit while processing the results, it stops the operation and returns -- the matching values up to that point and a @NextToken@. You can specify -- the @NextToken@ in a subsequent call to get the next set of results. -- -- If you change the KMS key alias for the KMS key used to encrypt a -- parameter, then you must also update the key alias the parameter uses to -- reference KMS. Otherwise, @DescribeParameters@ retrieves whatever the -- original key alias was referencing. -- -- This operation returns paginated results. module Amazonka.SSM.DescribeParameters ( -- * Creating a Request DescribeParameters (..), newDescribeParameters, -- * Request Lenses describeParameters_filters, describeParameters_maxResults, describeParameters_nextToken, describeParameters_parameterFilters, -- * Destructuring the Response DescribeParametersResponse (..), newDescribeParametersResponse, -- * Response Lenses describeParametersResponse_nextToken, describeParametersResponse_parameters, describeParametersResponse_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 qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.SSM.Types -- | /See:/ 'newDescribeParameters' smart constructor. data DescribeParameters = DescribeParameters' { -- | This data type is deprecated. Instead, use @ParameterFilters@. filters :: Prelude.Maybe [ParametersFilter], -- | The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. maxResults :: Prelude.Maybe Prelude.Natural, -- | The token for the next set of items to return. (You received this token -- from a previous call.) nextToken :: Prelude.Maybe Prelude.Text, -- | Filters to limit the request results. parameterFilters :: Prelude.Maybe [ParameterStringFilter] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeParameters' 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', 'describeParameters_filters' - This data type is deprecated. Instead, use @ParameterFilters@. -- -- 'maxResults', 'describeParameters_maxResults' - The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. -- -- 'nextToken', 'describeParameters_nextToken' - The token for the next set of items to return. (You received this token -- from a previous call.) -- -- 'parameterFilters', 'describeParameters_parameterFilters' - Filters to limit the request results. newDescribeParameters :: DescribeParameters newDescribeParameters = DescribeParameters' { filters = Prelude.Nothing, maxResults = Prelude.Nothing, nextToken = Prelude.Nothing, parameterFilters = Prelude.Nothing } -- | This data type is deprecated. Instead, use @ParameterFilters@. describeParameters_filters :: Lens.Lens' DescribeParameters (Prelude.Maybe [ParametersFilter]) describeParameters_filters = Lens.lens (\DescribeParameters' {filters} -> filters) (\s@DescribeParameters' {} a -> s {filters = a} :: DescribeParameters) Prelude.. Lens.mapping Lens.coerced -- | The maximum number of items to return for this call. The call also -- returns a token that you can specify in a subsequent call to get the -- next set of results. describeParameters_maxResults :: Lens.Lens' DescribeParameters (Prelude.Maybe Prelude.Natural) describeParameters_maxResults = Lens.lens (\DescribeParameters' {maxResults} -> maxResults) (\s@DescribeParameters' {} a -> s {maxResults = a} :: DescribeParameters) -- | The token for the next set of items to return. (You received this token -- from a previous call.) describeParameters_nextToken :: Lens.Lens' DescribeParameters (Prelude.Maybe Prelude.Text) describeParameters_nextToken = Lens.lens (\DescribeParameters' {nextToken} -> nextToken) (\s@DescribeParameters' {} a -> s {nextToken = a} :: DescribeParameters) -- | Filters to limit the request results. describeParameters_parameterFilters :: Lens.Lens' DescribeParameters (Prelude.Maybe [ParameterStringFilter]) describeParameters_parameterFilters = Lens.lens (\DescribeParameters' {parameterFilters} -> parameterFilters) (\s@DescribeParameters' {} a -> s {parameterFilters = a} :: DescribeParameters) Prelude.. Lens.mapping Lens.coerced instance Core.AWSPager DescribeParameters where page rq rs | Core.stop ( rs Lens.^? describeParametersResponse_nextToken Prelude.. Lens._Just ) = Prelude.Nothing | Core.stop ( rs Lens.^? describeParametersResponse_parameters Prelude.. Lens._Just ) = Prelude.Nothing | Prelude.otherwise = Prelude.Just Prelude.$ rq Prelude.& describeParameters_nextToken Lens..~ rs Lens.^? describeParametersResponse_nextToken Prelude.. Lens._Just instance Core.AWSRequest DescribeParameters where type AWSResponse DescribeParameters = DescribeParametersResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeParametersResponse' Prelude.<$> (x Data..?> "NextToken") Prelude.<*> (x Data..?> "Parameters" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeParameters where hashWithSalt _salt DescribeParameters' {..} = _salt `Prelude.hashWithSalt` filters `Prelude.hashWithSalt` maxResults `Prelude.hashWithSalt` nextToken `Prelude.hashWithSalt` parameterFilters instance Prelude.NFData DescribeParameters where rnf DescribeParameters' {..} = Prelude.rnf filters `Prelude.seq` Prelude.rnf maxResults `Prelude.seq` Prelude.rnf nextToken `Prelude.seq` Prelude.rnf parameterFilters instance Data.ToHeaders DescribeParameters where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AmazonSSM.DescribeParameters" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DescribeParameters where toJSON DescribeParameters' {..} = Data.object ( Prelude.catMaybes [ ("Filters" Data..=) Prelude.<$> filters, ("MaxResults" Data..=) Prelude.<$> maxResults, ("NextToken" Data..=) Prelude.<$> nextToken, ("ParameterFilters" Data..=) Prelude.<$> parameterFilters ] ) instance Data.ToPath DescribeParameters where toPath = Prelude.const "/" instance Data.ToQuery DescribeParameters where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeParametersResponse' smart constructor. data DescribeParametersResponse = DescribeParametersResponse' { -- | The token to use when requesting the next set of items. nextToken :: Prelude.Maybe Prelude.Text, -- | Parameters returned by the request. parameters :: Prelude.Maybe [ParameterMetadata], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeParametersResponse' 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: -- -- 'nextToken', 'describeParametersResponse_nextToken' - The token to use when requesting the next set of items. -- -- 'parameters', 'describeParametersResponse_parameters' - Parameters returned by the request. -- -- 'httpStatus', 'describeParametersResponse_httpStatus' - The response's http status code. newDescribeParametersResponse :: -- | 'httpStatus' Prelude.Int -> DescribeParametersResponse newDescribeParametersResponse pHttpStatus_ = DescribeParametersResponse' { nextToken = Prelude.Nothing, parameters = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The token to use when requesting the next set of items. describeParametersResponse_nextToken :: Lens.Lens' DescribeParametersResponse (Prelude.Maybe Prelude.Text) describeParametersResponse_nextToken = Lens.lens (\DescribeParametersResponse' {nextToken} -> nextToken) (\s@DescribeParametersResponse' {} a -> s {nextToken = a} :: DescribeParametersResponse) -- | Parameters returned by the request. describeParametersResponse_parameters :: Lens.Lens' DescribeParametersResponse (Prelude.Maybe [ParameterMetadata]) describeParametersResponse_parameters = Lens.lens (\DescribeParametersResponse' {parameters} -> parameters) (\s@DescribeParametersResponse' {} a -> s {parameters = a} :: DescribeParametersResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. describeParametersResponse_httpStatus :: Lens.Lens' DescribeParametersResponse Prelude.Int describeParametersResponse_httpStatus = Lens.lens (\DescribeParametersResponse' {httpStatus} -> httpStatus) (\s@DescribeParametersResponse' {} a -> s {httpStatus = a} :: DescribeParametersResponse) instance Prelude.NFData DescribeParametersResponse where rnf DescribeParametersResponse' {..} = Prelude.rnf nextToken `Prelude.seq` Prelude.rnf parameters `Prelude.seq` Prelude.rnf httpStatus