mirror of
https://github.com/ToolJet/ToolJet
synced 2026-04-21 21:47:17 +00:00
* node upgrade initial commit * Removed node-saas and added saas. Fixed the CSS warnings from saas * add node version 22 to dockerfile and AMI setup script * change the base image to debian 12 * Update the node version (#12860) * correction in builder image * Update ce-production.Dockerfile * upgrade node to 22.15.1 * server package lock * package upgrade * package upgrade * base directory package upgrade * revert sentry package upgrade * fix * added copy files * fix dockerfile for copywrite package issue * removed copy files package * fix dockerfile for copywrite package issue --------- Co-authored-by: Kavin Venkatachalam <kavin.saratha@gmail.com> Co-authored-by: Adish M <adish.madhu@gmail.com> Co-authored-by: Ajith KV <ajith.jaban@gmail.com> Co-authored-by: Adish M <44204658+adishM98@users.noreply.github.com> Co-authored-by: Muhsin Shah C P <muhsinshah21@gmail.com>
112 lines
2.7 KiB
TypeScript
112 lines
2.7 KiB
TypeScript
import { TypeOrmModuleOptions } from '@nestjs/typeorm';
|
|
import { getEnvVars } from './scripts/database-config-utils';
|
|
|
|
function dbSslConfig(envVars) {
|
|
let config = {};
|
|
|
|
if (envVars?.DATABASE_URL)
|
|
config = {
|
|
url: envVars.DATABASE_URL,
|
|
ssl: { rejectUnauthorized: false },
|
|
};
|
|
|
|
if (envVars?.CA_CERT)
|
|
config = {
|
|
...config,
|
|
...{ ssl: { rejectUnauthorized: false, ca: envVars.CA_CERT } },
|
|
};
|
|
|
|
return config;
|
|
}
|
|
|
|
function tooljetDbSslConfig(envVars) {
|
|
let config = {};
|
|
|
|
if (envVars?.TOOLJET_DB_URL)
|
|
config = {
|
|
url: envVars.TOOLJET_DB_URL,
|
|
ssl: { rejectUnauthorized: false },
|
|
};
|
|
|
|
if (envVars?.CA_CERT)
|
|
config = {
|
|
...config,
|
|
...{ ssl: { rejectUnauthorized: false, ca: envVars.CA_CERT } },
|
|
};
|
|
|
|
return config;
|
|
}
|
|
|
|
function buildConnectionOptions(data): TypeOrmModuleOptions {
|
|
const connectionParams = {
|
|
database: data.PG_DB,
|
|
port: +data.PG_PORT || 5432,
|
|
username: data.PG_USER,
|
|
password: data.PG_PASS,
|
|
host: data.PG_HOST,
|
|
connectTimeoutMS: 5000,
|
|
extra: {
|
|
max: 25,
|
|
},
|
|
...dbSslConfig(data),
|
|
};
|
|
|
|
const entitiesDir =
|
|
data?.NODE_ENV === 'test' ? [__dirname + '/**/*.entity.ts'] : [__dirname + '/**/*.entity{.js,.ts}'];
|
|
|
|
return {
|
|
type: 'postgres',
|
|
...connectionParams,
|
|
entities: entitiesDir,
|
|
synchronize: false,
|
|
uuidExtension: 'pgcrypto',
|
|
migrationsRun: false,
|
|
migrationsTransactionMode: 'all',
|
|
logging: data.ORM_LOGGING || false,
|
|
migrations: [__dirname + '/migrations/**/*{.ts,.js}'],
|
|
};
|
|
}
|
|
|
|
function buildToolJetDbConnectionOptions(data): TypeOrmModuleOptions {
|
|
const connectionParams = {
|
|
database: data.TOOLJET_DB,
|
|
port: +data.TOOLJET_DB_PORT || 5432,
|
|
username: data.TOOLJET_DB_USER,
|
|
password: data.TOOLJET_DB_PASS,
|
|
host: data.TOOLJET_DB_HOST,
|
|
connectTimeoutMS: 5000,
|
|
logging: data.ORM_LOGGING || false,
|
|
extra: {
|
|
max: 25,
|
|
statement_timeout: data.TOOLJET_DB_STATEMENT_TIMEOUT || 60000,
|
|
},
|
|
...tooljetDbSslConfig(data),
|
|
};
|
|
|
|
return {
|
|
name: 'tooljetDb',
|
|
type: 'postgres',
|
|
...connectionParams,
|
|
synchronize: false,
|
|
uuidExtension: 'pgcrypto',
|
|
migrationsRun: false,
|
|
migrationsTransactionMode: 'all',
|
|
logging: data.ORM_LOGGING || false,
|
|
};
|
|
}
|
|
|
|
function fetchConnectionOptions(type: string): TypeOrmModuleOptions {
|
|
const data = getEnvVars();
|
|
switch (type) {
|
|
case 'postgres':
|
|
return buildConnectionOptions(data);
|
|
case 'tooljetDb':
|
|
return buildToolJetDbConnectionOptions(data);
|
|
}
|
|
}
|
|
|
|
const ormconfig: TypeOrmModuleOptions = fetchConnectionOptions('postgres');
|
|
const tooljetDbOrmconfig: TypeOrmModuleOptions = fetchConnectionOptions('tooljetDb');
|
|
|
|
export { ormconfig, tooljetDbOrmconfig };
|
|
export default ormconfig;
|