{-# 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 #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.PrivateNetworks.UpdateNetworkSitePlan
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Updates the specified network site plan.
module Amazonka.PrivateNetworks.UpdateNetworkSitePlan
  ( -- * Creating a Request
    UpdateNetworkSitePlan (..),
    newUpdateNetworkSitePlan,

    -- * Request Lenses
    updateNetworkSitePlan_clientToken,
    updateNetworkSitePlan_networkSiteArn,
    updateNetworkSitePlan_pendingPlan,

    -- * Destructuring the Response
    UpdateNetworkSiteResponse (..),
    newUpdateNetworkSiteResponse,

    -- * Response Lenses
    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

-- | /See:/ 'newUpdateNetworkSitePlan' smart constructor.
data UpdateNetworkSitePlan = UpdateNetworkSitePlan'
  { -- | Unique, case-sensitive identifier that you provide to ensure the
    -- idempotency of the request. For more information, see
    -- <https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html How to ensure idempotency>.
    UpdateNetworkSitePlan -> Maybe Text
clientToken :: Prelude.Maybe Prelude.Text,
    -- | The Amazon Resource Name (ARN) of the network site.
    UpdateNetworkSitePlan -> Text
networkSiteArn :: Prelude.Text,
    -- | The pending plan.
    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)

-- |
-- Create a value of 'UpdateNetworkSitePlan' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'clientToken', 'updateNetworkSitePlan_clientToken' - Unique, case-sensitive identifier that you provide to ensure the
-- idempotency of the request. For more information, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html How to ensure idempotency>.
--
-- 'networkSiteArn', 'updateNetworkSitePlan_networkSiteArn' - The Amazon Resource Name (ARN) of the network site.
--
-- 'pendingPlan', 'updateNetworkSitePlan_pendingPlan' - The pending plan.
newUpdateNetworkSitePlan ::
  -- | 'networkSiteArn'
  Prelude.Text ->
  -- | 'pendingPlan'
  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_
      }

-- | Unique, case-sensitive identifier that you provide to ensure the
-- idempotency of the request. For more information, see
-- <https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html How to ensure idempotency>.
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)

-- | The Amazon Resource Name (ARN) of the network site.
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)

-- | The pending plan.
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