0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-13 21:30:30 -05:00

feat(core): database connection timeout env overwrite support (#6187) (#6674)

* feat(core): database connection timeout env overwrite support (#6187)

* chore: add changeset

---------

Co-authored-by: Charles Zhao <charleszhao@silverhand.io>
This commit is contained in:
Luis Lopez Cardona 2024-10-18 02:26:34 -04:00 committed by GitHub
parent 6289433d8c
commit bc2a0ac039
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 17 additions and 3 deletions

View file

@ -0,0 +1,8 @@
---
"@logto/shared": patch
"@logto/core": patch
---
add environment variable to override default database connection timeout
By default, out database connection timeout is set to 5 seconds, which might not be enough for some network conditions. This change allows users to override the default value by setting the `DATABASE_CONNECTION_TIMEOUT` environment variable.

View file

@ -10,7 +10,8 @@ import {
const createPoolByEnv = async (
databaseDsn: string,
mockDatabaseConnection: boolean,
poolSize?: number
poolSize?: number,
connectionTimeout?: number
) => {
// Database connection is disabled in unit test environment
if (mockDatabaseConnection) {
@ -22,6 +23,7 @@ const createPoolByEnv = async (
return createPool(databaseDsn, {
interceptors: createInterceptorsPreset(),
maximumPoolSize: poolSize,
connectionTimeout,
});
};

View file

@ -37,7 +37,8 @@ export class EnvSet {
static sharedPool = createPoolByEnv(
this.dbUrl,
EnvSet.values.isUnitTest,
this.values.databasePoolSize
this.values.databasePoolSize,
EnvSet.values.databaseConnectionTimeout
);
#pool: Optional<DatabasePool>;
@ -68,7 +69,8 @@ export class EnvSet {
const pool = await createPoolByEnv(
this.databaseUrl,
EnvSet.values.isUnitTest,
EnvSet.values.databasePoolSize
EnvSet.values.databasePoolSize,
EnvSet.values.databaseConnectionTimeout
);
this.#pool = pool;

View file

@ -104,6 +104,8 @@ export default class GlobalValues {
/** Maximum number of clients to keep in a single database pool (i.e. per `Tenant` class). */
public readonly databasePoolSize = Number(getEnv('DATABASE_POOL_SIZE', '20'));
public readonly databaseConnectionTimeout = Number(getEnv('DATABASE_CONNECTION_TIMEOUT', '5000'));
/** Case insensitive username */
public readonly isCaseSensitiveUsername = yes(getEnv('CASE_SENSITIVE_USERNAME', 'true'));