node-sp-publish
Version:
Publish your Stored Procedures conveniently to different MSSQL Servers
92 lines (74 loc) • 3.37 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var execute = exports.execute = function () {
var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(sqlFileList, connection) {
var _this = this;
var connectionPool, config, _config, files, rootFolder;
return regeneratorRuntime.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
_context2.next = 2;
return configService.getConnectionPool(connection);
case 2:
connectionPool = _context2.sent;
//
config = void 0;
try {
config = require(process.cwd() + '/' + sqlFileList).default;
} catch (error) {
out.error(error);
out.error('Could not find file: ' + process.cwd() + '/' + sqlFileList);
}
_config = config, files = _config.files, rootFolder = _config.rootFolder;
_context2.prev = 6;
_context2.next = 9;
return utils.asyncMap(function () {
var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(file) {
var filePath, statements;
return regeneratorRuntime.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
filePath = rootFolder ? rootFolder + '/' + file : file;
statements = parser.getStatementsFromFile(filePath);
out.info(file);
_context.next = 5;
return sqlExec.executeStatements(connectionPool, statements);
case 5:
case 'end':
return _context.stop();
}
}
}, _callee, _this);
}));
return function (_x3) {
return _ref2.apply(this, arguments);
};
}(), files);
case 9:
return _context2.abrupt('return', 'done');
case 12:
_context2.prev = 12;
_context2.t0 = _context2['catch'](6);
out.error(_context2.t0);
throw _context2.t0;
case 16:
case 'end':
return _context2.stop();
}
}
}, _callee2, this, [[6, 12]]);
}));
return function execute(_x, _x2) {
return _ref.apply(this, arguments);
};
}();
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
var out = require('../services/loggingService.js');
var configService = require('../services/configService.js');
var parser = require('../services/sqlParserService.js');
var sqlExec = require('../services/sqlExecutingService.js');
var utils = require('../services/utilsService.js');