{-# 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.InstanceStatusSummary 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.InstanceStatusDetails
import Amazonka.EC2.Types.SummaryStatus
import qualified Amazonka.Prelude as Prelude
data InstanceStatusSummary = InstanceStatusSummary'
{
InstanceStatusSummary -> Maybe [InstanceStatusDetails]
details :: Prelude.Maybe [InstanceStatusDetails],
InstanceStatusSummary -> SummaryStatus
status :: SummaryStatus
}
deriving (InstanceStatusSummary -> InstanceStatusSummary -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: InstanceStatusSummary -> InstanceStatusSummary -> Bool
$c/= :: InstanceStatusSummary -> InstanceStatusSummary -> Bool
== :: InstanceStatusSummary -> InstanceStatusSummary -> Bool
$c== :: InstanceStatusSummary -> InstanceStatusSummary -> Bool
Prelude.Eq, ReadPrec [InstanceStatusSummary]
ReadPrec InstanceStatusSummary
Int -> ReadS InstanceStatusSummary
ReadS [InstanceStatusSummary]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [InstanceStatusSummary]
$creadListPrec :: ReadPrec [InstanceStatusSummary]
readPrec :: ReadPrec InstanceStatusSummary
$creadPrec :: ReadPrec InstanceStatusSummary
readList :: ReadS [InstanceStatusSummary]
$creadList :: ReadS [InstanceStatusSummary]
readsPrec :: Int -> ReadS InstanceStatusSummary
$creadsPrec :: Int -> ReadS InstanceStatusSummary
Prelude.Read, Int -> InstanceStatusSummary -> ShowS
[InstanceStatusSummary] -> ShowS
InstanceStatusSummary -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [InstanceStatusSummary] -> ShowS
$cshowList :: [InstanceStatusSummary] -> ShowS
show :: InstanceStatusSummary -> String
$cshow :: InstanceStatusSummary -> String
showsPrec :: Int -> InstanceStatusSummary -> ShowS
$cshowsPrec :: Int -> InstanceStatusSummary -> ShowS
Prelude.Show, forall x. Rep InstanceStatusSummary x -> InstanceStatusSummary
forall x. InstanceStatusSummary -> Rep InstanceStatusSummary x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep InstanceStatusSummary x -> InstanceStatusSummary
$cfrom :: forall x. InstanceStatusSummary -> Rep InstanceStatusSummary x
Prelude.Generic)
newInstanceStatusSummary ::
SummaryStatus ->
InstanceStatusSummary
newInstanceStatusSummary :: SummaryStatus -> InstanceStatusSummary
newInstanceStatusSummary SummaryStatus
pStatus_ =
InstanceStatusSummary'
{ $sel:details:InstanceStatusSummary' :: Maybe [InstanceStatusDetails]
details = forall a. Maybe a
Prelude.Nothing,
$sel:status:InstanceStatusSummary' :: SummaryStatus
status = SummaryStatus
pStatus_
}
instanceStatusSummary_details :: Lens.Lens' InstanceStatusSummary (Prelude.Maybe [InstanceStatusDetails])
instanceStatusSummary_details :: Lens' InstanceStatusSummary (Maybe [InstanceStatusDetails])
instanceStatusSummary_details = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\InstanceStatusSummary' {Maybe [InstanceStatusDetails]
details :: Maybe [InstanceStatusDetails]
$sel:details:InstanceStatusSummary' :: InstanceStatusSummary -> Maybe [InstanceStatusDetails]
details} -> Maybe [InstanceStatusDetails]
details) (\s :: InstanceStatusSummary
s@InstanceStatusSummary' {} Maybe [InstanceStatusDetails]
a -> InstanceStatusSummary
s {$sel:details:InstanceStatusSummary' :: Maybe [InstanceStatusDetails]
details = Maybe [InstanceStatusDetails]
a} :: InstanceStatusSummary) 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
instanceStatusSummary_status :: Lens.Lens' InstanceStatusSummary SummaryStatus
instanceStatusSummary_status :: Lens' InstanceStatusSummary SummaryStatus
instanceStatusSummary_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\InstanceStatusSummary' {SummaryStatus
status :: SummaryStatus
$sel:status:InstanceStatusSummary' :: InstanceStatusSummary -> SummaryStatus
status} -> SummaryStatus
status) (\s :: InstanceStatusSummary
s@InstanceStatusSummary' {} SummaryStatus
a -> InstanceStatusSummary
s {$sel:status:InstanceStatusSummary' :: SummaryStatus
status = SummaryStatus
a} :: InstanceStatusSummary)
instance Data.FromXML InstanceStatusSummary where
parseXML :: [Node] -> Either String InstanceStatusSummary
parseXML [Node]
x =
Maybe [InstanceStatusDetails]
-> SummaryStatus -> InstanceStatusSummary
InstanceStatusSummary'
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
"details"
forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
Prelude.>>= forall (f :: * -> *) a b.
Applicative f =>
([a] -> f b) -> [a] -> f (Maybe b)
Core.may (forall a. FromXML a => Text -> [Node] -> Either String [a]
Data.parseXMLList Text
"item")
)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node]
x forall a. FromXML a => [Node] -> Text -> Either String a
Data..@ Text
"status")
instance Prelude.Hashable InstanceStatusSummary where
hashWithSalt :: Int -> InstanceStatusSummary -> Int
hashWithSalt Int
_salt InstanceStatusSummary' {Maybe [InstanceStatusDetails]
SummaryStatus
status :: SummaryStatus
details :: Maybe [InstanceStatusDetails]
$sel:status:InstanceStatusSummary' :: InstanceStatusSummary -> SummaryStatus
$sel:details:InstanceStatusSummary' :: InstanceStatusSummary -> Maybe [InstanceStatusDetails]
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [InstanceStatusDetails]
details
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` SummaryStatus
status
instance Prelude.NFData InstanceStatusSummary where
rnf :: InstanceStatusSummary -> ()
rnf InstanceStatusSummary' {Maybe [InstanceStatusDetails]
SummaryStatus
status :: SummaryStatus
details :: Maybe [InstanceStatusDetails]
$sel:status:InstanceStatusSummary' :: InstanceStatusSummary -> SummaryStatus
$sel:details:InstanceStatusSummary' :: InstanceStatusSummary -> Maybe [InstanceStatusDetails]
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe [InstanceStatusDetails]
details
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf SummaryStatus
status