{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DerivingStrategies #-}
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
{-# LANGUAGE LambdaCase #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE PatternSynonyms #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
module Amazonka.ECS.Types.ApplicationProtocol
( ApplicationProtocol
( ..,
ApplicationProtocol_Grpc,
ApplicationProtocol_Http,
ApplicationProtocol_Http2
),
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
newtype ApplicationProtocol = ApplicationProtocol'
{ ApplicationProtocol -> Text
fromApplicationProtocol ::
Data.Text
}
deriving stock
( Int -> ApplicationProtocol -> ShowS
[ApplicationProtocol] -> ShowS
ApplicationProtocol -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ApplicationProtocol] -> ShowS
$cshowList :: [ApplicationProtocol] -> ShowS
show :: ApplicationProtocol -> String
$cshow :: ApplicationProtocol -> String
showsPrec :: Int -> ApplicationProtocol -> ShowS
$cshowsPrec :: Int -> ApplicationProtocol -> ShowS
Prelude.Show,
ReadPrec [ApplicationProtocol]
ReadPrec ApplicationProtocol
Int -> ReadS ApplicationProtocol
ReadS [ApplicationProtocol]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ApplicationProtocol]
$creadListPrec :: ReadPrec [ApplicationProtocol]
readPrec :: ReadPrec ApplicationProtocol
$creadPrec :: ReadPrec ApplicationProtocol
readList :: ReadS [ApplicationProtocol]
$creadList :: ReadS [ApplicationProtocol]
readsPrec :: Int -> ReadS ApplicationProtocol
$creadsPrec :: Int -> ReadS ApplicationProtocol
Prelude.Read,
ApplicationProtocol -> ApplicationProtocol -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ApplicationProtocol -> ApplicationProtocol -> Bool
$c/= :: ApplicationProtocol -> ApplicationProtocol -> Bool
== :: ApplicationProtocol -> ApplicationProtocol -> Bool
$c== :: ApplicationProtocol -> ApplicationProtocol -> Bool
Prelude.Eq,
Eq ApplicationProtocol
ApplicationProtocol -> ApplicationProtocol -> Bool
ApplicationProtocol -> ApplicationProtocol -> Ordering
ApplicationProtocol -> ApplicationProtocol -> ApplicationProtocol
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: ApplicationProtocol -> ApplicationProtocol -> ApplicationProtocol
$cmin :: ApplicationProtocol -> ApplicationProtocol -> ApplicationProtocol
max :: ApplicationProtocol -> ApplicationProtocol -> ApplicationProtocol
$cmax :: ApplicationProtocol -> ApplicationProtocol -> ApplicationProtocol
>= :: ApplicationProtocol -> ApplicationProtocol -> Bool
$c>= :: ApplicationProtocol -> ApplicationProtocol -> Bool
> :: ApplicationProtocol -> ApplicationProtocol -> Bool
$c> :: ApplicationProtocol -> ApplicationProtocol -> Bool
<= :: ApplicationProtocol -> ApplicationProtocol -> Bool
$c<= :: ApplicationProtocol -> ApplicationProtocol -> Bool
< :: ApplicationProtocol -> ApplicationProtocol -> Bool
$c< :: ApplicationProtocol -> ApplicationProtocol -> Bool
compare :: ApplicationProtocol -> ApplicationProtocol -> Ordering
$ccompare :: ApplicationProtocol -> ApplicationProtocol -> Ordering
Prelude.Ord,
forall x. Rep ApplicationProtocol x -> ApplicationProtocol
forall x. ApplicationProtocol -> Rep ApplicationProtocol x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ApplicationProtocol x -> ApplicationProtocol
$cfrom :: forall x. ApplicationProtocol -> Rep ApplicationProtocol x
Prelude.Generic
)
deriving newtype
( Eq ApplicationProtocol
Int -> ApplicationProtocol -> Int
ApplicationProtocol -> Int
forall a. Eq a -> (Int -> a -> Int) -> (a -> Int) -> Hashable a
hash :: ApplicationProtocol -> Int
$chash :: ApplicationProtocol -> Int
hashWithSalt :: Int -> ApplicationProtocol -> Int
$chashWithSalt :: Int -> ApplicationProtocol -> Int
Prelude.Hashable,
ApplicationProtocol -> ()
forall a. (a -> ()) -> NFData a
rnf :: ApplicationProtocol -> ()
$crnf :: ApplicationProtocol -> ()
Prelude.NFData,
Text -> Either String ApplicationProtocol
forall a. (Text -> Either String a) -> FromText a
fromText :: Text -> Either String ApplicationProtocol
$cfromText :: Text -> Either String ApplicationProtocol
Data.FromText,
ApplicationProtocol -> Text
forall a. (a -> Text) -> ToText a
toText :: ApplicationProtocol -> Text
$ctoText :: ApplicationProtocol -> Text
Data.ToText,
ApplicationProtocol -> ByteString
forall a. (a -> ByteString) -> ToByteString a
toBS :: ApplicationProtocol -> ByteString
$ctoBS :: ApplicationProtocol -> ByteString
Data.ToByteString,
ApplicationProtocol -> ByteStringBuilder
forall a. (a -> ByteStringBuilder) -> ToLog a
build :: ApplicationProtocol -> ByteStringBuilder
$cbuild :: ApplicationProtocol -> ByteStringBuilder
Data.ToLog,
HeaderName -> ApplicationProtocol -> [Header]
forall a. (HeaderName -> a -> [Header]) -> ToHeader a
toHeader :: HeaderName -> ApplicationProtocol -> [Header]
$ctoHeader :: HeaderName -> ApplicationProtocol -> [Header]
Data.ToHeader,
ApplicationProtocol -> QueryString
forall a. (a -> QueryString) -> ToQuery a
toQuery :: ApplicationProtocol -> QueryString
$ctoQuery :: ApplicationProtocol -> QueryString
Data.ToQuery,
Value -> Parser [ApplicationProtocol]
Value -> Parser ApplicationProtocol
forall a.
(Value -> Parser a) -> (Value -> Parser [a]) -> FromJSON a
parseJSONList :: Value -> Parser [ApplicationProtocol]
$cparseJSONList :: Value -> Parser [ApplicationProtocol]
parseJSON :: Value -> Parser ApplicationProtocol
$cparseJSON :: Value -> Parser ApplicationProtocol
Data.FromJSON,
FromJSONKeyFunction [ApplicationProtocol]
FromJSONKeyFunction ApplicationProtocol
forall a.
FromJSONKeyFunction a -> FromJSONKeyFunction [a] -> FromJSONKey a
fromJSONKeyList :: FromJSONKeyFunction [ApplicationProtocol]
$cfromJSONKeyList :: FromJSONKeyFunction [ApplicationProtocol]
fromJSONKey :: FromJSONKeyFunction ApplicationProtocol
$cfromJSONKey :: FromJSONKeyFunction ApplicationProtocol
Data.FromJSONKey,
[ApplicationProtocol] -> Encoding
[ApplicationProtocol] -> Value
ApplicationProtocol -> Encoding
ApplicationProtocol -> Value
forall a.
(a -> Value)
-> (a -> Encoding)
-> ([a] -> Value)
-> ([a] -> Encoding)
-> ToJSON a
toEncodingList :: [ApplicationProtocol] -> Encoding
$ctoEncodingList :: [ApplicationProtocol] -> Encoding
toJSONList :: [ApplicationProtocol] -> Value
$ctoJSONList :: [ApplicationProtocol] -> Value
toEncoding :: ApplicationProtocol -> Encoding
$ctoEncoding :: ApplicationProtocol -> Encoding
toJSON :: ApplicationProtocol -> Value
$ctoJSON :: ApplicationProtocol -> Value
Data.ToJSON,
ToJSONKeyFunction [ApplicationProtocol]
ToJSONKeyFunction ApplicationProtocol
forall a.
ToJSONKeyFunction a -> ToJSONKeyFunction [a] -> ToJSONKey a
toJSONKeyList :: ToJSONKeyFunction [ApplicationProtocol]
$ctoJSONKeyList :: ToJSONKeyFunction [ApplicationProtocol]
toJSONKey :: ToJSONKeyFunction ApplicationProtocol
$ctoJSONKey :: ToJSONKeyFunction ApplicationProtocol
Data.ToJSONKey,
[Node] -> Either String ApplicationProtocol
forall a. ([Node] -> Either String a) -> FromXML a
parseXML :: [Node] -> Either String ApplicationProtocol
$cparseXML :: [Node] -> Either String ApplicationProtocol
Data.FromXML,
ApplicationProtocol -> XML
forall a. (a -> XML) -> ToXML a
toXML :: ApplicationProtocol -> XML
$ctoXML :: ApplicationProtocol -> XML
Data.ToXML
)
pattern ApplicationProtocol_Grpc :: ApplicationProtocol
pattern $bApplicationProtocol_Grpc :: ApplicationProtocol
$mApplicationProtocol_Grpc :: forall {r}.
ApplicationProtocol -> ((# #) -> r) -> ((# #) -> r) -> r
ApplicationProtocol_Grpc = ApplicationProtocol' "grpc"
pattern ApplicationProtocol_Http :: ApplicationProtocol
pattern $bApplicationProtocol_Http :: ApplicationProtocol
$mApplicationProtocol_Http :: forall {r}.
ApplicationProtocol -> ((# #) -> r) -> ((# #) -> r) -> r
ApplicationProtocol_Http = ApplicationProtocol' "http"
pattern ApplicationProtocol_Http2 :: ApplicationProtocol
pattern $bApplicationProtocol_Http2 :: ApplicationProtocol
$mApplicationProtocol_Http2 :: forall {r}.
ApplicationProtocol -> ((# #) -> r) -> ((# #) -> r) -> r
ApplicationProtocol_Http2 = ApplicationProtocol' "http2"
{-# COMPLETE
ApplicationProtocol_Grpc,
ApplicationProtocol_Http,
ApplicationProtocol_Http2,
ApplicationProtocol'
#-}