{-# 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.DirectConnect.UpdateVirtualInterfaceAttributes
-- 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 attributes of the specified virtual private
-- interface.
--
-- Setting the MTU of a virtual interface to 9001 (jumbo frames) can cause
-- an update to the underlying physical connection if it wasn\'t updated to
-- support jumbo frames. Updating the connection disrupts network
-- connectivity for all virtual interfaces associated with the connection
-- for up to 30 seconds. To check whether your connection supports jumbo
-- frames, call DescribeConnections. To check whether your virtual q
-- interface supports jumbo frames, call DescribeVirtualInterfaces.
module Amazonka.DirectConnect.UpdateVirtualInterfaceAttributes
  ( -- * Creating a Request
    UpdateVirtualInterfaceAttributes (..),
    newUpdateVirtualInterfaceAttributes,

    -- * Request Lenses
    updateVirtualInterfaceAttributes_enableSiteLink,
    updateVirtualInterfaceAttributes_mtu,
    updateVirtualInterfaceAttributes_virtualInterfaceName,
    updateVirtualInterfaceAttributes_virtualInterfaceId,

    -- * Destructuring the Response
    VirtualInterface (..),
    newVirtualInterface,

    -- * Response Lenses
    virtualInterface_addressFamily,
    virtualInterface_amazonAddress,
    virtualInterface_amazonSideAsn,
    virtualInterface_asn,
    virtualInterface_authKey,
    virtualInterface_awsDeviceV2,
    virtualInterface_awsLogicalDeviceId,
    virtualInterface_bgpPeers,
    virtualInterface_connectionId,
    virtualInterface_customerAddress,
    virtualInterface_customerRouterConfig,
    virtualInterface_directConnectGatewayId,
    virtualInterface_jumboFrameCapable,
    virtualInterface_location,
    virtualInterface_mtu,
    virtualInterface_ownerAccount,
    virtualInterface_region,
    virtualInterface_routeFilterPrefixes,
    virtualInterface_siteLinkEnabled,
    virtualInterface_tags,
    virtualInterface_virtualGatewayId,
    virtualInterface_virtualInterfaceId,
    virtualInterface_virtualInterfaceName,
    virtualInterface_virtualInterfaceState,
    virtualInterface_virtualInterfaceType,
    virtualInterface_vlan,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.DirectConnect.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newUpdateVirtualInterfaceAttributes' smart constructor.
data UpdateVirtualInterfaceAttributes = UpdateVirtualInterfaceAttributes'
  { -- | Indicates whether to enable or disable SiteLink.
    UpdateVirtualInterfaceAttributes -> Maybe Bool
enableSiteLink :: Prelude.Maybe Prelude.Bool,
    -- | The maximum transmission unit (MTU), in bytes. The supported values are
    -- 1500 and 9001. The default value is 1500.
    UpdateVirtualInterfaceAttributes -> Maybe Int
mtu :: Prelude.Maybe Prelude.Int,
    -- | The name of the virtual private interface.
    UpdateVirtualInterfaceAttributes -> Maybe Text
virtualInterfaceName :: Prelude.Maybe Prelude.Text,
    -- | The ID of the virtual private interface.
    UpdateVirtualInterfaceAttributes -> Text
virtualInterfaceId :: Prelude.Text
  }
  deriving (UpdateVirtualInterfaceAttributes
-> UpdateVirtualInterfaceAttributes -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateVirtualInterfaceAttributes
-> UpdateVirtualInterfaceAttributes -> Bool
$c/= :: UpdateVirtualInterfaceAttributes
-> UpdateVirtualInterfaceAttributes -> Bool
== :: UpdateVirtualInterfaceAttributes
-> UpdateVirtualInterfaceAttributes -> Bool
$c== :: UpdateVirtualInterfaceAttributes
-> UpdateVirtualInterfaceAttributes -> Bool
Prelude.Eq, ReadPrec [UpdateVirtualInterfaceAttributes]
ReadPrec UpdateVirtualInterfaceAttributes
Int -> ReadS UpdateVirtualInterfaceAttributes
ReadS [UpdateVirtualInterfaceAttributes]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateVirtualInterfaceAttributes]
$creadListPrec :: ReadPrec [UpdateVirtualInterfaceAttributes]
readPrec :: ReadPrec UpdateVirtualInterfaceAttributes
$creadPrec :: ReadPrec UpdateVirtualInterfaceAttributes
readList :: ReadS [UpdateVirtualInterfaceAttributes]
$creadList :: ReadS [UpdateVirtualInterfaceAttributes]
readsPrec :: Int -> ReadS UpdateVirtualInterfaceAttributes
$creadsPrec :: Int -> ReadS UpdateVirtualInterfaceAttributes
Prelude.Read, Int -> UpdateVirtualInterfaceAttributes -> ShowS
[UpdateVirtualInterfaceAttributes] -> ShowS
UpdateVirtualInterfaceAttributes -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateVirtualInterfaceAttributes] -> ShowS
$cshowList :: [UpdateVirtualInterfaceAttributes] -> ShowS
show :: UpdateVirtualInterfaceAttributes -> String
$cshow :: UpdateVirtualInterfaceAttributes -> String
showsPrec :: Int -> UpdateVirtualInterfaceAttributes -> ShowS
$cshowsPrec :: Int -> UpdateVirtualInterfaceAttributes -> ShowS
Prelude.Show, forall x.
Rep UpdateVirtualInterfaceAttributes x
-> UpdateVirtualInterfaceAttributes
forall x.
UpdateVirtualInterfaceAttributes
-> Rep UpdateVirtualInterfaceAttributes x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep UpdateVirtualInterfaceAttributes x
-> UpdateVirtualInterfaceAttributes
$cfrom :: forall x.
UpdateVirtualInterfaceAttributes
-> Rep UpdateVirtualInterfaceAttributes x
Prelude.Generic)

