graphql-engine/server/src-lib/Hasura/Backends/MSSQL
Antoine Leblanc 7aa341944b Remove HasServerConfigCtx from the schema cache build.
## Description

This PR is a incremental step towards achieving the goal of #8344. It is a less ambitious version of #8484.

This PR removes all references to `HasServerConfigCtx` from the cache build and removes `ServerConfigCtx` from `CacheBuildParams`, making `ServerConfigCtx` an argument being passed around manually instead. This has several benefits: by making it an arrow argument, we now properly integrate the fields that change over time in the dependency framework, as they should be, and we can clean up some of the top-level app code.

## Implementation

In practice, this PR introduces a `HasServerConfigCtx` instance for `CacheRWT`, the monad we use to build the cache, so we can retrieve the `ServerConfigCtx` in the implementation of `CacheRWM`. This contributes to reducing the amount of `HasServerConfigCtx` in the code: we can remove `SchemaUpdateT` altogether, and we can remove the `HasServerConfigCtx` instance of `Handler`. This makes `HasServerConfigCtx` almost **an implementation detail of the Metadata API**.

This first step is enough to achieve the goal of #8344: we can now build the schema cache in the app monad, since we no longer rely on `HasServerConfigCtx` to build it.

## Drawbacks

This PR does not attempt to remove the use of `ServerConfigCtx` itself in the schema cache build: doing so would make this PR much much bigger. Ideally, to avoid having all the static fields given as arrow-ish arguments to the cache, we could depend on `HasAppEnv` in the cache build, and use `AppContext` as an arrow argument. But making the cache build depend on the full `AppEnv` and `AppContext` creates a lot of circular imports; and since removing `ServerConfigCtx` itself isn't required to achieve #8344, this PR keeps it wholesale and defers cleaning it to a future PR.

A negative consequence of this is that we need an `Eq` instance on `ServerConfigCtx`, and that instance is inelegant.

## Future work

There are several further steps we can take in parallel after this is merged. First, again, we can make a new version of #8344, removing `CacheBuild`, FINALLY. As for `ServerConfigCtx`, we can split it / rename it to make ad-hoc structures. If it turns out that `ServerConfigCtx` is only ever used for the schema cache build, we could split it between `CacheBuildEnv` and `CacheBuildContext`, which will be subsets of `AppEnv` and `AppContext`, avoiding import loops.

PR-URL: https://github.com/hasura/graphql-engine-mono/pull/8509
GitOrigin-RevId: 01b37cc3fd3490d6b117701e22fc4ac88b62b6b5
2023-03-27 17:44:27 +00:00
..
DDL Remove HasServerConfigCtx from the schema cache build. 2023-03-27 17:44:27 +00:00
Execute feature(server): add SQLServer logical models 2023-03-27 16:56:05 +00:00
FromIr feature(server): add SQLServer logical models 2023-03-27 16:56:05 +00:00
Instances feature(server): add SQLServer logical models 2023-03-27 16:56:05 +00:00
Schema [server] Custom types prototype 2023-02-15 17:56:58 +00:00
SQL Remove RQL/Types.hs 2022-04-27 13:58:47 +00:00
Types feature(server): add SQLServer logical models 2023-03-27 16:56:05 +00:00
Connection.hs multitenant: enhancements to resize pools logs 2023-03-15 10:30:48 +00:00
DDL.hs Move MkTypename and NamingCase into their own modules. 2022-07-12 14:01:28 +00:00
FromIr.hs feature(server): add SQLServer logical models 2023-03-27 16:56:05 +00:00
Meta.hs feature(server): metadata for SQLServer logical model 2023-03-22 17:11:19 +00:00
Plan.hs feature(server): add SQLServer logical models 2023-03-27 16:56:05 +00:00
ToQuery.hs feature(server): add SQLServer logical models 2023-03-27 16:56:05 +00:00
Types.hs Add docstrings to the module headers of a few selected mssql modules 2022-01-03 17:17:18 +00:00