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
  = -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-wafv2-webacl-headers.html>
    HeadersProperty {HeadersProperty -> ()
haddock_workaround_ :: (),
                     -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-wafv2-webacl-headers.html#cfn-wafv2-webacl-headers-matchpattern>
                     HeadersProperty -> HeaderMatchPatternProperty
matchPattern :: HeaderMatchPatternProperty,
                     -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-wafv2-webacl-headers.html#cfn-wafv2-webacl-headers-matchscope>
                     HeadersProperty -> Value Text
matchScope :: (Value Prelude.Text),
                     -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-wafv2-webacl-headers.html#cfn-wafv2-webacl-headers-oversizehandling>
                     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
mkHeadersProperty :: HeaderMatchPatternProperty
-> Value Text -> Value Text -> HeadersProperty
mkHeadersProperty 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
..}