From bc2a0ac0395dff91a4fa580848c2449e04158541 Mon Sep 17 00:00:00 2001 From: Luis Lopez Cardona <22754517+luis815@users.noreply.github.com> Date: Fri, 18 Oct 2024 02:26:34 -0400 Subject: [PATCH] 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 --- .changeset/fifty-apes-arrive.md | 8 ++++++++ packages/core/src/env-set/create-pool.ts | 4 +++- packages/core/src/env-set/index.ts | 6 ++++-- packages/shared/src/node/env/GlobalValues.ts | 2 ++ 4 files changed, 17 insertions(+), 3 deletions(-) create mode 100644 .changeset/fifty-apes-arrive.md diff --git a/.changeset/fifty-apes-arrive.md b/.changeset/fifty-apes-arrive.md new file mode 100644 index 000000000..ef5e68e57 --- /dev/null +++ b/.changeset/fifty-apes-arrive.md @@ -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. diff --git a/packages/core/src/env-set/create-pool.ts b/packages/core/src/env-set/create-pool.ts index 6dce0f532..2d20124db 100644 --- a/packages/core/src/env-set/create-pool.ts +++ b/packages/core/src/env-set/create-pool.ts @@ -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, }); }; diff --git a/packages/core/src/env-set/index.ts b/packages/core/src/env-set/index.ts index 1aa82b48b..eee74ee95 100644 --- a/packages/core/src/env-set/index.ts +++ b/packages/core/src/env-set/index.ts @@ -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; @@ -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; diff --git a/packages/shared/src/node/env/GlobalValues.ts b/packages/shared/src/node/env/GlobalValues.ts index 3ccd58895..9863cc271 100644 --- a/packages/shared/src/node/env/GlobalValues.ts +++ b/packages/shared/src/node/env/GlobalValues.ts @@ -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'));