2013-09-13 16:58:38 -04:00
|
|
|
// Raw
|
|
|
|
// -------
|
2014-04-15 13:10:32 -04:00
|
|
|
var _ = require('lodash');
|
2014-04-27 19:35:36 -04:00
|
|
|
var inherits = require('inherits');
|
|
|
|
var EventEmitter = require('events').EventEmitter;
|
2013-09-03 22:25:54 -04:00
|
|
|
|
2014-03-14 16:56:55 -04:00
|
|
|
function Raw(sql, bindings) {
|
2014-06-09 16:27:03 -04:00
|
|
|
if (sql && sql.toSQL) {
|
2014-06-09 15:26:48 -04:00
|
|
|
var output = sql.toSQL();
|
|
|
|
sql = output.sql;
|
|
|
|
bindings = output.bindings;
|
2014-04-15 13:10:32 -04:00
|
|
|
}
|
2014-04-08 16:25:57 -04:00
|
|
|
this.sql = sql;
|
2014-04-15 13:10:32 -04:00
|
|
|
this.bindings = _.isArray(bindings) ? bindings :
|
|
|
|
bindings ? [bindings] : [];
|
2014-07-17 17:19:17 +10:00
|
|
|
|
2014-07-17 18:51:36 +10:00
|
|
|
if (_.isString(sql)) {
|
|
|
|
var replacements = [];
|
|
|
|
this.bindings = _.reduce(this.bindings, function(accum, param, index) {
|
|
|
|
var innerBindings = [param];
|
|
|
|
if (param instanceof Raw) {
|
|
|
|
var result = this.splicer(param, index);
|
|
|
|
innerBindings = result.bindings;
|
|
|
|
replacements.push(result.replacer);
|
|
|
|
}
|
|
|
|
return accum.concat(innerBindings);
|
|
|
|
}.bind(this), []);
|
2014-07-17 17:19:17 +10:00
|
|
|
|
2014-07-17 18:51:36 +10:00
|
|
|
// we don't need to care about replacements adding more '?'s
|
|
|
|
// and disrupting the indices, because we split first, join later
|
|
|
|
this.sql = _.reduce(replacements, function(accum, fn) {
|
|
|
|
return fn(accum);
|
|
|
|
}, this.sql.split('?')).join('?');
|
|
|
|
}
|
2014-07-17 17:19:17 +10:00
|
|
|
|
2014-04-08 16:25:57 -04:00
|
|
|
this._debug = void 0;
|
|
|
|
this._transacting = void 0;
|
2014-03-14 16:56:55 -04:00
|
|
|
}
|
2014-04-27 19:35:36 -04:00
|
|
|
inherits(Raw, EventEmitter);
|
2013-09-03 22:01:31 -04:00
|
|
|
|
2014-04-08 16:25:57 -04:00
|
|
|
// Wraps the current sql with `before` and `after`.
|
|
|
|
Raw.prototype.wrap = function(before, after) {
|
|
|
|
this.sql = before + this.sql + after;
|
|
|
|
return this;
|
|
|
|
};
|
2014-03-14 16:56:55 -04:00
|
|
|
|
2014-04-08 16:25:57 -04:00
|
|
|
// Calls `toString` on the Knex object.
|
|
|
|
Raw.prototype.toString = function() {
|
|
|
|
return this.toQuery();
|
|
|
|
};
|
2014-03-14 16:56:55 -04:00
|
|
|
|
2014-07-17 17:19:17 +10:00
|
|
|
// Returns a replacer function that splices into the i'th
|
|
|
|
// ? in the sql string the inner raw's sql,
|
|
|
|
// and the bindings associated with it
|
|
|
|
Raw.prototype.splicer = function(raw, i) {
|
|
|
|
var obj = raw.toSQL();
|
|
|
|
|
|
|
|
// the replacer function assumes that the sql has been
|
|
|
|
// already sql.split('?') and will be arr.join('?')
|
|
|
|
var replacer = function(arr) {
|
|
|
|
arr[i] = arr[i] + obj.sql + arr[i+1];
|
|
|
|
arr.splice(i+1,1);
|
|
|
|
return arr;
|
|
|
|
};
|
|
|
|
|
|
|
|
return {
|
|
|
|
replacer: replacer,
|
|
|
|
bindings: obj.bindings
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2014-04-08 16:25:57 -04:00
|
|
|
// Returns the raw sql for the query.
|
2014-04-09 10:11:41 -04:00
|
|
|
Raw.prototype.toSQL = function() {
|
2014-04-08 16:25:57 -04:00
|
|
|
return {
|
|
|
|
sql: this.sql,
|
2014-04-09 10:11:41 -04:00
|
|
|
method: 'raw',
|
2014-04-08 16:25:57 -04:00
|
|
|
bindings: this.bindings
|
|
|
|
};
|
|
|
|
};
|
2014-03-14 16:56:55 -04:00
|
|
|
|
|
|
|
// Allow the `Raw` object to be utilized with full access to the relevant
|
|
|
|
// promise API.
|
2014-04-08 16:25:57 -04:00
|
|
|
require('./interface')(Raw);
|
2014-03-14 16:56:55 -04:00
|
|
|
|
|
|
|
module.exports = Raw;
|