From 7ce10936838e8e0176242b23f5196731d3076b9b Mon Sep 17 00:00:00 2001 From: Solomon Date: Wed, 12 Apr 2023 15:02:19 -0700 Subject: [PATCH] Allow CE users to attempt GDC requests PR-URL: https://github.com/hasura/graphql-engine-mono/pull/8754 GitOrigin-RevId: 26a364a6c9d5788d4b06a84942ba9953be104ab7 --- .../DataConnector/Adapter/Transport.hs | 60 ++++++++++--------- .../Backends/DataConnector/Agent/Client.hs | 4 +- 2 files changed, 36 insertions(+), 28 deletions(-) diff --git a/server/src-lib/Hasura/Backends/DataConnector/Adapter/Transport.hs b/server/src-lib/Hasura/Backends/DataConnector/Adapter/Transport.hs index 8b62c2e7f5d..7ba28a13582 100644 --- a/server/src-lib/Hasura/Backends/DataConnector/Adapter/Transport.hs +++ b/server/src-lib/Hasura/Backends/DataConnector/Adapter/Transport.hs @@ -9,11 +9,10 @@ import Control.Exception.Safe (throwIO) import Control.Monad.Trans.Control import Data.Aeson qualified as J import Data.Text.Extended ((<>>)) -import Hasura.Backends.DataConnector.API.V0 import Hasura.Backends.DataConnector.Adapter.Execute (DataConnectorPreparedQuery (..), encodePreparedQueryToJsonText) import Hasura.Backends.DataConnector.Adapter.Types (SourceConfig (..)) import Hasura.Backends.DataConnector.Agent.Client (AgentClientContext (..), AgentClientT, AgentLicenseKey (..), runAgentClientT) -import Hasura.Base.Error (QErr, throw401) +import Hasura.Base.Error (QErr (..)) import Hasura.CredentialCache import Hasura.EncJSON (EncJSON) import Hasura.GraphQL.Execute.Backend (DBStepInfo (..), OnBaseMonad (..), arResult) @@ -66,16 +65,18 @@ runDBQuery' requestId query fieldName _userInfo logger licenseKeyCacheMaybe Sour -- TODO: If the license key has expired or is otherwise invalid, request a key refresh pure key - case (_cLicensing _scCapabilities, agentAuthKey) of - (Just _, Nothing) -> throw401 "EE License Key Required." - _ -> do - void $ HGL.logQueryLog logger $ mkQueryLog query fieldName queryRequest requestId - withElapsedTime - . Tracing.newSpan ("Data Connector backend query for root field " <>> fieldName) - . flip runAgentClientT (AgentClientContext logger _scEndpoint _scManager _scTimeoutMicroseconds agentAuthKey) - . runOnBaseMonad - . fmap snd - $ action + -- TODO: Re-introduce this case statement once we no longer want to + -- allow CE to attempt GDC requests. + -- case (_cLicensing _scCapabilities, agentAuthKey) of + -- (Just _, Nothing) -> throw401 "EE License Key Required." + -- _ -> do + void $ HGL.logQueryLog logger $ mkQueryLog query fieldName queryRequest requestId + withElapsedTime + . Tracing.newSpan ("Data Connector backend query for root field " <>> fieldName) + . flip runAgentClientT (AgentClientContext logger _scEndpoint _scManager _scTimeoutMicroseconds agentAuthKey) + . runOnBaseMonad + . fmap snd + $ action mkQueryLog :: GQLReqUnparsed -> @@ -106,12 +107,14 @@ runDBQueryExplain' licenseKeyCacheMaybe (DBStepInfo _ SourceConfig {..} _ action (key, _requestKeyRefresh) <- liftIO $ atomically $ getCredential licenseKeyCache -- TODO: If the license key has expired or is otherwise invalid, request a key refresh pure key - case (_cLicensing _scCapabilities, agentAuthKey) of - (Just _, Nothing) -> throw401 "EE License Key Required." - _ -> - flip runAgentClientT (AgentClientContext nullLogger _scEndpoint _scManager _scTimeoutMicroseconds agentAuthKey) - . fmap arResult - $ runOnBaseMonad action + -- TODO: Re-introduce this case statement once we no longer want to + -- allow CE to attempt GDC requests. + -- case (_cLicensing _scCapabilities, agentAuthKey) of + -- (Just _, Nothing) -> throw401 "EE License Key Required." + -- _ -> + flip runAgentClientT (AgentClientContext nullLogger _scEndpoint _scManager _scTimeoutMicroseconds agentAuthKey) + . fmap arResult + $ runOnBaseMonad action runDBMutation' :: ( MonadIO m, @@ -137,12 +140,15 @@ runDBMutation' requestId query fieldName _userInfo logger licenseKeyCacheMaybe S (key, _requestKeyRefresh) <- liftIO $ atomically $ getCredential licenseKeyCache -- TODO: If the license key has expired or is otherwise invalid, request a key refresh pure key - case (_cLicensing _scCapabilities, agentAuthKey) of - (Just _, Nothing) -> throw401 "EE License Key Required." - _ -> do - void $ HGL.logQueryLog logger $ mkQueryLog query fieldName queryRequest requestId - withElapsedTime - . Tracing.newSpan ("Data Connector backend mutation for root field " <>> fieldName) - . flip runAgentClientT (AgentClientContext logger _scEndpoint _scManager _scTimeoutMicroseconds agentAuthKey) - . runOnBaseMonad - $ action + + -- TODO: Re-introduce this case statement once we no longer want to + -- allow CE to attempt GDC requests. + -- case (_cLicensing _scCapabilities, agentAuthKey) of + -- (Just _, Nothing) -> throw401 "EE License Key Required." + -- _ -> do + void $ HGL.logQueryLog logger $ mkQueryLog query fieldName queryRequest requestId + withElapsedTime + . Tracing.newSpan ("Data Connector backend mutation for root field " <>> fieldName) + . flip runAgentClientT (AgentClientContext logger _scEndpoint _scManager _scTimeoutMicroseconds agentAuthKey) + . runOnBaseMonad + $ action diff --git a/server/src-lib/Hasura/Backends/DataConnector/Agent/Client.hs b/server/src-lib/Hasura/Backends/DataConnector/Agent/Client.hs index c57b7ccb1e5..da71ba39062 100644 --- a/server/src-lib/Hasura/Backends/DataConnector/Agent/Client.hs +++ b/server/src-lib/Hasura/Backends/DataConnector/Agent/Client.hs @@ -83,4 +83,6 @@ throwClientError' :: (MonadIO m, MonadTrace m, MonadError QErr m) => ClientError throwClientError' err = do AgentClientContext {..} <- askClientContext logClientError _accLogger err - throw500 $ "Error in Data Connector backend: " <> Hasura.HTTP.serializeServantClientErrorMessage err + case err of + FailureResponse _ r | responseStatusCode r == HTTP.status401 -> throw401 "EE License Key Required." + _ -> throw500 $ "Error in Data Connector backend: " <> Hasura.HTTP.serializeServantClientErrorMessage err