mempool/backend/src/database.ts

51 lines
1.5 KiB
TypeScript
Raw Normal View History

import config from './config';
import { createPool, PoolConnection } from 'mysql2/promise';
import logger from './logger';
2022-03-13 14:57:17 +01:00
import { PoolOptions } from 'mysql2/typings/mysql';
2019-07-21 16:59:47 +02:00
export class DB {
2022-03-13 14:57:17 +01:00
static poolConfig = ():PoolOptions => {
let poolConfig:PoolOptions = {
port: config.DATABASE.PORT,
database: config.DATABASE.DATABASE,
user: config.DATABASE.USERNAME,
password: config.DATABASE.PASSWORD,
connectionLimit: 10,
supportBigNumbers: true,
timezone: '+00:00',
}
if (config.DATABASE.SOCKET && config.DATABASE.SOCKET != "")
2022-03-13 14:57:17 +01:00
poolConfig.socketPath = config.DATABASE.SOCKET
else
poolConfig.host = config.DATABASE.HOST
return poolConfig;
}
static pool = createPool(DB.poolConfig());
static connectionsReady: number[] = [];
static async getConnection() {
const connection: PoolConnection = await DB.pool.getConnection();
const connectionId = connection['connection'].connectionId;
if (!DB.connectionsReady.includes(connectionId)) {
await connection.query(`SET time_zone='+00:00';`);
this.connectionsReady.push(connectionId);
}
return connection;
}
2019-07-21 16:59:47 +02:00
}
export async function checkDbConnection() {
try {
const connection = await DB.getConnection();
logger.info('Database connection established.');
2019-07-21 16:59:47 +02:00
connection.release();
} catch (e) {
logger.err('Could not connect to database: ' + (e instanceof Error ? e.message : e));
2019-07-21 16:59:47 +02:00
process.exit(1);
}
}