{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.PrivateNetworks.UpdateNetworkSitePlan
(
UpdateNetworkSitePlan (..),
newUpdateNetworkSitePlan,
updateNetworkSitePlan_clientToken,
updateNetworkSitePlan_networkSiteArn,
updateNetworkSitePlan_pendingPlan,
UpdateNetworkSiteResponse (..),
newUpdateNetworkSiteResponse,
updateNetworkSiteResponse_networkSite,
updateNetworkSiteResponse_tags,
)
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.PrivateNetworks.Types
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data UpdateNetworkSitePlan = UpdateNetworkSitePlan'
{
UpdateNetworkSitePlan -> Maybe Text
clientToken :: Prelude.Maybe Prelude.Text,
UpdateNetworkSitePlan -> Text
networkSiteArn :: Prelude.Text,
UpdateNetworkSitePlan -> SitePlan
pendingPlan :: SitePlan
}
deriving (UpdateNetworkSitePlan -> UpdateNetworkSitePlan -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateNetworkSitePlan -> UpdateNetworkSitePlan -> Bool
$c/= :: UpdateNetworkSitePlan -> UpdateNetworkSitePlan -> Bool
== :: UpdateNetworkSitePlan -> UpdateNetworkSitePlan -> Bool
$c== :: UpdateNetworkSitePlan -> UpdateNetworkSitePlan -> Bool
Prelude.Eq, ReadPrec [UpdateNetworkSitePlan]
ReadPrec UpdateNetworkSitePlan
Int -> ReadS UpdateNetworkSitePlan
ReadS [UpdateNetworkSitePlan]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateNetworkSitePlan]
$creadListPrec :: ReadPrec [UpdateNetworkSitePlan]
readPrec :: ReadPrec UpdateNetworkSitePlan
$creadPrec :: ReadPrec UpdateNetworkSitePlan
readList :: ReadS [UpdateNetworkSitePlan]
$creadList :: ReadS [UpdateNetworkSitePlan]
readsPrec :: Int -> ReadS UpdateNetworkSitePlan
$creadsPrec :: Int -> ReadS UpdateNetworkSitePlan
Prelude.Read, Int -> UpdateNetworkSitePlan -> ShowS
[UpdateNetworkSitePlan] -> ShowS
UpdateNetworkSitePlan -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateNetworkSitePlan] -> ShowS
$cshowList :: [UpdateNetworkSitePlan] -> ShowS
show :: UpdateNetworkSitePlan -> String
$cshow :: UpdateNetworkSitePlan -> String
showsPrec :: Int -> UpdateNetworkSitePlan -> ShowS
$cshowsPrec :: Int -> UpdateNetworkSitePlan -> ShowS
Prelude.Show, forall x. Rep UpdateNetworkSitePlan x -> UpdateNetworkSitePlan
forall x. UpdateNetworkSitePlan -> Rep UpdateNetworkSitePlan x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateNetworkSitePlan x -> UpdateNetworkSitePlan
$cfrom :: forall x. UpdateNetworkSitePlan -> Rep UpdateNetworkSitePlan x
Prelude.Generic)
newUpdateNetworkSitePlan ::
Prelude.Text ->
SitePlan ->
UpdateNetworkSitePlan
newUpdateNetworkSitePlan :: Text -> SitePlan -> UpdateNetworkSitePlan
newUpdateNetworkSitePlan
Text
pNetworkSiteArn_
SitePlan
pPendingPlan_ =
UpdateNetworkSitePlan'
{ $sel:clientToken:UpdateNetworkSitePlan' :: Maybe Text
clientToken =
forall a. Maybe a
Prelude.Nothing,
$sel:networkSiteArn:UpdateNetworkSitePlan' :: Text
networkSiteArn = Text
pNetworkSiteArn_,
$sel:pendingPlan:UpdateNetworkSitePlan' :: SitePlan
pendingPlan = SitePlan
pPendingPlan_
}
updateNetworkSitePlan_clientToken :: Lens.Lens' UpdateNetworkSitePlan (Prelude.Maybe Prelude.Text)
updateNetworkSitePlan_clientToken :: Lens' UpdateNetworkSitePlan (Maybe Text)
updateNetworkSitePlan_clientToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateNetworkSitePlan' {Maybe Text
clientToken :: Maybe Text
$sel:clientToken:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> Maybe Text
clientToken} -> Maybe Text
clientToken) (\s :: UpdateNetworkSitePlan
s@UpdateNetworkSitePlan' {} Maybe Text
a -> UpdateNetworkSitePlan
s {$sel:clientToken:UpdateNetworkSitePlan' :: Maybe Text
clientToken = Maybe Text
a} :: UpdateNetworkSitePlan)
updateNetworkSitePlan_networkSiteArn :: Lens.Lens' UpdateNetworkSitePlan Prelude.Text
updateNetworkSitePlan_networkSiteArn :: Lens' UpdateNetworkSitePlan Text
updateNetworkSitePlan_networkSiteArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateNetworkSitePlan' {Text
networkSiteArn :: Text
$sel:networkSiteArn:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> Text
networkSiteArn} -> Text
networkSiteArn) (\s :: UpdateNetworkSitePlan
s@UpdateNetworkSitePlan' {} Text
a -> UpdateNetworkSitePlan
s {$sel:networkSiteArn:UpdateNetworkSitePlan' :: Text
networkSiteArn = Text
a} :: UpdateNetworkSitePlan)
updateNetworkSitePlan_pendingPlan :: Lens.Lens' UpdateNetworkSitePlan SitePlan
updateNetworkSitePlan_pendingPlan :: Lens' UpdateNetworkSitePlan SitePlan
updateNetworkSitePlan_pendingPlan = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateNetworkSitePlan' {SitePlan
pendingPlan :: SitePlan
$sel:pendingPlan:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> SitePlan
pendingPlan} -> SitePlan
pendingPlan) (\s :: UpdateNetworkSitePlan
s@UpdateNetworkSitePlan' {} SitePlan
a -> UpdateNetworkSitePlan
s {$sel:pendingPlan:UpdateNetworkSitePlan' :: SitePlan
pendingPlan = SitePlan
a} :: UpdateNetworkSitePlan)
instance Core.AWSRequest UpdateNetworkSitePlan where
type
AWSResponse UpdateNetworkSitePlan =
UpdateNetworkSiteResponse
request :: (Service -> Service)
-> UpdateNetworkSitePlan -> Request UpdateNetworkSitePlan
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.putJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy UpdateNetworkSitePlan
-> ClientResponse ClientBody
-> m (Either
Error (ClientResponse (AWSResponse UpdateNetworkSitePlan)))
response =
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
(\Int
s ResponseHeaders
h Object
x -> forall a. FromJSON a => Object -> Either String a
Data.eitherParseJSON Object
x)
instance Prelude.Hashable UpdateNetworkSitePlan where
hashWithSalt :: Int -> UpdateNetworkSitePlan -> Int
hashWithSalt Int
_salt UpdateNetworkSitePlan' {Maybe Text
Text
SitePlan
pendingPlan :: SitePlan
networkSiteArn :: Text
clientToken :: Maybe Text
$sel:pendingPlan:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> SitePlan
$sel:networkSiteArn:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> Text
$sel:clientToken:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> Maybe Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
clientToken
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
networkSiteArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` SitePlan
pendingPlan
instance Prelude.NFData UpdateNetworkSitePlan where
rnf :: UpdateNetworkSitePlan -> ()
rnf UpdateNetworkSitePlan' {Maybe Text
Text
SitePlan
pendingPlan :: SitePlan
networkSiteArn :: Text
clientToken :: Maybe Text
$sel:pendingPlan:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> SitePlan
$sel:networkSiteArn:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> Text
$sel:clientToken:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> Maybe Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clientToken
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
networkSiteArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf SitePlan
pendingPlan
instance Data.ToHeaders UpdateNetworkSitePlan where
toHeaders :: UpdateNetworkSitePlan -> ResponseHeaders
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON UpdateNetworkSitePlan where
toJSON :: UpdateNetworkSitePlan -> Value
toJSON UpdateNetworkSitePlan' {Maybe Text
Text
SitePlan
pendingPlan :: SitePlan
networkSiteArn :: Text
clientToken :: Maybe Text
$sel:pendingPlan:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> SitePlan
$sel:networkSiteArn:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> Text
$sel:clientToken:UpdateNetworkSitePlan' :: UpdateNetworkSitePlan -> Maybe Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"clientToken" 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
clientToken,
forall a. a -> Maybe a
Prelude.Just
(Key
"networkSiteArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
networkSiteArn),
forall a. a -> Maybe a
Prelude.Just (Key
"pendingPlan" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= SitePlan
pendingPlan)
]
)
instance Data.ToPath UpdateNetworkSitePlan where
toPath :: UpdateNetworkSitePlan -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/v1/network-sites/plan"
instance Data.ToQuery UpdateNetworkSitePlan where
toQuery :: UpdateNetworkSitePlan -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty