2021-03-15 16:02:58 +03:00
|
|
|
module Hasura.SQL.Backend
|
|
|
|
( BackendType(..)
|
|
|
|
, supportedBackends
|
|
|
|
) where
|
2020-10-22 23:42:27 +03:00
|
|
|
|
2021-02-03 19:17:20 +03:00
|
|
|
import Hasura.Prelude
|
|
|
|
|
2021-03-18 23:34:11 +03:00
|
|
|
import Data.Aeson
|
|
|
|
import Data.Text (unpack)
|
|
|
|
import Data.Text.Extended
|
2021-02-03 19:17:20 +03:00
|
|
|
|
2021-02-14 09:07:52 +03:00
|
|
|
|
|
|
|
-- | An enum that represents each backend we support.
|
2021-03-18 23:34:11 +03:00
|
|
|
-- This type MUST be an enumeration (an enumeration consists of one or
|
|
|
|
-- more nullary, non-GADT constructors).
|
|
|
|
data BackendType
|
|
|
|
= Postgres
|
|
|
|
| MSSQL
|
|
|
|
deriving (Eq, Ord, Bounded, Enum)
|
|
|
|
|
|
|
|
-- | The name of the backend, as we expect it to appear in our metadata and API.
|
|
|
|
instance ToTxt BackendType where
|
|
|
|
toTxt Postgres = "postgres"
|
|
|
|
toTxt MSSQL = "mssql"
|
|
|
|
|
|
|
|
-- | The FromJSON instance uses this lookup mechanism to avoid having
|
|
|
|
-- to duplicate and hardcode the backend string.
|
|
|
|
instance FromJSON BackendType where
|
|
|
|
parseJSON = withText "backend type" \name ->
|
|
|
|
lookup name [(toTxt b, b) | b <- supportedBackends]
|
|
|
|
`onNothing` fail ("got: " <> unpack name <> ", expected one of: " <> unpack (commaSeparated supportedBackends))
|
|
|
|
|
|
|
|
instance ToJSON BackendType where
|
|
|
|
toJSON = String . toTxt
|
|
|
|
|
|
|
|
|
|
|
|
supportedBackends :: [BackendType]
|
|
|
|
supportedBackends = [minBound @BackendType .. maxBound]
|