module Stratosphere.WAFv2.WebACL.HeadersProperty (
module Exports, HeadersProperty(..), mkHeadersProperty
) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import {-# SOURCE #-} Stratosphere.WAFv2.WebACL.HeaderMatchPatternProperty as Exports
import Stratosphere.ResourceProperties
import Stratosphere.Value
data
=
{HeadersProperty -> ()
haddock_workaround_ :: (),
HeadersProperty -> HeaderMatchPatternProperty
matchPattern :: HeaderMatchPatternProperty,
HeadersProperty -> Value Text
matchScope :: (Value Prelude.Text),
HeadersProperty -> Value Text
oversizeHandling :: (Value Prelude.Text)}
deriving stock (HeadersProperty -> HeadersProperty -> Bool
(HeadersProperty -> HeadersProperty -> Bool)
-> (HeadersProperty -> HeadersProperty -> Bool)
-> Eq HeadersProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: HeadersProperty -> HeadersProperty -> Bool
== :: HeadersProperty -> HeadersProperty -> Bool
$c/= :: HeadersProperty -> HeadersProperty -> Bool
/= :: HeadersProperty -> HeadersProperty -> Bool
Prelude.Eq, Int -> HeadersProperty -> ShowS
[HeadersProperty] -> ShowS
HeadersProperty -> String
(Int -> HeadersProperty -> ShowS)
-> (HeadersProperty -> String)
-> ([HeadersProperty] -> ShowS)
-> Show HeadersProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> HeadersProperty -> ShowS
showsPrec :: Int -> HeadersProperty -> ShowS
$cshow :: HeadersProperty -> String
show :: HeadersProperty -> String
$cshowList :: [HeadersProperty] -> ShowS
showList :: [HeadersProperty] -> ShowS
Prelude.Show)
mkHeadersProperty ::
HeaderMatchPatternProperty
-> Value Prelude.Text -> Value Prelude.Text -> HeadersProperty
HeaderMatchPatternProperty
matchPattern Value Text
matchScope Value Text
oversizeHandling
= HeadersProperty
{haddock_workaround_ :: ()
haddock_workaround_ = (), matchPattern :: HeaderMatchPatternProperty
matchPattern = HeaderMatchPatternProperty
matchPattern,
matchScope :: Value Text
matchScope = Value Text
matchScope, oversizeHandling :: Value Text
oversizeHandling = Value Text
oversizeHandling}
instance ToResourceProperties HeadersProperty where
toResourceProperties :: HeadersProperty -> ResourceProperties
toResourceProperties HeadersProperty {()
Value Text
HeaderMatchPatternProperty
haddock_workaround_ :: HeadersProperty -> ()
matchPattern :: HeadersProperty -> HeaderMatchPatternProperty
matchScope :: HeadersProperty -> Value Text
oversizeHandling :: HeadersProperty -> Value Text
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
matchScope :: Value Text
oversizeHandling :: Value Text
..}
= ResourceProperties
{awsType :: Text
awsType = Text
"AWS::WAFv2::WebACL.Headers",
supportsTags :: Bool
supportsTags = Bool
Prelude.False,
properties :: Object
properties = [Key
"MatchPattern" Key -> HeaderMatchPatternProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= HeaderMatchPatternProperty
matchPattern,
Key
"MatchScope" Key -> Value Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Text
matchScope,
Key
"OversizeHandling" Key -> Value Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Text
oversizeHandling]}
instance JSON.ToJSON HeadersProperty where
toJSON :: HeadersProperty -> Value
toJSON HeadersProperty {()
Value Text
HeaderMatchPatternProperty
haddock_workaround_ :: HeadersProperty -> ()
matchPattern :: HeadersProperty -> HeaderMatchPatternProperty
matchScope :: HeadersProperty -> Value Text
oversizeHandling :: HeadersProperty -> Value Text
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
matchScope :: Value Text
oversizeHandling :: Value Text
..}
= [(Key, Value)] -> Value
JSON.object
[Key
"MatchPattern" Key -> HeaderMatchPatternProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= HeaderMatchPatternProperty
matchPattern,
Key
"MatchScope" Key -> Value Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Text
matchScope,
Key
"OversizeHandling" Key -> Value Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Text
oversizeHandling]
instance Property "MatchPattern" HeadersProperty where
type PropertyType "MatchPattern" HeadersProperty = HeaderMatchPatternProperty
set :: PropertyType "MatchPattern" HeadersProperty
-> HeadersProperty -> HeadersProperty
set PropertyType "MatchPattern" HeadersProperty
newValue HeadersProperty {()
Value Text
HeaderMatchPatternProperty
haddock_workaround_ :: HeadersProperty -> ()
matchPattern :: HeadersProperty -> HeaderMatchPatternProperty
matchScope :: HeadersProperty -> Value Text
oversizeHandling :: HeadersProperty -> Value Text
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
matchScope :: Value Text
oversizeHandling :: Value Text
..}
= HeadersProperty {matchPattern :: HeaderMatchPatternProperty
matchPattern = PropertyType "MatchPattern" HeadersProperty
HeaderMatchPatternProperty
newValue, ()
Value Text
haddock_workaround_ :: ()
matchScope :: Value Text
oversizeHandling :: Value Text
haddock_workaround_ :: ()
matchScope :: Value Text
oversizeHandling :: Value Text
..}
instance Property "MatchScope" HeadersProperty where
type PropertyType "MatchScope" HeadersProperty = Value Prelude.Text
set :: PropertyType "MatchScope" HeadersProperty
-> HeadersProperty -> HeadersProperty
set PropertyType "MatchScope" HeadersProperty
newValue HeadersProperty {()
Value Text
HeaderMatchPatternProperty
haddock_workaround_ :: HeadersProperty -> ()
matchPattern :: HeadersProperty -> HeaderMatchPatternProperty
matchScope :: HeadersProperty -> Value Text
oversizeHandling :: HeadersProperty -> Value Text
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
matchScope :: Value Text
oversizeHandling :: Value Text
..}
= HeadersProperty {matchScope :: Value Text
matchScope = PropertyType "MatchScope" HeadersProperty
Value Text
newValue, ()
Value Text
HeaderMatchPatternProperty
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
oversizeHandling :: Value Text
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
oversizeHandling :: Value Text
..}
instance Property "OversizeHandling" HeadersProperty where
type PropertyType "OversizeHandling" HeadersProperty = Value Prelude.Text
set :: PropertyType "OversizeHandling" HeadersProperty
-> HeadersProperty -> HeadersProperty
set PropertyType "OversizeHandling" HeadersProperty
newValue HeadersProperty {()
Value Text
HeaderMatchPatternProperty
haddock_workaround_ :: HeadersProperty -> ()
matchPattern :: HeadersProperty -> HeaderMatchPatternProperty
matchScope :: HeadersProperty -> Value Text
oversizeHandling :: HeadersProperty -> Value Text
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
matchScope :: Value Text
oversizeHandling :: Value Text
..}
= HeadersProperty {oversizeHandling :: Value Text
oversizeHandling = PropertyType "OversizeHandling" HeadersProperty
Value Text
newValue, ()
Value Text
HeaderMatchPatternProperty
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
matchScope :: Value Text
haddock_workaround_ :: ()
matchPattern :: HeaderMatchPatternProperty
matchScope :: Value Text
..}