-- |
-- Create a value of 'UpdateVirtualInterfaceAttributes' 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:
--
-- 'enableSiteLink', 'updateVirtualInterfaceAttributes_enableSiteLink' - Indicates whether to enable or disable SiteLink.
--
-- 'mtu', 'updateVirtualInterfaceAttributes_mtu' - The maximum transmission unit (MTU), in bytes. The supported values are
-- 1500 and 9001. The default value is 1500.
--
-- 'virtualInterfaceName', 'updateVirtualInterfaceAttributes_virtualInterfaceName' - The name of the virtual private interface.
--
-- 'virtualInterfaceId', 'updateVirtualInterfaceAttributes_virtualInterfaceId' - The ID of the virtual private interface.
newUpdateVirtualInterfaceAttributes ::
  -- | 'virtualInterfaceId'
  Prelude.Text ->
  UpdateVirtualInterfaceAttributes
newUpdateVirtualInterfaceAttributes :: Text -> UpdateVirtualInterfaceAttributes
newUpdateVirtualInterfaceAttributes
  Text
pVirtualInterfaceId_ =
    UpdateVirtualInterfaceAttributes'
      { $sel:enableSiteLink:UpdateVirtualInterfaceAttributes' :: Maybe Bool
enableSiteLink =
          forall a. Maybe a
Prelude.Nothing,
        $sel:mtu:UpdateVirtualInterfaceAttributes' :: Maybe Int
mtu = forall a. Maybe a
Prelude.Nothing,
        $sel:virtualInterfaceName:UpdateVirtualInterfaceAttributes' :: Maybe Text
virtualInterfaceName = forall a. Maybe a
Prelude.Nothing,
        $sel:virtualInterfaceId:UpdateVirtualInterfaceAttributes' :: Text
virtualInterfaceId = Text
pVirtualInterfaceId_
      }

-- | Indicates whether to enable or disable SiteLink.
updateVirtualInterfaceAttributes_enableSiteLink :: Lens.Lens' UpdateVirtualInterfaceAttributes (Prelude.Maybe Prelude.Bool)
updateVirtualInterfaceAttributes_enableSiteLink :: Lens' UpdateVirtualInterfaceAttributes (Maybe Bool)
updateVirtualInterfaceAttributes_enableSiteLink = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateVirtualInterfaceAttributes' {Maybe Bool
enableSiteLink :: Maybe Bool
$sel:enableSiteLink:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Bool
enableSiteLink} -> Maybe Bool
enableSiteLink) (\s :: UpdateVirtualInterfaceAttributes
s@UpdateVirtualInterfaceAttributes' {} Maybe Bool
a -> UpdateVirtualInterfaceAttributes
s {$sel:enableSiteLink:UpdateVirtualInterfaceAttributes' :: Maybe Bool
enableSiteLink = Maybe Bool
a} :: UpdateVirtualInterfaceAttributes)

-- | The maximum transmission unit (MTU), in bytes. The supported values are
-- 1500 and 9001. The default value is 1500.
updateVirtualInterfaceAttributes_mtu :: Lens.Lens' UpdateVirtualInterfaceAttributes (Prelude.Maybe Prelude.Int)
updateVirtualInterfaceAttributes_mtu :: Lens' UpdateVirtualInterfaceAttributes (Maybe Int)
updateVirtualInterfaceAttributes_mtu = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateVirtualInterfaceAttributes' {Maybe Int
mtu :: Maybe Int
$sel:mtu:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Int
mtu} -> Maybe Int
mtu) (\s :: UpdateVirtualInterfaceAttributes
s@UpdateVirtualInterfaceAttributes' {} Maybe Int
a -> UpdateVirtualInterfaceAttributes
s {$sel:mtu:UpdateVirtualInterfaceAttributes' :: Maybe Int
mtu = Maybe Int
a} :: UpdateVirtualInterfaceAttributes)

