knex/lib/transaction.js
Tim Griesser 3c8d08a64b Removing unnecessary UMD
When this eventually enabled on the client side,
we can build this into the build script.
2013-11-27 16:51:01 -05:00

74 lines
1.9 KiB
JavaScript

// Transaction
// -------
var Promise = require('./promise').Promise;
var _ = require('lodash');
// Creates a new wrapper object for constructing a transaction.
// Called by the `knex.transaction`, which sets the correct client
// and handles the `container` object, passing along the correct
// `connection` to keep all of the transactions on the correct connection.
var Transaction = function(instance) {
this.client = instance.client;
};
Transaction.prototype = {
// Passed a `container` function, this method runs the current
// transaction, returning a promise.
run: function(container, connection) {
return this.client.startTransaction(connection)
.bind(this)
.then(this.getContainerObject)
.then(this.initiateDeferred(container))
.bind();
},
getContainerObject: function(connection) {
// The client we need to call `finishTransaction` on.
var client = this.client;
// The object passed around inside the transaction container.
var containerObj = {
commit: function(message) {
client.finishTransaction('commit', this, message);
},
rollback: function(error) {
client.finishTransaction('rollback', this, error);
},
// "rollback to"?
connection: connection
};
// Ensure the transacting object methods are bound with the correct context.
_.bindAll(containerObj, 'commit', 'rollback');
return containerObj;
},
initiateDeferred: function(container) {
return function(containerObj) {
// Initiate a deferred object, so we know when the
// transaction completes or fails, we know what to do.
var dfd = containerObj.dfd = Promise.pending();
// Call the container with the transaction
// commit & rollback objects.
container(containerObj);
// Return the promise for the entire transaction.
return dfd.promise;
};
}
};
exports.Transaction = Transaction;