graphql-engine/server/src-lib/Hasura/RQL/DDL/Network.hs
Lyndon Maydwell 9a1c7d5ea0 server: Adding support for TLS allowlist by domain and service id (port)
https://github.com/hasura/graphql-engine-mono/pull/2153

Co-authored-by: Sameer Kolhar <6604943+kolharsam@users.noreply.github.com>
GitOrigin-RevId: 473a29af97236fc879ae178b0c2a6c31c1f12563
2021-08-24 07:37:25 +00:00

76 lines
2.4 KiB
Haskell

module Hasura.RQL.DDL.Network where
import Hasura.Prelude
import Data.Text (pack)
import Data.Text.Extended
import Hasura.Base.Error
import Hasura.EncJSON
import Hasura.Metadata.Class ()
import Hasura.RQL.Types
import Hasura.RQL.Types.Network ()
runAddHostToTLSAllowlist
:: (QErrM m, CacheRWM m, MetadataM m)
=> TlsAllow
-> m EncJSON
runAddHostToTLSAllowlist tlsAllowListEntry@TlsAllow{..} = do
networkMetadata <- _metaNetwork <$> getMetadata
when (null taHost) $ do
throw400 BadRequest $ "key \"host\" cannot be empty"
when (checkForHostInTLSAllowlist taHost (tlsList networkMetadata)) $ do
throw400 AlreadyExists $
"the host " <> dquote (pack taHost) <> " already exists in the allowlist"
withNewInconsistentObjsCheck
$ buildSchemaCacheFor (MOHostTlsAllowlist taHost)
$ addHostToTLSAllowList tlsAllowListEntry
pure successMsg
where
tlsList nm = networkTlsAllowlist nm
runDropHostFromTLSAllowlist
:: (QErrM m, CacheRWM m, MetadataM m)
=> DropHostFromTLSAllowlist
-> m EncJSON
runDropHostFromTLSAllowlist (DropHostFromTLSAllowlist hostname) = do
networkMetadata <- _metaNetwork <$> getMetadata
when (null hostname) $ do
throw400 BadRequest $ "hostname cannot be empty"
unless (checkForHostInTLSAllowlist hostname (networkTlsAllowlist networkMetadata)) $ do
throw400 NotExists $
"the host " <> dquote (pack hostname) <> " isn't present in the allowlist"
withNewInconsistentObjsCheck
$ buildSchemaCache
$ dropHostFromAllowList hostname
pure successMsg
addHostToTLSAllowList :: TlsAllow -> MetadataModifier
addHostToTLSAllowList tlsaObj = MetadataModifier $ \m ->
m { _metaNetwork = Network $ (tlsList m) ++ [tlsaObj] }
where
tlsList md = networkTlsAllowlist (_metaNetwork md)
dropHostFromAllowList :: String -> MetadataModifier
dropHostFromAllowList host = MetadataModifier $ \m ->
m { _metaNetwork = Network $ filteredList m }
where
tlsList md = networkTlsAllowlist (_metaNetwork md)
filteredList md = filter (not . checkForHostnameInAllowlistObject host) (tlsList md)
checkForHostnameInAllowlistObject :: String -> TlsAllow -> Bool
checkForHostnameInAllowlistObject host tlsa = host == (taHost tlsa)
checkForHostInTLSAllowlist :: String -> [TlsAllow] -> Bool
checkForHostInTLSAllowlist host tlsAllowList =
any (checkForHostnameInAllowlistObject host) tlsAllowList