{-# 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 #-}
module Amazonka.IoT.Types.Behavior 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.BehaviorCriteria
import Amazonka.IoT.Types.MetricDimension
import qualified Amazonka.Prelude as Prelude
data Behavior = Behavior'
{
Behavior -> Maybe BehaviorCriteria
criteria :: Prelude.Maybe BehaviorCriteria,
Behavior -> Maybe Text
metric :: Prelude.Maybe Prelude.Text,
Behavior -> Maybe MetricDimension
metricDimension :: Prelude.Maybe MetricDimension,
Behavior -> Maybe Bool
suppressAlerts :: Prelude.Maybe Prelude.Bool,
Behavior -> Text
name :: Prelude.Text
}
deriving (Behavior -> Behavior -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: Behavior -> Behavior -> Bool
$c/= :: Behavior -> Behavior -> Bool
== :: Behavior -> Behavior -> Bool
$c== :: Behavior -> Behavior -> Bool
Prelude.Eq, ReadPrec [Behavior]
ReadPrec Behavior
Int -> ReadS Behavior
ReadS [Behavior]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [Behavior]
$creadListPrec :: ReadPrec [Behavior]
readPrec :: ReadPrec Behavior
$creadPrec :: ReadPrec Behavior
readList :: ReadS [Behavior]
$creadList :: ReadS [Behavior]
readsPrec :: Int -> ReadS Behavior
$creadsPrec :: Int -> ReadS Behavior
Prelude.Read, Int -> Behavior -> ShowS
[Behavior] -> ShowS
Behavior -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [Behavior] -> ShowS
$cshowList :: [Behavior] -> ShowS
show :: Behavior -> String
$cshow :: Behavior -> String
showsPrec :: Int -> Behavior -> ShowS
$cshowsPrec :: Int -> Behavior -> ShowS
Prelude.Show, forall x. Rep Behavior x -> Behavior
forall x. Behavior -> Rep Behavior x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep Behavior x -> Behavior
$cfrom :: forall x. Behavior -> Rep Behavior x
Prelude.Generic)
newBehavior ::
Prelude.Text ->
Behavior
newBehavior :: Text -> Behavior
newBehavior Text
pName_ =
Behavior'
{ $sel:criteria:Behavior' :: Maybe BehaviorCriteria
criteria = forall a. Maybe a
Prelude.Nothing,
$sel:metric:Behavior' :: Maybe Text
metric = forall a. Maybe a
Prelude.Nothing,
$sel:metricDimension:Behavior' :: Maybe MetricDimension
metricDimension = forall a. Maybe a
Prelude.Nothing,
$sel:suppressAlerts:Behavior' :: Maybe Bool
suppressAlerts = forall a. Maybe a
Prelude.Nothing,
$sel:name:Behavior' :: Text
name = Text
pName_
}
behavior_criteria :: Lens.Lens' Behavior (Prelude.Maybe BehaviorCriteria)
behavior_criteria :: Lens' Behavior (Maybe BehaviorCriteria)
behavior_criteria = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\Behavior' {Maybe BehaviorCriteria
criteria :: Maybe BehaviorCriteria
$sel:criteria:Behavior' :: Behavior -> Maybe BehaviorCriteria
criteria} -> Maybe BehaviorCriteria
criteria) (\s :: Behavior
s@Behavior' {} Maybe BehaviorCriteria
a -> Behavior
s {$sel:criteria:Behavior' :: Maybe BehaviorCriteria
criteria = Maybe BehaviorCriteria
a} :: Behavior)
behavior_metric :: Lens.Lens' Behavior (Prelude.Maybe Prelude.Text)
behavior_metric :: Lens' Behavior (Maybe Text)
behavior_metric = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\Behavior' {Maybe Text
metric :: Maybe Text
$sel:metric:Behavior' :: Behavior -> Maybe Text
metric} -> Maybe Text
metric) (\s :: Behavior
s@Behavior' {} Maybe Text
a -> Behavior
s {$sel:metric:Behavior' :: Maybe Text
metric = Maybe Text
a} :: Behavior)
behavior_metricDimension :: Lens.Lens' Behavior (Prelude.Maybe MetricDimension)
behavior_metricDimension :: Lens' Behavior (Maybe MetricDimension)
behavior_metricDimension = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\Behavior' {Maybe MetricDimension
metricDimension :: Maybe MetricDimension
$sel:metricDimension:Behavior' :: Behavior -> Maybe MetricDimension
metricDimension} -> Maybe MetricDimension
metricDimension) (\s :: Behavior
s@Behavior' {} Maybe MetricDimension
a -> Behavior
s {$sel:metricDimension:Behavior' :: Maybe MetricDimension
metricDimension = Maybe MetricDimension
a} :: Behavior)
behavior_suppressAlerts :: Lens.Lens' Behavior (Prelude.Maybe Prelude.Bool)
behavior_suppressAlerts :: Lens' Behavior (Maybe Bool)
behavior_suppressAlerts = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\Behavior' {Maybe Bool
suppressAlerts :: Maybe Bool
$sel:suppressAlerts:Behavior' :: Behavior -> Maybe Bool
suppressAlerts} -> Maybe Bool
suppressAlerts) (\s :: Behavior
s@Behavior' {} Maybe Bool
a -> Behavior
s {$sel:suppressAlerts:Behavior' :: Maybe Bool
suppressAlerts = Maybe Bool
a} :: Behavior)
behavior_name :: Lens.Lens' Behavior Prelude.Text
behavior_name :: Lens' Behavior Text
behavior_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\Behavior' {Text
name :: Text
$sel:name:Behavior' :: Behavior -> Text
name} -> Text
name) (\s :: Behavior
s@Behavior' {} Text
a -> Behavior
s {$sel:name:Behavior' :: Text
name = Text
a} :: Behavior)
instance Data.FromJSON Behavior where
parseJSON :: Value -> Parser Behavior
parseJSON =
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
String
"Behavior"
( \Object
x ->
Maybe BehaviorCriteria
-> Maybe Text
-> Maybe MetricDimension
-> Maybe Bool
-> Text
-> Behavior
Behavior'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"criteria")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"metric")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"metricDimension")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
Data..:? Key
"suppressAlerts")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser a
Data..: Key
"name")
)
instance Prelude.Hashable Behavior where
hashWithSalt :: Int -> Behavior -> Int
hashWithSalt Int
_salt Behavior' {Maybe Bool
Maybe Text
Maybe MetricDimension
Maybe BehaviorCriteria
Text
name :: Text
suppressAlerts :: Maybe Bool
metricDimension :: Maybe MetricDimension
metric :: Maybe Text
criteria :: Maybe BehaviorCriteria
$sel:name:Behavior' :: Behavior -> Text
$sel:suppressAlerts:Behavior' :: Behavior -> Maybe Bool
$sel:metricDimension:Behavior' :: Behavior -> Maybe MetricDimension
$sel:metric:Behavior' :: Behavior -> Maybe Text
$sel:criteria:Behavior' :: Behavior -> Maybe BehaviorCriteria
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe BehaviorCriteria
criteria
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
metric
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe MetricDimension
metricDimension
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
suppressAlerts
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
name
instance Prelude.NFData Behavior where
rnf :: Behavior -> ()
rnf Behavior' {Maybe Bool
Maybe Text
Maybe MetricDimension
Maybe BehaviorCriteria
Text
name :: Text
suppressAlerts :: Maybe Bool
metricDimension :: Maybe MetricDimension
metric :: Maybe Text
criteria :: Maybe BehaviorCriteria
$sel:name:Behavior' :: Behavior -> Text
$sel:suppressAlerts:Behavior' :: Behavior -> Maybe Bool
$sel:metricDimension:Behavior' :: Behavior -> Maybe MetricDimension
$sel:metric:Behavior' :: Behavior -> Maybe Text
$sel:criteria:Behavior' :: Behavior -> Maybe BehaviorCriteria
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe BehaviorCriteria
criteria
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
metric
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe MetricDimension
metricDimension
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
suppressAlerts
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
name
instance Data.ToJSON Behavior where
toJSON :: Behavior -> Value
toJSON Behavior' {Maybe Bool
Maybe Text
Maybe MetricDimension
Maybe BehaviorCriteria
Text
name :: Text
suppressAlerts :: Maybe Bool
metricDimension :: Maybe MetricDimension
metric :: Maybe Text
criteria :: Maybe BehaviorCriteria
$sel:name:Behavior' :: Behavior -> Text
$sel:suppressAlerts:Behavior' :: Behavior -> Maybe Bool
$sel:metricDimension:Behavior' :: Behavior -> Maybe MetricDimension
$sel:metric:Behavior' :: Behavior -> Maybe Text
$sel:criteria:Behavior' :: Behavior -> Maybe BehaviorCriteria
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"criteria" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe BehaviorCriteria
criteria,
(Key
"metric" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
metric,
(Key
"metricDimension" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe MetricDimension
metricDimension,
(Key
"suppressAlerts" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Bool
suppressAlerts,
forall a. a -> Maybe a
Prelude.Just (Key
"name" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
name)
]
)