mempool/backend/src/database.ts

39 lines
1.1 KiB
TypeScript
Raw Normal View History

import config from './config';
import { createPool, PoolConnection } from 'mysql2/promise';
import logger from './logger';
2019-07-21 16:59:47 +02:00
export class DB {
static pool = createPool({
host: config.DATABASE.HOST,
port: config.DATABASE.PORT,
database: config.DATABASE.DATABASE,
user: config.DATABASE.USERNAME,
password: config.DATABASE.PASSWORD,
2019-07-21 16:59:47 +02:00
connectionLimit: 10,
supportBigNumbers: true,
});
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);
}
}