UNPKG

tspace-mysql

Version:

Tspace MySQL is a promise-based ORM for Node.js, designed with modern TypeScript and providing type safety for schema databases.

197 lines 6.56 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.MariadbDriver = void 0; const __1 = require(".."); const MariadbQueryBuilder_1 = require("./MariadbQueryBuilder"); class MariadbDriver extends __1.BaseDriver { constructor(options) { super(); this.options = options; } connect() { const options = this.options; const mariadb = this.import("mariadb"); const configs = { host: options.host, port: options.port, database: options.database, user: options.user || options.username, password: options.password, connectionLimit: options.connectionLimit ?? 20, connectTimeout: options.connectTimeout ?? 1000 * 60, minimumIdle: Math.max(2, Math.floor((options.connectionLimit ?? 20) / 3)), acquireTimeout: 1000 * 20, idleTimeout: 1000 * 60, queryTimeout: 1000 * 60, pipelining: true, bigIntAsNumber: true, insertIdAsNumber: true, }; this.pool = mariadb.createPool(configs); this.poolTrx = mariadb.createPool({ ...configs, connectionLimit: configs.connectionLimit * 1.5 }); this.pool.getConnection().catch(async (err) => { if (!err) return; if (err?.message?.includes('Unknown database') || err?.message.includes('(conn:-1, no: 45028, SQLState: HY000) pool timeout')) { const db = await mariadb.createConnection({ host: options.host, port: options.port, user: options.user || options.username, password: options.password, }); const sql = new MariadbQueryBuilder_1.MariadbQueryBuilder({}).createDatabase(options.database); await db.query(sql); await db.end(); return; } const message = this._messageError.bind(this); process.nextTick(() => { if (String(err.message).includes('Pool is close')) { return; } console.log(message(err.message == null || err.message === '' ? err.code : err.message)); if (this.options.CONNECTION_ERROR) return process.exit(); }); }); return { database: () => options.database, on: (event, data) => this.on(event, data), queryBuilder: MariadbQueryBuilder_1.MariadbQueryBuilder, query: (sql) => this._query(sql), connection: () => this._connection(), end: () => this._end() }; } disconnect(pool) { if (pool == null) return; pool?.end(() => { pool = undefined; }); } async _query(sql) { const start = Date.now(); const results = await this.pool.query(sql); this._detectEventQuery({ start, sql }); this.meta(results, sql); return this.returning(results); } async _connection() { const conn = await this.poolTrx.getConnection(); let started = false; let closed = false; let commited = false; let rollbacked = false; const query = async (sql) => { const start = Date.now(); const results = await conn.query(sql); this._detectEventQuery({ start, sql }); this.meta(results, sql); return this.returning(results); }; const startTransaction = async () => { await conn.beginTransaction(); started = true; closed = false; return; }; const commit = async () => { if (closed) { throw new Error(this.MESSAGE_TRX_CLOSED); } if (!started) { throw new Error(this.MESSAGE_TRX_NOT_STARTED); } commited = true; await conn.commit(); await end(); return; }; const rollback = async () => { if (closed) { throw new Error(this.MESSAGE_TRX_CLOSED); } if (!started) { throw new Error(this.MESSAGE_TRX_NOT_STARTED); } rollbacked = true; await conn.rollback(); await end(); return; }; const end = async () => { if (closed) return; if (!started) { throw new Error(this.MESSAGE_TRX_NOT_STARTED); } if (!commited && !rollbacked) { await rollback(); return; } await conn.release(); started = false; closed = true; return; }; const release = async () => { if (closed) return; await conn.release(); return; }; return { on: (event, data) => this.on(event, data), queryBuilder: MariadbQueryBuilder_1.MariadbQueryBuilder, query, startTransaction, commit, rollback, end, release }; } async _end() { await this.pool.end(); this.pool = undefined; } meta(results, sql) { if (Array.isArray(results)) return; if (results.$meta == null) results.$meta = {}; const command = this._detectQueryType(sql); results.$meta = { command }; if (command === 'INSERT') { const insertIds = results.affectedRows <= 1 ? [results.insertId] : [...Array(results.affectedRows)].map((_, i) => results.insertId + i); results.$meta = { ...results.$meta, insertIds, affected: true }; } if (command === 'UPDATE' || command === 'DELETE') { results.$meta = { ...results.$meta, insertIds: [], affected: Boolean(results.affectedRows) }; } } returning(results) { if (Array.isArray(results)) return results; return results; } } exports.MariadbDriver = MariadbDriver; //# sourceMappingURL=MariadbDriver.js.map