transaction.js 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. 'use strict';
  2. exports.__esModule = true;
  3. var _isUndefined2 = require('lodash/isUndefined');
  4. var _isUndefined3 = _interopRequireDefault(_isUndefined2);
  5. var _assign2 = require('lodash/assign');
  6. var _assign3 = _interopRequireDefault(_assign2);
  7. var _transaction = require('../../transaction');
  8. var _transaction2 = _interopRequireDefault(_transaction);
  9. var _inherits = require('inherits');
  10. var _inherits2 = _interopRequireDefault(_inherits);
  11. var _debug = require('debug');
  12. var _debug2 = _interopRequireDefault(_debug);
  13. var _helpers = require('../../helpers');
  14. var helpers = _interopRequireWildcard(_helpers);
  15. function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }
  16. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  17. var debug = (0, _debug2.default)('knex:tx');
  18. function Transaction_MySQL() {
  19. _transaction2.default.apply(this, arguments);
  20. }
  21. (0, _inherits2.default)(Transaction_MySQL, _transaction2.default);
  22. (0, _assign3.default)(Transaction_MySQL.prototype, {
  23. query: function query(conn, sql, status, value) {
  24. var t = this;
  25. var q = this.trxClient.query(conn, sql).catch(function (err) {
  26. return err.errno === 1305;
  27. }, function () {
  28. helpers.warn('Transaction was implicitly committed, do not mix transactions and ' + 'DDL with MySQL (#805)');
  29. }).catch(function (err) {
  30. status = 2;
  31. value = err;
  32. t._completed = true;
  33. debug('%s error running transaction query', t.txid);
  34. }).tap(function () {
  35. if (status === 1) t._resolver(value);
  36. if (status === 2) {
  37. if ((0, _isUndefined3.default)(value)) {
  38. value = new Error('Transaction rejected with non-error: ' + value);
  39. }
  40. t._rejecter(value);
  41. }
  42. });
  43. if (status === 1 || status === 2) {
  44. t._completed = true;
  45. }
  46. return q;
  47. }
  48. });
  49. exports.default = Transaction_MySQL;
  50. module.exports = exports['default'];