knex/src/dialects/oracledb/transaction.js

68 lines
1.7 KiB
JavaScript
Raw Normal View History

import {isUndefined} from 'lodash';
const Promise = require('bluebird');
const Transaction = require('../../transaction');
const debugTx = require('debug')('knex:tx');
2016-09-12 18:45:35 -04:00
export default 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.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);
}
});
});
}
2016-09-12 18:45:35 -04:00
}