2021-07-07 18:15:53 +02:00
|
|
|
const Client = require("./index")
|
|
|
|
const utils = require("./utils")
|
2022-06-01 18:52:41 +02:00
|
|
|
const { getRedlock } = require("./redlock")
|
2021-07-06 19:10:04 +02:00
|
|
|
|
2022-06-23 21:22:51 +02:00
|
|
|
let userClient, sessionClient, appClient, cacheClient, writethroughClient
|
2022-06-01 18:52:41 +02:00
|
|
|
let migrationsRedlock
|
|
|
|
|
|
|
|
// turn retry off so that only one instance can ever hold the lock
|
|
|
|
const migrationsRedlockConfig = { retryCount: 0 }
|
2021-07-06 19:10:04 +02:00
|
|
|
|
|
|
|
async function init() {
|
|
|
|
userClient = await new Client(utils.Databases.USER_CACHE).init()
|
|
|
|
sessionClient = await new Client(utils.Databases.SESSIONS).init()
|
2021-11-15 18:40:45 +01:00
|
|
|
appClient = await new Client(utils.Databases.APP_METADATA).init()
|
2022-05-23 16:03:52 +02:00
|
|
|
cacheClient = await new Client(utils.Databases.GENERIC_CACHE).init()
|
2022-06-23 21:22:51 +02:00
|
|
|
writethroughClient = await new Client(
|
|
|
|
utils.Databases.WRITE_THROUGH,
|
|
|
|
utils.SelectableDatabases.WRITE_THROUGH
|
|
|
|
).init()
|
2022-06-01 18:52:41 +02:00
|
|
|
// pass the underlying ioredis client to redlock
|
|
|
|
migrationsRedlock = getRedlock(
|
|
|
|
cacheClient.getClient(),
|
|
|
|
migrationsRedlockConfig
|
|
|
|
)
|
2021-07-06 19:10:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
process.on("exit", async () => {
|
|
|
|
if (userClient) await userClient.finish()
|
|
|
|
if (sessionClient) await sessionClient.finish()
|
2021-11-15 18:40:45 +01:00
|
|
|
if (appClient) await appClient.finish()
|
2022-05-23 16:03:52 +02:00
|
|
|
if (cacheClient) await cacheClient.finish()
|
2022-06-23 21:22:51 +02:00
|
|
|
if (writethroughClient) await writethroughClient.finish()
|
2021-07-06 19:10:04 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
getUserClient: async () => {
|
|
|
|
if (!userClient) {
|
|
|
|
await init()
|
|
|
|
}
|
|
|
|
return userClient
|
|
|
|
},
|
|
|
|
getSessionClient: async () => {
|
|
|
|
if (!sessionClient) {
|
|
|
|
await init()
|
|
|
|
}
|
|
|
|
return sessionClient
|
|
|
|
},
|
2021-11-15 18:40:45 +01:00
|
|
|
getAppClient: async () => {
|
|
|
|
if (!appClient) {
|
|
|
|
await init()
|
|
|
|
}
|
|
|
|
return appClient
|
|
|
|
},
|
2022-05-23 16:03:52 +02:00
|
|
|
getCacheClient: async () => {
|
|
|
|
if (!cacheClient) {
|
|
|
|
await init()
|
|
|
|
}
|
|
|
|
return cacheClient
|
|
|
|
},
|
2022-06-23 21:22:51 +02:00
|
|
|
getWritethroughClient: async () => {
|
|
|
|
if (!writethroughClient) {
|
|
|
|
await init()
|
|
|
|
}
|
|
|
|
return writethroughClient
|
|
|
|
},
|
2022-06-01 18:52:41 +02:00
|
|
|
getMigrationsRedlock: async () => {
|
|
|
|
if (!migrationsRedlock) {
|
|
|
|
await init()
|
|
|
|
}
|
|
|
|
return migrationsRedlock
|
|
|
|
},
|
2021-07-06 19:10:04 +02:00
|
|
|
}
|