module Stratosphere.AppSync.DataSource.AuthorizationConfigProperty (
module Exports, AuthorizationConfigProperty(..),
mkAuthorizationConfigProperty
) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import {-# SOURCE #-} Stratosphere.AppSync.DataSource.AwsIamConfigProperty as Exports
import Stratosphere.ResourceProperties
import Stratosphere.Value
data AuthorizationConfigProperty
=
AuthorizationConfigProperty {AuthorizationConfigProperty -> ()
haddock_workaround_ :: (),
AuthorizationConfigProperty -> Value Text
authorizationType :: (Value Prelude.Text),
AuthorizationConfigProperty -> Maybe AwsIamConfigProperty
awsIamConfig :: (Prelude.Maybe AwsIamConfigProperty)}
deriving stock (AuthorizationConfigProperty -> AuthorizationConfigProperty -> Bool
(AuthorizationConfigProperty
-> AuthorizationConfigProperty -> Bool)
-> (AuthorizationConfigProperty
-> AuthorizationConfigProperty -> Bool)
-> Eq AuthorizationConfigProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: AuthorizationConfigProperty -> AuthorizationConfigProperty -> Bool
== :: AuthorizationConfigProperty -> AuthorizationConfigProperty -> Bool
$c/= :: AuthorizationConfigProperty -> AuthorizationConfigProperty -> Bool
/= :: AuthorizationConfigProperty -> AuthorizationConfigProperty -> Bool
Prelude.Eq, Int -> AuthorizationConfigProperty -> ShowS
[AuthorizationConfigProperty] -> ShowS
AuthorizationConfigProperty -> String
(Int -> AuthorizationConfigProperty -> ShowS)
-> (AuthorizationConfigProperty -> String)
-> ([AuthorizationConfigProperty] -> ShowS)
-> Show AuthorizationConfigProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> AuthorizationConfigProperty -> ShowS
showsPrec :: Int -> AuthorizationConfigProperty -> ShowS
$cshow :: AuthorizationConfigProperty -> String
show :: AuthorizationConfigProperty -> String
$cshowList :: [AuthorizationConfigProperty] -> ShowS
showList :: [AuthorizationConfigProperty] -> ShowS
Prelude.Show)
mkAuthorizationConfigProperty ::
Value Prelude.Text -> AuthorizationConfigProperty
mkAuthorizationConfigProperty :: Value Text -> AuthorizationConfigProperty
mkAuthorizationConfigProperty Value Text
authorizationType
= AuthorizationConfigProperty
{haddock_workaround_ :: ()
haddock_workaround_ = (), authorizationType :: Value Text
authorizationType = Value Text
authorizationType,
awsIamConfig :: Maybe AwsIamConfigProperty
awsIamConfig = Maybe AwsIamConfigProperty
forall a. Maybe a
Prelude.Nothing}
instance ToResourceProperties AuthorizationConfigProperty where
toResourceProperties :: AuthorizationConfigProperty -> ResourceProperties
toResourceProperties AuthorizationConfigProperty {Maybe AwsIamConfigProperty
()
Value Text
haddock_workaround_ :: AuthorizationConfigProperty -> ()
authorizationType :: AuthorizationConfigProperty -> Value Text
awsIamConfig :: AuthorizationConfigProperty -> Maybe AwsIamConfigProperty
haddock_workaround_ :: ()
authorizationType :: Value Text
awsIamConfig :: Maybe AwsIamConfigProperty
..}
= ResourceProperties
{awsType :: Text
awsType = Text
"AWS::AppSync::DataSource.AuthorizationConfig",
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
"AuthorizationType" 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
authorizationType]
([Maybe (Key, Value)] -> [(Key, Value)]
forall a. [Maybe a] -> [a]
Prelude.catMaybes
[Key -> AwsIamConfigProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"AwsIamConfig" (AwsIamConfigProperty -> (Key, Value))
-> Maybe AwsIamConfigProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe AwsIamConfigProperty
awsIamConfig]))}
instance JSON.ToJSON AuthorizationConfigProperty where
toJSON :: AuthorizationConfigProperty -> Value
toJSON AuthorizationConfigProperty {Maybe AwsIamConfigProperty
()
Value Text
haddock_workaround_ :: AuthorizationConfigProperty -> ()
authorizationType :: AuthorizationConfigProperty -> Value Text
awsIamConfig :: AuthorizationConfigProperty -> Maybe AwsIamConfigProperty
haddock_workaround_ :: ()
authorizationType :: Value Text
awsIamConfig :: Maybe AwsIamConfigProperty
..}
= [(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
"AuthorizationType" 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
authorizationType]
([Maybe (Key, Value)] -> [(Key, Value)]
forall a. [Maybe a] -> [a]
Prelude.catMaybes
[Key -> AwsIamConfigProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"AwsIamConfig" (AwsIamConfigProperty -> (Key, Value))
-> Maybe AwsIamConfigProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe AwsIamConfigProperty
awsIamConfig])))
instance Property "AuthorizationType" AuthorizationConfigProperty where
type PropertyType "AuthorizationType" AuthorizationConfigProperty = Value Prelude.Text
set :: PropertyType "AuthorizationType" AuthorizationConfigProperty
-> AuthorizationConfigProperty -> AuthorizationConfigProperty
set PropertyType "AuthorizationType" AuthorizationConfigProperty
newValue AuthorizationConfigProperty {Maybe AwsIamConfigProperty
()
Value Text
haddock_workaround_ :: AuthorizationConfigProperty -> ()
authorizationType :: AuthorizationConfigProperty -> Value Text
awsIamConfig :: AuthorizationConfigProperty -> Maybe AwsIamConfigProperty
haddock_workaround_ :: ()
authorizationType :: Value Text
awsIamConfig :: Maybe AwsIamConfigProperty
..}
= AuthorizationConfigProperty {authorizationType :: Value Text
authorizationType = PropertyType "AuthorizationType" AuthorizationConfigProperty
Value Text
newValue, Maybe AwsIamConfigProperty
()
haddock_workaround_ :: ()
awsIamConfig :: Maybe AwsIamConfigProperty
haddock_workaround_ :: ()
awsIamConfig :: Maybe AwsIamConfigProperty
..}
instance Property "AwsIamConfig" AuthorizationConfigProperty where
type PropertyType "AwsIamConfig" AuthorizationConfigProperty = AwsIamConfigProperty
set :: PropertyType "AwsIamConfig" AuthorizationConfigProperty
-> AuthorizationConfigProperty -> AuthorizationConfigProperty
set PropertyType "AwsIamConfig" AuthorizationConfigProperty
newValue AuthorizationConfigProperty {Maybe AwsIamConfigProperty
()
Value Text
haddock_workaround_ :: AuthorizationConfigProperty -> ()
authorizationType :: AuthorizationConfigProperty -> Value Text
awsIamConfig :: AuthorizationConfigProperty -> Maybe AwsIamConfigProperty
haddock_workaround_ :: ()
authorizationType :: Value Text
awsIamConfig :: Maybe AwsIamConfigProperty
..}
= AuthorizationConfigProperty
{awsIamConfig :: Maybe AwsIamConfigProperty
awsIamConfig = AwsIamConfigProperty -> Maybe AwsIamConfigProperty
forall a. a -> Maybe a
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure PropertyType "AwsIamConfig" AuthorizationConfigProperty
AwsIamConfigProperty
newValue, ()
Value Text
haddock_workaround_ :: ()
authorizationType :: Value Text
haddock_workaround_ :: ()
authorizationType :: Value Text
..}