2021-11-04 19:08:33 +03:00
|
|
|
module Hasura.RQL.DDL.ApiLimit
|
|
|
|
( runRemoveApiLimits,
|
|
|
|
runSetApiLimits,
|
2023-03-13 14:44:18 +03:00
|
|
|
warningMessage,
|
|
|
|
compareTimeLimitWith,
|
|
|
|
MonadGetApiTimeLimit (..),
|
2021-11-04 19:08:33 +03:00
|
|
|
)
|
|
|
|
where
|
2021-02-11 20:54:25 +03:00
|
|
|
|
2021-09-24 01:56:37 +03:00
|
|
|
import Control.Lens ((.~))
|
|
|
|
import Hasura.Base.Error
|
|
|
|
import Hasura.EncJSON
|
|
|
|
import Hasura.Prelude
|
2023-03-13 14:44:18 +03:00
|
|
|
import Hasura.RQL.DDL.Warnings
|
2022-04-27 16:57:28 +03:00
|
|
|
import Hasura.RQL.Types.ApiLimit
|
|
|
|
import Hasura.RQL.Types.Common
|
|
|
|
import Hasura.RQL.Types.Metadata
|
2023-03-13 14:44:18 +03:00
|
|
|
import Hasura.RQL.Types.Metadata.Object
|
2022-04-27 16:57:28 +03:00
|
|
|
import Hasura.RQL.Types.SchemaCache.Build
|
2023-03-13 14:44:18 +03:00
|
|
|
import Hasura.Tracing (TraceT)
|
2021-05-11 18:18:31 +03:00
|
|
|
|
2021-09-24 01:56:37 +03:00
|
|
|
runSetApiLimits ::
|
2023-03-13 14:44:18 +03:00
|
|
|
(MonadError QErr m, MetadataM m, CacheRWM m, MonadGetApiTimeLimit m) =>
|
2021-09-24 01:56:37 +03:00
|
|
|
ApiLimit ->
|
|
|
|
m EncJSON
|
2021-02-11 20:54:25 +03:00
|
|
|
runSetApiLimits al = do
|
2023-03-13 14:44:18 +03:00
|
|
|
let userTimeLimitAPILimit = _lGlobal <$> _alTimeLimit al
|
|
|
|
-- If both user time limit and cloud limit are present then check if the user time limit API limit is greater than the
|
|
|
|
-- cloud time limit API limit. Otheriwse, apply the API limit configuration (without the warning).
|
|
|
|
warningResultEither <- compareTimeLimitWith userTimeLimitAPILimit
|
|
|
|
case warningResultEither of
|
|
|
|
Left warning -> do
|
|
|
|
successMsgWithWarning <- successMsgWithWarnings $ warn warning
|
|
|
|
setApiLimit successMsgWithWarning
|
|
|
|
Right _ -> setApiLimit successMsg
|
|
|
|
where
|
|
|
|
setApiLimit successMessage = do
|
|
|
|
withNewInconsistentObjsCheck $
|
|
|
|
buildSchemaCache $
|
|
|
|
MetadataModifier $
|
|
|
|
metaApiLimits .~ al
|
|
|
|
return successMessage
|
|
|
|
|
|
|
|
-- This function compares the user time_limit and the cloud time_limit (used in both set_api_limit and replace_metadata
|
|
|
|
-- APIs). The function returns either a metadata warning or `()`
|
|
|
|
compareTimeLimitWith :: MonadGetApiTimeLimit m => Maybe MaxTime -> m (Either MetadataWarning ())
|
|
|
|
compareTimeLimitWith userTimeLimitMaybe = do
|
|
|
|
cloudApiTimeLimit <- runGetApiTimeLimit
|
|
|
|
let compareTimeLimitResultEither =
|
|
|
|
case (userTimeLimitMaybe, cloudApiTimeLimit) of
|
|
|
|
(Just userTimeLimitAPILimit, Just cloudTimeLimit) -> do
|
|
|
|
if userTimeLimitAPILimit > cloudTimeLimit
|
|
|
|
then Left $ warningMessage userTimeLimitAPILimit cloudTimeLimit
|
|
|
|
else Right ()
|
|
|
|
_ -> Right ()
|
|
|
|
pure compareTimeLimitResultEither
|
|
|
|
|
|
|
|
-- warning message if the user time limit API limit is greater than the cloud time limit API limit
|
|
|
|
warningMessage :: MaxTime -> MaxTime -> MetadataWarning
|
|
|
|
warningMessage userTimeLimit cloudTimeLimit =
|
2023-04-06 05:38:03 +03:00
|
|
|
MetadataWarning WCTimeLimitExceededSystemLimit (MOSource defaultSource) $
|
2023-03-13 14:44:18 +03:00
|
|
|
"the configured time limit: "
|
|
|
|
<> tshow (seconds $ unMaxTime userTimeLimit)
|
|
|
|
<> " exceeds the project time limit: "
|
|
|
|
<> tshow (seconds $ unMaxTime cloudTimeLimit)
|
|
|
|
<> ". Time limit of "
|
|
|
|
<> tshow (seconds $ unMaxTime cloudTimeLimit)
|
|
|
|
<> " will be applied"
|
2021-02-11 20:54:25 +03:00
|
|
|
|
2021-09-24 01:56:37 +03:00
|
|
|
runRemoveApiLimits ::
|
|
|
|
(MonadError QErr m, MetadataM m, CacheRWM m) =>
|
|
|
|
m EncJSON
|
2021-02-11 20:54:25 +03:00
|
|
|
runRemoveApiLimits = do
|
2021-09-24 01:56:37 +03:00
|
|
|
withNewInconsistentObjsCheck $
|
|
|
|
buildSchemaCache $
|
|
|
|
MetadataModifier $
|
|
|
|
metaApiLimits .~ emptyApiLimit
|
2021-02-11 20:54:25 +03:00
|
|
|
return successMsg
|
2023-03-13 14:44:18 +03:00
|
|
|
|
|
|
|
class Monad m => MonadGetApiTimeLimit m where
|
|
|
|
runGetApiTimeLimit ::
|
|
|
|
m (Maybe MaxTime)
|
|
|
|
|
|
|
|
instance (MonadGetApiTimeLimit m) => MonadGetApiTimeLimit (ReaderT r m) where
|
|
|
|
runGetApiTimeLimit = lift runGetApiTimeLimit
|
|
|
|
|
|
|
|
instance (MonadGetApiTimeLimit m) => MonadGetApiTimeLimit (MetadataT m) where
|
|
|
|
runGetApiTimeLimit = lift runGetApiTimeLimit
|
|
|
|
|
|
|
|
instance (MonadGetApiTimeLimit m) => MonadGetApiTimeLimit (TraceT m) where
|
|
|
|
runGetApiTimeLimit = lift runGetApiTimeLimit
|
|
|
|
|
|
|
|
instance (MonadGetApiTimeLimit m) => MonadGetApiTimeLimit (ExceptT e m) where
|
|
|
|
runGetApiTimeLimit = lift runGetApiTimeLimit
|
|
|
|
|
|
|
|
instance (MonadGetApiTimeLimit m) => MonadGetApiTimeLimit (StateT w m) where
|
|
|
|
runGetApiTimeLimit = lift runGetApiTimeLimit
|