{-# 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.Batch.Types.EvaluateOnExit where
import Amazonka.Batch.Types.RetryAction
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
data EvaluateOnExit = EvaluateOnExit'
{
EvaluateOnExit -> Maybe Text
onExitCode :: Prelude.Maybe Prelude.Text,
EvaluateOnExit -> Maybe Text
onReason :: Prelude.Maybe Prelude.Text,
EvaluateOnExit -> Maybe Text
onStatusReason :: Prelude.Maybe Prelude.Text,
EvaluateOnExit -> RetryAction
action :: RetryAction
}
deriving (EvaluateOnExit -> EvaluateOnExit -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: EvaluateOnExit -> EvaluateOnExit -> Bool
$c/= :: EvaluateOnExit -> EvaluateOnExit -> Bool
== :: EvaluateOnExit -> EvaluateOnExit -> Bool
$c== :: EvaluateOnExit -> EvaluateOnExit -> Bool
Prelude.Eq, ReadPrec [EvaluateOnExit]
ReadPrec EvaluateOnExit
Int -> ReadS EvaluateOnExit
ReadS [EvaluateOnExit]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [EvaluateOnExit]
$creadListPrec :: ReadPrec [EvaluateOnExit]
readPrec :: ReadPrec EvaluateOnExit
$creadPrec :: ReadPrec EvaluateOnExit
readList :: ReadS [EvaluateOnExit]
$creadList :: ReadS [EvaluateOnExit]
readsPrec :: Int -> ReadS EvaluateOnExit
$creadsPrec :: Int -> ReadS EvaluateOnExit
Prelude.Read, Int -> EvaluateOnExit -> ShowS
[EvaluateOnExit] -> ShowS
EvaluateOnExit -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [EvaluateOnExit] -> ShowS
$cshowList :: [EvaluateOnExit] -> ShowS
show :: EvaluateOnExit -> String
$cshow :: EvaluateOnExit -> String
showsPrec :: Int -> EvaluateOnExit -> ShowS
$cshowsPrec :: Int -> EvaluateOnExit -> ShowS
Prelude.Show, forall x. Rep EvaluateOnExit x -> EvaluateOnExit
forall x. EvaluateOnExit -> Rep EvaluateOnExit x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep EvaluateOnExit x -> EvaluateOnExit
$cfrom :: forall x. EvaluateOnExit -> Rep EvaluateOnExit x
Prelude.Generic)
newEvaluateOnExit ::
RetryAction ->
EvaluateOnExit
newEvaluateOnExit :: RetryAction -> EvaluateOnExit
newEvaluateOnExit RetryAction
pAction_ =
EvaluateOnExit'
{ $sel:onExitCode:EvaluateOnExit' :: Maybe Text
onExitCode = forall a. Maybe a
Prelude.Nothing,
$sel:onReason:EvaluateOnExit' :: Maybe Text
onReason = forall a. Maybe a
Prelude.Nothing,
$sel:onStatusReason:EvaluateOnExit' :: Maybe Text
onStatusReason = forall a. Maybe a
Prelude.Nothing,
$sel:action:EvaluateOnExit' :: RetryAction
action = RetryAction
pAction_
}
evaluateOnExit_onExitCode :: Lens.Lens' EvaluateOnExit (Prelude.Maybe Prelude.Text)
evaluateOnExit_onExitCode :: Lens' EvaluateOnExit (Maybe Text)
evaluateOnExit_onExitCode = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EvaluateOnExit' {Maybe Text
onExitCode :: Maybe Text
$sel:onExitCode:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
onExitCode} -> Maybe Text
onExitCode) (\s :: EvaluateOnExit
s@EvaluateOnExit' {} Maybe Text
a -> EvaluateOnExit
s {$sel:onExitCode:EvaluateOnExit' :: Maybe Text
onExitCode = Maybe Text
a} :: EvaluateOnExit)
evaluateOnExit_onReason :: Lens.Lens' EvaluateOnExit (Prelude.Maybe Prelude.Text)
evaluateOnExit_onReason :: Lens' EvaluateOnExit (Maybe Text)
evaluateOnExit_onReason = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EvaluateOnExit' {Maybe Text
onReason :: Maybe Text
$sel:onReason:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
onReason} -> Maybe Text
onReason) (\s :: EvaluateOnExit
s@EvaluateOnExit' {} Maybe Text
a -> EvaluateOnExit
s {$sel:onReason:EvaluateOnExit' :: Maybe Text
onReason = Maybe Text
a} :: EvaluateOnExit)
evaluateOnExit_onStatusReason :: Lens.Lens' EvaluateOnExit (Prelude.Maybe Prelude.Text)
evaluateOnExit_onStatusReason :: Lens' EvaluateOnExit (Maybe Text)
evaluateOnExit_onStatusReason = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EvaluateOnExit' {Maybe Text
onStatusReason :: Maybe Text
$sel:onStatusReason:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
onStatusReason} -> Maybe Text
onStatusReason) (\s :: EvaluateOnExit
s@EvaluateOnExit' {} Maybe Text
a -> EvaluateOnExit
s {$sel:onStatusReason:EvaluateOnExit' :: Maybe Text
onStatusReason = Maybe Text
a} :: EvaluateOnExit)
evaluateOnExit_action :: Lens.Lens' EvaluateOnExit RetryAction
evaluateOnExit_action :: Lens' EvaluateOnExit RetryAction
evaluateOnExit_action = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EvaluateOnExit' {RetryAction
action :: RetryAction
$sel:action:EvaluateOnExit' :: EvaluateOnExit -> RetryAction
action} -> RetryAction
action) (\s :: EvaluateOnExit
s@EvaluateOnExit' {} RetryAction
a -> EvaluateOnExit
s {$sel:action:EvaluateOnExit' :: RetryAction
action = RetryAction
a} :: EvaluateOnExit)
instance Data.FromJSON EvaluateOnExit where
parseJSON :: Value -> Parser EvaluateOnExit
parseJSON =
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
String
"EvaluateOnExit"
( \Object
x ->
Maybe Text
-> Maybe Text -> Maybe Text -> RetryAction -> EvaluateOnExit
EvaluateOnExit'
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
"onExitCode")
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
"onReason")
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
"onStatusReason")
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
"action")
)
instance Prelude.Hashable EvaluateOnExit where
hashWithSalt :: Int -> EvaluateOnExit -> Int
hashWithSalt Int
_salt EvaluateOnExit' {Maybe Text
RetryAction
action :: RetryAction
onStatusReason :: Maybe Text
onReason :: Maybe Text
onExitCode :: Maybe Text
$sel:action:EvaluateOnExit' :: EvaluateOnExit -> RetryAction
$sel:onStatusReason:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
$sel:onReason:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
$sel:onExitCode:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
onExitCode
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
onReason
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
onStatusReason
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` RetryAction
action
instance Prelude.NFData EvaluateOnExit where
rnf :: EvaluateOnExit -> ()
rnf EvaluateOnExit' {Maybe Text
RetryAction
action :: RetryAction
onStatusReason :: Maybe Text
onReason :: Maybe Text
onExitCode :: Maybe Text
$sel:action:EvaluateOnExit' :: EvaluateOnExit -> RetryAction
$sel:onStatusReason:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
$sel:onReason:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
$sel:onExitCode:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
onExitCode
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
onReason
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
onStatusReason
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf RetryAction
action
instance Data.ToJSON EvaluateOnExit where
toJSON :: EvaluateOnExit -> Value
toJSON EvaluateOnExit' {Maybe Text
RetryAction
action :: RetryAction
onStatusReason :: Maybe Text
onReason :: Maybe Text
onExitCode :: Maybe Text
$sel:action:EvaluateOnExit' :: EvaluateOnExit -> RetryAction
$sel:onStatusReason:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
$sel:onReason:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
$sel:onExitCode:EvaluateOnExit' :: EvaluateOnExit -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"onExitCode" 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
onExitCode,
(Key
"onReason" 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
onReason,
(Key
"onStatusReason" 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
onStatusReason,
forall a. a -> Maybe a
Prelude.Just (Key
"action" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= RetryAction
action)
]
)