module Hasura.RQL.Types.Metadata.Serialization
( actionMetadataToOrdJSONList,
allowlistToOrdJSONList,
apiLimitsToOrdJSON,
backendConfigsToOrdJSON,
cronTriggersToOrdJSONList,
customTypesToOrdJSON,
endpointsToOrdJSONList,
inheritedRolesToOrdJSONList,
introspectionDisabledRolesToOrdJSON,
metricsConfigToOrdJSON,
networkConfigToOrdJSON,
queryCollectionsToOrdJSONList,
remoteSchemasToOrdJSONList,
sourcesToOrdJSONList,
)
where
import Data.Aeson (ToJSON (..))
import Data.Aeson qualified as JSON
import Data.Aeson.Ordered qualified as AO
import Data.HashMap.Strict.InsOrd.Extended qualified as OM
import Data.Text.Extended qualified as T
import Data.Vector qualified as Vector
import Hasura.Prelude
import Hasura.RQL.Types.Action
( ActionDefinition (..),
ActionDefinitionInput,
ActionMetadata (..),
ActionPermissionMetadata (..),
ActionType (..),
ArgumentDefinition (..),
)
import Hasura.RQL.Types.Allowlist (AllowlistEntry (..), MetadataAllowlist)
import Hasura.RQL.Types.ApiLimit (ApiLimit, emptyApiLimit)
import Hasura.RQL.Types.Backend (Backend)
import Hasura.RQL.Types.Column (ColumnValues)
import Hasura.RQL.Types.Common (Comment, MetricsConfig, commentToMaybeText, defaultActionTimeoutSecs, emptyMetricsConfig)
import Hasura.RQL.Types.CustomTypes
( CustomTypes (..),
EnumTypeDefinition (..),
GraphQLType (..),
InputObjectFieldDefinition (..),
InputObjectTypeDefinition (..),
ObjectFieldDefinition (..),
ObjectTypeDefinition (..),
ScalarTypeDefinition (..),
emptyCustomTypes,
)
import Hasura.RQL.Types.Endpoint (EndpointMetadata (..))
import Hasura.RQL.Types.EventTrigger (EventTriggerConf (..))
import Hasura.RQL.Types.Function (emptyFunctionConfig)
import Hasura.RQL.Types.GraphqlSchemaIntrospection (SetGraphqlIntrospectionOptions)
import Hasura.RQL.Types.Metadata.Common
( Actions,
BackendConfigWrapper (..),
BackendSourceMetadata (..),
ComputedFieldMetadata (..),
CronTriggers,
Endpoints,
FunctionMetadata (..),
InheritedRoles,
RemoteSchemaMetadata (..),
RemoteSchemaPermissionMetadata (..),
RemoteSchemas,
SourceMetadata (..),
Sources,
TableMetadata (..),
getSourceName,
)
import Hasura.RQL.Types.Network (Network, emptyNetwork)
import Hasura.RQL.Types.Permission
( AllowedRootFields (..),
DelPermDef,
InsPerm (..),
InsPermDef,
PermDef (..),
SelPerm (..),
SelPermDef,
UpdPerm (..),
UpdPermDef,
unPermDefPermission,
)
import Hasura.RQL.Types.QueryCollection (CreateCollection (..), QueryCollections)
import Hasura.RQL.Types.Relationships.Local (RelDef (..))
import Hasura.RQL.Types.Relationships.Remote (RemoteRelationship (..))
import Hasura.RQL.Types.RemoteSchema (RemoteSchemaDef (..))
import Hasura.RQL.Types.Roles (InheritedRole, Role (..))
import Hasura.RQL.Types.ScheduledTrigger (CronTriggerMetadata (..), defaultSTRetryConf)
import Hasura.RQL.Types.SourceCustomization (emptySourceCustomization)
import Hasura.RQL.Types.Table (emptyTableConfig)
import Hasura.SQL.AnyBackend qualified as AB
import Hasura.SQL.BackendMap (BackendMap)
import Hasura.SQL.BackendMap qualified as BackendMap
import Hasura.SQL.Tag (HasTag (backendTag), reify)
import Language.GraphQL.Draft.Syntax qualified as G
sourcesToOrdJSONList :: Sources -> AO.Array
sourcesToOrdJSONList :: Sources -> Array
sourcesToOrdJSONList Sources
sources =
[Value] -> Array
forall a. [a] -> Vector a
Vector.fromList ([Value] -> Array) -> [Value] -> Array
forall a b. (a -> b) -> a -> b
$
(BackendSourceMetadata -> Value)
-> [BackendSourceMetadata] -> [Value]
forall a b. (a -> b) -> [a] -> [b]
map BackendSourceMetadata -> Value
sourceMetaToOrdJSON ([BackendSourceMetadata] -> [Value])
-> [BackendSourceMetadata] -> [Value]
forall a b. (a -> b) -> a -> b
$ (BackendSourceMetadata -> SourceName)
-> [BackendSourceMetadata] -> [BackendSourceMetadata]
forall b a. Ord b => (a -> b) -> [a] -> [a]
sortOn BackendSourceMetadata -> SourceName
getSourceName ([BackendSourceMetadata] -> [BackendSourceMetadata])
-> [BackendSourceMetadata] -> [BackendSourceMetadata]
forall a b. (a -> b) -> a -> b
$ Sources -> [BackendSourceMetadata]
forall k v. InsOrdHashMap k v -> [v]
OM.elems Sources
sources
where
sourceMetaToOrdJSON :: BackendSourceMetadata -> AO.Value
sourceMetaToOrdJSON :: BackendSourceMetadata -> Value
sourceMetaToOrdJSON (BackendSourceMetadata AnyBackend SourceMetadata
exists) =
AnyBackend SourceMetadata
-> (forall (b :: BackendType).
Backend b =>
SourceMetadata b -> Value)
-> Value
forall (c :: BackendType -> Constraint) (i :: BackendType -> *) r.
AllBackendsSatisfy c =>
AnyBackend i -> (forall (b :: BackendType). c b => i b -> r) -> r
AB.dispatchAnyBackend @Backend AnyBackend SourceMetadata
exists ((forall (b :: BackendType).
Backend b =>
SourceMetadata b -> Value)
-> Value)
-> (forall (b :: BackendType).
Backend b =>
SourceMetadata b -> Value)
-> Value
forall a b. (a -> b) -> a -> b
$ \(SourceMetadata {Maybe QueryTagsConfig
Tables b
Functions b
SourceName
BackendSourceKind b
SourceConnConfiguration b
SourceCustomization
_smCustomization :: forall (b :: BackendType). SourceMetadata b -> SourceCustomization
_smQueryTags :: forall (b :: BackendType).
SourceMetadata b -> Maybe QueryTagsConfig
_smConfiguration :: forall (b :: BackendType).
SourceMetadata b -> SourceConnConfiguration b
_smFunctions :: forall (b :: BackendType). SourceMetadata b -> Functions b
_smTables :: forall (b :: BackendType). SourceMetadata b -> Tables b
_smKind :: forall (b :: BackendType). SourceMetadata b -> BackendSourceKind b
_smName :: forall (b :: BackendType). SourceMetadata b -> SourceName
_smCustomization :: SourceCustomization
_smQueryTags :: Maybe QueryTagsConfig
_smConfiguration :: SourceConnConfiguration b
_smFunctions :: Functions b
_smTables :: Tables b
_smKind :: BackendSourceKind b
_smName :: SourceName
..} :: SourceMetadata b) ->
let sourceNamePair :: (Text, Value)
sourceNamePair = (Text
"name", SourceName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered SourceName
_smName)
sourceKindPair :: (Text, Value)
sourceKindPair = (Text
"kind", BackendSourceKind b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered BackendSourceKind b
_smKind)
tablesPair :: (Text, Value)
tablesPair = (Text
"tables", [Value] -> Value
AO.array ([Value] -> Value) -> [Value] -> Value
forall a b. (a -> b) -> a -> b
$ (TableMetadata b -> Value) -> [TableMetadata b] -> [Value]
forall a b. (a -> b) -> [a] -> [b]
map TableMetadata b -> Value
forall (b :: BackendType). Backend b => TableMetadata b -> Value
tableMetaToOrdJSON ([TableMetadata b] -> [Value]) -> [TableMetadata b] -> [Value]
forall a b. (a -> b) -> a -> b
$ (TableMetadata b -> TableName b)
-> [TableMetadata b] -> [TableMetadata b]
forall b a. Ord b => (a -> b) -> [a] -> [a]
sortOn TableMetadata b -> TableName b
forall (b :: BackendType). TableMetadata b -> TableName b
_tmTable ([TableMetadata b] -> [TableMetadata b])
-> [TableMetadata b] -> [TableMetadata b]
forall a b. (a -> b) -> a -> b
$ Tables b -> [TableMetadata b]
forall k v. InsOrdHashMap k v -> [v]
OM.elems Tables b
_smTables)
functionsPair :: Maybe (Text, Value)
functionsPair = Text
-> (FunctionMetadata b -> Value)
-> (FunctionMetadata b -> FunctionName b)
-> Functions b
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort Text
"functions" FunctionMetadata b -> Value
forall (b :: BackendType). Backend b => FunctionMetadata b -> Value
functionMetadataToOrdJSON FunctionMetadata b -> FunctionName b
forall (b :: BackendType). FunctionMetadata b -> FunctionName b
_fmFunction Functions b
_smFunctions
configurationPair :: [(Text, Value)]
configurationPair = [(Text
"configuration", SourceConnConfiguration b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered SourceConnConfiguration b
_smConfiguration)]
queryTagsConfigPair :: [(Text, Value)]
queryTagsConfigPair = [(Text, Value)]
-> (QueryTagsConfig -> [(Text, Value)])
-> Maybe QueryTagsConfig
-> [(Text, Value)]
forall b a. b -> (a -> b) -> Maybe a -> b
maybe [] (\QueryTagsConfig
queryTagsConfig -> [(Text
"query_tags", QueryTagsConfig -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered QueryTagsConfig
queryTagsConfig)]) Maybe QueryTagsConfig
_smQueryTags
customizationPair :: [(Text, Value)]
customizationPair =
Bool -> [()]
forall (f :: * -> *). Alternative f => Bool -> f ()
guard (SourceCustomization
_smCustomization SourceCustomization -> SourceCustomization -> Bool
forall a. Eq a => a -> a -> Bool
/= SourceCustomization
emptySourceCustomization)
[()] -> [(Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a b. Applicative f => f a -> f b -> f b
*> [(Text
"customization", SourceCustomization -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered SourceCustomization
_smCustomization)]
in [(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[(Text, Value)
sourceNamePair, (Text, Value)
sourceKindPair, (Text, Value)
tablesPair]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> Maybe (Text, Value) -> [(Text, Value)]
forall a. Maybe a -> [a]
maybeToList Maybe (Text, Value)
functionsPair
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text, Value)]
configurationPair
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text, Value)]
queryTagsConfigPair
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text, Value)]
customizationPair
tableMetaToOrdJSON :: (Backend b) => TableMetadata b -> AO.Value
tableMetaToOrdJSON :: TableMetadata b -> Value
tableMetaToOrdJSON
( TableMetadata
TableName b
table
Bool
isEnum
TableConfig b
config
Relationships (ObjRelDef b)
objectRelationships
Relationships (ArrRelDef b)
arrayRelationships
ComputedFields b
computedFields
RemoteRelationships
remoteRelationships
Permissions (InsPermDef b)
insertPermissions
Permissions (SelPermDef b)
selectPermissions
Permissions (UpdPermDef b)
updatePermissions
Permissions (DelPermDef b)
deletePermissions
EventTriggers b
eventTriggers
Maybe ApolloFederationConfig
enableApolloFed
) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[(Text
"table", TableName b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered TableName b
table)]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Maybe (Text, Value)
isEnumPair,
Maybe (Text, Value)
configPair,
Maybe (Text, Value)
objectRelationshipsPair,
Maybe (Text, Value)
arrayRelationshipsPair,
Maybe (Text, Value)
computedFieldsPair,
Maybe (Text, Value)
remoteRelationshipsPair,
Maybe (Text, Value)
insertPermissionsPair,
Maybe (Text, Value)
selectPermissionsPair,
Maybe (Text, Value)
updatePermissionsPair,
Maybe (Text, Value)
deletePermissionsPair,
Maybe (Text, Value)
eventTriggersPair,
Maybe (Text, Value)
apolloFedConfigPair
]
where
isEnumPair :: Maybe (Text, Value)
isEnumPair = if Bool
isEnum then (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"is_enum", Bool -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Bool
isEnum) else Maybe (Text, Value)
forall a. Maybe a
Nothing
apolloFedConfigPair :: Maybe (Text, Value)
apolloFedConfigPair = (ApolloFederationConfig -> (Text, Value))
-> Maybe ApolloFederationConfig -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (\ApolloFederationConfig
afConfig -> (Text
"apollo_federation_config", ApolloFederationConfig -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ApolloFederationConfig
afConfig)) Maybe ApolloFederationConfig
enableApolloFed
configPair :: Maybe (Text, Value)
configPair =
if TableConfig b
config TableConfig b -> TableConfig b -> Bool
forall a. Eq a => a -> a -> Bool
== TableConfig b
forall (b :: BackendType). TableConfig b
emptyTableConfig
then Maybe (Text, Value)
forall a. Maybe a
Nothing
else (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"configuration", TableConfig b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered TableConfig b
config)
objectRelationshipsPair :: Maybe (Text, Value)
objectRelationshipsPair =
Text
-> (ObjRelDef b -> Value)
-> (ObjRelDef b -> RelName)
-> Relationships (ObjRelDef b)
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"object_relationships"
ObjRelDef b -> Value
forall a. ToJSON a => RelDef a -> Value
relDefToOrdJSON
ObjRelDef b -> RelName
forall a. RelDef a -> RelName
_rdName
Relationships (ObjRelDef b)
objectRelationships
arrayRelationshipsPair :: Maybe (Text, Value)
arrayRelationshipsPair =
Text
-> (ArrRelDef b -> Value)
-> (ArrRelDef b -> RelName)
-> Relationships (ArrRelDef b)
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"array_relationships"
ArrRelDef b -> Value
forall a. ToJSON a => RelDef a -> Value
relDefToOrdJSON
ArrRelDef b -> RelName
forall a. RelDef a -> RelName
_rdName
Relationships (ArrRelDef b)
arrayRelationships
computedFieldsPair :: Maybe (Text, Value)
computedFieldsPair =
Text
-> (ComputedFieldMetadata b -> Value)
-> (ComputedFieldMetadata b -> ComputedFieldName)
-> ComputedFields b
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"computed_fields"
ComputedFieldMetadata b -> Value
forall (b :: BackendType).
Backend b =>
ComputedFieldMetadata b -> Value
computedFieldMetaToOrdJSON
ComputedFieldMetadata b -> ComputedFieldName
forall (b :: BackendType).
ComputedFieldMetadata b -> ComputedFieldName
_cfmName
ComputedFields b
computedFields
remoteRelationshipsPair :: Maybe (Text, Value)
remoteRelationshipsPair =
Text
-> (RemoteRelationship -> Value)
-> (RemoteRelationship -> RelName)
-> RemoteRelationships
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"remote_relationships"
RemoteRelationship -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
RemoteRelationship -> RelName
_rrName
RemoteRelationships
remoteRelationships
insertPermissionsPair :: Maybe (Text, Value)
insertPermissionsPair =
Text
-> (InsPermDef b -> Value)
-> (InsPermDef b -> RoleName)
-> Permissions (InsPermDef b)
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"insert_permissions"
InsPermDef b -> Value
forall (b :: BackendType). Backend b => InsPermDef b -> Value
insPermDefToOrdJSON
InsPermDef b -> RoleName
forall (b :: BackendType) (perm :: BackendType -> *).
PermDef b perm -> RoleName
_pdRole
Permissions (InsPermDef b)
insertPermissions
selectPermissionsPair :: Maybe (Text, Value)
selectPermissionsPair =
Text
-> (SelPermDef b -> Value)
-> (SelPermDef b -> RoleName)
-> Permissions (SelPermDef b)
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"select_permissions"
SelPermDef b -> Value
forall (b :: BackendType). Backend b => SelPermDef b -> Value
selPermDefToOrdJSON
SelPermDef b -> RoleName
forall (b :: BackendType) (perm :: BackendType -> *).
PermDef b perm -> RoleName
_pdRole
Permissions (SelPermDef b)
selectPermissions
updatePermissionsPair :: Maybe (Text, Value)
updatePermissionsPair =
Text
-> (UpdPermDef b -> Value)
-> (UpdPermDef b -> RoleName)
-> Permissions (UpdPermDef b)
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"update_permissions"
UpdPermDef b -> Value
forall (b :: BackendType). Backend b => UpdPermDef b -> Value
updPermDefToOrdJSON
UpdPermDef b -> RoleName
forall (b :: BackendType) (perm :: BackendType -> *).
PermDef b perm -> RoleName
_pdRole
Permissions (UpdPermDef b)
updatePermissions
deletePermissionsPair :: Maybe (Text, Value)
deletePermissionsPair =
Text
-> (DelPermDef b -> Value)
-> (DelPermDef b -> RoleName)
-> Permissions (DelPermDef b)
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"delete_permissions"
DelPermDef b -> Value
forall (b :: BackendType). Backend b => DelPermDef b -> Value
delPermDefToOrdJSON
DelPermDef b -> RoleName
forall (b :: BackendType) (perm :: BackendType -> *).
PermDef b perm -> RoleName
_pdRole
Permissions (DelPermDef b)
deletePermissions
eventTriggersPair :: Maybe (Text, Value)
eventTriggersPair =
Text
-> (EventTriggerConf b -> Value)
-> (EventTriggerConf b -> TriggerName)
-> EventTriggers b
-> Maybe (Text, Value)
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort
Text
"event_triggers"
EventTriggerConf b -> Value
forall (b :: BackendType). Backend b => EventTriggerConf b -> Value
eventTriggerConfToOrdJSON
EventTriggerConf b -> TriggerName
forall (b :: BackendType). EventTriggerConf b -> TriggerName
etcName
EventTriggers b
eventTriggers
relDefToOrdJSON :: (ToJSON a) => RelDef a -> AO.Value
relDefToOrdJSON :: RelDef a -> Value
relDefToOrdJSON (RelDef RelName
name a
using Maybe Text
comment) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", RelName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered RelName
name),
(Text
"using", a -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered a
using)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Text -> Maybe (Text, Value)
maybeCommentToMaybeOrdPair Maybe Text
comment]
computedFieldMetaToOrdJSON :: (Backend b) => ComputedFieldMetadata b -> AO.Value
computedFieldMetaToOrdJSON :: ComputedFieldMetadata b -> Value
computedFieldMetaToOrdJSON (ComputedFieldMetadata ComputedFieldName
name ComputedFieldDefinition b
definition Comment
comment) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", ComputedFieldName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ComputedFieldName
name),
(Text
"definition", ComputedFieldDefinition b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ComputedFieldDefinition b
definition)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Comment -> Maybe (Text, Value)
commentToMaybeOrdPair Comment
comment]
insPermDefToOrdJSON :: forall b. (Backend b) => InsPermDef b -> AO.Value
insPermDefToOrdJSON :: InsPermDef b -> Value
insPermDefToOrdJSON = (InsPerm b -> Value) -> InsPermDef b -> Value
forall (a :: BackendType -> *) (b :: BackendType).
(a b -> Value) -> PermDef b a -> Value
permDefToOrdJSON InsPerm b -> Value
insPermToOrdJSON
where
insPermToOrdJSON :: InsPerm b -> Value
insPermToOrdJSON (InsPerm BoolExp b
check Maybe (ColumnValues b Value)
set Maybe (PermColSpec b)
columns Bool
backendOnly) =
let columnsPair :: Maybe (Text, Value)
columnsPair = (Text
"columns",) (Value -> (Text, Value))
-> (PermColSpec b -> Value) -> PermColSpec b -> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. PermColSpec b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered (PermColSpec b -> (Text, Value))
-> Maybe (PermColSpec b) -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe (PermColSpec b)
columns
backendOnlyPair :: Maybe (Text, Value)
backendOnlyPair =
if Bool
backendOnly
then (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"backend_only", Bool -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Bool
backendOnly)
else Maybe (Text, Value)
forall a. Maybe a
Nothing
in [(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[(Text
"check", BoolExp b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered BoolExp b
check)]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe (ColumnValues b Value) -> Maybe (Text, Value)
forall (b :: BackendType).
Backend b =>
Maybe (ColumnValues b Value) -> Maybe (Text, Value)
maybeSetToMaybeOrdPair @b Maybe (ColumnValues b Value)
set, Maybe (Text, Value)
columnsPair, Maybe (Text, Value)
backendOnlyPair]
selPermDefToOrdJSON :: Backend b => SelPermDef b -> AO.Value
selPermDefToOrdJSON :: SelPermDef b -> Value
selPermDefToOrdJSON = (SelPerm b -> Value) -> SelPermDef b -> Value
forall (a :: BackendType -> *) (b :: BackendType).
(a b -> Value) -> PermDef b a -> Value
permDefToOrdJSON SelPerm b -> Value
forall (b :: BackendType). Backend b => SelPerm b -> Value
selPermToOrdJSON
where
selPermToOrdJSON :: SelPerm b -> Value
selPermToOrdJSON (SelPerm PermColSpec b
columns BoolExp b
fltr Maybe Int
limit Bool
allowAgg [ComputedFieldName]
computedFieldsPerm AllowedRootFields QueryRootFieldType
allowedQueryRootFieldTypes AllowedRootFields SubscriptionRootFieldType
allowedSubscriptionRootFieldTypes) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Maybe (Text, Value)
columnsPair,
Maybe (Text, Value)
computedFieldsPermPair,
Maybe (Text, Value)
filterPair,
Maybe (Text, Value)
limitPair,
Maybe (Text, Value)
allowAggPair,
Maybe (Text, Value)
allowedQueryRootFieldsPair,
Maybe (Text, Value)
allowedSubscriptionRootFieldsPair
]
where
columnsPair :: Maybe (Text, Value)
columnsPair = (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"columns", PermColSpec b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered PermColSpec b
columns)
computedFieldsPermPair :: Maybe (Text, Value)
computedFieldsPermPair = Text
-> (ComputedFieldName -> Value)
-> [ComputedFieldName]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"computed_fields" ComputedFieldName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered [ComputedFieldName]
computedFieldsPerm
filterPair :: Maybe (Text, Value)
filterPair = (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"filter", BoolExp b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered BoolExp b
fltr)
limitPair :: Maybe (Text, Value)
limitPair = Text -> (Int -> Value) -> Maybe Int -> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"limit" Int -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Maybe Int
limit
allowAggPair :: Maybe (Text, Value)
allowAggPair =
if Bool
allowAgg
then (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"allow_aggregations", Bool -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Bool
allowAgg)
else Maybe (Text, Value)
forall a. Maybe a
Nothing
allowedQueryRootFieldsPair :: Maybe (Text, Value)
allowedQueryRootFieldsPair =
case AllowedRootFields QueryRootFieldType
allowedQueryRootFieldTypes of
AllowedRootFields QueryRootFieldType
ARFAllowAllRootFields -> Maybe (Text, Value)
forall a. Maybe a
Nothing
ARFAllowConfiguredRootFields HashSet QueryRootFieldType
configuredRootFields ->
(Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"query_root_fields", HashSet QueryRootFieldType -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered HashSet QueryRootFieldType
configuredRootFields)
allowedSubscriptionRootFieldsPair :: Maybe (Text, Value)
allowedSubscriptionRootFieldsPair =
case AllowedRootFields SubscriptionRootFieldType
allowedSubscriptionRootFieldTypes of
AllowedRootFields SubscriptionRootFieldType
ARFAllowAllRootFields -> Maybe (Text, Value)
forall a. Maybe a
Nothing
ARFAllowConfiguredRootFields HashSet SubscriptionRootFieldType
configuredRootFields ->
(Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"subscription_root_fields", HashSet SubscriptionRootFieldType -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered HashSet SubscriptionRootFieldType
configuredRootFields)
updPermDefToOrdJSON :: forall b. Backend b => UpdPermDef b -> AO.Value
updPermDefToOrdJSON :: UpdPermDef b -> Value
updPermDefToOrdJSON = (UpdPerm b -> Value) -> UpdPermDef b -> Value
forall (a :: BackendType -> *) (b :: BackendType).
(a b -> Value) -> PermDef b a -> Value
permDefToOrdJSON UpdPerm b -> Value
updPermToOrdJSON
where
updPermToOrdJSON :: UpdPerm b -> Value
updPermToOrdJSON (UpdPerm PermColSpec b
columns Maybe (ColumnValues b Value)
set BoolExp b
fltr Maybe (BoolExp b)
check Bool
backendOnly) =
let backendOnlyPair :: Maybe (Text, Value)
backendOnlyPair =
if Bool
backendOnly
then (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"backend_only", Bool -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Bool
backendOnly)
else Maybe (Text, Value)
forall a. Maybe a
Nothing
in [(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"columns", PermColSpec b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered PermColSpec b
columns),
(Text
"filter", BoolExp b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered BoolExp b
fltr),
(Text
"check", Maybe (BoolExp b) -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Maybe (BoolExp b)
check)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe (ColumnValues b Value) -> Maybe (Text, Value)
forall (b :: BackendType).
Backend b =>
Maybe (ColumnValues b Value) -> Maybe (Text, Value)
maybeSetToMaybeOrdPair @b Maybe (ColumnValues b Value)
set, Maybe (Text, Value)
backendOnlyPair]
delPermDefToOrdJSON :: Backend b => DelPermDef b -> AO.Value
delPermDefToOrdJSON :: DelPermDef b -> Value
delPermDefToOrdJSON = (DelPerm b -> Value) -> DelPermDef b -> Value
forall (a :: BackendType -> *) (b :: BackendType).
(a b -> Value) -> PermDef b a -> Value
permDefToOrdJSON DelPerm b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
permDefToOrdJSON :: (a b -> AO.Value) -> PermDef b a -> AO.Value
permDefToOrdJSON :: (a b -> Value) -> PermDef b a -> Value
permDefToOrdJSON a b -> Value
permToOrdJSON (PermDef RoleName
role PermDefPermission b a
permission Maybe Text
comment) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"role", RoleName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered RoleName
role),
(Text
"permission", a b -> Value
permToOrdJSON (PermDefPermission b a -> a b
forall (b :: BackendType) (perm :: BackendType -> *).
PermDefPermission b perm -> perm b
unPermDefPermission PermDefPermission b a
permission))
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Text -> Maybe (Text, Value)
maybeCommentToMaybeOrdPair Maybe Text
comment]
eventTriggerConfToOrdJSON :: Backend b => EventTriggerConf b -> AO.Value
eventTriggerConfToOrdJSON :: EventTriggerConf b -> Value
eventTriggerConfToOrdJSON (EventTriggerConf TriggerName
name TriggerOpsDef b
definition Maybe InputWebhook
webhook Maybe Text
webhookFromEnv RetryConf
retryConf Maybe [HeaderConf]
headers Maybe RequestTransform
reqTransform Maybe MetadataResponseTransform
respTransform) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", TriggerName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered TriggerName
name),
(Text
"definition", TriggerOpsDef b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered TriggerOpsDef b
definition),
(Text
"retry_conf", RetryConf -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered RetryConf
retryConf)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Text
-> (InputWebhook -> Value)
-> Maybe InputWebhook
-> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"webhook" InputWebhook -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Maybe InputWebhook
webhook,
Text -> (Text -> Value) -> Maybe Text -> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"webhook_from_env" Text -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Maybe Text
webhookFromEnv,
Maybe [HeaderConf]
headers Maybe [HeaderConf]
-> ([HeaderConf] -> Maybe (Text, Value)) -> Maybe (Text, Value)
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Text
-> (HeaderConf -> Value) -> [HeaderConf] -> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"headers" HeaderConf -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered,
(RequestTransform -> (Text, Value))
-> Maybe RequestTransform -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((Text
"request_transform",) (Value -> (Text, Value))
-> (RequestTransform -> Value) -> RequestTransform -> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. RequestTransform -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered) Maybe RequestTransform
reqTransform,
(MetadataResponseTransform -> (Text, Value))
-> Maybe MetadataResponseTransform -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((Text
"response_transform",) (Value -> (Text, Value))
-> (MetadataResponseTransform -> Value)
-> MetadataResponseTransform
-> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MetadataResponseTransform -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered) Maybe MetadataResponseTransform
respTransform
]
functionMetadataToOrdJSON :: Backend b => FunctionMetadata b -> AO.Value
functionMetadataToOrdJSON :: FunctionMetadata b -> Value
functionMetadataToOrdJSON FunctionMetadata {[FunctionPermissionInfo]
Maybe Text
FunctionName b
FunctionConfig
_fmComment :: forall (b :: BackendType). FunctionMetadata b -> Maybe Text
_fmPermissions :: forall (b :: BackendType).
FunctionMetadata b -> [FunctionPermissionInfo]
_fmConfiguration :: forall (b :: BackendType). FunctionMetadata b -> FunctionConfig
_fmComment :: Maybe Text
_fmPermissions :: [FunctionPermissionInfo]
_fmConfiguration :: FunctionConfig
_fmFunction :: FunctionName b
_fmFunction :: forall (b :: BackendType). FunctionMetadata b -> FunctionName b
..} =
let confKeyPair :: [(Text, Value)]
confKeyPair =
if FunctionConfig
_fmConfiguration FunctionConfig -> FunctionConfig -> Bool
forall a. Eq a => a -> a -> Bool
== FunctionConfig
emptyFunctionConfig
then []
else (Text, Value) -> [(Text, Value)]
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Text
"configuration", FunctionConfig -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered FunctionConfig
_fmConfiguration)
permissionsKeyPair :: [(Text, Value)]
permissionsKeyPair =
if [FunctionPermissionInfo] -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null [FunctionPermissionInfo]
_fmPermissions
then []
else (Text, Value) -> [(Text, Value)]
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Text
"permissions", [FunctionPermissionInfo] -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered [FunctionPermissionInfo]
_fmPermissions)
commentKeyPair :: [(Text, Value)]
commentKeyPair =
if Maybe Text -> Bool
forall a. Maybe a -> Bool
isNothing Maybe Text
_fmComment
then []
else (Text, Value) -> [(Text, Value)]
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Text
"comment", Maybe Text -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Maybe Text
_fmComment)
in [(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$ [(Text
"function", FunctionName b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered FunctionName b
_fmFunction)] [(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text, Value)]
confKeyPair [(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text, Value)]
permissionsKeyPair [(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text, Value)]
commentKeyPair
remoteSchemasToOrdJSONList :: RemoteSchemas -> Maybe AO.Array
remoteSchemasToOrdJSONList :: RemoteSchemas -> Maybe Array
remoteSchemasToOrdJSONList = (RemoteSchemaMetadata -> Value)
-> (RemoteSchemaMetadata -> RemoteSchemaName)
-> RemoteSchemas
-> Maybe Array
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
(a -> Value) -> (a -> b) -> t a -> Maybe Array
listToMaybeArraySort RemoteSchemaMetadata -> Value
remoteSchemaQToOrdJSON RemoteSchemaMetadata -> RemoteSchemaName
_rsmName
where
remoteSchemaQToOrdJSON :: RemoteSchemaMetadata -> AO.Value
remoteSchemaQToOrdJSON :: RemoteSchemaMetadata -> Value
remoteSchemaQToOrdJSON (RemoteSchemaMetadata RemoteSchemaName
name RemoteSchemaDef
definition Maybe Text
comment [RemoteSchemaPermissionMetadata]
permissions SchemaRemoteRelationships
relationships) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", RemoteSchemaName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered RemoteSchemaName
name),
(Text
"definition", RemoteSchemaDef -> Value
remoteSchemaDefToOrdJSON RemoteSchemaDef
definition)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Maybe Text -> Maybe (Text, Value)
maybeCommentToMaybeOrdPair Maybe Text
comment,
Text
-> (RemoteSchemaPermissionMetadata -> Value)
-> [RemoteSchemaPermissionMetadata]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair
Text
"permissions"
RemoteSchemaPermissionMetadata -> Value
permsToMaybeOrdJSON
[RemoteSchemaPermissionMetadata]
permissions,
Text
-> (RemoteSchemaTypeRelationships -> Value)
-> SchemaRemoteRelationships
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair
Text
"remote_relationships"
RemoteSchemaTypeRelationships -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
SchemaRemoteRelationships
relationships
]
where
permsToMaybeOrdJSON :: RemoteSchemaPermissionMetadata -> AO.Value
permsToMaybeOrdJSON :: RemoteSchemaPermissionMetadata -> Value
permsToMaybeOrdJSON (RemoteSchemaPermissionMetadata RoleName
role RemoteSchemaPermissionDefinition
defn Maybe Text
permComment) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"role", RoleName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered RoleName
role),
(Text
"definition", RemoteSchemaPermissionDefinition -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered RemoteSchemaPermissionDefinition
defn)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Text -> Maybe (Text, Value)
maybeCommentToMaybeOrdPair Maybe Text
permComment]
remoteSchemaDefToOrdJSON :: RemoteSchemaDef -> AO.Value
remoteSchemaDefToOrdJSON :: RemoteSchemaDef -> Value
remoteSchemaDefToOrdJSON (RemoteSchemaDef Maybe InputWebhook
url Maybe Text
urlFromEnv Maybe [HeaderConf]
headers Bool
frwrdClientHdrs Maybe Int
timeout Maybe RemoteSchemaCustomization
customization) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Text -> Maybe InputWebhook -> Maybe (Text, Value)
forall a. ToJSON a => Text -> Maybe a -> Maybe (Text, Value)
maybeToPair Text
"url" Maybe InputWebhook
url,
Text -> Maybe Text -> Maybe (Text, Value)
forall a. ToJSON a => Text -> Maybe a -> Maybe (Text, Value)
maybeToPair Text
"url_from_env" Maybe Text
urlFromEnv,
Text -> Maybe Int -> Maybe (Text, Value)
forall a. ToJSON a => Text -> Maybe a -> Maybe (Text, Value)
maybeToPair Text
"timeout_seconds" Maybe Int
timeout,
Text -> Maybe RemoteSchemaCustomization -> Maybe (Text, Value)
forall a. ToJSON a => Text -> Maybe a -> Maybe (Text, Value)
maybeToPair Text
"customization" Maybe RemoteSchemaCustomization
customization,
Maybe [HeaderConf]
headers Maybe [HeaderConf]
-> ([HeaderConf] -> Maybe (Text, Value)) -> Maybe (Text, Value)
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Text
-> (HeaderConf -> Value) -> [HeaderConf] -> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"headers" HeaderConf -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text
"forward_client_headers", Bool -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Bool
frwrdClientHdrs) | Bool
frwrdClientHdrs]
where
maybeToPair :: Text -> Maybe a -> Maybe (Text, Value)
maybeToPair Text
n = Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
n a -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
backendConfigsToOrdJSON :: BackendMap BackendConfigWrapper -> Maybe AO.Value
backendConfigsToOrdJSON :: BackendMap BackendConfigWrapper -> Maybe Value
backendConfigsToOrdJSON = (BackendMap BackendConfigWrapper -> Bool)
-> (BackendMap BackendConfigWrapper -> Value)
-> BackendMap BackendConfigWrapper
-> Maybe Value
forall a b. (a -> Bool) -> (a -> b) -> a -> Maybe b
ifNotEmpty (BackendMap BackendConfigWrapper
-> BackendMap BackendConfigWrapper -> Bool
forall a. Eq a => a -> a -> Bool
== BackendMap BackendConfigWrapper
forall a. Monoid a => a
mempty) BackendMap BackendConfigWrapper -> Value
configsToOrdJSON
where
configsToOrdJSON :: BackendMap BackendConfigWrapper -> AO.Value
configsToOrdJSON :: BackendMap BackendConfigWrapper -> Value
configsToOrdJSON BackendMap BackendConfigWrapper
backendConfigs' =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value)
-> ([(Text, Value)] -> [(Text, Value)]) -> [(Text, Value)] -> Value
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ((Text, Value) -> Text) -> [(Text, Value)] -> [(Text, Value)]
forall b a. Ord b => (a -> b) -> [a] -> [a]
sortOn (Text, Value) -> Text
forall a b. (a, b) -> a
fst ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$ AnyBackend BackendConfigWrapper -> (Text, Value)
backendConfigToOrdJSON (AnyBackend BackendConfigWrapper -> (Text, Value))
-> [AnyBackend BackendConfigWrapper] -> [(Text, Value)]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> BackendMap BackendConfigWrapper
-> [AnyBackend BackendConfigWrapper]
forall (i :: BackendType -> *). BackendMap i -> [AnyBackend i]
BackendMap.elems BackendMap BackendConfigWrapper
backendConfigs'
backendConfigToOrdJSON :: AB.AnyBackend BackendConfigWrapper -> (Text, AO.Value)
backendConfigToOrdJSON :: AnyBackend BackendConfigWrapper -> (Text, Value)
backendConfigToOrdJSON AnyBackend BackendConfigWrapper
backendConfig =
AnyBackend BackendConfigWrapper
-> (forall (b :: BackendType).
Backend b =>
BackendConfigWrapper b -> (Text, Value))
-> (Text, Value)
forall (c :: BackendType -> Constraint) (i :: BackendType -> *) r.
AllBackendsSatisfy c =>
AnyBackend i -> (forall (b :: BackendType). c b => i b -> r) -> r
AB.dispatchAnyBackend @Backend AnyBackend BackendConfigWrapper
backendConfig ((forall (b :: BackendType).
Backend b =>
BackendConfigWrapper b -> (Text, Value))
-> (Text, Value))
-> (forall (b :: BackendType).
Backend b =>
BackendConfigWrapper b -> (Text, Value))
-> (Text, Value)
forall a b. (a -> b) -> a -> b
$ \((BackendConfigWrapper BackendConfig b
backendConfig') :: BackendConfigWrapper b) ->
let backendTypeStr :: Text
backendTypeStr = BackendType -> Text
forall a. ToTxt a => a -> Text
T.toTxt (BackendType -> Text) -> BackendType -> Text
forall a b. (a -> b) -> a -> b
$ BackendTag b -> BackendType
forall (b :: BackendType). BackendTag b -> BackendType
reify (BackendTag b -> BackendType) -> BackendTag b -> BackendType
forall a b. (a -> b) -> a -> b
$ HasTag b => BackendTag b
forall (b :: BackendType). HasTag b => BackendTag b
backendTag @b
val :: Value
val = BackendConfig b -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered BackendConfig b
backendConfig'
in (Text
backendTypeStr, Value
val)
inheritedRolesToOrdJSONList :: InheritedRoles -> Maybe AO.Array
inheritedRolesToOrdJSONList :: InheritedRoles -> Maybe Array
inheritedRolesToOrdJSONList = (InheritedRole -> Value)
-> (InheritedRole -> RoleName) -> InheritedRoles -> Maybe Array
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
(a -> Value) -> (a -> b) -> t a -> Maybe Array
listToMaybeArraySort InheritedRole -> Value
inheritedRolesQToOrdJSON InheritedRole -> RoleName
_rRoleName
where
inheritedRolesQToOrdJSON :: InheritedRole -> AO.Value
inheritedRolesQToOrdJSON :: InheritedRole -> Value
inheritedRolesQToOrdJSON (Role RoleName
roleName ParentRoles
roleSet) =
[(Text, Value)] -> Value
AO.object
[ (Text
"role_name", RoleName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered RoleName
roleName),
(Text
"role_set", ParentRoles -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ParentRoles
roleSet)
]
queryCollectionsToOrdJSONList :: QueryCollections -> Maybe AO.Array
queryCollectionsToOrdJSONList :: QueryCollections -> Maybe Array
queryCollectionsToOrdJSONList = (CreateCollection -> Value)
-> (CreateCollection -> CollectionName)
-> QueryCollections
-> Maybe Array
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
(a -> Value) -> (a -> b) -> t a -> Maybe Array
listToMaybeArraySort CreateCollection -> Value
createCollectionToOrdJSON CreateCollection -> CollectionName
_ccName
where
createCollectionToOrdJSON :: CreateCollection -> AO.Value
createCollectionToOrdJSON :: CreateCollection -> Value
createCollectionToOrdJSON (CreateCollection CollectionName
name CollectionDef
definition Maybe Text
comment) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", CollectionName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered CollectionName
name),
(Text
"definition", CollectionDef -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered CollectionDef
definition)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Text -> Maybe (Text, Value)
maybeCommentToMaybeOrdPair Maybe Text
comment]
allowlistToOrdJSONList :: MetadataAllowlist -> Maybe AO.Array
allowlistToOrdJSONList :: MetadataAllowlist -> Maybe Array
allowlistToOrdJSONList = (AllowlistEntry -> Value)
-> (AllowlistEntry -> CollectionName)
-> MetadataAllowlist
-> Maybe Array
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
(a -> Value) -> (a -> b) -> t a -> Maybe Array
listToMaybeArraySort (Value -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered (Value -> Value)
-> (AllowlistEntry -> Value) -> AllowlistEntry -> Value
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ToJSON AllowlistEntry => AllowlistEntry -> Value
forall a. ToJSON a => a -> Value
toJSON @AllowlistEntry) AllowlistEntry -> CollectionName
aeCollection
apiLimitsToOrdJSON :: ApiLimit -> Maybe AO.Value
apiLimitsToOrdJSON :: ApiLimit -> Maybe Value
apiLimitsToOrdJSON ApiLimit
apiLimits
| ApiLimit
apiLimits ApiLimit -> ApiLimit -> Bool
forall a. Eq a => a -> a -> Bool
== ApiLimit
emptyApiLimit = Maybe Value
forall a. Maybe a
Nothing
| Bool
otherwise = Value -> Maybe Value
forall a. a -> Maybe a
Just (Value -> Maybe Value) -> Value -> Maybe Value
forall a b. (a -> b) -> a -> b
$ ApiLimit -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ApiLimit
apiLimits
cronTriggersToOrdJSONList :: CronTriggers -> Maybe AO.Array
cronTriggersToOrdJSONList :: CronTriggers -> Maybe Array
cronTriggersToOrdJSONList = (CronTriggerMetadata -> Value)
-> (CronTriggerMetadata -> TriggerName)
-> CronTriggers
-> Maybe Array
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
(a -> Value) -> (a -> b) -> t a -> Maybe Array
listToMaybeArraySort CronTriggerMetadata -> Value
crontriggerQToOrdJSON CronTriggerMetadata -> TriggerName
ctName
where
crontriggerQToOrdJSON :: CronTriggerMetadata -> AO.Value
crontriggerQToOrdJSON :: CronTriggerMetadata -> Value
crontriggerQToOrdJSON
(CronTriggerMetadata TriggerName
name InputWebhook
webhook CronSchedule
schedule Maybe Value
payload STRetryConf
retryConf [HeaderConf]
headers Bool
includeInMetadata Maybe Text
comment Maybe RequestTransform
reqTransform Maybe MetadataResponseTransform
respTransform) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", TriggerName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered TriggerName
name),
(Text
"webhook", InputWebhook -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered InputWebhook
webhook),
(Text
"schedule", CronSchedule -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered CronSchedule
schedule),
(Text
"include_in_metadata", Bool -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Bool
includeInMetadata)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Text -> (Value -> Value) -> Maybe Value -> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"payload" Value -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Maybe Value
payload,
Text
-> (STRetryConf -> Value)
-> Maybe STRetryConf
-> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"retry_conf" STRetryConf -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered (STRetryConf -> Maybe STRetryConf
maybeRetryConfiguration STRetryConf
retryConf),
Text
-> ([HeaderConf] -> Value)
-> Maybe [HeaderConf]
-> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"headers" [HeaderConf] -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ([HeaderConf] -> Maybe [HeaderConf]
forall (t :: * -> *) a. Foldable t => t a -> Maybe (t a)
maybeHeader [HeaderConf]
headers),
Text -> (Text -> Value) -> Maybe Text -> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"comment" Text -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Maybe Text
comment,
(RequestTransform -> (Text, Value))
-> Maybe RequestTransform -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((Text
"request_transform",) (Value -> (Text, Value))
-> (RequestTransform -> Value) -> RequestTransform -> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. RequestTransform -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered) Maybe RequestTransform
reqTransform,
(MetadataResponseTransform -> (Text, Value))
-> Maybe MetadataResponseTransform -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((Text
"response_transform",) (Value -> (Text, Value))
-> (MetadataResponseTransform -> Value)
-> MetadataResponseTransform
-> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MetadataResponseTransform -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered) Maybe MetadataResponseTransform
respTransform
]
where
maybeRetryConfiguration :: STRetryConf -> Maybe STRetryConf
maybeRetryConfiguration STRetryConf
retryConfig
| STRetryConf
retryConfig STRetryConf -> STRetryConf -> Bool
forall a. Eq a => a -> a -> Bool
== STRetryConf
defaultSTRetryConf = Maybe STRetryConf
forall a. Maybe a
Nothing
| Bool
otherwise = STRetryConf -> Maybe STRetryConf
forall a. a -> Maybe a
Just STRetryConf
retryConfig
maybeHeader :: t a -> Maybe (t a)
maybeHeader t a
headerConfig
| t a -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null t a
headerConfig = Maybe (t a)
forall a. Maybe a
Nothing
| Bool
otherwise = t a -> Maybe (t a)
forall a. a -> Maybe a
Just t a
headerConfig
customTypesToOrdJSON :: CustomTypes -> Maybe AO.Object
customTypesToOrdJSON :: CustomTypes -> Maybe Object
customTypesToOrdJSON customTypes :: CustomTypes
customTypes@(CustomTypes [InputObjectTypeDefinition]
inpObjs [ObjectTypeDefinition]
objs [ScalarTypeDefinition]
scalars [EnumTypeDefinition]
enums)
| CustomTypes
customTypes CustomTypes -> CustomTypes -> Bool
forall a. Eq a => a -> a -> Bool
== CustomTypes
emptyCustomTypes = Maybe Object
forall a. Maybe a
Nothing
| Bool
otherwise =
Object -> Maybe Object
forall a. a -> Maybe a
Just (Object -> Maybe Object)
-> ([Maybe (Text, Value)] -> Object)
-> [Maybe (Text, Value)]
-> Maybe Object
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [(Text, Value)] -> Object
AO.fromList ([(Text, Value)] -> Object)
-> ([Maybe (Text, Value)] -> [(Text, Value)])
-> [Maybe (Text, Value)]
-> Object
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes ([Maybe (Text, Value)] -> Maybe Object)
-> [Maybe (Text, Value)] -> Maybe Object
forall a b. (a -> b) -> a -> b
$
[ Text
-> (InputObjectTypeDefinition -> Value)
-> [InputObjectTypeDefinition]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"input_objects" InputObjectTypeDefinition -> Value
inputObjectToOrdJSON [InputObjectTypeDefinition]
inpObjs,
Text
-> (ObjectTypeDefinition -> Value)
-> [ObjectTypeDefinition]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"objects" ObjectTypeDefinition -> Value
objectTypeToOrdJSON [ObjectTypeDefinition]
objs,
Text
-> (ScalarTypeDefinition -> Value)
-> [ScalarTypeDefinition]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"scalars" ScalarTypeDefinition -> Value
scalarTypeToOrdJSON [ScalarTypeDefinition]
scalars,
Text
-> (EnumTypeDefinition -> Value)
-> [EnumTypeDefinition]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"enums" EnumTypeDefinition -> Value
enumTypeToOrdJSON [EnumTypeDefinition]
enums
]
where
inputObjectToOrdJSON :: InputObjectTypeDefinition -> AO.Value
inputObjectToOrdJSON :: InputObjectTypeDefinition -> Value
inputObjectToOrdJSON (InputObjectTypeDefinition InputObjectTypeName
tyName Maybe Description
descM NonEmpty InputObjectFieldDefinition
fields) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", InputObjectTypeName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered InputObjectTypeName
tyName),
(Text
"fields", [Value] -> Value
AO.array ([Value] -> Value) -> [Value] -> Value
forall a b. (a -> b) -> a -> b
$ (InputObjectFieldDefinition -> Value)
-> [InputObjectFieldDefinition] -> [Value]
forall a b. (a -> b) -> [a] -> [b]
map InputObjectFieldDefinition -> Value
fieldDefinitionToOrdJSON ([InputObjectFieldDefinition] -> [Value])
-> [InputObjectFieldDefinition] -> [Value]
forall a b. (a -> b) -> a -> b
$ NonEmpty InputObjectFieldDefinition -> [InputObjectFieldDefinition]
forall (t :: * -> *) a. Foldable t => t a -> [a]
toList NonEmpty InputObjectFieldDefinition
fields)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Description -> Maybe (Text, Value)
maybeDescriptionToMaybeOrdPair Maybe Description
descM]
where
fieldDefinitionToOrdJSON :: InputObjectFieldDefinition -> AO.Value
fieldDefinitionToOrdJSON :: InputObjectFieldDefinition -> Value
fieldDefinitionToOrdJSON (InputObjectFieldDefinition InputObjectFieldName
fieldName Maybe Description
fieldDescM GraphQLType
ty) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", InputObjectFieldName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered InputObjectFieldName
fieldName),
(Text
"type", GraphQLType -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered GraphQLType
ty)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Description -> Maybe (Text, Value)
maybeDescriptionToMaybeOrdPair Maybe Description
fieldDescM]
objectTypeToOrdJSON :: ObjectTypeDefinition -> AO.Value
objectTypeToOrdJSON :: ObjectTypeDefinition -> Value
objectTypeToOrdJSON (ObjectTypeDefinition ObjectTypeName
tyName Maybe Description
descM NonEmpty (ObjectFieldDefinition GraphQLType)
fields [TypeRelationshipDefinition]
rels) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", ObjectTypeName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ObjectTypeName
tyName),
(Text
"fields", [Value] -> Value
AO.array ([Value] -> Value) -> [Value] -> Value
forall a b. (a -> b) -> a -> b
$ (ObjectFieldDefinition GraphQLType -> Value)
-> [ObjectFieldDefinition GraphQLType] -> [Value]
forall a b. (a -> b) -> [a] -> [b]
map ObjectFieldDefinition GraphQLType -> Value
fieldDefinitionToOrdJSON ([ObjectFieldDefinition GraphQLType] -> [Value])
-> [ObjectFieldDefinition GraphQLType] -> [Value]
forall a b. (a -> b) -> a -> b
$ NonEmpty (ObjectFieldDefinition GraphQLType)
-> [ObjectFieldDefinition GraphQLType]
forall (t :: * -> *) a. Foldable t => t a -> [a]
toList NonEmpty (ObjectFieldDefinition GraphQLType)
fields)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Maybe Description -> Maybe (Text, Value)
maybeDescriptionToMaybeOrdPair Maybe Description
descM,
Text
-> (TypeRelationshipDefinition -> Value)
-> [TypeRelationshipDefinition]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"relationships" TypeRelationshipDefinition -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered [TypeRelationshipDefinition]
rels
]
where
fieldDefinitionToOrdJSON :: ObjectFieldDefinition GraphQLType -> AO.Value
fieldDefinitionToOrdJSON :: ObjectFieldDefinition GraphQLType -> Value
fieldDefinitionToOrdJSON (ObjectFieldDefinition ObjectFieldName
fieldName Maybe Value
argsValM Maybe Description
fieldDescM GraphQLType
ty) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", ObjectFieldName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ObjectFieldName
fieldName),
(Text
"type", GraphQLType -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered GraphQLType
ty)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ (Text
"arguments",) (Value -> (Text, Value))
-> (Value -> Value) -> Value -> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Value -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered (Value -> (Text, Value)) -> Maybe Value -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe Value
argsValM,
Maybe Description -> Maybe (Text, Value)
maybeDescriptionToMaybeOrdPair Maybe Description
fieldDescM
]
scalarTypeToOrdJSON :: ScalarTypeDefinition -> AO.Value
scalarTypeToOrdJSON :: ScalarTypeDefinition -> Value
scalarTypeToOrdJSON (ScalarTypeDefinition Name
tyName Maybe Description
descM) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[(Text
"name", Name -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Name
tyName)]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Description -> Maybe (Text, Value)
maybeDescriptionToMaybeOrdPair Maybe Description
descM]
enumTypeToOrdJSON :: EnumTypeDefinition -> AO.Value
enumTypeToOrdJSON :: EnumTypeDefinition -> Value
enumTypeToOrdJSON (EnumTypeDefinition EnumTypeName
tyName Maybe Description
descM NonEmpty EnumValueDefinition
values) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", EnumTypeName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered EnumTypeName
tyName),
(Text
"values", NonEmpty EnumValueDefinition -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered NonEmpty EnumValueDefinition
values)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Description -> Maybe (Text, Value)
maybeDescriptionToMaybeOrdPair Maybe Description
descM]
endpointsToOrdJSONList :: Endpoints -> Maybe AO.Array
endpointsToOrdJSONList :: Endpoints -> Maybe Array
endpointsToOrdJSONList = (EndpointMetadata QueryReference -> Value)
-> (EndpointMetadata QueryReference -> EndpointUrl)
-> Endpoints
-> Maybe Array
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
(a -> Value) -> (a -> b) -> t a -> Maybe Array
listToMaybeArraySort EndpointMetadata QueryReference -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered EndpointMetadata QueryReference -> EndpointUrl
forall query. EndpointMetadata query -> EndpointUrl
_ceUrl
introspectionDisabledRolesToOrdJSON :: SetGraphqlIntrospectionOptions -> Maybe AO.Value
introspectionDisabledRolesToOrdJSON :: SetGraphqlIntrospectionOptions -> Maybe Value
introspectionDisabledRolesToOrdJSON = (SetGraphqlIntrospectionOptions -> Bool)
-> (SetGraphqlIntrospectionOptions -> Value)
-> SetGraphqlIntrospectionOptions
-> Maybe Value
forall a b. (a -> Bool) -> (a -> b) -> a -> Maybe b
ifNotEmpty (SetGraphqlIntrospectionOptions
-> SetGraphqlIntrospectionOptions -> Bool
forall a. Eq a => a -> a -> Bool
== SetGraphqlIntrospectionOptions
forall a. Monoid a => a
mempty) SetGraphqlIntrospectionOptions -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
metricsConfigToOrdJSON :: MetricsConfig -> Maybe AO.Value
metricsConfigToOrdJSON :: MetricsConfig -> Maybe Value
metricsConfigToOrdJSON = (MetricsConfig -> Bool)
-> (MetricsConfig -> Value) -> MetricsConfig -> Maybe Value
forall a b. (a -> Bool) -> (a -> b) -> a -> Maybe b
ifNotEmpty (MetricsConfig -> MetricsConfig -> Bool
forall a. Eq a => a -> a -> Bool
== MetricsConfig
emptyMetricsConfig) MetricsConfig -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
networkConfigToOrdJSON :: Network -> Maybe AO.Value
networkConfigToOrdJSON :: Network -> Maybe Value
networkConfigToOrdJSON = (Network -> Bool) -> (Network -> Value) -> Network -> Maybe Value
forall a b. (a -> Bool) -> (a -> b) -> a -> Maybe b
ifNotEmpty (Network -> Network -> Bool
forall a. Eq a => a -> a -> Bool
== Network
emptyNetwork) Network -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
actionMetadataToOrdJSONList :: Actions -> Maybe AO.Array
actionMetadataToOrdJSONList :: Actions -> Maybe Array
actionMetadataToOrdJSONList = (ActionMetadata -> Value)
-> (ActionMetadata -> ActionName) -> Actions -> Maybe Array
forall (t :: * -> *) b a.
(Foldable t, Ord b) =>
(a -> Value) -> (a -> b) -> t a -> Maybe Array
listToMaybeArraySort ActionMetadata -> Value
actionMetadataToOrdJSON ActionMetadata -> ActionName
_amName
where
actionMetadataToOrdJSON :: ActionMetadata -> AO.Value
actionMetadataToOrdJSON :: ActionMetadata -> Value
actionMetadataToOrdJSON (ActionMetadata ActionName
name Maybe Text
comment ActionDefinitionInput
definition [ActionPermissionMetadata]
permissions) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", ActionName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ActionName
name),
(Text
"definition", ActionDefinitionInput -> Value
actionDefinitionToOrdJSON ActionDefinitionInput
definition)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Maybe Text -> Maybe (Text, Value)
maybeCommentToMaybeOrdPair Maybe Text
comment,
Text
-> (ActionPermissionMetadata -> Value)
-> [ActionPermissionMetadata]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"permissions" ActionPermissionMetadata -> Value
permToOrdJSON [ActionPermissionMetadata]
permissions
]
where
argDefinitionToOrdJSON :: ArgumentDefinition GraphQLType -> AO.Value
argDefinitionToOrdJSON :: ArgumentDefinition GraphQLType -> Value
argDefinitionToOrdJSON (ArgumentDefinition ArgumentName
argName GraphQLType
ty Maybe Description
descM) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"name", ArgumentName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ArgumentName
argName),
(Text
"type", GraphQLType -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered GraphQLType
ty)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Text
-> (Description -> Value)
-> Maybe Description
-> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"description" Description -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Maybe Description
descM]
actionDefinitionToOrdJSON :: ActionDefinitionInput -> AO.Value
actionDefinitionToOrdJSON :: ActionDefinitionInput -> Value
actionDefinitionToOrdJSON
( ActionDefinition
[ArgumentDefinition GraphQLType]
args
GraphQLType
outputType
ActionType
actionType
[HeaderConf]
headers
Bool
frwrdClientHdrs
Timeout
timeout
InputWebhook
handler
Maybe RequestTransform
requestTransform
Maybe MetadataResponseTransform
responseTransform
) =
let typeAndKind :: [(Text, Value)]
typeAndKind = case ActionType
actionType of
ActionType
ActionQuery -> [(Text
"type", String -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered (String
"query" :: String))]
ActionMutation ActionMutationKind
kind ->
[ (Text
"type", String -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered (String
"mutation" :: String)),
(Text
"kind", ActionMutationKind -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ActionMutationKind
kind)
]
in [(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$
[ (Text
"handler", InputWebhook -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered InputWebhook
handler),
(Text
"output_type", GraphQLType -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered GraphQLType
outputType)
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text
"forward_client_headers", Bool -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Bool
frwrdClientHdrs) | Bool
frwrdClientHdrs]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes
[ Text
-> (HeaderConf -> Value) -> [HeaderConf] -> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"headers" HeaderConf -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered [HeaderConf]
headers,
Text
-> (ArgumentDefinition GraphQLType -> Value)
-> [ArgumentDefinition GraphQLType]
-> Maybe (Text, Value)
forall (t :: * -> *) a.
Foldable t =>
Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
"arguments" ArgumentDefinition GraphQLType -> Value
argDefinitionToOrdJSON [ArgumentDefinition GraphQLType]
args,
(RequestTransform -> (Text, Value))
-> Maybe RequestTransform -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((Text
"request_transform",) (Value -> (Text, Value))
-> (RequestTransform -> Value) -> RequestTransform -> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. RequestTransform -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered) Maybe RequestTransform
requestTransform,
(MetadataResponseTransform -> (Text, Value))
-> Maybe MetadataResponseTransform -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((Text
"response_transform",) (Value -> (Text, Value))
-> (MetadataResponseTransform -> Value)
-> MetadataResponseTransform
-> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. MetadataResponseTransform -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered) Maybe MetadataResponseTransform
responseTransform
]
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text, Value)]
typeAndKind
[(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [(Text, Value)] -> [(Text, Value)] -> Bool -> [(Text, Value)]
forall a. a -> a -> Bool -> a
bool [(Text
"timeout", Timeout -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Timeout
timeout)] [(Text, Value)]
forall a. Monoid a => a
mempty (Timeout
timeout Timeout -> Timeout -> Bool
forall a. Eq a => a -> a -> Bool
== Timeout
defaultActionTimeoutSecs)
permToOrdJSON :: ActionPermissionMetadata -> AO.Value
permToOrdJSON :: ActionPermissionMetadata -> Value
permToOrdJSON (ActionPermissionMetadata RoleName
role Maybe Text
permComment) =
[(Text, Value)] -> Value
AO.object ([(Text, Value)] -> Value) -> [(Text, Value)] -> Value
forall a b. (a -> b) -> a -> b
$ [(Text
"role", RoleName -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered RoleName
role)] [(Text, Value)] -> [(Text, Value)] -> [(Text, Value)]
forall a. Semigroup a => a -> a -> a
<> [Maybe (Text, Value)] -> [(Text, Value)]
forall (f :: * -> *) a. Filterable f => f (Maybe a) -> f a
catMaybes [Maybe Text -> Maybe (Text, Value)
maybeCommentToMaybeOrdPair Maybe Text
permComment]
ifNotEmpty :: (a -> Bool) -> (a -> b) -> a -> Maybe b
ifNotEmpty :: (a -> Bool) -> (a -> b) -> a -> Maybe b
ifNotEmpty a -> Bool
isEmpty a -> b
f a
x
| a -> Bool
isEmpty a
x = Maybe b
forall a. Maybe a
Nothing
| Bool
otherwise = b -> Maybe b
forall a. a -> Maybe a
Just (b -> Maybe b) -> b -> Maybe b
forall a b. (a -> b) -> a -> b
$ a -> b
f a
x
listToMaybeOrdPairSort ::
(Foldable t, Ord b) =>
Text ->
(a -> AO.Value) ->
(a -> b) ->
t a ->
Maybe (Text, AO.Value)
listToMaybeOrdPairSort :: Text -> (a -> Value) -> (a -> b) -> t a -> Maybe (Text, Value)
listToMaybeOrdPairSort Text
name a -> Value
f a -> b
sortF t a
ta = case t a -> [a]
forall (t :: * -> *) a. Foldable t => t a -> [a]
toList t a
ta of
[] -> Maybe (Text, Value)
forall a. Maybe a
Nothing
[a]
list -> (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just ((Text, Value) -> Maybe (Text, Value))
-> (Text, Value) -> Maybe (Text, Value)
forall a b. (a -> b) -> a -> b
$ (Text
name,) (Value -> (Text, Value)) -> Value -> (Text, Value)
forall a b. (a -> b) -> a -> b
$ [Value] -> Value
AO.array ([Value] -> Value) -> [Value] -> Value
forall a b. (a -> b) -> a -> b
$ (a -> Value) -> [a] -> [Value]
forall a b. (a -> b) -> [a] -> [b]
map a -> Value
f ([a] -> [Value]) -> [a] -> [Value]
forall a b. (a -> b) -> a -> b
$ (a -> b) -> [a] -> [a]
forall b a. Ord b => (a -> b) -> [a] -> [a]
sortOn a -> b
sortF [a]
list
listToMaybeArraySort ::
(Foldable t, Ord b) =>
(a -> AO.Value) ->
(a -> b) ->
t a ->
Maybe AO.Array
listToMaybeArraySort :: (a -> Value) -> (a -> b) -> t a -> Maybe Array
listToMaybeArraySort a -> Value
f a -> b
sortF t a
ta = case t a -> [a]
forall (t :: * -> *) a. Foldable t => t a -> [a]
toList t a
ta of
[] -> Maybe Array
forall a. Maybe a
Nothing
[a]
list -> Array -> Maybe Array
forall a. a -> Maybe a
Just (Array -> Maybe Array) -> Array -> Maybe Array
forall a b. (a -> b) -> a -> b
$ [Value] -> Array
forall a. [a] -> Vector a
Vector.fromList ([Value] -> Array) -> [Value] -> Array
forall a b. (a -> b) -> a -> b
$ (a -> Value) -> [a] -> [Value]
forall a b. (a -> b) -> [a] -> [b]
map a -> Value
f ([a] -> [Value]) -> [a] -> [Value]
forall a b. (a -> b) -> a -> b
$ (a -> b) -> [a] -> [a]
forall b a. Ord b => (a -> b) -> [a] -> [a]
sortOn a -> b
sortF [a]
list
listToMaybeOrdPair ::
(Foldable t) =>
Text ->
(a -> AO.Value) ->
t a ->
Maybe (Text, AO.Value)
listToMaybeOrdPair :: Text -> (a -> Value) -> t a -> Maybe (Text, Value)
listToMaybeOrdPair Text
name a -> Value
f t a
ta = case t a -> [a]
forall (t :: * -> *) a. Foldable t => t a -> [a]
toList t a
ta of
[] -> Maybe (Text, Value)
forall a. Maybe a
Nothing
[a]
list -> (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just ((Text, Value) -> Maybe (Text, Value))
-> (Text, Value) -> Maybe (Text, Value)
forall a b. (a -> b) -> a -> b
$ (Text
name,) (Value -> (Text, Value)) -> Value -> (Text, Value)
forall a b. (a -> b) -> a -> b
$ [Value] -> Value
AO.array ([Value] -> Value) -> [Value] -> Value
forall a b. (a -> b) -> a -> b
$ (a -> Value) -> [a] -> [Value]
forall a b. (a -> b) -> [a] -> [b]
map a -> Value
f [a]
list
maybeSetToMaybeOrdPair :: (Backend b) => Maybe (ColumnValues b JSON.Value) -> Maybe (Text, AO.Value)
maybeSetToMaybeOrdPair :: Maybe (ColumnValues b Value) -> Maybe (Text, Value)
maybeSetToMaybeOrdPair Maybe (ColumnValues b Value)
set =
Maybe (ColumnValues b Value)
set Maybe (ColumnValues b Value)
-> (ColumnValues b Value -> Maybe (Text, Value))
-> Maybe (Text, Value)
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= \ColumnValues b Value
colVals ->
if ColumnValues b Value
colVals ColumnValues b Value -> ColumnValues b Value -> Bool
forall a. Eq a => a -> a -> Bool
== ColumnValues b Value
forall a. Monoid a => a
mempty
then Maybe (Text, Value)
forall a. Maybe a
Nothing
else (Text, Value) -> Maybe (Text, Value)
forall a. a -> Maybe a
Just (Text
"set", ColumnValues b Value -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered ColumnValues b Value
colVals)
maybeDescriptionToMaybeOrdPair :: Maybe G.Description -> Maybe (Text, AO.Value)
maybeDescriptionToMaybeOrdPair :: Maybe Description -> Maybe (Text, Value)
maybeDescriptionToMaybeOrdPair = Text
-> (Description -> Value)
-> Maybe Description
-> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"description" Description -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
maybeCommentToMaybeOrdPair :: Maybe Text -> Maybe (Text, AO.Value)
= Text -> (Text -> Value) -> Maybe Text -> Maybe (Text, Value)
forall a. Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
"comment" Text -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered
maybeAnyToMaybeOrdPair :: Text -> (a -> AO.Value) -> Maybe a -> Maybe (Text, AO.Value)
maybeAnyToMaybeOrdPair :: Text -> (a -> Value) -> Maybe a -> Maybe (Text, Value)
maybeAnyToMaybeOrdPair Text
name a -> Value
f = (a -> (Text, Value)) -> Maybe a -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((Text
name,) (Value -> (Text, Value)) -> (a -> Value) -> a -> (Text, Value)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> Value
f)
commentToMaybeOrdPair :: Comment -> Maybe (Text, AO.Value)
Comment
comment = (\Text
val -> (Text
"comment", Text -> Value
forall a. ToJSON a => a -> Value
AO.toOrdered Text
val)) (Text -> (Text, Value)) -> Maybe Text -> Maybe (Text, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Comment -> Maybe Text
commentToMaybeText Comment
comment