Description
First of thanks for this nice data source.
The reason why I'm writing is your given example in the usage section. You're creating the MyDatabase
instance outside of the context creation, thus, it will only get created once. Reusing this instance (data source) will result in context being overwritten by resolvers. A more detailed example:
user 1
makes a request- database gets initialized with context that contains the user id
- the resolver waits 5 seconds
- then executes a database call
user 2
makes a request afteruser 1
(first requests resolver still waits!)- database gets initialized with context (overwrites context) that contains the user id
- the resolver waits 5 seconds
- then executes a database call
Both request have different context, but the database instance context is being overwritten, meaning the first requests database call will have the context of request 2. Generally this won't happen since queries are fast, but when using a websocket server that will create the context only once on subscribe this becomes a major problem.
This is how I implemented it instead:
- const db = new MyDatabase(knexConfig);
+ const knexInstance = knex(knexConfig)
const server = new ApolloServer({
typeDefs,
resolvers,
cache,
context,
- dataSources: () => ({ db })
+ dataSources: () => ({ db: new MyDatabase(knexInstance) })
});
Maybe I'm not understanding the example correctly. Anyway, I'd love to hear you feedback, thanks.