module Stratosphere.Deadline.Fleet.AcceleratorCapabilitiesProperty (
module Exports, AcceleratorCapabilitiesProperty(..),
mkAcceleratorCapabilitiesProperty
) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import {-# SOURCE #-} Stratosphere.Deadline.Fleet.AcceleratorCountRangeProperty as Exports
import {-# SOURCE #-} Stratosphere.Deadline.Fleet.AcceleratorSelectionProperty as Exports
import Stratosphere.ResourceProperties
data AcceleratorCapabilitiesProperty
=
AcceleratorCapabilitiesProperty {AcceleratorCapabilitiesProperty -> ()
haddock_workaround_ :: (),
AcceleratorCapabilitiesProperty
-> Maybe AcceleratorCountRangeProperty
count :: (Prelude.Maybe AcceleratorCountRangeProperty),
AcceleratorCapabilitiesProperty -> [AcceleratorSelectionProperty]
selections :: [AcceleratorSelectionProperty]}
deriving stock (AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty -> Bool
(AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty -> Bool)
-> (AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty -> Bool)
-> Eq AcceleratorCapabilitiesProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty -> Bool
== :: AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty -> Bool
$c/= :: AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty -> Bool
/= :: AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty -> Bool
Prelude.Eq, Int -> AcceleratorCapabilitiesProperty -> ShowS
[AcceleratorCapabilitiesProperty] -> ShowS
AcceleratorCapabilitiesProperty -> String
(Int -> AcceleratorCapabilitiesProperty -> ShowS)
-> (AcceleratorCapabilitiesProperty -> String)
-> ([AcceleratorCapabilitiesProperty] -> ShowS)
-> Show AcceleratorCapabilitiesProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> AcceleratorCapabilitiesProperty -> ShowS
showsPrec :: Int -> AcceleratorCapabilitiesProperty -> ShowS
$cshow :: AcceleratorCapabilitiesProperty -> String
show :: AcceleratorCapabilitiesProperty -> String
$cshowList :: [AcceleratorCapabilitiesProperty] -> ShowS
showList :: [AcceleratorCapabilitiesProperty] -> ShowS
Prelude.Show)
mkAcceleratorCapabilitiesProperty ::
[AcceleratorSelectionProperty] -> AcceleratorCapabilitiesProperty
mkAcceleratorCapabilitiesProperty :: [AcceleratorSelectionProperty] -> AcceleratorCapabilitiesProperty
mkAcceleratorCapabilitiesProperty [AcceleratorSelectionProperty]
selections
= AcceleratorCapabilitiesProperty
{haddock_workaround_ :: ()
haddock_workaround_ = (), selections :: [AcceleratorSelectionProperty]
selections = [AcceleratorSelectionProperty]
selections,
count :: Maybe AcceleratorCountRangeProperty
count = Maybe AcceleratorCountRangeProperty
forall a. Maybe a
Prelude.Nothing}
instance ToResourceProperties AcceleratorCapabilitiesProperty where
toResourceProperties :: AcceleratorCapabilitiesProperty -> ResourceProperties
toResourceProperties AcceleratorCapabilitiesProperty {[AcceleratorSelectionProperty]
Maybe AcceleratorCountRangeProperty
()
haddock_workaround_ :: AcceleratorCapabilitiesProperty -> ()
count :: AcceleratorCapabilitiesProperty
-> Maybe AcceleratorCountRangeProperty
selections :: AcceleratorCapabilitiesProperty -> [AcceleratorSelectionProperty]
haddock_workaround_ :: ()
count :: Maybe AcceleratorCountRangeProperty
selections :: [AcceleratorSelectionProperty]
..}
= ResourceProperties
{awsType :: Text
awsType = Text
"AWS::Deadline::Fleet.AcceleratorCapabilities",
supportsTags :: Bool
supportsTags = Bool
Prelude.False,
properties :: Object
properties = [Item Object] -> Object
forall l. IsList l => [Item l] -> l
Prelude.fromList
([(Key, Value)] -> [(Key, Value)] -> [(Key, Value)]
forall a. Semigroup a => a -> a -> a
(Prelude.<>)
[Key
"Selections" Key -> [AcceleratorSelectionProperty] -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= [AcceleratorSelectionProperty]
selections]
([Maybe (Key, Value)] -> [(Key, Value)]
forall a. [Maybe a] -> [a]
Prelude.catMaybes [Key -> AcceleratorCountRangeProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"Count" (AcceleratorCountRangeProperty -> (Key, Value))
-> Maybe AcceleratorCountRangeProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe AcceleratorCountRangeProperty
count]))}
instance JSON.ToJSON AcceleratorCapabilitiesProperty where
toJSON :: AcceleratorCapabilitiesProperty -> Value
toJSON AcceleratorCapabilitiesProperty {[AcceleratorSelectionProperty]
Maybe AcceleratorCountRangeProperty
()
haddock_workaround_ :: AcceleratorCapabilitiesProperty -> ()
count :: AcceleratorCapabilitiesProperty
-> Maybe AcceleratorCountRangeProperty
selections :: AcceleratorCapabilitiesProperty -> [AcceleratorSelectionProperty]
haddock_workaround_ :: ()
count :: Maybe AcceleratorCountRangeProperty
selections :: [AcceleratorSelectionProperty]
..}
= [(Key, Value)] -> Value
JSON.object
([Item [(Key, Value)]] -> [(Key, Value)]
forall l. IsList l => [Item l] -> l
Prelude.fromList
([(Key, Value)] -> [(Key, Value)] -> [(Key, Value)]
forall a. Semigroup a => a -> a -> a
(Prelude.<>)
[Key
"Selections" Key -> [AcceleratorSelectionProperty] -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= [AcceleratorSelectionProperty]
selections]
([Maybe (Key, Value)] -> [(Key, Value)]
forall a. [Maybe a] -> [a]
Prelude.catMaybes [Key -> AcceleratorCountRangeProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"Count" (AcceleratorCountRangeProperty -> (Key, Value))
-> Maybe AcceleratorCountRangeProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe AcceleratorCountRangeProperty
count])))
instance Property "Count" AcceleratorCapabilitiesProperty where
type PropertyType "Count" AcceleratorCapabilitiesProperty = AcceleratorCountRangeProperty
set :: PropertyType "Count" AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty
set PropertyType "Count" AcceleratorCapabilitiesProperty
newValue AcceleratorCapabilitiesProperty {[AcceleratorSelectionProperty]
Maybe AcceleratorCountRangeProperty
()
haddock_workaround_ :: AcceleratorCapabilitiesProperty -> ()
count :: AcceleratorCapabilitiesProperty
-> Maybe AcceleratorCountRangeProperty
selections :: AcceleratorCapabilitiesProperty -> [AcceleratorSelectionProperty]
haddock_workaround_ :: ()
count :: Maybe AcceleratorCountRangeProperty
selections :: [AcceleratorSelectionProperty]
..}
= AcceleratorCapabilitiesProperty
{count :: Maybe AcceleratorCountRangeProperty
count = AcceleratorCountRangeProperty
-> Maybe AcceleratorCountRangeProperty
forall a. a -> Maybe a
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure PropertyType "Count" AcceleratorCapabilitiesProperty
AcceleratorCountRangeProperty
newValue, [AcceleratorSelectionProperty]
()
haddock_workaround_ :: ()
selections :: [AcceleratorSelectionProperty]
haddock_workaround_ :: ()
selections :: [AcceleratorSelectionProperty]
..}
instance Property "Selections" AcceleratorCapabilitiesProperty where
type PropertyType "Selections" AcceleratorCapabilitiesProperty = [AcceleratorSelectionProperty]
set :: PropertyType "Selections" AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty
-> AcceleratorCapabilitiesProperty
set PropertyType "Selections" AcceleratorCapabilitiesProperty
newValue AcceleratorCapabilitiesProperty {[AcceleratorSelectionProperty]
Maybe AcceleratorCountRangeProperty
()
haddock_workaround_ :: AcceleratorCapabilitiesProperty -> ()
count :: AcceleratorCapabilitiesProperty
-> Maybe AcceleratorCountRangeProperty
selections :: AcceleratorCapabilitiesProperty -> [AcceleratorSelectionProperty]
haddock_workaround_ :: ()
count :: Maybe AcceleratorCountRangeProperty
selections :: [AcceleratorSelectionProperty]
..}
= AcceleratorCapabilitiesProperty {selections :: [AcceleratorSelectionProperty]
selections = [AcceleratorSelectionProperty]
PropertyType "Selections" AcceleratorCapabilitiesProperty
newValue, Maybe AcceleratorCountRangeProperty
()
haddock_workaround_ :: ()
count :: Maybe AcceleratorCountRangeProperty
haddock_workaround_ :: ()
count :: Maybe AcceleratorCountRangeProperty
..}