{-# 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.EC2.Types.InstanceStatusEvent where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EC2.Internal
import Amazonka.EC2.Types.EventCode
import qualified Amazonka.Prelude as Prelude
data InstanceStatusEvent = InstanceStatusEvent'
{
InstanceStatusEvent -> Maybe EventCode
code :: Prelude.Maybe EventCode,
InstanceStatusEvent -> Maybe Text
description :: Prelude.Maybe Prelude.Text,
InstanceStatusEvent -> Maybe Text
instanceEventId :: Prelude.Maybe Prelude.Text,
InstanceStatusEvent -> Maybe ISO8601
notAfter :: Prelude.Maybe Data.ISO8601,
InstanceStatusEvent -> Maybe ISO8601
notBefore :: Prelude.Maybe Data.ISO8601,
InstanceStatusEvent -> Maybe ISO8601
notBeforeDeadline :: Prelude.Maybe Data.ISO8601
}
deriving (InstanceStatusEvent -> InstanceStatusEvent -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: InstanceStatusEvent -> InstanceStatusEvent -> Bool
$c/= :: InstanceStatusEvent -> InstanceStatusEvent -> Bool
== :: InstanceStatusEvent -> InstanceStatusEvent -> Bool
$c== :: InstanceStatusEvent -> InstanceStatusEvent -> Bool
Prelude.Eq, ReadPrec [InstanceStatusEvent]
ReadPrec InstanceStatusEvent
Int -> ReadS InstanceStatusEvent
ReadS [InstanceStatusEvent]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [InstanceStatusEvent]
$creadListPrec :: ReadPrec [InstanceStatusEvent]
readPrec :: ReadPrec InstanceStatusEvent
$creadPrec :: ReadPrec InstanceStatusEvent
readList :: ReadS [InstanceStatusEvent]
$creadList :: ReadS [InstanceStatusEvent]
readsPrec :: Int -> ReadS InstanceStatusEvent
$creadsPrec :: Int -> ReadS InstanceStatusEvent
Prelude.Read, Int -> InstanceStatusEvent -> ShowS
[InstanceStatusEvent] -> ShowS
InstanceStatusEvent -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [InstanceStatusEvent] -> ShowS
$cshowList :: [InstanceStatusEvent] -> ShowS
show :: InstanceStatusEvent -> String
$cshow :: InstanceStatusEvent -> String
showsPrec :: Int -> InstanceStatusEvent -> ShowS
$cshowsPrec :: Int -> InstanceStatusEvent -> ShowS
Prelude.Show, forall x. Rep InstanceStatusEvent x -> InstanceStatusEvent
forall x. InstanceStatusEvent -> Rep InstanceStatusEvent x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep InstanceStatusEvent x -> InstanceStatusEvent
$cfrom :: forall x. InstanceStatusEvent -> Rep InstanceStatusEvent x
Prelude.Generic)
newInstanceStatusEvent ::
InstanceStatusEvent
newInstanceStatusEvent :: InstanceStatusEvent
newInstanceStatusEvent =
InstanceStatusEvent'
{ $sel:code:InstanceStatusEvent' :: Maybe EventCode
code = forall a. Maybe a
Prelude.Nothing,
$sel:description:InstanceStatusEvent' :: Maybe Text
description = forall a. Maybe a
Prelude.Nothing,
$sel:instanceEventId:InstanceStatusEvent' :: Maybe Text
instanceEventId = forall a. Maybe a
Prelude.Nothing,
$sel:notAfter:InstanceStatusEvent' :: Maybe ISO8601
notAfter = forall a. Maybe a
Prelude.Nothing,
$sel:notBefore:InstanceStatusEvent' :: Maybe ISO8601
notBefore = forall a. Maybe a
Prelude.Nothing,
$sel:notBeforeDeadline:InstanceStatusEvent' :: Maybe ISO8601
notBeforeDeadline = forall a. Maybe a
Prelude.Nothing
}
instanceStatusEvent_code :: Lens.Lens' InstanceStatusEvent (Prelude.Maybe EventCode)
instanceStatusEvent_code :: Lens' InstanceStatusEvent (Maybe EventCode)
instanceStatusEvent_code = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\InstanceStatusEvent' {Maybe EventCode
code :: Maybe EventCode
$sel:code:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe EventCode
code} -> Maybe EventCode
code) (\s :: InstanceStatusEvent
s@InstanceStatusEvent' {} Maybe EventCode
a -> InstanceStatusEvent
s {$sel:code:InstanceStatusEvent' :: Maybe EventCode
code = Maybe EventCode
a} :: InstanceStatusEvent)
instanceStatusEvent_description :: Lens.Lens' InstanceStatusEvent (Prelude.Maybe Prelude.Text)
instanceStatusEvent_description :: Lens' InstanceStatusEvent (Maybe Text)
instanceStatusEvent_description = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\InstanceStatusEvent' {Maybe Text
description :: Maybe Text
$sel:description:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe Text
description} -> Maybe Text
description) (\s :: InstanceStatusEvent
s@InstanceStatusEvent' {} Maybe Text
a -> InstanceStatusEvent
s {$sel:description:InstanceStatusEvent' :: Maybe Text
description = Maybe Text
a} :: InstanceStatusEvent)
instanceStatusEvent_instanceEventId :: Lens.Lens' InstanceStatusEvent (Prelude.Maybe Prelude.Text)
instanceStatusEvent_instanceEventId :: Lens' InstanceStatusEvent (Maybe Text)
instanceStatusEvent_instanceEventId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\InstanceStatusEvent' {Maybe Text
instanceEventId :: Maybe Text
$sel:instanceEventId:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe Text
instanceEventId} -> Maybe Text
instanceEventId) (\s :: InstanceStatusEvent
s@InstanceStatusEvent' {} Maybe Text
a -> InstanceStatusEvent
s {$sel:instanceEventId:InstanceStatusEvent' :: Maybe Text
instanceEventId = Maybe Text
a} :: InstanceStatusEvent)
instanceStatusEvent_notAfter :: Lens.Lens' InstanceStatusEvent (Prelude.Maybe Prelude.UTCTime)
instanceStatusEvent_notAfter :: Lens' InstanceStatusEvent (Maybe UTCTime)
instanceStatusEvent_notAfter = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\InstanceStatusEvent' {Maybe ISO8601
notAfter :: Maybe ISO8601
$sel:notAfter:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
notAfter} -> Maybe ISO8601
notAfter) (\s :: InstanceStatusEvent
s@InstanceStatusEvent' {} Maybe ISO8601
a -> InstanceStatusEvent
s {$sel:notAfter:InstanceStatusEvent' :: Maybe ISO8601
notAfter = Maybe ISO8601
a} :: InstanceStatusEvent) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall (a :: Format). Iso' (Time a) UTCTime
Data._Time
instanceStatusEvent_notBefore :: Lens.Lens' InstanceStatusEvent (Prelude.Maybe Prelude.UTCTime)
instanceStatusEvent_notBefore :: Lens' InstanceStatusEvent (Maybe UTCTime)
instanceStatusEvent_notBefore = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\InstanceStatusEvent' {Maybe ISO8601
notBefore :: Maybe ISO8601
$sel:notBefore:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
notBefore} -> Maybe ISO8601
notBefore) (\s :: InstanceStatusEvent
s@InstanceStatusEvent' {} Maybe ISO8601
a -> InstanceStatusEvent
s {$sel:notBefore:InstanceStatusEvent' :: Maybe ISO8601
notBefore = Maybe ISO8601
a} :: InstanceStatusEvent) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall (a :: Format). Iso' (Time a) UTCTime
Data._Time
instanceStatusEvent_notBeforeDeadline :: Lens.Lens' InstanceStatusEvent (Prelude.Maybe Prelude.UTCTime)
instanceStatusEvent_notBeforeDeadline :: Lens' InstanceStatusEvent (Maybe UTCTime)
instanceStatusEvent_notBeforeDeadline = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\InstanceStatusEvent' {Maybe ISO8601
notBeforeDeadline :: Maybe ISO8601
$sel:notBeforeDeadline:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
notBeforeDeadline} -> Maybe ISO8601
notBeforeDeadline) (\s :: InstanceStatusEvent
s@InstanceStatusEvent' {} Maybe ISO8601
a -> InstanceStatusEvent
s {$sel:notBeforeDeadline:InstanceStatusEvent' :: Maybe ISO8601
notBeforeDeadline = Maybe ISO8601
a} :: InstanceStatusEvent) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall (a :: Format). Iso' (Time a) UTCTime
Data._Time
instance Data.FromXML InstanceStatusEvent where
parseXML :: [Node] -> Either String InstanceStatusEvent
parseXML [Node]
x =
Maybe EventCode
-> Maybe Text
-> Maybe Text
-> Maybe ISO8601
-> Maybe ISO8601
-> Maybe ISO8601
-> InstanceStatusEvent
InstanceStatusEvent'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"code")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"description")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"instanceEventId")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"notAfter")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"notBefore")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"notBeforeDeadline")
instance Prelude.Hashable InstanceStatusEvent where
hashWithSalt :: Int -> InstanceStatusEvent -> Int
hashWithSalt Int
_salt InstanceStatusEvent' {Maybe Text
Maybe ISO8601
Maybe EventCode
notBeforeDeadline :: Maybe ISO8601
notBefore :: Maybe ISO8601
notAfter :: Maybe ISO8601
instanceEventId :: Maybe Text
description :: Maybe Text
code :: Maybe EventCode
$sel:notBeforeDeadline:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
$sel:notBefore:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
$sel:notAfter:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
$sel:instanceEventId:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe Text
$sel:description:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe Text
$sel:code:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe EventCode
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe EventCode
code
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
description
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
instanceEventId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ISO8601
notAfter
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ISO8601
notBefore
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ISO8601
notBeforeDeadline
instance Prelude.NFData InstanceStatusEvent where
rnf :: InstanceStatusEvent -> ()
rnf InstanceStatusEvent' {Maybe Text
Maybe ISO8601
Maybe EventCode
notBeforeDeadline :: Maybe ISO8601
notBefore :: Maybe ISO8601
notAfter :: Maybe ISO8601
instanceEventId :: Maybe Text
description :: Maybe Text
code :: Maybe EventCode
$sel:notBeforeDeadline:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
$sel:notBefore:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
$sel:notAfter:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe ISO8601
$sel:instanceEventId:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe Text
$sel:description:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe Text
$sel:code:InstanceStatusEvent' :: InstanceStatusEvent -> Maybe EventCode
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe EventCode
code
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
description
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
instanceEventId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe ISO8601
notAfter
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe ISO8601
notBefore
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe ISO8601
notBeforeDeadline