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

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

-- |
-- Module      : Amazonka.EC2.Types.EnaSrdUdpSpecification
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
module Amazonka.EC2.Types.EnaSrdUdpSpecification 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

-- | ENA Express is compatible with both TCP and UDP transport protocols.
-- When it’s enabled, TCP traffic automatically uses it. However, some
-- UDP-based applications are designed to handle network packets that are
-- out of order, without a need for retransmission, such as live video
-- broadcasting or other near-real-time applications. For UDP traffic, you
-- can specify whether to use ENA Express, based on your application
-- environment needs.
--
-- /See:/ 'newEnaSrdUdpSpecification' smart constructor.
data EnaSrdUdpSpecification = EnaSrdUdpSpecification'
  { -- | Indicates whether UDP traffic uses ENA Express. To specify this setting,
    -- you must first enable ENA Express.
    EnaSrdUdpSpecification -> Maybe Bool
enaSrdUdpEnabled :: Prelude.Maybe Prelude.Bool
  }
  deriving (EnaSrdUdpSpecification -> EnaSrdUdpSpecification -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: EnaSrdUdpSpecification -> EnaSrdUdpSpecification -> Bool
$c/= :: EnaSrdUdpSpecification -> EnaSrdUdpSpecification -> Bool
== :: EnaSrdUdpSpecification -> EnaSrdUdpSpecification -> Bool
$c== :: EnaSrdUdpSpecification -> EnaSrdUdpSpecification -> Bool
Prelude.Eq, ReadPrec [EnaSrdUdpSpecification]
ReadPrec EnaSrdUdpSpecification
Int -> ReadS EnaSrdUdpSpecification
ReadS [EnaSrdUdpSpecification]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [EnaSrdUdpSpecification]
$creadListPrec :: ReadPrec [EnaSrdUdpSpecification]
readPrec :: ReadPrec EnaSrdUdpSpecification
$creadPrec :: ReadPrec EnaSrdUdpSpecification
readList :: ReadS [EnaSrdUdpSpecification]
$creadList :: ReadS [EnaSrdUdpSpecification]
readsPrec :: Int -> ReadS EnaSrdUdpSpecification
$creadsPrec :: Int -> ReadS EnaSrdUdpSpecification
Prelude.Read, Int -> EnaSrdUdpSpecification -> ShowS
[EnaSrdUdpSpecification] -> ShowS
EnaSrdUdpSpecification -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [EnaSrdUdpSpecification] -> ShowS
$cshowList :: [EnaSrdUdpSpecification] -> ShowS
show :: EnaSrdUdpSpecification -> String
$cshow :: EnaSrdUdpSpecification -> String
showsPrec :: Int -> EnaSrdUdpSpecification -> ShowS
$cshowsPrec :: Int -> EnaSrdUdpSpecification -> ShowS
Prelude.Show, forall x. Rep EnaSrdUdpSpecification x -> EnaSrdUdpSpecification
forall x. EnaSrdUdpSpecification -> Rep EnaSrdUdpSpecification x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep EnaSrdUdpSpecification x -> EnaSrdUdpSpecification
$cfrom :: forall x. EnaSrdUdpSpecification -> Rep EnaSrdUdpSpecification x
Prelude.Generic)

-- |
-- Create a value of 'EnaSrdUdpSpecification' 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:
--
-- 'enaSrdUdpEnabled', 'enaSrdUdpSpecification_enaSrdUdpEnabled' - Indicates whether UDP traffic uses ENA Express. To specify this setting,
-- you must first enable ENA Express.
newEnaSrdUdpSpecification ::
  EnaSrdUdpSpecification
newEnaSrdUdpSpecification :: EnaSrdUdpSpecification
newEnaSrdUdpSpecification =
  EnaSrdUdpSpecification'
    { $sel:enaSrdUdpEnabled:EnaSrdUdpSpecification' :: Maybe Bool
enaSrdUdpEnabled =
        forall a. Maybe a
Prelude.Nothing
    }

-- | Indicates whether UDP traffic uses ENA Express. To specify this setting,
-- you must first enable ENA Express.
enaSrdUdpSpecification_enaSrdUdpEnabled :: Lens.Lens' EnaSrdUdpSpecification (Prelude.Maybe Prelude.Bool)
enaSrdUdpSpecification_enaSrdUdpEnabled :: Lens' EnaSrdUdpSpecification (Maybe Bool)
enaSrdUdpSpecification_enaSrdUdpEnabled = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EnaSrdUdpSpecification' {Maybe Bool
enaSrdUdpEnabled :: Maybe Bool
$sel:enaSrdUdpEnabled:EnaSrdUdpSpecification' :: EnaSrdUdpSpecification -> Maybe Bool
enaSrdUdpEnabled} -> Maybe Bool
enaSrdUdpEnabled) (\s :: EnaSrdUdpSpecification
s@EnaSrdUdpSpecification' {} Maybe Bool
a -> EnaSrdUdpSpecification
s {$sel:enaSrdUdpEnabled:EnaSrdUdpSpecification' :: Maybe Bool
enaSrdUdpEnabled = Maybe Bool
a} :: EnaSrdUdpSpecification)

instance Prelude.Hashable EnaSrdUdpSpecification where
  hashWithSalt :: Int -> EnaSrdUdpSpecification -> Int
hashWithSalt Int
_salt EnaSrdUdpSpecification' {Maybe Bool
enaSrdUdpEnabled :: Maybe Bool
$sel:enaSrdUdpEnabled:EnaSrdUdpSpecification' :: EnaSrdUdpSpecification -> Maybe Bool
..} =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Bool
enaSrdUdpEnabled

instance Prelude.NFData EnaSrdUdpSpecification where
  rnf :: EnaSrdUdpSpecification -> ()
rnf EnaSrdUdpSpecification' {Maybe Bool
enaSrdUdpEnabled :: Maybe Bool
$sel:enaSrdUdpEnabled:EnaSrdUdpSpecification' :: EnaSrdUdpSpecification -> Maybe Bool
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Bool
enaSrdUdpEnabled

instance Data.ToQuery EnaSrdUdpSpecification where
  toQuery :: EnaSrdUdpSpecification -> QueryString
toQuery EnaSrdUdpSpecification' {Maybe Bool
enaSrdUdpEnabled :: Maybe Bool
$sel:enaSrdUdpEnabled:EnaSrdUdpSpecification' :: EnaSrdUdpSpecification -> Maybe Bool
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ByteString
"EnaSrdUdpEnabled" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Bool
enaSrdUdpEnabled]