{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Network.AWS.APIGateway.UpdateVPCLink
(
updateVPCLink
, UpdateVPCLink
, uvlPatchOperations
, uvlVpcLinkId
, vpcLink
, VPCLink
, vlStatus
, vlTargetARNs
, vlName
, vlStatusMessage
, vlId
, vlDescription
) where
import Network.AWS.APIGateway.Types
import Network.AWS.APIGateway.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data UpdateVPCLink = UpdateVPCLink'
{ _uvlPatchOperations :: !(Maybe [PatchOperation])
, _uvlVpcLinkId :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updateVPCLink
:: Text
-> UpdateVPCLink
updateVPCLink pVpcLinkId_ =
UpdateVPCLink' {_uvlPatchOperations = Nothing, _uvlVpcLinkId = pVpcLinkId_}
uvlPatchOperations :: Lens' UpdateVPCLink [PatchOperation]
uvlPatchOperations = lens _uvlPatchOperations (\ s a -> s{_uvlPatchOperations = a}) . _Default . _Coerce
uvlVpcLinkId :: Lens' UpdateVPCLink Text
uvlVpcLinkId = lens _uvlVpcLinkId (\ s a -> s{_uvlVpcLinkId = a})
instance AWSRequest UpdateVPCLink where
type Rs UpdateVPCLink = VPCLink
request = patchJSON apiGateway
response = receiveJSON (\ s h x -> eitherParseJSON x)
instance Hashable UpdateVPCLink where
instance NFData UpdateVPCLink where
instance ToHeaders UpdateVPCLink where
toHeaders
= const
(mconcat
["Accept" =# ("application/json" :: ByteString)])
instance ToJSON UpdateVPCLink where
toJSON UpdateVPCLink'{..}
= object
(catMaybes
[("patchOperations" .=) <$> _uvlPatchOperations])
instance ToPath UpdateVPCLink where
toPath UpdateVPCLink'{..}
= mconcat ["/vpclinks/", toBS _uvlVpcLinkId]
instance ToQuery UpdateVPCLink where
toQuery = const mempty