{-# 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.PeeringTgwInfo 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 qualified Amazonka.Prelude as Prelude
data PeeringTgwInfo = PeeringTgwInfo'
{
PeeringTgwInfo -> Maybe Text
coreNetworkId :: Prelude.Maybe Prelude.Text,
PeeringTgwInfo -> Maybe Text
ownerId :: Prelude.Maybe Prelude.Text,
PeeringTgwInfo -> Maybe Text
region :: Prelude.Maybe Prelude.Text,
PeeringTgwInfo -> Maybe Text
transitGatewayId :: Prelude.Maybe Prelude.Text
}
deriving (PeeringTgwInfo -> PeeringTgwInfo -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PeeringTgwInfo -> PeeringTgwInfo -> Bool
$c/= :: PeeringTgwInfo -> PeeringTgwInfo -> Bool
== :: PeeringTgwInfo -> PeeringTgwInfo -> Bool
$c== :: PeeringTgwInfo -> PeeringTgwInfo -> Bool
Prelude.Eq, ReadPrec [PeeringTgwInfo]
ReadPrec PeeringTgwInfo
Int -> ReadS PeeringTgwInfo
ReadS [PeeringTgwInfo]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [PeeringTgwInfo]
$creadListPrec :: ReadPrec [PeeringTgwInfo]
readPrec :: ReadPrec PeeringTgwInfo
$creadPrec :: ReadPrec PeeringTgwInfo
readList :: ReadS [PeeringTgwInfo]
$creadList :: ReadS [PeeringTgwInfo]
readsPrec :: Int -> ReadS PeeringTgwInfo
$creadsPrec :: Int -> ReadS PeeringTgwInfo
Prelude.Read, Int -> PeeringTgwInfo -> ShowS
[PeeringTgwInfo] -> ShowS
PeeringTgwInfo -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PeeringTgwInfo] -> ShowS
$cshowList :: [PeeringTgwInfo] -> ShowS
show :: PeeringTgwInfo -> String
$cshow :: PeeringTgwInfo -> String
showsPrec :: Int -> PeeringTgwInfo -> ShowS
$cshowsPrec :: Int -> PeeringTgwInfo -> ShowS
Prelude.Show, forall x. Rep PeeringTgwInfo x -> PeeringTgwInfo
forall x. PeeringTgwInfo -> Rep PeeringTgwInfo x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep PeeringTgwInfo x -> PeeringTgwInfo
$cfrom :: forall x. PeeringTgwInfo -> Rep PeeringTgwInfo x
Prelude.Generic)
newPeeringTgwInfo ::
PeeringTgwInfo
newPeeringTgwInfo :: PeeringTgwInfo
newPeeringTgwInfo =
PeeringTgwInfo'
{ $sel:coreNetworkId:PeeringTgwInfo' :: Maybe Text
coreNetworkId = forall a. Maybe a
Prelude.Nothing,
$sel:ownerId:PeeringTgwInfo' :: Maybe Text
ownerId = forall a. Maybe a
Prelude.Nothing,
$sel:region:PeeringTgwInfo' :: Maybe Text
region = forall a. Maybe a
Prelude.Nothing,
$sel:transitGatewayId:PeeringTgwInfo' :: Maybe Text
transitGatewayId = forall a. Maybe a
Prelude.Nothing
}
peeringTgwInfo_coreNetworkId :: Lens.Lens' PeeringTgwInfo (Prelude.Maybe Prelude.Text)
peeringTgwInfo_coreNetworkId :: Lens' PeeringTgwInfo (Maybe Text)
peeringTgwInfo_coreNetworkId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PeeringTgwInfo' {Maybe Text
coreNetworkId :: Maybe Text
$sel:coreNetworkId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
coreNetworkId} -> Maybe Text
coreNetworkId) (\s :: PeeringTgwInfo
s@PeeringTgwInfo' {} Maybe Text
a -> PeeringTgwInfo
s {$sel:coreNetworkId:PeeringTgwInfo' :: Maybe Text
coreNetworkId = Maybe Text
a} :: PeeringTgwInfo)
peeringTgwInfo_ownerId :: Lens.Lens' PeeringTgwInfo (Prelude.Maybe Prelude.Text)
peeringTgwInfo_ownerId :: Lens' PeeringTgwInfo (Maybe Text)
peeringTgwInfo_ownerId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PeeringTgwInfo' {Maybe Text
ownerId :: Maybe Text
$sel:ownerId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
ownerId} -> Maybe Text
ownerId) (\s :: PeeringTgwInfo
s@PeeringTgwInfo' {} Maybe Text
a -> PeeringTgwInfo
s {$sel:ownerId:PeeringTgwInfo' :: Maybe Text
ownerId = Maybe Text
a} :: PeeringTgwInfo)
peeringTgwInfo_region :: Lens.Lens' PeeringTgwInfo (Prelude.Maybe Prelude.Text)
peeringTgwInfo_region :: Lens' PeeringTgwInfo (Maybe Text)
peeringTgwInfo_region = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PeeringTgwInfo' {Maybe Text
region :: Maybe Text
$sel:region:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
region} -> Maybe Text
region) (\s :: PeeringTgwInfo
s@PeeringTgwInfo' {} Maybe Text
a -> PeeringTgwInfo
s {$sel:region:PeeringTgwInfo' :: Maybe Text
region = Maybe Text
a} :: PeeringTgwInfo)
peeringTgwInfo_transitGatewayId :: Lens.Lens' PeeringTgwInfo (Prelude.Maybe Prelude.Text)
peeringTgwInfo_transitGatewayId :: Lens' PeeringTgwInfo (Maybe Text)
peeringTgwInfo_transitGatewayId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PeeringTgwInfo' {Maybe Text
transitGatewayId :: Maybe Text
$sel:transitGatewayId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
transitGatewayId} -> Maybe Text
transitGatewayId) (\s :: PeeringTgwInfo
s@PeeringTgwInfo' {} Maybe Text
a -> PeeringTgwInfo
s {$sel:transitGatewayId:PeeringTgwInfo' :: Maybe Text
transitGatewayId = Maybe Text
a} :: PeeringTgwInfo)
instance Data.FromXML PeeringTgwInfo where
parseXML :: [Node] -> Either String PeeringTgwInfo
parseXML [Node]
x =
Maybe Text
-> Maybe Text -> Maybe Text -> Maybe Text -> PeeringTgwInfo
PeeringTgwInfo'
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
"coreNetworkId")
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
"ownerId")
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
"region")
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
"transitGatewayId")
instance Prelude.Hashable PeeringTgwInfo where
hashWithSalt :: Int -> PeeringTgwInfo -> Int
hashWithSalt Int
_salt PeeringTgwInfo' {Maybe Text
transitGatewayId :: Maybe Text
region :: Maybe Text
ownerId :: Maybe Text
coreNetworkId :: Maybe Text
$sel:transitGatewayId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
$sel:region:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
$sel:ownerId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
$sel:coreNetworkId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
coreNetworkId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
ownerId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
region
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
transitGatewayId
instance Prelude.NFData PeeringTgwInfo where
rnf :: PeeringTgwInfo -> ()
rnf PeeringTgwInfo' {Maybe Text
transitGatewayId :: Maybe Text
region :: Maybe Text
ownerId :: Maybe Text
coreNetworkId :: Maybe Text
$sel:transitGatewayId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
$sel:region:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
$sel:ownerId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
$sel:coreNetworkId:PeeringTgwInfo' :: PeeringTgwInfo -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
coreNetworkId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
ownerId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
region
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
transitGatewayId