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
JavaScript
;
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