{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# 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.Types.AggregationType -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.IoT.Types.AggregationType 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.AggregationTypeName import qualified Amazonka.Prelude as Prelude -- | The type of aggregation queries. -- -- /See:/ 'newAggregationType' smart constructor. data AggregationType = AggregationType' { -- | A list of the values of aggregation types. values :: Prelude.Maybe [Prelude.Text], -- | The name of the aggregation type. name :: AggregationTypeName } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AggregationType' 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: -- -- 'values', 'aggregationType_values' - A list of the values of aggregation types. -- -- 'name', 'aggregationType_name' - The name of the aggregation type. newAggregationType :: -- | 'name' AggregationTypeName -> AggregationType newAggregationType pName_ = AggregationType' { values = Prelude.Nothing, name = pName_ } -- | A list of the values of aggregation types. aggregationType_values :: Lens.Lens' AggregationType (Prelude.Maybe [Prelude.Text]) aggregationType_values = Lens.lens (\AggregationType' {values} -> values) (\s@AggregationType' {} a -> s {values = a} :: AggregationType) Prelude.. Lens.mapping Lens.coerced -- | The name of the aggregation type. aggregationType_name :: Lens.Lens' AggregationType AggregationTypeName aggregationType_name = Lens.lens (\AggregationType' {name} -> name) (\s@AggregationType' {} a -> s {name = a} :: AggregationType) instance Data.FromJSON AggregationType where parseJSON = Data.withObject "AggregationType" ( \x -> AggregationType' Prelude.<$> (x Data..:? "values" Data..!= Prelude.mempty) Prelude.<*> (x Data..: "name") ) instance Prelude.Hashable AggregationType where hashWithSalt _salt AggregationType' {..} = _salt `Prelude.hashWithSalt` values `Prelude.hashWithSalt` name instance Prelude.NFData AggregationType where rnf AggregationType' {..} = Prelude.rnf values `Prelude.seq` Prelude.rnf name instance Data.ToJSON AggregationType where toJSON AggregationType' {..} = Data.object ( Prelude.catMaybes [ ("values" Data..=) Prelude.<$> values, Prelude.Just ("name" Data..= name) ] )