-- | The name of the virtual private interface.
updateVirtualInterfaceAttributes_virtualInterfaceName :: Lens.Lens' UpdateVirtualInterfaceAttributes (Prelude.Maybe Prelude.Text)
updateVirtualInterfaceAttributes_virtualInterfaceName :: Lens' UpdateVirtualInterfaceAttributes (Maybe Text)
updateVirtualInterfaceAttributes_virtualInterfaceName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateVirtualInterfaceAttributes' {Maybe Text
virtualInterfaceName :: Maybe Text
$sel:virtualInterfaceName:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Text
virtualInterfaceName} -> Maybe Text
virtualInterfaceName) (\s :: UpdateVirtualInterfaceAttributes
s@UpdateVirtualInterfaceAttributes' {} Maybe Text
a -> UpdateVirtualInterfaceAttributes
s {$sel:virtualInterfaceName:UpdateVirtualInterfaceAttributes' :: Maybe Text
virtualInterfaceName = Maybe Text
a} :: UpdateVirtualInterfaceAttributes)

-- | The ID of the virtual private interface.
updateVirtualInterfaceAttributes_virtualInterfaceId :: Lens.Lens' UpdateVirtualInterfaceAttributes Prelude.Text
updateVirtualInterfaceAttributes_virtualInterfaceId :: Lens' UpdateVirtualInterfaceAttributes Text
updateVirtualInterfaceAttributes_virtualInterfaceId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateVirtualInterfaceAttributes' {Text
virtualInterfaceId :: Text
$sel:virtualInterfaceId:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Text
virtualInterfaceId} -> Text
virtualInterfaceId) (\s :: UpdateVirtualInterfaceAttributes
s@UpdateVirtualInterfaceAttributes' {} Text
a -> UpdateVirtualInterfaceAttributes
s {$sel:virtualInterfaceId:UpdateVirtualInterfaceAttributes' :: Text
virtualInterfaceId = Text
a} :: UpdateVirtualInterfaceAttributes)

instance
  Core.AWSRequest
    UpdateVirtualInterfaceAttributes
  where
  type
    AWSResponse UpdateVirtualInterfaceAttributes =
      VirtualInterface
  request :: (Service -> Service)
-> UpdateVirtualInterfaceAttributes
-> Request UpdateVirtualInterfaceAttributes
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy UpdateVirtualInterfaceAttributes
-> ClientResponse ClientBody
-> m (Either
        Error
        (ClientResponse (AWSResponse UpdateVirtualInterfaceAttributes)))
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
    UpdateVirtualInterfaceAttributes
  where
  hashWithSalt :: Int -> UpdateVirtualInterfaceAttributes -> Int
hashWithSalt
    Int
_salt
    UpdateVirtualInterfaceAttributes' {Maybe Bool
Maybe Int
Maybe Text
Text
virtualInterfaceId :: Text
virtualInterfaceName :: Maybe Text
mtu :: Maybe Int
enableSiteLink :: Maybe Bool
$sel:virtualInterfaceId:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Text
$sel:virtualInterfaceName:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Text
$sel:mtu:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Int
$sel:enableSiteLink:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Bool
..} =
      Int
_salt
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
enableSiteLink
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Int
mtu
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
virtualInterfaceName
        forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
virtualInterfaceId

instance
  Prelude.NFData
    UpdateVirtualInterfaceAttributes
  where
  rnf :: UpdateVirtualInterfaceAttributes -> ()
rnf UpdateVirtualInterfaceAttributes' {Maybe Bool
Maybe Int
Maybe Text
Text
virtualInterfaceId :: Text
virtualInterfaceName :: Maybe Text
mtu :: Maybe Int
enableSiteLink :: Maybe Bool
$sel:virtualInterfaceId:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Text
$sel:virtualInterfaceName:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Text
$sel:mtu:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Int
$sel:enableSiteLink:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Bool
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
enableSiteLink
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Int
mtu
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
virtualInterfaceName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
virtualInterfaceId

instance
  Data.ToHeaders
    UpdateVirtualInterfaceAttributes
  where
  toHeaders :: UpdateVirtualInterfaceAttributes -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"OvertureService.UpdateVirtualInterfaceAttributes" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON UpdateVirtualInterfaceAttributes where
  toJSON :: UpdateVirtualInterfaceAttributes -> Value
toJSON UpdateVirtualInterfaceAttributes' {Maybe Bool
Maybe Int
Maybe Text
Text
virtualInterfaceId :: Text
virtualInterfaceName :: Maybe Text
mtu :: Maybe Int
enableSiteLink :: Maybe Bool
$sel:virtualInterfaceId:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Text
$sel:virtualInterfaceName:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Text
$sel:mtu:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Int
$sel:enableSiteLink:UpdateVirtualInterfaceAttributes' :: UpdateVirtualInterfaceAttributes -> Maybe Bool
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"enableSiteLink" 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 Bool
enableSiteLink,
            (Key
"mtu" 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 Int
mtu,
            (Key
"virtualInterfaceName" 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
virtualInterfaceName,
            forall a. a -> Maybe a
Prelude.Just
              (Key
"virtualInterfaceId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
virtualInterfaceId)
          ]
      )

instance Data.ToPath UpdateVirtualInterfaceAttributes where
  toPath :: UpdateVirtualInterfaceAttributes -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance
  Data.ToQuery
    UpdateVirtualInterfaceAttributes
  where
  toQuery :: UpdateVirtualInterfaceAttributes -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty