UNPKG

knex

Version:

A batteries-included SQL query & schema builder for Postgres, MySQL and SQLite3 and the Browser

101 lines (72 loc) 3.07 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = _default; var _lodash = require("lodash"); function _default(Target) { Target.prototype.toQuery = function (tz) { let data = this.toSQL(this._method, tz); if (!(0, _lodash.isArray)(data)) data = [data]; return (0, _lodash.map)(data, statement => { return this.client._formatQuery(statement.sql, statement.bindings, tz); }).join(';\n'); }; // Create a new instance of the `Runner`, passing in the current object. Target.prototype.then = function () /* onFulfilled, onRejected */ { let result = this.client.runner(this).run(); if (this.client.config.asyncStackTraces) { result = result.catch(err => { err.originalStack = err.stack; const firstLine = err.stack.split('\n')[0]; this._asyncStack.unshift(firstLine); // put the fake more helpful "async" stack on the thrown error err.stack = this._asyncStack.join('\n'); throw err; }); } return result.then.apply(result, arguments); }; // Add additional "options" to the builder. Typically used for client specific // items, like the `mysql` and `sqlite3` drivers. Target.prototype.options = function (opts) { this._options = this._options || []; this._options.push((0, _lodash.clone)(opts) || {}); return this; }; // Sets an explicit "connection" we wish to use for this query. Target.prototype.connection = function (connection) { this._connection = connection; return this; }; // Set a debug flag for the current schema query stack. Target.prototype.debug = function (enabled) { this._debug = arguments.length ? enabled : true; return this; }; // Set the transaction object for this query. Target.prototype.transacting = function (t) { if (t && t.client) { if (!t.client.transacting) { t.client.logger.warn(`Invalid transaction value: ${t.client}`); } else { this.client = t.client; } } if ((0, _lodash.isEmpty)(t)) { this.client.logger.error('Invalid value on transacting call, potential bug'); throw Error('Invalid transacting value (null, undefined or empty object)'); } return this; }; // Initializes a stream. Target.prototype.stream = function (options) { return this.client.runner(this).stream(options); }; // Initialize a stream & pipe automatically. Target.prototype.pipe = function (writable, options) { return this.client.runner(this).pipe(writable, options); }; // Creates a method which "coerces" to a promise, by calling a // "then" method on the current `Target` (0, _lodash.each)(['bind', 'catch', 'finally', 'asCallback', 'spread', 'map', 'reduce', 'tap', 'thenReturn', 'return', 'yield', 'ensure', 'reflect', 'get', 'mapSeries', 'delay'], function (method) { Target.prototype[method] = function () { const promise = this.then(); return promise[method].apply(promise, arguments); }; }); } module.exports = exports.default;