murmuration 2.0.69 → 2.0.71

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -22,42 +22,42 @@ _export(exports, {
22
22
  return showLikeTables;
23
23
  }
24
24
  });
25
- var _database = require("../database");
25
+ const _database = require("../database");
26
26
  function createTable(connection, sql, callback) {
27
- (0, _database.execute)(connection, sql, function(error) {
27
+ (0, _database.execute)(connection, sql, (error)=>{
28
28
  if (error) {
29
- var log = connection.getLog();
29
+ const log = connection.getLog();
30
30
  log.error("createTable() failed.");
31
31
  }
32
32
  callback(error);
33
33
  });
34
34
  }
35
35
  function insertVersion(connection, version, sql, callback) {
36
- (0, _database.execute)(connection, sql, version, function(error) {
36
+ (0, _database.execute)(connection, sql, version, (error)=>{
37
37
  if (error) {
38
- var log = connection.getLog();
38
+ const log = connection.getLog();
39
39
  log.error("insertVersion() failed.");
40
40
  }
41
41
  callback(error);
42
42
  });
43
43
  }
44
44
  function showLikeTables(connection, sql, callback) {
45
- (0, _database.query)(connection, sql, function(error, rows) {
45
+ (0, _database.query)(connection, sql, (error, rows)=>{
46
46
  if (error) {
47
- var log = connection.getLog();
47
+ const log = connection.getLog();
48
48
  log.error("showLikeTables() failed.");
49
49
  }
50
50
  callback(error, rows);
51
51
  });
52
52
  }
53
53
  function selectMaximumVersion(connection, sql, callback) {
54
- (0, _database.query)(connection, sql, function(error, rows) {
54
+ (0, _database.query)(connection, sql, (error, rows)=>{
55
55
  if (error) {
56
- var log = connection.getLog();
56
+ const log = connection.getLog();
57
57
  log.error("selectMaximumVersion() failed.");
58
58
  }
59
59
  callback(error, rows);
60
60
  });
61
61
  }
62
62
 
63
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90YWJsZS9taWdyYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7IHF1ZXJ5LCBleGVjdXRlIH0gZnJvbSBcIi4uL2RhdGFiYXNlXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVUYWJsZShjb25uZWN0aW9uLCBzcWwsIGNhbGxiYWNrKSB7XG4gIGV4ZWN1dGUoY29ubmVjdGlvbiwgc3FsLCAoZXJyb3IpID0+IHtcbiAgICBpZiAoZXJyb3IpIHtcbiAgICAgIGNvbnN0IGxvZyA9IGNvbm5lY3Rpb24uZ2V0TG9nKCk7XG5cbiAgICAgIGxvZy5lcnJvcihcImNyZWF0ZVRhYmxlKCkgZmFpbGVkLlwiKTtcbiAgICB9XG4gICAgXG4gICAgY2FsbGJhY2soZXJyb3IpO1xuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluc2VydFZlcnNpb24oY29ubmVjdGlvbiwgdmVyc2lvbiwgc3FsLCBjYWxsYmFjaykge1xuICBleGVjdXRlKGNvbm5lY3Rpb24sIHNxbCwgdmVyc2lvbiwgKGVycm9yKSA9PiB7XG4gICAgaWYgKGVycm9yKSB7XG4gICAgICBjb25zdCBsb2cgPSBjb25uZWN0aW9uLmdldExvZygpO1xuXG4gICAgICBsb2cuZXJyb3IoXCJpbnNlcnRWZXJzaW9uKCkgZmFpbGVkLlwiKTtcbiAgICB9XG5cbiAgICBjYWxsYmFjayhlcnJvcik7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2hvd0xpa2VUYWJsZXMoY29ubmVjdGlvbiwgc3FsLCBjYWxsYmFjaykge1xuICBxdWVyeShjb25uZWN0aW9uLCBzcWwsIChlcnJvciwgcm93cykgPT4ge1xuICAgIGlmIChlcnJvcikge1xuICAgICAgY29uc3QgbG9nID0gY29ubmVjdGlvbi5nZXRMb2coKTtcblxuICAgICAgbG9nLmVycm9yKFwic2hvd0xpa2VUYWJsZXMoKSBmYWlsZWQuXCIpO1xuICAgIH1cbiAgICBcbiAgICBjYWxsYmFjayhlcnJvciwgcm93cyk7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2VsZWN0TWF4aW11bVZlcnNpb24oY29ubmVjdGlvbiwgc3FsLCBjYWxsYmFjaykge1xuICBxdWVyeShjb25uZWN0aW9uLCBzcWwsIChlcnJvciwgcm93cykgPT4ge1xuICAgIGlmIChlcnJvcikge1xuICAgICAgY29uc3QgbG9nID0gY29ubmVjdGlvbi5nZXRMb2coKTtcblxuICAgICAgbG9nLmVycm9yKFwic2VsZWN0TWF4aW11bVZlcnNpb24oKSBmYWlsZWQuXCIpO1xuICAgIH1cblxuICAgIGNhbGxiYWNrKGVycm9yLCByb3dzKTtcbiAgfSk7XG59XG4iXSwibmFtZXMiOlsiY3JlYXRlVGFibGUiLCJpbnNlcnRWZXJzaW9uIiwic2VsZWN0TWF4aW11bVZlcnNpb24iLCJzaG93TGlrZVRhYmxlcyIsImNvbm5lY3Rpb24iLCJzcWwiLCJjYWxsYmFjayIsImV4ZWN1dGUiLCJlcnJvciIsImxvZyIsImdldExvZyIsInZlcnNpb24iLCJxdWVyeSIsInJvd3MiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQUlnQkE7ZUFBQUE7O1FBWUFDO2VBQUFBOztRQXdCQUM7ZUFBQUE7O1FBWkFDO2VBQUFBOzs7d0JBMUJlO0FBRXhCLFNBQVNILFlBQVlJLFVBQVUsRUFBRUMsR0FBRyxFQUFFQyxRQUFRO0lBQ25EQyxJQUFBQSxpQkFBTyxFQUFDSCxZQUFZQyxLQUFLLFNBQUNHO1FBQ3hCLElBQUlBLE9BQU87WUFDVCxJQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRTtJQUNYO0FBQ0Y7QUFFTyxTQUFTUCxjQUFjRyxVQUFVLEVBQUVPLE9BQU8sRUFBRU4sR0FBRyxFQUFFQyxRQUFRO0lBQzlEQyxJQUFBQSxpQkFBTyxFQUFDSCxZQUFZQyxLQUFLTSxTQUFTLFNBQUNIO1FBQ2pDLElBQUlBLE9BQU87WUFDVCxJQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRTtJQUNYO0FBQ0Y7QUFFTyxTQUFTTCxlQUFlQyxVQUFVLEVBQUVDLEdBQUcsRUFBRUMsUUFBUTtJQUN0RE0sSUFBQUEsZUFBSyxFQUFDUixZQUFZQyxLQUFLLFNBQUNHLE9BQU9LO1FBQzdCLElBQUlMLE9BQU87WUFDVCxJQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRSxPQUFPSztJQUNsQjtBQUNGO0FBRU8sU0FBU1gscUJBQXFCRSxVQUFVLEVBQUVDLEdBQUcsRUFBRUMsUUFBUTtJQUM1RE0sSUFBQUEsZUFBSyxFQUFDUixZQUFZQyxLQUFLLFNBQUNHLE9BQU9LO1FBQzdCLElBQUlMLE9BQU87WUFDVCxJQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRSxPQUFPSztJQUNsQjtBQUNGIn0=
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90YWJsZS9taWdyYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7IHF1ZXJ5LCBleGVjdXRlIH0gZnJvbSBcIi4uL2RhdGFiYXNlXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVUYWJsZShjb25uZWN0aW9uLCBzcWwsIGNhbGxiYWNrKSB7XG4gIGV4ZWN1dGUoY29ubmVjdGlvbiwgc3FsLCAoZXJyb3IpID0+IHtcbiAgICBpZiAoZXJyb3IpIHtcbiAgICAgIGNvbnN0IGxvZyA9IGNvbm5lY3Rpb24uZ2V0TG9nKCk7XG5cbiAgICAgIGxvZy5lcnJvcihcImNyZWF0ZVRhYmxlKCkgZmFpbGVkLlwiKTtcbiAgICB9XG4gICAgXG4gICAgY2FsbGJhY2soZXJyb3IpO1xuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluc2VydFZlcnNpb24oY29ubmVjdGlvbiwgdmVyc2lvbiwgc3FsLCBjYWxsYmFjaykge1xuICBleGVjdXRlKGNvbm5lY3Rpb24sIHNxbCwgdmVyc2lvbiwgKGVycm9yKSA9PiB7XG4gICAgaWYgKGVycm9yKSB7XG4gICAgICBjb25zdCBsb2cgPSBjb25uZWN0aW9uLmdldExvZygpO1xuXG4gICAgICBsb2cuZXJyb3IoXCJpbnNlcnRWZXJzaW9uKCkgZmFpbGVkLlwiKTtcbiAgICB9XG5cbiAgICBjYWxsYmFjayhlcnJvcik7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2hvd0xpa2VUYWJsZXMoY29ubmVjdGlvbiwgc3FsLCBjYWxsYmFjaykge1xuICBxdWVyeShjb25uZWN0aW9uLCBzcWwsIChlcnJvciwgcm93cykgPT4ge1xuICAgIGlmIChlcnJvcikge1xuICAgICAgY29uc3QgbG9nID0gY29ubmVjdGlvbi5nZXRMb2coKTtcblxuICAgICAgbG9nLmVycm9yKFwic2hvd0xpa2VUYWJsZXMoKSBmYWlsZWQuXCIpO1xuICAgIH1cbiAgICBcbiAgICBjYWxsYmFjayhlcnJvciwgcm93cyk7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2VsZWN0TWF4aW11bVZlcnNpb24oY29ubmVjdGlvbiwgc3FsLCBjYWxsYmFjaykge1xuICBxdWVyeShjb25uZWN0aW9uLCBzcWwsIChlcnJvciwgcm93cykgPT4ge1xuICAgIGlmIChlcnJvcikge1xuICAgICAgY29uc3QgbG9nID0gY29ubmVjdGlvbi5nZXRMb2coKTtcblxuICAgICAgbG9nLmVycm9yKFwic2VsZWN0TWF4aW11bVZlcnNpb24oKSBmYWlsZWQuXCIpO1xuICAgIH1cblxuICAgIGNhbGxiYWNrKGVycm9yLCByb3dzKTtcbiAgfSk7XG59XG4iXSwibmFtZXMiOlsiY3JlYXRlVGFibGUiLCJpbnNlcnRWZXJzaW9uIiwic2VsZWN0TWF4aW11bVZlcnNpb24iLCJzaG93TGlrZVRhYmxlcyIsImNvbm5lY3Rpb24iLCJzcWwiLCJjYWxsYmFjayIsImV4ZWN1dGUiLCJlcnJvciIsImxvZyIsImdldExvZyIsInZlcnNpb24iLCJxdWVyeSIsInJvd3MiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQUlnQkE7ZUFBQUE7O1FBWUFDO2VBQUFBOztRQXdCQUM7ZUFBQUE7O1FBWkFDO2VBQUFBOzs7MEJBMUJlO0FBRXhCLFNBQVNILFlBQVlJLFVBQVUsRUFBRUMsR0FBRyxFQUFFQyxRQUFRO0lBQ25EQyxJQUFBQSxpQkFBTyxFQUFDSCxZQUFZQyxLQUFLLENBQUNHO1FBQ3hCLElBQUlBLE9BQU87WUFDVCxNQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRTtJQUNYO0FBQ0Y7QUFFTyxTQUFTUCxjQUFjRyxVQUFVLEVBQUVPLE9BQU8sRUFBRU4sR0FBRyxFQUFFQyxRQUFRO0lBQzlEQyxJQUFBQSxpQkFBTyxFQUFDSCxZQUFZQyxLQUFLTSxTQUFTLENBQUNIO1FBQ2pDLElBQUlBLE9BQU87WUFDVCxNQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRTtJQUNYO0FBQ0Y7QUFFTyxTQUFTTCxlQUFlQyxVQUFVLEVBQUVDLEdBQUcsRUFBRUMsUUFBUTtJQUN0RE0sSUFBQUEsZUFBSyxFQUFDUixZQUFZQyxLQUFLLENBQUNHLE9BQU9LO1FBQzdCLElBQUlMLE9BQU87WUFDVCxNQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRSxPQUFPSztJQUNsQjtBQUNGO0FBRU8sU0FBU1gscUJBQXFCRSxVQUFVLEVBQUVDLEdBQUcsRUFBRUMsUUFBUTtJQUM1RE0sSUFBQUEsZUFBSyxFQUFDUixZQUFZQyxLQUFLLENBQUNHLE9BQU9LO1FBQzdCLElBQUlMLE9BQU87WUFDVCxNQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRSxPQUFPSztJQUNsQjtBQUNGIn0=
@@ -8,27 +8,27 @@ Object.defineProperty(exports, "default", {
8
8
  return transaction;
9
9
  }
10
10
  });
11
- var _defaultLog = /*#__PURE__*/ _interop_require_default(require("./defaultLog"));
12
- var _necessary = require("necessary");
11
+ const _defaultLog = /*#__PURE__*/ _interop_require_default(require("./defaultLog"));
12
+ const _necessary = require("necessary");
13
13
  function _interop_require_default(obj) {
14
14
  return obj && obj.__esModule ? obj : {
15
15
  default: obj
16
16
  };
17
17
  }
18
- var whilst = _necessary.asynchronousUtilities.whilst, sequence = _necessary.asynchronousUtilities.sequence;
18
+ const { whilst, sequence } = _necessary.asynchronousUtilities;
19
19
  function transaction(configuration, operations, callback, context) {
20
- var Connection = configuration.Connection, completed = false;
21
- Connection.fromConfiguration(configuration, function(error, connection) {
20
+ const { Connection } = configuration, completed = false;
21
+ Connection.fromConfiguration(configuration, (error, connection)=>{
22
22
  if (error) {
23
- var _configuration_log = configuration.log, log = _configuration_log === void 0 ? _defaultLog.default : _configuration_log;
23
+ const { log = _defaultLog.default } = configuration;
24
24
  log.error("The transaction wasn't completed because there was no connection.");
25
25
  callback(completed);
26
26
  return;
27
27
  }
28
28
  Object.assign(context, {
29
- connection: connection,
30
- operations: operations,
31
- completed: completed
29
+ connection,
30
+ operations,
31
+ completed
32
32
  });
33
33
  operations = [
34
34
  beginTransactionOperation,
@@ -36,8 +36,8 @@ function transaction(configuration, operations, callback, context) {
36
36
  commitTransactionOperation,
37
37
  rollbackTransactionOperation
38
38
  ];
39
- sequence(operations, function() {
40
- var completed = context.completed;
39
+ sequence(operations, ()=>{
40
+ const { completed } = context;
41
41
  delete context.connection;
42
42
  delete context.operations;
43
43
  delete context.completed;
@@ -47,12 +47,12 @@ function transaction(configuration, operations, callback, context) {
47
47
  });
48
48
  }
49
49
  function beginTransactionOperation(next, done, context) {
50
- var connection = context.connection, log = connection.getLog();
50
+ const { connection } = context, log = connection.getLog();
51
51
  log.debug("Beginning transaction...");
52
- connection.begin(function(error) {
52
+ connection.begin((error)=>{
53
53
  if (error) {
54
- var code = error.code;
55
- log.error("An error with '".concat(code, "' has occurred."));
54
+ const { code } = error;
55
+ log.error(`An error with '${code}' has occurred.`);
56
56
  done();
57
57
  return;
58
58
  }
@@ -60,16 +60,16 @@ function beginTransactionOperation(next, done, context) {
60
60
  });
61
61
  }
62
62
  function commitTransactionOperation(next, done, context) {
63
- var completed = context.completed;
63
+ const { completed } = context;
64
64
  if (!completed) {
65
65
  next();
66
66
  return;
67
67
  }
68
- var connection = context.connection, log = connection.getLog();
68
+ const { connection } = context, log = connection.getLog();
69
69
  log.debug("Committing transaction...");
70
- connection.commit(function(error) {
70
+ connection.commit((error)=>{
71
71
  if (error) {
72
- var code = error.code;
72
+ const { code } = error;
73
73
  log.error("An error with '${code}' has occurred.");
74
74
  done();
75
75
  return;
@@ -78,17 +78,17 @@ function commitTransactionOperation(next, done, context) {
78
78
  });
79
79
  }
80
80
  function rollbackTransactionOperation(next, done, context) {
81
- var completed = context.completed;
81
+ const { completed } = context;
82
82
  if (completed) {
83
83
  next();
84
84
  return;
85
85
  }
86
- var connection = context.connection, log = connection.getLog();
86
+ const { connection } = context, log = connection.getLog();
87
87
  log.debug("Rolling back transaction...");
88
- connection.rollback(function(error) {
88
+ connection.rollback((error)=>{
89
89
  if (error) {
90
- var code = error.code;
91
- log.error("...failed with error code ".concat(code, "."));
90
+ const { code } = error;
91
+ log.error(`...failed with error code ${code}.`);
92
92
  done();
93
93
  return;
94
94
  }
@@ -99,22 +99,22 @@ function executeOperationsOperation(next, done, context) {
99
99
  whilst(executeOperation, next, context);
100
100
  }
101
101
  function executeOperation(next, done, context, index) {
102
- var operations = context.operations, operationsLength = operations.length, lastOperationIndex = operationsLength - 1;
102
+ const { operations } = context, operationsLength = operations.length, lastOperationIndex = operationsLength - 1;
103
103
  if (index > lastOperationIndex) {
104
104
  complete();
105
105
  return;
106
106
  }
107
- var connection = context.connection, log = connection.getLog();
107
+ const { connection } = context, log = connection.getLog();
108
108
  log.debug("Executing operation...");
109
- var operation = operations[index], abort = done, proceed = next; ///
109
+ const operation = operations[index], abort = done, proceed = next; ///
110
110
  operation(connection, abort, proceed, complete, context);
111
111
  function complete() {
112
- var completed = true;
112
+ const completed = true;
113
113
  Object.assign(context, {
114
- completed: completed
114
+ completed
115
115
  });
116
116
  done();
117
117
  }
118
118
  }
119
119
 
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/transaction.js"],"sourcesContent":["\"use strict\";\n\nimport defaultLog from \"./defaultLog\";\n\nimport { asynchronousUtilities } from \"necessary\";\n\nconst { whilst, sequence } = asynchronousUtilities;\n      \nexport default function transaction(configuration, operations, callback, context) {\n  const { Connection } = configuration,\n        completed = false;\n\n  Connection.fromConfiguration(configuration, (error, connection) => {\n    if (error) {\n      const { log = defaultLog } = configuration;\n\n      log.error(\"The transaction wasn't completed because there was no connection.\");\n\n      callback(completed);\n\n      return;\n    }\n\n    Object.assign(context, {\n      connection,\n      operations,\n      completed\n    });\n\n    operations = [  ///\n      beginTransactionOperation,\n      executeOperationsOperation,\n      commitTransactionOperation,\n      rollbackTransactionOperation\n    ];\n\n    sequence(operations, () => {\n      const { completed } = context;\n\n      delete context.connection;\n      delete context.operations;\n      delete context.completed;\n\n      connection.release();\n\n      callback(completed);\n    }, context);\n  });\n}\n\nfunction beginTransactionOperation(next, done, context) {\n  const { connection } = context,\n        log = connection.getLog();\n\n  log.debug(\"Beginning transaction...\");\n\n  connection.begin((error) => {\n    if (error) {\n      const { code } = error;\n\n      log.error(`An error with '${code}' has occurred.`);\n\n      done();\n\n      return;\n    }\n\n    next();\n  });\n}\n\nfunction commitTransactionOperation(next, done, context) {\n  const { completed } = context;\n\n  if (!completed) {\n    next();\n\n    return;\n  }\n\n  const { connection } = context,\n        log = connection.getLog();\n\n  log.debug(\"Committing transaction...\");\n\n  connection.commit((error) => {\n    if (error) {\n      const { code } = error;\n\n      log.error(\"An error with '${code}' has occurred.\");\n\n      done();\n\n      return;\n    }\n\n    next();\n  });\n}\n\nfunction rollbackTransactionOperation(next, done, context) {\n  const { completed } = context;\n\n  if (completed) {\n    next();\n\n    return;\n  }\n\n  const { connection } = context,\n        log = connection.getLog();\n\n  log.debug(\"Rolling back transaction...\");\n\n  connection.rollback((error) => {\n    if (error) {\n      const { code } = error;\n\n      log.error(`...failed with error code ${code}.`);\n\n      done();\n\n      return;\n    }\n\n    next();\n  });\n}\n\nfunction executeOperationsOperation(next, done, context) {\n  whilst(executeOperation, next, context);\n}\n\nfunction executeOperation(next, done, context, index) {\n  const { operations } = context,\n        operationsLength = operations.length,\n        lastOperationIndex = operationsLength - 1;\n\n  if (index > lastOperationIndex) {\n    complete();\n\n    return;\n  }\n\n  const { connection } = context,\n        log = connection.getLog();\n\n  log.debug(\"Executing operation...\");\n\n  const operation = operations[index],\n        abort = done, ///\n        proceed = next; ///\n\n  operation(connection, abort, proceed, complete, context);\n\n  function complete() {\n    const completed = true;\n\n    Object.assign(context, {\n      completed\n    });\n\n    done();\n  }\n}\n"],"names":["transaction","whilst","asynchronousUtilities","sequence","configuration","operations","callback","context","Connection","completed","fromConfiguration","error","connection","log","defaultLog","Object","assign","beginTransactionOperation","executeOperationsOperation","commitTransactionOperation","rollbackTransactionOperation","release","next","done","getLog","debug","begin","code","commit","rollback","executeOperation","index","operationsLength","length","lastOperationIndex","complete","operation","abort","proceed"],"mappings":"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"}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/transaction.js"],"sourcesContent":["\"use strict\";\n\nimport defaultLog from \"./defaultLog\";\n\nimport { asynchronousUtilities } from \"necessary\";\n\nconst { whilst, sequence } = asynchronousUtilities;\n      \nexport default function transaction(configuration, operations, callback, context) {\n  const { Connection } = configuration,\n        completed = false;\n\n  Connection.fromConfiguration(configuration, (error, connection) => {\n    if (error) {\n      const { log = defaultLog } = configuration;\n\n      log.error(\"The transaction wasn't completed because there was no connection.\");\n\n      callback(completed);\n\n      return;\n    }\n\n    Object.assign(context, {\n      connection,\n      operations,\n      completed\n    });\n\n    operations = [  ///\n      beginTransactionOperation,\n      executeOperationsOperation,\n      commitTransactionOperation,\n      rollbackTransactionOperation\n    ];\n\n    sequence(operations, () => {\n      const { completed } = context;\n\n      delete context.connection;\n      delete context.operations;\n      delete context.completed;\n\n      connection.release();\n\n      callback(completed);\n    }, context);\n  });\n}\n\nfunction beginTransactionOperation(next, done, context) {\n  const { connection } = context,\n        log = connection.getLog();\n\n  log.debug(\"Beginning transaction...\");\n\n  connection.begin((error) => {\n    if (error) {\n      const { code } = error;\n\n      log.error(`An error with '${code}' has occurred.`);\n\n      done();\n\n      return;\n    }\n\n    next();\n  });\n}\n\nfunction commitTransactionOperation(next, done, context) {\n  const { completed } = context;\n\n  if (!completed) {\n    next();\n\n    return;\n  }\n\n  const { connection } = context,\n        log = connection.getLog();\n\n  log.debug(\"Committing transaction...\");\n\n  connection.commit((error) => {\n    if (error) {\n      const { code } = error;\n\n      log.error(\"An error with '${code}' has occurred.\");\n\n      done();\n\n      return;\n    }\n\n    next();\n  });\n}\n\nfunction rollbackTransactionOperation(next, done, context) {\n  const { completed } = context;\n\n  if (completed) {\n    next();\n\n    return;\n  }\n\n  const { connection } = context,\n        log = connection.getLog();\n\n  log.debug(\"Rolling back transaction...\");\n\n  connection.rollback((error) => {\n    if (error) {\n      const { code } = error;\n\n      log.error(`...failed with error code ${code}.`);\n\n      done();\n\n      return;\n    }\n\n    next();\n  });\n}\n\nfunction executeOperationsOperation(next, done, context) {\n  whilst(executeOperation, next, context);\n}\n\nfunction executeOperation(next, done, context, index) {\n  const { operations } = context,\n        operationsLength = operations.length,\n        lastOperationIndex = operationsLength - 1;\n\n  if (index > lastOperationIndex) {\n    complete();\n\n    return;\n  }\n\n  const { connection } = context,\n        log = connection.getLog();\n\n  log.debug(\"Executing operation...\");\n\n  const operation = operations[index],\n        abort = done, ///\n        proceed = next; ///\n\n  operation(connection, abort, proceed, complete, context);\n\n  function complete() {\n    const completed = true;\n\n    Object.assign(context, {\n      completed\n    });\n\n    done();\n  }\n}\n"],"names":["transaction","whilst","sequence","asynchronousUtilities","configuration","operations","callback","context","Connection","completed","fromConfiguration","error","connection","log","defaultLog","Object","assign","beginTransactionOperation","executeOperationsOperation","commitTransactionOperation","rollbackTransactionOperation","release","next","done","getLog","debug","begin","code","commit","rollback","executeOperation","index","operationsLength","length","lastOperationIndex","complete","operation","abort","proceed"],"mappings":"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"}
@@ -20,20 +20,20 @@ _export(exports, {
20
20
  }
21
21
  });
22
22
  function camelCaseToSnakeCase(string) {
23
- return string.replace(/([A-Z])/g, function(match, character) {
24
- var lowerCaseCharacter = character.toLowerCase(), characters = "_".concat(lowerCaseCharacter);
23
+ return string.replace(/([A-Z])/g, (match, character)=>{
24
+ const lowerCaseCharacter = character.toLowerCase(), characters = `_${lowerCaseCharacter}`;
25
25
  return characters;
26
26
  });
27
27
  }
28
28
  function snakeCaseToCamelCase(string) {
29
- return string.replace(/_(.)/g, function(match, character) {
30
- var upperCaseCharacter = character.toUpperCase();
29
+ return string.replace(/_(.)/g, (match, character)=>{
30
+ const upperCaseCharacter = character.toUpperCase();
31
31
  return upperCaseCharacter;
32
32
  });
33
33
  }
34
- var _default = {
35
- camelCaseToSnakeCase: camelCaseToSnakeCase,
36
- snakeCaseToCamelCase: snakeCaseToCamelCase
34
+ const _default = {
35
+ camelCaseToSnakeCase,
36
+ snakeCaseToCamelCase
37
37
  };
38
38
 
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvY2FzZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNhbWVsQ2FzZVRvU25ha2VDYXNlKHN0cmluZykge1xuICByZXR1cm4gc3RyaW5nLnJlcGxhY2UoLyhbQS1aXSkvZywgKG1hdGNoLCBjaGFyYWN0ZXIpID0+IHtcbiAgICBjb25zdCBsb3dlckNhc2VDaGFyYWN0ZXIgPSBjaGFyYWN0ZXIudG9Mb3dlckNhc2UoKSxcbiAgICAgICAgICBjaGFyYWN0ZXJzID0gYF8ke2xvd2VyQ2FzZUNoYXJhY3Rlcn1gXG5cbiAgICByZXR1cm4gY2hhcmFjdGVycztcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzbmFrZUNhc2VUb0NhbWVsQ2FzZShzdHJpbmcpIHtcbiAgcmV0dXJuIHN0cmluZy5yZXBsYWNlKC9fKC4pL2csIChtYXRjaCwgY2hhcmFjdGVyKSA9PiB7XG4gICAgY29uc3QgdXBwZXJDYXNlQ2hhcmFjdGVyID0gY2hhcmFjdGVyLnRvVXBwZXJDYXNlKCk7XG5cbiAgICByZXR1cm4gdXBwZXJDYXNlQ2hhcmFjdGVyO1xuICB9KTtcbn1cblxuZXhwb3J0IGRlZmF1bHQge1xuICBjYW1lbENhc2VUb1NuYWtlQ2FzZSxcbiAgc25ha2VDYXNlVG9DYW1lbENhc2UsXG59OyJdLCJuYW1lcyI6WyJjYW1lbENhc2VUb1NuYWtlQ2FzZSIsInNuYWtlQ2FzZVRvQ2FtZWxDYXNlIiwic3RyaW5nIiwicmVwbGFjZSIsIm1hdGNoIiwiY2hhcmFjdGVyIiwibG93ZXJDYXNlQ2hhcmFjdGVyIiwidG9Mb3dlckNhc2UiLCJjaGFyYWN0ZXJzIiwidXBwZXJDYXNlQ2hhcmFjdGVyIiwidG9VcHBlckNhc2UiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQUVnQkE7ZUFBQUE7O1FBaUJoQjtlQUFBOztRQVJnQkM7ZUFBQUE7OztBQVRULFNBQVNELHFCQUFxQkUsTUFBTTtJQUN6QyxPQUFPQSxPQUFPQyxPQUFPLENBQUMsWUFBWSxTQUFDQyxPQUFPQztRQUN4QyxJQUFNQyxxQkFBcUJELFVBQVVFLFdBQVcsSUFDMUNDLGFBQWEsQUFBQyxJQUFzQixPQUFuQkY7UUFFdkIsT0FBT0U7SUFDVDtBQUNGO0FBRU8sU0FBU1AscUJBQXFCQyxNQUFNO0lBQ3pDLE9BQU9BLE9BQU9DLE9BQU8sQ0FBQyxTQUFTLFNBQUNDLE9BQU9DO1FBQ3JDLElBQU1JLHFCQUFxQkosVUFBVUssV0FBVztRQUVoRCxPQUFPRDtJQUNUO0FBQ0Y7SUFFQSxXQUFlO0lBQ2JULHNCQUFBQTtJQUNBQyxzQkFBQUE7QUFDRiJ9
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvY2FzZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGNhbWVsQ2FzZVRvU25ha2VDYXNlKHN0cmluZykge1xuICByZXR1cm4gc3RyaW5nLnJlcGxhY2UoLyhbQS1aXSkvZywgKG1hdGNoLCBjaGFyYWN0ZXIpID0+IHtcbiAgICBjb25zdCBsb3dlckNhc2VDaGFyYWN0ZXIgPSBjaGFyYWN0ZXIudG9Mb3dlckNhc2UoKSxcbiAgICAgICAgICBjaGFyYWN0ZXJzID0gYF8ke2xvd2VyQ2FzZUNoYXJhY3Rlcn1gXG5cbiAgICByZXR1cm4gY2hhcmFjdGVycztcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzbmFrZUNhc2VUb0NhbWVsQ2FzZShzdHJpbmcpIHtcbiAgcmV0dXJuIHN0cmluZy5yZXBsYWNlKC9fKC4pL2csIChtYXRjaCwgY2hhcmFjdGVyKSA9PiB7XG4gICAgY29uc3QgdXBwZXJDYXNlQ2hhcmFjdGVyID0gY2hhcmFjdGVyLnRvVXBwZXJDYXNlKCk7XG5cbiAgICByZXR1cm4gdXBwZXJDYXNlQ2hhcmFjdGVyO1xuICB9KTtcbn1cblxuZXhwb3J0IGRlZmF1bHQge1xuICBjYW1lbENhc2VUb1NuYWtlQ2FzZSxcbiAgc25ha2VDYXNlVG9DYW1lbENhc2UsXG59OyJdLCJuYW1lcyI6WyJjYW1lbENhc2VUb1NuYWtlQ2FzZSIsInNuYWtlQ2FzZVRvQ2FtZWxDYXNlIiwic3RyaW5nIiwicmVwbGFjZSIsIm1hdGNoIiwiY2hhcmFjdGVyIiwibG93ZXJDYXNlQ2hhcmFjdGVyIiwidG9Mb3dlckNhc2UiLCJjaGFyYWN0ZXJzIiwidXBwZXJDYXNlQ2hhcmFjdGVyIiwidG9VcHBlckNhc2UiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQUVnQkE7ZUFBQUE7O1FBaUJoQjtlQUFBOztRQVJnQkM7ZUFBQUE7OztBQVRULFNBQVNELHFCQUFxQkUsTUFBTTtJQUN6QyxPQUFPQSxPQUFPQyxPQUFPLENBQUMsWUFBWSxDQUFDQyxPQUFPQztRQUN4QyxNQUFNQyxxQkFBcUJELFVBQVVFLFdBQVcsSUFDMUNDLGFBQWEsQ0FBQyxDQUFDLEVBQUVGLG9CQUFvQjtRQUUzQyxPQUFPRTtJQUNUO0FBQ0Y7QUFFTyxTQUFTUCxxQkFBcUJDLE1BQU07SUFDekMsT0FBT0EsT0FBT0MsT0FBTyxDQUFDLFNBQVMsQ0FBQ0MsT0FBT0M7UUFDckMsTUFBTUkscUJBQXFCSixVQUFVSyxXQUFXO1FBRWhELE9BQU9EO0lBQ1Q7QUFDRjtNQUVBLFdBQWU7SUFDYlQ7SUFDQUM7QUFDRiJ9
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "murmuration",
3
3
  "author": "James Smith",
4
- "version": "2.0.69",
4
+ "version": "2.0.71",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/murmuration",
7
7
  "description": "Database statements, transactions and migrations.",
@@ -10,7 +10,7 @@
10
10
  "url": "https://github.com/djalbat/murmuration"
11
11
  },
12
12
  "dependencies": {
13
- "necessary": "^17.0.9"
13
+ "necessary": "^17.1.1"
14
14
  },
15
15
  "devDependencies": {
16
16
  "@swc/core": "1.13.20",