{-# 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.SSMIncidents.Types.TimelineEvent where
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
import Amazonka.SSMIncidents.Types.EventReference
data TimelineEvent = TimelineEvent'
{
TimelineEvent -> Maybe [EventReference]
eventReferences :: Prelude.Maybe [EventReference],
TimelineEvent -> Text
eventData :: Prelude.Text,
TimelineEvent -> Text
eventId :: Prelude.Text,
TimelineEvent -> POSIX
eventTime :: Data.POSIX,
TimelineEvent -> Text
eventType :: Prelude.Text,
TimelineEvent -> POSIX
eventUpdatedTime :: Data.POSIX,
TimelineEvent -> Text
incidentRecordArn :: Prelude.Text
}
deriving (TimelineEvent -> TimelineEvent -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: TimelineEvent -> TimelineEvent -> Bool
$c/= :: TimelineEvent -> TimelineEvent -> Bool
== :: TimelineEvent -> TimelineEvent -> Bool
$c== :: TimelineEvent -> TimelineEvent -> Bool
Prelude.Eq, ReadPrec [TimelineEvent]
ReadPrec TimelineEvent
Int -> ReadS TimelineEvent
ReadS [TimelineEvent]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [TimelineEvent]
$creadListPrec :: ReadPrec [TimelineEvent]
readPrec :: ReadPrec TimelineEvent
$creadPrec :: ReadPrec TimelineEvent
readList :: ReadS [TimelineEvent]
$creadList :: ReadS [TimelineEvent]
readsPrec :: Int -> ReadS TimelineEvent
$creadsPrec :: Int -> ReadS TimelineEvent
Prelude.Read, Int -> TimelineEvent -> ShowS
[TimelineEvent] -> ShowS
TimelineEvent -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [TimelineEvent] -> ShowS
$cshowList :: [TimelineEvent] -> ShowS
show :: TimelineEvent -> String
$cshow :: TimelineEvent -> String
showsPrec :: Int -> TimelineEvent -> ShowS
$cshowsPrec :: Int -> TimelineEvent -> ShowS
Prelude.Show, forall x. Rep TimelineEvent x -> TimelineEvent
forall x. TimelineEvent -> Rep TimelineEvent x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep TimelineEvent x -> TimelineEvent
$cfrom :: forall x. TimelineEvent -> Rep TimelineEvent x
Prelude.Generic)
newTimelineEvent ::
Prelude.Text ->
Prelude.Text ->
Prelude.UTCTime ->
Prelude.Text ->
Prelude.UTCTime ->
Prelude.Text ->
TimelineEvent
newTimelineEvent :: Text -> Text -> UTCTime -> Text -> UTCTime -> Text -> TimelineEvent
newTimelineEvent
Text
pEventData_
Text
pEventId_
UTCTime
pEventTime_
Text
pEventType_
UTCTime
pEventUpdatedTime_
Text
pIncidentRecordArn_ =
TimelineEvent'
{ $sel:eventReferences:TimelineEvent' :: Maybe [EventReference]
eventReferences = forall a. Maybe a
Prelude.Nothing,
$sel:eventData:TimelineEvent' :: Text
eventData = Text
pEventData_,
$sel:eventId:TimelineEvent' :: Text
eventId = Text
pEventId_,
$sel:eventTime:TimelineEvent' :: POSIX
eventTime = forall (a :: Format). Iso' (Time a) UTCTime
Data._Time forall t b. AReview t b -> b -> t
Lens.# UTCTime
pEventTime_,
$sel:eventType:TimelineEvent' :: Text
eventType = Text
pEventType_,
$sel:eventUpdatedTime:TimelineEvent' :: POSIX
eventUpdatedTime =
forall (a :: Format). Iso' (Time a) UTCTime
Data._Time forall t b. AReview t b -> b -> t
Lens.# UTCTime
pEventUpdatedTime_,
$sel:incidentRecordArn:TimelineEvent' :: Text
incidentRecordArn = Text
pIncidentRecordArn_
}
timelineEvent_eventReferences :: Lens.Lens' TimelineEvent (Prelude.Maybe [EventReference])
timelineEvent_eventReferences :: Lens' TimelineEvent (Maybe [EventReference])
timelineEvent_eventReferences = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimelineEvent' {Maybe [EventReference]
eventReferences :: Maybe [EventReference]
$sel:eventReferences:TimelineEvent' :: TimelineEvent -> Maybe [EventReference]
eventReferences} -> Maybe [EventReference]
eventReferences) (\s :: TimelineEvent
s@TimelineEvent' {} Maybe [EventReference]
a -> TimelineEvent
s {$sel:eventReferences:TimelineEvent' :: Maybe [EventReference]
eventReferences = Maybe [EventReference]
a} :: TimelineEvent) 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 s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
timelineEvent_eventData :: Lens.Lens' TimelineEvent Prelude.Text
timelineEvent_eventData :: Lens' TimelineEvent Text
timelineEvent_eventData = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimelineEvent' {Text
eventData :: Text
$sel:eventData:TimelineEvent' :: TimelineEvent -> Text
eventData} -> Text
eventData) (\s :: TimelineEvent
s@TimelineEvent' {} Text
a -> TimelineEvent
s {$sel:eventData:TimelineEvent' :: Text
eventData = Text
a} :: TimelineEvent)
timelineEvent_eventId :: Lens.Lens' TimelineEvent Prelude.Text
timelineEvent_eventId :: Lens' TimelineEvent Text
timelineEvent_eventId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimelineEvent' {Text
eventId :: Text
$sel:eventId:TimelineEvent' :: TimelineEvent -> Text
eventId} -> Text
eventId) (\s :: TimelineEvent
s@TimelineEvent' {} Text
a -> TimelineEvent
s {$sel:eventId:TimelineEvent' :: Text
eventId = Text
a} :: TimelineEvent)
timelineEvent_eventTime :: Lens.Lens' TimelineEvent Prelude.UTCTime
timelineEvent_eventTime :: Lens' TimelineEvent UTCTime
timelineEvent_eventTime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimelineEvent' {POSIX
eventTime :: POSIX
$sel:eventTime:TimelineEvent' :: TimelineEvent -> POSIX
eventTime} -> POSIX
eventTime) (\s :: TimelineEvent
s@TimelineEvent' {} POSIX
a -> TimelineEvent
s {$sel:eventTime:TimelineEvent' :: POSIX
eventTime = POSIX
a} :: TimelineEvent) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (a :: Format). Iso' (Time a) UTCTime
Data._Time
timelineEvent_eventType :: Lens.Lens' TimelineEvent Prelude.Text
timelineEvent_eventType :: Lens' TimelineEvent Text
timelineEvent_eventType = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimelineEvent' {Text
eventType :: Text
$sel:eventType:TimelineEvent' :: TimelineEvent -> Text
eventType} -> Text
eventType) (\s :: TimelineEvent
s@TimelineEvent' {} Text
a -> TimelineEvent
s {$sel:eventType:TimelineEvent' :: Text
eventType = Text
a} :: TimelineEvent)
timelineEvent_eventUpdatedTime :: Lens.Lens' TimelineEvent Prelude.UTCTime
timelineEvent_eventUpdatedTime :: Lens' TimelineEvent UTCTime
timelineEvent_eventUpdatedTime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimelineEvent' {POSIX
eventUpdatedTime :: POSIX
$sel:eventUpdatedTime:TimelineEvent' :: TimelineEvent -> POSIX
eventUpdatedTime} -> POSIX
eventUpdatedTime) (\s :: TimelineEvent
s@TimelineEvent' {} POSIX
a -> TimelineEvent
s {$sel:eventUpdatedTime:TimelineEvent' :: POSIX
eventUpdatedTime = POSIX
a} :: TimelineEvent) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (a :: Format). Iso' (Time a) UTCTime
Data._Time
timelineEvent_incidentRecordArn :: Lens.Lens' TimelineEvent Prelude.Text
timelineEvent_incidentRecordArn :: Lens' TimelineEvent Text
timelineEvent_incidentRecordArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\TimelineEvent' {Text
incidentRecordArn :: Text
$sel:incidentRecordArn:TimelineEvent' :: TimelineEvent -> Text
incidentRecordArn} -> Text
incidentRecordArn) (\s :: TimelineEvent
s@TimelineEvent' {} Text
a -> TimelineEvent
s {$sel:incidentRecordArn:TimelineEvent' :: Text
incidentRecordArn = Text
a} :: TimelineEvent)
instance Data.FromJSON TimelineEvent where
parseJSON :: Value -> Parser TimelineEvent
parseJSON =
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
String
"TimelineEvent"
( \Object
x ->
Maybe [EventReference]
-> Text -> Text -> POSIX -> Text -> POSIX -> Text -> TimelineEvent
TimelineEvent'
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
"eventReferences"
forall a. Parser (Maybe a) -> a -> Parser a
Data..!= forall a. Monoid a => a
Prelude.mempty
)
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
"eventData")
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
"eventId")
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
"eventTime")
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
"eventType")
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
"eventUpdatedTime")
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
"incidentRecordArn")
)
instance Prelude.Hashable TimelineEvent where
hashWithSalt :: Int -> TimelineEvent -> Int
hashWithSalt Int
_salt TimelineEvent' {Maybe [EventReference]
Text
POSIX
incidentRecordArn :: Text
eventUpdatedTime :: POSIX
eventType :: Text
eventTime :: POSIX
eventId :: Text
eventData :: Text
eventReferences :: Maybe [EventReference]
$sel:incidentRecordArn:TimelineEvent' :: TimelineEvent -> Text
$sel:eventUpdatedTime:TimelineEvent' :: TimelineEvent -> POSIX
$sel:eventType:TimelineEvent' :: TimelineEvent -> Text
$sel:eventTime:TimelineEvent' :: TimelineEvent -> POSIX
$sel:eventId:TimelineEvent' :: TimelineEvent -> Text
$sel:eventData:TimelineEvent' :: TimelineEvent -> Text
$sel:eventReferences:TimelineEvent' :: TimelineEvent -> Maybe [EventReference]
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [EventReference]
eventReferences
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
eventData
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
eventId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` POSIX
eventTime
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
eventType
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` POSIX
eventUpdatedTime
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
incidentRecordArn
instance Prelude.NFData TimelineEvent where
rnf :: TimelineEvent -> ()
rnf TimelineEvent' {Maybe [EventReference]
Text
POSIX
incidentRecordArn :: Text
eventUpdatedTime :: POSIX
eventType :: Text
eventTime :: POSIX
eventId :: Text
eventData :: Text
eventReferences :: Maybe [EventReference]
$sel:incidentRecordArn:TimelineEvent' :: TimelineEvent -> Text
$sel:eventUpdatedTime:TimelineEvent' :: TimelineEvent -> POSIX
$sel:eventType:TimelineEvent' :: TimelineEvent -> Text
$sel:eventTime:TimelineEvent' :: TimelineEvent -> POSIX
$sel:eventId:TimelineEvent' :: TimelineEvent -> Text
$sel:eventData:TimelineEvent' :: TimelineEvent -> Text
$sel:eventReferences:TimelineEvent' :: TimelineEvent -> Maybe [EventReference]
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe [EventReference]
eventReferences
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
eventData
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
eventId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf POSIX
eventTime
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
eventType
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf POSIX
eventUpdatedTime
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
incidentRecordArn