knex/src/dialects/oracledb/transaction.js

71 lines
1.8 KiB
JavaScript
Raw Normal View History

const { isUndefined } = require('lodash');
const Promise = require('bluebird');
const Transaction = require('../../transaction');
const debugTx = require('debug')('knex:tx');
module.exports = class Oracle_Transaction extends Transaction {
// disable autocommit to allow correct behavior (default is true)
2016-09-12 18:45:35 -04:00
begin() {
return Promise.resolve();
2016-09-12 18:45:35 -04:00
}
commit(conn, value) {
this._completed = true;
return conn
.commitAsync()
.return(value)
.then(this._resolver, this._rejecter);
2016-09-12 18:45:35 -04:00
}
release(conn, value) {
return this._resolver(value);
2016-09-12 18:45:35 -04:00
}
rollback(conn, err) {
const self = this;
this._completed = true;
debugTx('%s: rolling back', this.txid);
return conn
.rollbackAsync()
.timeout(5000)
.catch(Promise.TimeoutError, function(e) {
self._rejecter(e);
})
.then(function() {
if (isUndefined(err)) {
err = new Error(`Transaction rejected with non-error: ${err}`);
}
self._rejecter(err);
});
2016-09-12 18:45:35 -04:00
}
savepoint(conn) {
return this.query(conn, `SAVEPOINT ${this.txid}`);
}
2016-09-12 18:45:35 -04:00
acquireConnection(config) {
const t = this;
return Promise.try(function() {
2016-10-09 14:00:55 -04:00
return t.client.acquireConnection().then(function(cnx) {
cnx.__knexTxId = t.txid;
cnx.isTransaction = true;
return cnx;
});
}).disposer(function(connection) {
debugTx('%s: releasing connection', t.txid);
connection.isTransaction = false;
connection.commitAsync().then(function(err) {
if (err) {
this._rejecter(err);
}
if (!config.connection) {
t.client.releaseConnection(connection);
} else {
debugTx('%s: not releasing external connection', t.txid);
}
});
});
}
};