module Stratosphere.FMS.Policy.PortRangeProperty (
        PortRangeProperty(..), mkPortRangeProperty
    ) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import Stratosphere.ResourceProperties
import Stratosphere.Value
data PortRangeProperty
  = -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-fms-policy-portrange.html>
    PortRangeProperty {PortRangeProperty -> ()
haddock_workaround_ :: (),
                       -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-fms-policy-portrange.html#cfn-fms-policy-portrange-from>
                       PortRangeProperty -> Value Integer
from :: (Value Prelude.Integer),
                       -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-fms-policy-portrange.html#cfn-fms-policy-portrange-to>
                       PortRangeProperty -> Value Integer
to :: (Value Prelude.Integer)}
  deriving stock (PortRangeProperty -> PortRangeProperty -> Bool
(PortRangeProperty -> PortRangeProperty -> Bool)
-> (PortRangeProperty -> PortRangeProperty -> Bool)
-> Eq PortRangeProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: PortRangeProperty -> PortRangeProperty -> Bool
== :: PortRangeProperty -> PortRangeProperty -> Bool
$c/= :: PortRangeProperty -> PortRangeProperty -> Bool
/= :: PortRangeProperty -> PortRangeProperty -> Bool
Prelude.Eq, Int -> PortRangeProperty -> ShowS
[PortRangeProperty] -> ShowS
PortRangeProperty -> String
(Int -> PortRangeProperty -> ShowS)
-> (PortRangeProperty -> String)
-> ([PortRangeProperty] -> ShowS)
-> Show PortRangeProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> PortRangeProperty -> ShowS
showsPrec :: Int -> PortRangeProperty -> ShowS
$cshow :: PortRangeProperty -> String
show :: PortRangeProperty -> String
$cshowList :: [PortRangeProperty] -> ShowS
showList :: [PortRangeProperty] -> ShowS
Prelude.Show)
mkPortRangeProperty ::
  Value Prelude.Integer -> Value Prelude.Integer -> PortRangeProperty
mkPortRangeProperty :: Value Integer -> Value Integer -> PortRangeProperty
mkPortRangeProperty Value Integer
from Value Integer
to
  = PortRangeProperty
      {haddock_workaround_ :: ()
haddock_workaround_ = (), from :: Value Integer
from = Value Integer
from, to :: Value Integer
to = Value Integer
to}
instance ToResourceProperties PortRangeProperty where
  toResourceProperties :: PortRangeProperty -> ResourceProperties
toResourceProperties PortRangeProperty {()
Value Integer
haddock_workaround_ :: PortRangeProperty -> ()
from :: PortRangeProperty -> Value Integer
to :: PortRangeProperty -> Value Integer
haddock_workaround_ :: ()
from :: Value Integer
to :: Value Integer
..}
    = ResourceProperties
        {awsType :: Text
awsType = Text
"AWS::FMS::Policy.PortRange",
         supportsTags :: Bool
supportsTags = Bool
Prelude.False,
         properties :: Object
properties = [Key
"From" Key -> Value Integer -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Integer
from, Key
"To" Key -> Value Integer -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Integer
to]}
instance JSON.ToJSON PortRangeProperty where
  toJSON :: PortRangeProperty -> Value
toJSON PortRangeProperty {()
Value Integer
haddock_workaround_ :: PortRangeProperty -> ()
from :: PortRangeProperty -> Value Integer
to :: PortRangeProperty -> Value Integer
haddock_workaround_ :: ()
from :: Value Integer
to :: Value Integer
..}
    = [(Key, Value)] -> Value
JSON.object [Key
"From" Key -> Value Integer -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Integer
from, Key
"To" Key -> Value Integer -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Integer
to]
instance Property "From" PortRangeProperty where
  type PropertyType "From" PortRangeProperty = Value Prelude.Integer
  set :: PropertyType "From" PortRangeProperty
-> PortRangeProperty -> PortRangeProperty
set PropertyType "From" PortRangeProperty
newValue PortRangeProperty {()
Value Integer
haddock_workaround_ :: PortRangeProperty -> ()
from :: PortRangeProperty -> Value Integer
to :: PortRangeProperty -> Value Integer
haddock_workaround_ :: ()
from :: Value Integer
to :: Value Integer
..}
    = PortRangeProperty {from :: Value Integer
from = PropertyType "From" PortRangeProperty
Value Integer
newValue, ()
Value Integer
haddock_workaround_ :: ()
to :: Value Integer
haddock_workaround_ :: ()
to :: Value Integer
..}
instance Property "To" PortRangeProperty where
  type PropertyType "To" PortRangeProperty = Value Prelude.Integer
  set :: PropertyType "To" PortRangeProperty
-> PortRangeProperty -> PortRangeProperty
set PropertyType "To" PortRangeProperty
newValue PortRangeProperty {()
Value Integer
haddock_workaround_ :: PortRangeProperty -> ()
from :: PortRangeProperty -> Value Integer
to :: PortRangeProperty -> Value Integer
haddock_workaround_ :: ()
from :: Value Integer
to :: Value Integer
..}
    = PortRangeProperty {to :: Value Integer
to = PropertyType "To" PortRangeProperty
Value Integer
newValue, ()
Value Integer
haddock_workaround_ :: ()
from :: Value Integer
haddock_workaround_ :: ()
from :: Value Integer
..}