module Hasura.Backends.Postgres.DDL
( parseCollectableType,
module M,
)
where
import Data.Aeson
import Hasura.Backends.Postgres.DDL.BoolExp as M
import Hasura.Backends.Postgres.DDL.ComputedField as M
import Hasura.Backends.Postgres.DDL.EventTrigger as M
import Hasura.Backends.Postgres.DDL.Function as M
import Hasura.Backends.Postgres.DDL.Source as M
import Hasura.Backends.Postgres.DDL.Table as M
import Hasura.Backends.Postgres.SQL.DML
import Hasura.Backends.Postgres.Translate.Column
import Hasura.Backends.Postgres.Types.Column
import Hasura.Base.Error
import Hasura.Prelude
import Hasura.RQL.IR.BoolExp
import Hasura.RQL.Types.Backend
import Hasura.RQL.Types.Column
import Hasura.SQL.Backend
import Hasura.SQL.Types
import Hasura.Server.Utils
import Hasura.Session
parseCollectableType ::
forall pgKind m.
(Backend ('Postgres pgKind), MonadError QErr m) =>
CollectableType (ColumnType ('Postgres pgKind)) ->
Value ->
m (PartialSQLExp ('Postgres pgKind))
parseCollectableType :: CollectableType (ColumnType ('Postgres pgKind))
-> Value -> m (PartialSQLExp ('Postgres pgKind))
parseCollectableType CollectableType (ColumnType ('Postgres pgKind))
pgType = \case
String Text
t
| Text -> Bool
isSessionVariable Text
t -> PartialSQLExp ('Postgres pgKind)
-> m (PartialSQLExp ('Postgres pgKind))
forall (m :: * -> *) a. Monad m => a -> m a
return (PartialSQLExp ('Postgres pgKind)
-> m (PartialSQLExp ('Postgres pgKind)))
-> PartialSQLExp ('Postgres pgKind)
-> m (PartialSQLExp ('Postgres pgKind))
forall a b. (a -> b) -> a -> b
$ CollectableType (ColumnType ('Postgres pgKind))
-> SessionVariable -> PartialSQLExp ('Postgres pgKind)
forall (pgKind :: PostgresKind).
CollectableType (ColumnType ('Postgres pgKind))
-> SessionVariable -> PartialSQLExp ('Postgres pgKind)
mkTypedSessionVar CollectableType (ColumnType ('Postgres pgKind))
pgType (SessionVariable -> PartialSQLExp ('Postgres pgKind))
-> SessionVariable -> PartialSQLExp ('Postgres pgKind)
forall a b. (a -> b) -> a -> b
$ Text -> SessionVariable
mkSessionVariable Text
t
| Text -> Bool
isReqUserId Text
t -> PartialSQLExp ('Postgres pgKind)
-> m (PartialSQLExp ('Postgres pgKind))
forall (m :: * -> *) a. Monad m => a -> m a
return (PartialSQLExp ('Postgres pgKind)
-> m (PartialSQLExp ('Postgres pgKind)))
-> PartialSQLExp ('Postgres pgKind)
-> m (PartialSQLExp ('Postgres pgKind))
forall a b. (a -> b) -> a -> b
$ CollectableType (ColumnType ('Postgres pgKind))
-> SessionVariable -> PartialSQLExp ('Postgres pgKind)
forall (pgKind :: PostgresKind).
CollectableType (ColumnType ('Postgres pgKind))
-> SessionVariable -> PartialSQLExp ('Postgres pgKind)
mkTypedSessionVar CollectableType (ColumnType ('Postgres pgKind))
pgType SessionVariable
forall a. IsString a => a
userIdHeader
Value
val -> case CollectableType (ColumnType ('Postgres pgKind))
pgType of
CollectableTypeScalar ColumnType ('Postgres pgKind)
cvType ->
SQLExp -> PartialSQLExp ('Postgres pgKind)
forall (backend :: BackendType).
SQLExpression backend -> PartialSQLExp backend
PSESQLExp (SQLExp -> PartialSQLExp ('Postgres pgKind))
-> (PGScalarValue -> SQLExp)
-> PGScalarValue
-> PartialSQLExp ('Postgres pgKind)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ColumnValue ('Postgres pgKind) -> SQLExp
forall (pgKind :: PostgresKind).
ColumnValue ('Postgres pgKind) -> SQLExp
toTxtValue (ColumnValue ('Postgres pgKind) -> SQLExp)
-> (PGScalarValue -> ColumnValue ('Postgres pgKind))
-> PGScalarValue
-> SQLExp
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ColumnType ('Postgres pgKind)
-> ScalarValue ('Postgres pgKind) -> ColumnValue ('Postgres pgKind)
forall (b :: BackendType).
ColumnType b -> ScalarValue b -> ColumnValue b
ColumnValue ColumnType ('Postgres pgKind)
cvType (PGScalarValue -> PartialSQLExp ('Postgres pgKind))
-> m PGScalarValue -> m (PartialSQLExp ('Postgres pgKind))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> ColumnType ('Postgres pgKind)
-> Value -> m (ScalarValue ('Postgres pgKind))
forall (m :: * -> *) (b :: BackendType).
(MonadError QErr m, Backend b) =>
ColumnType b -> Value -> m (ScalarValue b)
parseScalarValueColumnType ColumnType ('Postgres pgKind)
cvType Value
val
CollectableTypeArray ColumnType ('Postgres pgKind)
ofType -> do
[Value]
vals <- (Value -> Parser [Value]) -> Value -> m [Value]
forall (m :: * -> *) v a. QErrM m => (v -> Parser a) -> v -> m a
runAesonParser Value -> Parser [Value]
forall a. FromJSON a => Value -> Parser a
parseJSON Value
val
[PGScalarValue]
scalarValues <- ColumnType ('Postgres pgKind)
-> [Value] -> m [ScalarValue ('Postgres pgKind)]
forall (m :: * -> *) (b :: BackendType).
(MonadError QErr m, Backend b) =>
ColumnType b -> [Value] -> m [ScalarValue b]
parseScalarValuesColumnType ColumnType ('Postgres pgKind)
ofType [Value]
vals
PartialSQLExp ('Postgres pgKind)
-> m (PartialSQLExp ('Postgres pgKind))
forall (m :: * -> *) a. Monad m => a -> m a
return (PartialSQLExp ('Postgres pgKind)
-> m (PartialSQLExp ('Postgres pgKind)))
-> (SQLExp -> PartialSQLExp ('Postgres pgKind))
-> SQLExp
-> m (PartialSQLExp ('Postgres pgKind))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SQLExp -> PartialSQLExp ('Postgres pgKind)
forall (backend :: BackendType).
SQLExpression backend -> PartialSQLExp backend
PSESQLExp (SQLExp -> m (PartialSQLExp ('Postgres pgKind)))
-> SQLExp -> m (PartialSQLExp ('Postgres pgKind))
forall a b. (a -> b) -> a -> b
$
SQLExp -> TypeAnn -> SQLExp
SETyAnn
([SQLExp] -> SQLExp
SEArray ([SQLExp] -> SQLExp) -> [SQLExp] -> SQLExp
forall a b. (a -> b) -> a -> b
$ (PGScalarValue -> SQLExp) -> [PGScalarValue] -> [SQLExp]
forall a b. (a -> b) -> [a] -> [b]
map (ColumnValue ('Postgres pgKind) -> SQLExp
forall (pgKind :: PostgresKind).
ColumnValue ('Postgres pgKind) -> SQLExp
toTxtValue (ColumnValue ('Postgres pgKind) -> SQLExp)
-> (PGScalarValue -> ColumnValue ('Postgres pgKind))
-> PGScalarValue
-> SQLExp
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ColumnType ('Postgres pgKind)
-> ScalarValue ('Postgres pgKind) -> ColumnValue ('Postgres pgKind)
forall (b :: BackendType).
ColumnType b -> ScalarValue b -> ColumnValue b
ColumnValue ColumnType ('Postgres pgKind)
ofType) [PGScalarValue]
scalarValues)
(CollectableType PGScalarType -> TypeAnn
mkTypeAnn (CollectableType PGScalarType -> TypeAnn)
-> CollectableType PGScalarType -> TypeAnn
forall a b. (a -> b) -> a -> b
$ PGScalarType -> CollectableType PGScalarType
forall a. a -> CollectableType a
CollectableTypeArray (ColumnType ('Postgres pgKind) -> PGScalarType
forall (pgKind :: PostgresKind).
ColumnType ('Postgres pgKind) -> PGScalarType
unsafePGColumnToBackend ColumnType ('Postgres pgKind)
ofType))
mkTypedSessionVar ::
CollectableType (ColumnType ('Postgres pgKind)) ->
SessionVariable ->
PartialSQLExp ('Postgres pgKind)
mkTypedSessionVar :: CollectableType (ColumnType ('Postgres pgKind))
-> SessionVariable -> PartialSQLExp ('Postgres pgKind)
mkTypedSessionVar CollectableType (ColumnType ('Postgres pgKind))
columnType =
SessionVarType ('Postgres pgKind)
-> SessionVariable -> PartialSQLExp ('Postgres pgKind)
forall (backend :: BackendType).
SessionVarType backend -> SessionVariable -> PartialSQLExp backend
PSESessVar (ColumnType ('Postgres pgKind) -> PGScalarType
forall (pgKind :: PostgresKind).
ColumnType ('Postgres pgKind) -> PGScalarType
unsafePGColumnToBackend (ColumnType ('Postgres pgKind) -> PGScalarType)
-> CollectableType (ColumnType ('Postgres pgKind))
-> CollectableType PGScalarType
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> CollectableType (ColumnType ('Postgres pgKind))
columnType)