{-# 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.IoT.GetPercentiles -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Groups the aggregated values that match the query into percentile -- groupings. The default percentile groupings are: 1,5,25,50,75,95,99, -- although you can specify your own when you call @GetPercentiles@. This -- function returns a value for each percentile group specified (or the -- default percentile groupings). The percentile group \"1\" contains the -- aggregated field value that occurs in approximately one percent of the -- values that match the query. The percentile group \"5\" contains the -- aggregated field value that occurs in approximately five percent of the -- values that match the query, and so on. The result is an approximation, -- the more values that match the query, the more accurate the percentile -- values. -- -- Requires permission to access the -- -- action. module Amazonka.IoT.GetPercentiles ( -- * Creating a Request GetPercentiles (..), newGetPercentiles, -- * Request Lenses getPercentiles_aggregationField, getPercentiles_indexName, getPercentiles_percents, getPercentiles_queryVersion, getPercentiles_queryString, -- * Destructuring the Response GetPercentilesResponse (..), newGetPercentilesResponse, -- * Response Lenses getPercentilesResponse_percentiles, getPercentilesResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IoT.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newGetPercentiles' smart constructor. data GetPercentiles = GetPercentiles' { -- | The field to aggregate. aggregationField :: Prelude.Maybe Prelude.Text, -- | The name of the index to search. indexName :: Prelude.Maybe Prelude.Text, -- | The percentile groups returned. percents :: Prelude.Maybe [Prelude.Double], -- | The query version. queryVersion :: Prelude.Maybe Prelude.Text, -- | The search query string. queryString :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetPercentiles' 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: -- -- 'aggregationField', 'getPercentiles_aggregationField' - The field to aggregate. -- -- 'indexName', 'getPercentiles_indexName' - The name of the index to search. -- -- 'percents', 'getPercentiles_percents' - The percentile groups returned. -- -- 'queryVersion', 'getPercentiles_queryVersion' - The query version. -- -- 'queryString', 'getPercentiles_queryString' - The search query string. newGetPercentiles :: -- | 'queryString' Prelude.Text -> GetPercentiles newGetPercentiles pQueryString_ = GetPercentiles' { aggregationField = Prelude.Nothing, indexName = Prelude.Nothing, percents = Prelude.Nothing, queryVersion = Prelude.Nothing, queryString = pQueryString_ } -- | The field to aggregate. getPercentiles_aggregationField :: Lens.Lens' GetPercentiles (Prelude.Maybe Prelude.Text) getPercentiles_aggregationField = Lens.lens (\GetPercentiles' {aggregationField} -> aggregationField) (\s@GetPercentiles' {} a -> s {aggregationField = a} :: GetPercentiles) -- | The name of the index to search. getPercentiles_indexName :: Lens.Lens' GetPercentiles (Prelude.Maybe Prelude.Text) getPercentiles_indexName = Lens.lens (\GetPercentiles' {indexName} -> indexName) (\s@GetPercentiles' {} a -> s {indexName = a} :: GetPercentiles) -- | The percentile groups returned. getPercentiles_percents :: Lens.Lens' GetPercentiles (Prelude.Maybe [Prelude.Double]) getPercentiles_percents = Lens.lens (\GetPercentiles' {percents} -> percents) (\s@GetPercentiles' {} a -> s {percents = a} :: GetPercentiles) Prelude.. Lens.mapping Lens.coerced -- | The query version. getPercentiles_queryVersion :: Lens.Lens' GetPercentiles (Prelude.Maybe Prelude.Text) getPercentiles_queryVersion = Lens.lens (\GetPercentiles' {queryVersion} -> queryVersion) (\s@GetPercentiles' {} a -> s {queryVersion = a} :: GetPercentiles) -- | The search query string. getPercentiles_queryString :: Lens.Lens' GetPercentiles Prelude.Text getPercentiles_queryString = Lens.lens (\GetPercentiles' {queryString} -> queryString) (\s@GetPercentiles' {} a -> s {queryString = a} :: GetPercentiles) instance Core.AWSRequest GetPercentiles where type AWSResponse GetPercentiles = GetPercentilesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> GetPercentilesResponse' Prelude.<$> (x Data..?> "percentiles" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable GetPercentiles where hashWithSalt _salt GetPercentiles' {..} = _salt `Prelude.hashWithSalt` aggregationField `Prelude.hashWithSalt` indexName `Prelude.hashWithSalt` percents `Prelude.hashWithSalt` queryVersion `Prelude.hashWithSalt` queryString instance Prelude.NFData GetPercentiles where rnf GetPercentiles' {..} = Prelude.rnf aggregationField `Prelude.seq` Prelude.rnf indexName `Prelude.seq` Prelude.rnf percents `Prelude.seq` Prelude.rnf queryVersion `Prelude.seq` Prelude.rnf queryString instance Data.ToHeaders GetPercentiles where toHeaders = Prelude.const Prelude.mempty instance Data.ToJSON GetPercentiles where toJSON GetPercentiles' {..} = Data.object ( Prelude.catMaybes [ ("aggregationField" Data..=) Prelude.<$> aggregationField, ("indexName" Data..=) Prelude.<$> indexName, ("percents" Data..=) Prelude.<$> percents, ("queryVersion" Data..=) Prelude.<$> queryVersion, Prelude.Just ("queryString" Data..= queryString) ] ) instance Data.ToPath GetPercentiles where toPath = Prelude.const "/indices/percentiles" instance Data.ToQuery GetPercentiles where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newGetPercentilesResponse' smart constructor. data GetPercentilesResponse = GetPercentilesResponse' { -- | The percentile values of the aggregated fields. percentiles :: Prelude.Maybe [PercentPair], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'GetPercentilesResponse' 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: -- -- 'percentiles', 'getPercentilesResponse_percentiles' - The percentile values of the aggregated fields. -- -- 'httpStatus', 'getPercentilesResponse_httpStatus' - The response's http status code. newGetPercentilesResponse :: -- | 'httpStatus' Prelude.Int -> GetPercentilesResponse newGetPercentilesResponse pHttpStatus_ = GetPercentilesResponse' { percentiles = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The percentile values of the aggregated fields. getPercentilesResponse_percentiles :: Lens.Lens' GetPercentilesResponse (Prelude.Maybe [PercentPair]) getPercentilesResponse_percentiles = Lens.lens (\GetPercentilesResponse' {percentiles} -> percentiles) (\s@GetPercentilesResponse' {} a -> s {percentiles = a} :: GetPercentilesResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. getPercentilesResponse_httpStatus :: Lens.Lens' GetPercentilesResponse Prelude.Int getPercentilesResponse_httpStatus = Lens.lens (\GetPercentilesResponse' {httpStatus} -> httpStatus) (\s@GetPercentilesResponse' {} a -> s {httpStatus = a} :: GetPercentilesResponse) instance Prelude.NFData GetPercentilesResponse where rnf GetPercentilesResponse' {..} = Prelude.rnf percentiles `Prelude.seq` Prelude.rnf httpStatus