mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-07 08:13:18 +03:00
c04c4bc0d9
PR-URL: https://github.com/hasura/graphql-engine-mono/pull/10100 GitOrigin-RevId: 55f38a904767e1b25916fb31b3c5ece898c10349
51 lines
1.7 KiB
Haskell
51 lines
1.7 KiB
Haskell
-- | Common codecs shared between similar logical model resolvers.
|
|
module Hasura.LogicalModelResolver.Codec
|
|
( nativeQueryRelationshipsCodec,
|
|
)
|
|
where
|
|
|
|
import Autodocodec (HasCodec (), HasObjectCodec (..), bimapCodec)
|
|
import Autodocodec qualified as AC
|
|
import Data.Aeson (Value)
|
|
import Data.HashMap.Strict.InsOrd qualified as InsOrdHashMap
|
|
import Hasura.Prelude hiding (first)
|
|
import Hasura.RQL.Types.Backend (Backend (..))
|
|
import Hasura.RQL.Types.Common (RelName)
|
|
import Hasura.RQL.Types.Relationships.Local (RelDef, RelManualConfig)
|
|
|
|
-- | Codec for native-query-or-table relationships
|
|
nativeQueryRelationshipsCodec ::
|
|
forall b.
|
|
(Backend b) =>
|
|
AC.Codec
|
|
Value
|
|
(InsOrdHashMap.InsOrdHashMap RelName (RelDef (RelManualConfig b)))
|
|
(InsOrdHashMap.InsOrdHashMap RelName (RelDef (RelManualConfig b)))
|
|
nativeQueryRelationshipsCodec =
|
|
AC.dimapCodec
|
|
( InsOrdHashMap.fromList
|
|
. fmap
|
|
( \(MergedObject (NameField name) nst) ->
|
|
(name, nst)
|
|
)
|
|
)
|
|
( fmap (\(fld, nst) -> MergedObject (NameField fld) nst) . InsOrdHashMap.toList
|
|
)
|
|
( AC.listCodec
|
|
$ AC.object "RelDefRelManualConfig"
|
|
$ AC.objectCodec @(MergedObject (NameField RelName) (RelDef (RelManualConfig b)))
|
|
)
|
|
|
|
data MergedObject a b = MergedObject
|
|
{ moFst :: a,
|
|
moSnd :: b
|
|
}
|
|
|
|
instance (HasObjectCodec a, HasObjectCodec b) => HasObjectCodec (MergedObject a b) where
|
|
objectCodec = MergedObject <$> bimapCodec Right moFst objectCodec <*> bimapCodec Right moSnd objectCodec
|
|
|
|
newtype NameField a = NameField {nameField :: a}
|
|
|
|
instance (HasCodec a) => HasObjectCodec (NameField a) where
|
|
objectCodec = NameField <$> AC.requiredField "name" "name" AC..= nameField
|