murmuration 2.0.25 → 2.0.28
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.
- package/.swcrc +5 -0
- package/lib/constants.js +13 -0
- package/lib/database.js +51 -0
- package/lib/defaultLog.js +22 -0
- package/lib/index.js +47 -0
- package/lib/migrate/customMigration.js +72 -0
- package/lib/migrate/migration.js +76 -0
- package/lib/migrate/migrations.js +93 -0
- package/lib/migrate/operation/applyMigrations.js +110 -0
- package/lib/migrate/operation/initialise.js +71 -0
- package/lib/migrate.js +40 -0
- package/lib/statement.js +461 -0
- package/lib/table/migration.js +63 -0
- package/lib/transaction.js +120 -0
- package/lib/utilities/case.js +32 -0
- package/package.json +18 -3
- package/src/constants.js +3 -0
- package/{bin → src}/database.js +2 -7
- package/{bin → src}/defaultLog.js +1 -1
- package/src/index.js +9 -0
- package/{bin → src}/migrate/customMigration.js +2 -4
- package/{bin → src}/migrate/migration.js +3 -5
- package/{bin → src}/migrate/migrations.js +3 -5
- package/{bin → src}/migrate/operation/applyMigrations.js +5 -7
- package/{bin → src}/migrate/operation/initialise.js +3 -5
- package/{bin → src}/migrate.js +4 -6
- package/{bin → src}/statement.js +4 -6
- package/{bin → src}/table/migration.js +5 -12
- package/{bin → src}/transaction.js +3 -5
- package/{bin → src}/utilities/case.js +2 -7
- package/bin/constants.js +0 -7
- package/index.js +0 -19
package/lib/migrate.js
ADDED
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return migrate;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
var _initialise = /*#__PURE__*/ _interop_require_default(require("./migrate/operation/initialise"));
|
|
12
|
+
var _applyMigrations = /*#__PURE__*/ _interop_require_default(require("./migrate/operation/applyMigrations"));
|
|
13
|
+
var _necessary = require("necessary");
|
|
14
|
+
function _interop_require_default(obj) {
|
|
15
|
+
return obj && obj.__esModule ? obj : {
|
|
16
|
+
default: obj
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
var sequence = _necessary.asynchronousUtilities.sequence;
|
|
20
|
+
function migrate(configuration, migrationsDirectoryPath, CustomMigrationMap, callback) {
|
|
21
|
+
if (callback === undefined) {
|
|
22
|
+
callback = CustomMigrationMap; ///
|
|
23
|
+
CustomMigrationMap = {};
|
|
24
|
+
}
|
|
25
|
+
var callbacks = [
|
|
26
|
+
_initialise.default,
|
|
27
|
+
_applyMigrations.default
|
|
28
|
+
], error = false, context = {
|
|
29
|
+
error: error,
|
|
30
|
+
configuration: configuration,
|
|
31
|
+
CustomMigrationMap: CustomMigrationMap,
|
|
32
|
+
migrationsDirectoryPath: migrationsDirectoryPath
|
|
33
|
+
};
|
|
34
|
+
sequence(callbacks, function() {
|
|
35
|
+
var error = context.error;
|
|
36
|
+
callback(error);
|
|
37
|
+
}, context);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9taWdyYXRlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5pbXBvcnQgaW5pdGlhbGlzZU9wZXJhdGlvbiBmcm9tIFwiLi9taWdyYXRlL29wZXJhdGlvbi9pbml0aWFsaXNlXCI7XG5pbXBvcnQgYXBwbHlNaWdyYXRpb25zT3BlcmF0aW9uIGZyb20gXCIuL21pZ3JhdGUvb3BlcmF0aW9uL2FwcGx5TWlncmF0aW9uc1wiO1xuXG5pbXBvcnQgeyBhc3luY2hyb25vdXNVdGlsaXRpZXMgfSBmcm9tIFwibmVjZXNzYXJ5XCI7XG5cbmNvbnN0IHsgc2VxdWVuY2UgfSA9IGFzeW5jaHJvbm91c1V0aWxpdGllcztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gbWlncmF0ZShjb25maWd1cmF0aW9uLCBtaWdyYXRpb25zRGlyZWN0b3J5UGF0aCwgQ3VzdG9tTWlncmF0aW9uTWFwLCBjYWxsYmFjaykge1xuICBpZiAoY2FsbGJhY2sgPT09IHVuZGVmaW5lZCkge1xuICAgIGNhbGxiYWNrID0gQ3VzdG9tTWlncmF0aW9uTWFwOyAvLy9cblxuICAgIEN1c3RvbU1pZ3JhdGlvbk1hcCA9IHt9O1xuICB9XG5cbiAgY29uc3QgY2FsbGJhY2tzID0gW1xuICAgICAgICAgIGluaXRpYWxpc2VPcGVyYXRpb24sXG4gICAgICAgICAgYXBwbHlNaWdyYXRpb25zT3BlcmF0aW9uXG4gICAgICAgIF0sXG4gICAgICAgIGVycm9yID0gZmFsc2UsICAvLy9cbiAgICAgICAgY29udGV4dCA9IHtcbiAgICAgICAgICBlcnJvcixcbiAgICAgICAgICBjb25maWd1cmF0aW9uLFxuICAgICAgICAgIEN1c3RvbU1pZ3JhdGlvbk1hcCxcbiAgICAgICAgICBtaWdyYXRpb25zRGlyZWN0b3J5UGF0aFxuICAgICAgICB9O1xuXG4gIHNlcXVlbmNlKGNhbGxiYWNrcywgKCkgPT4ge1xuICAgIGNvbnN0IHsgZXJyb3IgfSA9IGNvbnRleHQ7XG5cbiAgICBjYWxsYmFjayhlcnJvcik7XG4gIH0sIGNvbnRleHQpO1xufVxuIl0sIm5hbWVzIjpbIm1pZ3JhdGUiLCJzZXF1ZW5jZSIsImFzeW5jaHJvbm91c1V0aWxpdGllcyIsImNvbmZpZ3VyYXRpb24iLCJtaWdyYXRpb25zRGlyZWN0b3J5UGF0aCIsIkN1c3RvbU1pZ3JhdGlvbk1hcCIsImNhbGxiYWNrIiwidW5kZWZpbmVkIiwiY2FsbGJhY2tzIiwiaW5pdGlhbGlzZU9wZXJhdGlvbiIsImFwcGx5TWlncmF0aW9uc09wZXJhdGlvbiIsImVycm9yIiwiY29udGV4dCJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7K0JBU0E7OztlQUF3QkE7OztpRUFQUTtzRUFDSzt5QkFFQzs7Ozs7O0FBRXRDLElBQU0sQUFBRUMsV0FBYUMsZ0NBQXFCLENBQWxDRDtBQUVPLFNBQVNELFFBQVFHLGFBQWEsRUFBRUMsdUJBQXVCLEVBQUVDLGtCQUFrQixFQUFFQyxRQUFRO0lBQ2xHLElBQUlBLGFBQWFDLFdBQVc7UUFDMUJELFdBQVdELG9CQUFvQixHQUFHO1FBRWxDQSxxQkFBcUIsQ0FBQztJQUN4QjtJQUVBLElBQU1HLFlBQVk7UUFDVkMsbUJBQW1CO1FBQ25CQyx3QkFBd0I7S0FDekIsRUFDREMsUUFBUSxPQUNSQyxVQUFVO1FBQ1JELE9BQUFBO1FBQ0FSLGVBQUFBO1FBQ0FFLG9CQUFBQTtRQUNBRCx5QkFBQUE7SUFDRjtJQUVOSCxTQUFTTyxXQUFXO1FBQ2xCLElBQU0sQUFBRUcsUUFBVUMsUUFBVkQ7UUFFUkwsU0FBU0s7SUFDWCxHQUFHQztBQUNMIn0=
|
package/lib/statement.js
ADDED
|
@@ -0,0 +1,461 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return Statement;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
var _necessary = require("necessary");
|
|
12
|
+
var _database = /*#__PURE__*/ _interop_require_default(require("./database"));
|
|
13
|
+
var _constants = require("./constants");
|
|
14
|
+
function _array_like_to_array(arr, len) {
|
|
15
|
+
if (len == null || len > arr.length) len = arr.length;
|
|
16
|
+
for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
|
|
17
|
+
return arr2;
|
|
18
|
+
}
|
|
19
|
+
function _array_without_holes(arr) {
|
|
20
|
+
if (Array.isArray(arr)) return _array_like_to_array(arr);
|
|
21
|
+
}
|
|
22
|
+
function _class_call_check(instance, Constructor) {
|
|
23
|
+
if (!(instance instanceof Constructor)) {
|
|
24
|
+
throw new TypeError("Cannot call a class as a function");
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
function _defineProperties(target, props) {
|
|
28
|
+
for(var i = 0; i < props.length; i++){
|
|
29
|
+
var descriptor = props[i];
|
|
30
|
+
descriptor.enumerable = descriptor.enumerable || false;
|
|
31
|
+
descriptor.configurable = true;
|
|
32
|
+
if ("value" in descriptor) descriptor.writable = true;
|
|
33
|
+
Object.defineProperty(target, descriptor.key, descriptor);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
function _create_class(Constructor, protoProps, staticProps) {
|
|
37
|
+
if (protoProps) _defineProperties(Constructor.prototype, protoProps);
|
|
38
|
+
if (staticProps) _defineProperties(Constructor, staticProps);
|
|
39
|
+
return Constructor;
|
|
40
|
+
}
|
|
41
|
+
function _define_property(obj, key, value) {
|
|
42
|
+
if (key in obj) {
|
|
43
|
+
Object.defineProperty(obj, key, {
|
|
44
|
+
value: value,
|
|
45
|
+
enumerable: true,
|
|
46
|
+
configurable: true,
|
|
47
|
+
writable: true
|
|
48
|
+
});
|
|
49
|
+
} else {
|
|
50
|
+
obj[key] = value;
|
|
51
|
+
}
|
|
52
|
+
return obj;
|
|
53
|
+
}
|
|
54
|
+
function _interop_require_default(obj) {
|
|
55
|
+
return obj && obj.__esModule ? obj : {
|
|
56
|
+
default: obj
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
function _iterable_to_array(iter) {
|
|
60
|
+
if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
|
|
61
|
+
}
|
|
62
|
+
function _non_iterable_spread() {
|
|
63
|
+
throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
64
|
+
}
|
|
65
|
+
function _to_consumable_array(arr) {
|
|
66
|
+
return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
|
|
67
|
+
}
|
|
68
|
+
function _unsupported_iterable_to_array(o, minLen) {
|
|
69
|
+
if (!o) return;
|
|
70
|
+
if (typeof o === "string") return _array_like_to_array(o, minLen);
|
|
71
|
+
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
72
|
+
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
73
|
+
if (n === "Map" || n === "Set") return Array.from(n);
|
|
74
|
+
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
|
75
|
+
}
|
|
76
|
+
var first = _necessary.arrayUtilities.first, query = _database.default.query, command = _database.default.execute;
|
|
77
|
+
var Statement = /*#__PURE__*/ function() {
|
|
78
|
+
function Statement(connection, sql, query, parameters, oneHandler, noneHandler, manyHandler, elseHandler, firstHandler, errorHandler, successHandler) {
|
|
79
|
+
var _this = this;
|
|
80
|
+
_class_call_check(this, Statement);
|
|
81
|
+
_define_property(this, "queryHandler", function(error, rows) {
|
|
82
|
+
if (error) {
|
|
83
|
+
_this.errorHandler(error);
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
var rowsLength = rows.length;
|
|
87
|
+
if (false) {
|
|
88
|
+
///
|
|
89
|
+
} else if (_this.noneHandler !== null) {
|
|
90
|
+
if (rowsLength === 0) {
|
|
91
|
+
_this.noneHandler();
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
} else if (_this.firstHandler !== null) {
|
|
95
|
+
if (rowsLength > 0) {
|
|
96
|
+
var firstRow = first(rows), row = firstRow, object = _this.objectFromRow(row);
|
|
97
|
+
_this.firstHandler(object);
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
} else if (_this.oneHandler !== null) {
|
|
101
|
+
if (rowsLength === 1) {
|
|
102
|
+
var firstRow1 = first(rows), row1 = firstRow1, object1 = _this.objectFromRow(row1);
|
|
103
|
+
_this.oneHandler(object1);
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
} else if (_this.manyHandler !== null) {
|
|
107
|
+
var objects = rows.map(function(row) {
|
|
108
|
+
return _this.objectFromRow(row);
|
|
109
|
+
});
|
|
110
|
+
_this.manyHandler(objects);
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
_this.elseHandler(rows);
|
|
114
|
+
});
|
|
115
|
+
_define_property(this, "commandHandler", function(error) {
|
|
116
|
+
if (error) {
|
|
117
|
+
_this.errorHandler(error);
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
_this.successHandler();
|
|
121
|
+
});
|
|
122
|
+
this.connection = connection;
|
|
123
|
+
this.sql = sql;
|
|
124
|
+
this.query = query;
|
|
125
|
+
this.parameters = parameters;
|
|
126
|
+
this.oneHandler = oneHandler;
|
|
127
|
+
this.noneHandler = noneHandler;
|
|
128
|
+
this.manyHandler = manyHandler;
|
|
129
|
+
this.elseHandler = elseHandler;
|
|
130
|
+
this.firstHandler = firstHandler;
|
|
131
|
+
this.errorHandler = errorHandler;
|
|
132
|
+
this.successHandler = successHandler;
|
|
133
|
+
}
|
|
134
|
+
_create_class(Statement, [
|
|
135
|
+
{
|
|
136
|
+
key: "getConnection",
|
|
137
|
+
value: function getConnection() {
|
|
138
|
+
return this.connection;
|
|
139
|
+
}
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
key: "getSQL",
|
|
143
|
+
value: function getSQL() {
|
|
144
|
+
return this.sql;
|
|
145
|
+
}
|
|
146
|
+
},
|
|
147
|
+
{
|
|
148
|
+
key: "isQuery",
|
|
149
|
+
value: function isQuery() {
|
|
150
|
+
return this.query;
|
|
151
|
+
}
|
|
152
|
+
},
|
|
153
|
+
{
|
|
154
|
+
key: "getParameters",
|
|
155
|
+
value: function getParameters() {
|
|
156
|
+
return this.parameters;
|
|
157
|
+
}
|
|
158
|
+
},
|
|
159
|
+
{
|
|
160
|
+
key: "getOneHandler",
|
|
161
|
+
value: function getOneHandler() {
|
|
162
|
+
return this.oneHandler;
|
|
163
|
+
}
|
|
164
|
+
},
|
|
165
|
+
{
|
|
166
|
+
key: "getNoneHandler",
|
|
167
|
+
value: function getNoneHandler() {
|
|
168
|
+
return this.noneHandler;
|
|
169
|
+
}
|
|
170
|
+
},
|
|
171
|
+
{
|
|
172
|
+
key: "getManyHandler",
|
|
173
|
+
value: function getManyHandler() {
|
|
174
|
+
return this.manyHandler;
|
|
175
|
+
}
|
|
176
|
+
},
|
|
177
|
+
{
|
|
178
|
+
key: "getElseHandler",
|
|
179
|
+
value: function getElseHandler() {
|
|
180
|
+
return this.elseHandler;
|
|
181
|
+
}
|
|
182
|
+
},
|
|
183
|
+
{
|
|
184
|
+
key: "getFirstHandler",
|
|
185
|
+
value: function getFirstHandler() {
|
|
186
|
+
return this.firstHandler;
|
|
187
|
+
}
|
|
188
|
+
},
|
|
189
|
+
{
|
|
190
|
+
key: "getErrorHandler",
|
|
191
|
+
value: function getErrorHandler() {
|
|
192
|
+
return this.errorHandler;
|
|
193
|
+
}
|
|
194
|
+
},
|
|
195
|
+
{
|
|
196
|
+
key: "getSuccessHandler",
|
|
197
|
+
value: function getSuccessHandler() {
|
|
198
|
+
return this.successHandler;
|
|
199
|
+
}
|
|
200
|
+
},
|
|
201
|
+
{
|
|
202
|
+
key: "setSQL",
|
|
203
|
+
value: function setSQL(sql) {
|
|
204
|
+
this.sql = sql;
|
|
205
|
+
}
|
|
206
|
+
},
|
|
207
|
+
{
|
|
208
|
+
key: "setQuery",
|
|
209
|
+
value: function setQuery(query) {
|
|
210
|
+
this.query = query;
|
|
211
|
+
}
|
|
212
|
+
},
|
|
213
|
+
{
|
|
214
|
+
key: "setParameters",
|
|
215
|
+
value: function setParameters(parameters) {
|
|
216
|
+
this.parameters = parameters;
|
|
217
|
+
}
|
|
218
|
+
},
|
|
219
|
+
{
|
|
220
|
+
key: "one",
|
|
221
|
+
value: function one(oneHandler) {
|
|
222
|
+
this.oneHandler = oneHandler;
|
|
223
|
+
return this;
|
|
224
|
+
}
|
|
225
|
+
},
|
|
226
|
+
{
|
|
227
|
+
key: "none",
|
|
228
|
+
value: function none(noneHandler) {
|
|
229
|
+
this.noneHandler = noneHandler;
|
|
230
|
+
return this;
|
|
231
|
+
}
|
|
232
|
+
},
|
|
233
|
+
{
|
|
234
|
+
key: "many",
|
|
235
|
+
value: function many(manyHandler) {
|
|
236
|
+
this.manyHandler = manyHandler;
|
|
237
|
+
return this;
|
|
238
|
+
}
|
|
239
|
+
},
|
|
240
|
+
{
|
|
241
|
+
key: "else",
|
|
242
|
+
value: function _else(elseHandler) {
|
|
243
|
+
this.elseHandler = elseHandler;
|
|
244
|
+
return this;
|
|
245
|
+
}
|
|
246
|
+
},
|
|
247
|
+
{
|
|
248
|
+
key: "first",
|
|
249
|
+
value: function first(firstHandler) {
|
|
250
|
+
this.firstHandler = firstHandler;
|
|
251
|
+
return this;
|
|
252
|
+
}
|
|
253
|
+
},
|
|
254
|
+
{
|
|
255
|
+
key: "catch",
|
|
256
|
+
value: function _catch(errorHandler) {
|
|
257
|
+
this.errorHandler = errorHandler;
|
|
258
|
+
return this;
|
|
259
|
+
}
|
|
260
|
+
},
|
|
261
|
+
{
|
|
262
|
+
key: "success",
|
|
263
|
+
value: function success(successHandler) {
|
|
264
|
+
this.successHandler = successHandler;
|
|
265
|
+
return this;
|
|
266
|
+
}
|
|
267
|
+
},
|
|
268
|
+
{
|
|
269
|
+
key: "set",
|
|
270
|
+
value: function set(objectOrArray) {
|
|
271
|
+
for(var _len = arguments.length, parameters = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++){
|
|
272
|
+
parameters[_key - 1] = arguments[_key];
|
|
273
|
+
}
|
|
274
|
+
var assignments;
|
|
275
|
+
var objectOrArrayIsArray = Array.isArray(objectOrArray);
|
|
276
|
+
if (objectOrArrayIsArray) {
|
|
277
|
+
var array = objectOrArray, strings = array; ///
|
|
278
|
+
assignments = this.assignmentsFromStringsAndParameters(strings, parameters);
|
|
279
|
+
} else {
|
|
280
|
+
var object = objectOrArray; ///
|
|
281
|
+
assignments = this.assignmentsFromObject(object); ///
|
|
282
|
+
}
|
|
283
|
+
this.sql = " ".concat(this.sql, " SET ").concat(assignments);
|
|
284
|
+
return this;
|
|
285
|
+
}
|
|
286
|
+
},
|
|
287
|
+
{
|
|
288
|
+
key: "where",
|
|
289
|
+
value: function where(objectOrArray) {
|
|
290
|
+
for(var _len = arguments.length, parameters = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++){
|
|
291
|
+
parameters[_key - 1] = arguments[_key];
|
|
292
|
+
}
|
|
293
|
+
var clause;
|
|
294
|
+
var objectOrArrayIsArray = Array.isArray(objectOrArray);
|
|
295
|
+
if (objectOrArrayIsArray) {
|
|
296
|
+
var array = objectOrArray, strings = array; ///
|
|
297
|
+
clause = this.clauseFromStringsAndParameters(strings, parameters);
|
|
298
|
+
} else {
|
|
299
|
+
var object = objectOrArray; ///
|
|
300
|
+
clause = this.clauseFromObject(object); ///
|
|
301
|
+
}
|
|
302
|
+
this.sql = " ".concat(this.sql, " WHERE ").concat(clause);
|
|
303
|
+
return this;
|
|
304
|
+
}
|
|
305
|
+
},
|
|
306
|
+
{
|
|
307
|
+
key: "values",
|
|
308
|
+
value: function values(objectOrArray) {
|
|
309
|
+
for(var _len = arguments.length, parameters = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++){
|
|
310
|
+
parameters[_key - 1] = arguments[_key];
|
|
311
|
+
}
|
|
312
|
+
var objectOrArrayIsArray = Array.isArray(objectOrArray);
|
|
313
|
+
var columnsAndValues;
|
|
314
|
+
if (objectOrArrayIsArray) {
|
|
315
|
+
var array = objectOrArray, strings = array; ///
|
|
316
|
+
columnsAndValues = this.columnsAndValuesFromStringsAndParameters(strings, parameters);
|
|
317
|
+
} else {
|
|
318
|
+
var object = objectOrArray; ///
|
|
319
|
+
columnsAndValues = this.columnsAndValuesFromObject(object);
|
|
320
|
+
}
|
|
321
|
+
this.sql = "".concat(this.sql, " ").concat(columnsAndValues);
|
|
322
|
+
return this;
|
|
323
|
+
}
|
|
324
|
+
},
|
|
325
|
+
{
|
|
326
|
+
key: "objectFromRow",
|
|
327
|
+
value: function objectFromRow(row) {
|
|
328
|
+
var _this = this;
|
|
329
|
+
var values = Object.values(row), columns = Object.keys(row), object = columns.reduce(function(object, column, index) {
|
|
330
|
+
var key = _this.keyFromColumn(column), value = values[index];
|
|
331
|
+
object[key] = value;
|
|
332
|
+
return object;
|
|
333
|
+
}, {});
|
|
334
|
+
return object;
|
|
335
|
+
}
|
|
336
|
+
},
|
|
337
|
+
{
|
|
338
|
+
key: "clauseFromObject",
|
|
339
|
+
value: function clauseFromObject(object) {
|
|
340
|
+
var _this = this;
|
|
341
|
+
var keys = Object.keys(object), columns = keys.map(function(key) {
|
|
342
|
+
return _this.columnFromKey(key);
|
|
343
|
+
}), parameters = Object.values(object), firstIndex = 0, clause = columns.reduce(function(clause, column, index) {
|
|
344
|
+
var placeholder = _this.placeholder();
|
|
345
|
+
clause = index === firstIndex ? "".concat(column, "=").concat(placeholder) : " ".concat(clause, " AND ").concat(column, "=").concat(placeholder);
|
|
346
|
+
return clause;
|
|
347
|
+
}, _constants.EMPTY_STRING);
|
|
348
|
+
this.parameters = _to_consumable_array(this.parameters).concat(_to_consumable_array(parameters));
|
|
349
|
+
return clause;
|
|
350
|
+
}
|
|
351
|
+
},
|
|
352
|
+
{
|
|
353
|
+
key: "assignmentsFromObject",
|
|
354
|
+
value: function assignmentsFromObject(object) {
|
|
355
|
+
var _this = this;
|
|
356
|
+
var keys = Object.keys(object), columns = keys.map(function(key) {
|
|
357
|
+
return _this.columnFromKey(key);
|
|
358
|
+
}), parameters = Object.values(object), firstIndex = 0, assignments = columns.reduce(function(assignments, column, index) {
|
|
359
|
+
var placeholder = _this.placeholder();
|
|
360
|
+
assignments = index === firstIndex ? "".concat(column, "=").concat(placeholder) : " ".concat(assignments, ", ").concat(column, "=").concat(placeholder);
|
|
361
|
+
return assignments;
|
|
362
|
+
}, _constants.EMPTY_STRING);
|
|
363
|
+
this.parameters = _to_consumable_array(this.parameters).concat(_to_consumable_array(parameters));
|
|
364
|
+
return assignments;
|
|
365
|
+
}
|
|
366
|
+
},
|
|
367
|
+
{
|
|
368
|
+
key: "columnsAndValuesFromObject",
|
|
369
|
+
value: function columnsAndValuesFromObject(object) {
|
|
370
|
+
var _this = this;
|
|
371
|
+
var keys = Object.keys(object), columns = keys.map(function(key) {
|
|
372
|
+
return _this.columnFromKey(key);
|
|
373
|
+
}), parameters = Object.values(object), firstIndex = 0, values = columns.reduce(function(values, column, index) {
|
|
374
|
+
var placeholder = _this.placeholder();
|
|
375
|
+
values = index === firstIndex ? "".concat(placeholder) : " ".concat(values, ", ").concat(placeholder);
|
|
376
|
+
return values;
|
|
377
|
+
}, _constants.EMPTY_STRING), columnsAndValues = "(".concat(columns, ") VALUES (").concat(values, ")");
|
|
378
|
+
this.parameters = _to_consumable_array(this.parameters).concat(_to_consumable_array(parameters));
|
|
379
|
+
return columnsAndValues;
|
|
380
|
+
}
|
|
381
|
+
},
|
|
382
|
+
{
|
|
383
|
+
key: "clauseFromStringsAndParameters",
|
|
384
|
+
value: function clauseFromStringsAndParameters(strings, parameters) {
|
|
385
|
+
var _this = this;
|
|
386
|
+
var stringsLength = strings.length, lastIndex = stringsLength - 1, clause = strings.reduce(function(clause, string, index) {
|
|
387
|
+
if (index < lastIndex) {
|
|
388
|
+
var placeholder = _this.placeholder();
|
|
389
|
+
clause = "".concat(clause).concat(string).concat(placeholder);
|
|
390
|
+
} else {
|
|
391
|
+
clause = "".concat(clause).concat(string);
|
|
392
|
+
}
|
|
393
|
+
return clause;
|
|
394
|
+
}, _constants.EMPTY_STRING);
|
|
395
|
+
this.parameters = _to_consumable_array(this.parameters).concat(_to_consumable_array(parameters));
|
|
396
|
+
return clause;
|
|
397
|
+
}
|
|
398
|
+
},
|
|
399
|
+
{
|
|
400
|
+
key: "assignmentsFromStringsAndParameters",
|
|
401
|
+
value: function assignmentsFromStringsAndParameters(strings, parameters) {
|
|
402
|
+
var _this = this;
|
|
403
|
+
var stringsLength = strings.length, lastIndex = stringsLength - 1, assignments = strings.reduce(function(assignments, string, index) {
|
|
404
|
+
if (index < lastIndex) {
|
|
405
|
+
var placeholder = _this.placeholder();
|
|
406
|
+
assignments = "".concat(assignments).concat(string).concat(placeholder);
|
|
407
|
+
} else {
|
|
408
|
+
assignments = "".concat(assignments).concat(string);
|
|
409
|
+
}
|
|
410
|
+
return assignments;
|
|
411
|
+
}, _constants.EMPTY_STRING);
|
|
412
|
+
this.parameters = _to_consumable_array(this.parameters).concat(_to_consumable_array(parameters));
|
|
413
|
+
return assignments;
|
|
414
|
+
}
|
|
415
|
+
},
|
|
416
|
+
{
|
|
417
|
+
key: "columnsAndValuesFromStringsAndParameters",
|
|
418
|
+
value: function columnsAndValuesFromStringsAndParameters(strings, parameters) {
|
|
419
|
+
var _this = this;
|
|
420
|
+
var stringsLength = strings.length, lastIndex = stringsLength - 1, columnsAndValues = strings.reduce(function(columnsAndValues, string, index) {
|
|
421
|
+
if (index < lastIndex) {
|
|
422
|
+
var placeholder = _this.placeholder();
|
|
423
|
+
columnsAndValues = "".concat(columnsAndValues).concat(string).concat(placeholder);
|
|
424
|
+
} else {
|
|
425
|
+
columnsAndValues = "".concat(columnsAndValues).concat(string);
|
|
426
|
+
}
|
|
427
|
+
return columnsAndValues;
|
|
428
|
+
}, _constants.EMPTY_STRING);
|
|
429
|
+
this.parameters = _to_consumable_array(this.parameters).concat(_to_consumable_array(parameters));
|
|
430
|
+
return columnsAndValues;
|
|
431
|
+
}
|
|
432
|
+
},
|
|
433
|
+
{
|
|
434
|
+
key: "execute",
|
|
435
|
+
value: function execute() {
|
|
436
|
+
this.query ? query.apply(void 0, [
|
|
437
|
+
this.connection,
|
|
438
|
+
this.sql
|
|
439
|
+
].concat(_to_consumable_array(this.parameters), [
|
|
440
|
+
this.queryHandler
|
|
441
|
+
])) : command.apply(void 0, [
|
|
442
|
+
this.connection,
|
|
443
|
+
this.sql
|
|
444
|
+
].concat(_to_consumable_array(this.parameters), [
|
|
445
|
+
this.commandHandler
|
|
446
|
+
]));
|
|
447
|
+
}
|
|
448
|
+
}
|
|
449
|
+
], [
|
|
450
|
+
{
|
|
451
|
+
key: "fromConnection",
|
|
452
|
+
value: function fromConnection(Class, connection) {
|
|
453
|
+
var sql = null, query = false, parameters = [], oneHandler = null, noneHandler = null, manyHandler = null, elseHandler = null, firstHandler = null, errorHandler = null, successHandler = null, statement = new Class(connection, sql, query, parameters, oneHandler, noneHandler, manyHandler, elseHandler, firstHandler, errorHandler, successHandler);
|
|
454
|
+
return statement;
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
]);
|
|
458
|
+
return Statement;
|
|
459
|
+
}();
|
|
460
|
+
|
|
461
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/statement.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nimport database from \"./database\";\n\nimport { EMPTY_STRING } from \"./constants\";\n\nconst { first } = arrayUtilities,\n      { query, execute: command } = database;\n\nexport default class Statement {\n  constructor(connection, sql, query, parameters, oneHandler, noneHandler, manyHandler, elseHandler, firstHandler, errorHandler, successHandler) {\n    this.connection = connection;\n    this.sql = sql;\n    this.query = query;\n    this.parameters = parameters;\n    this.oneHandler = oneHandler;\n    this.noneHandler = noneHandler;\n    this.manyHandler = manyHandler;\n    this.elseHandler = elseHandler;\n    this.firstHandler = firstHandler;\n    this.errorHandler = errorHandler;\n    this.successHandler = successHandler;\n  }\n\n  getConnection() {\n    return this.connection;\n  }\n\n  getSQL() {\n    return this.sql;\n  }\n\n  isQuery() {\n    return this.query;\n  }\n\n  getParameters() {\n    return this.parameters;\n  }\n\n  getOneHandler() {\n    return this.oneHandler;\n  }\n\n  getNoneHandler() {\n    return this.noneHandler;\n  }\n\n  getManyHandler() {\n    return this.manyHandler;\n  }\n\n  getElseHandler() {\n    return this.elseHandler;\n  }\n\n  getFirstHandler() {\n    return this.firstHandler;\n  }\n\n  getErrorHandler() {\n    return this.errorHandler;\n  }\n\n  getSuccessHandler() {\n    return this.successHandler;\n  }\n\n  setSQL(sql) {\n    this.sql = sql;\n  }\n\n  setQuery(query) {\n    this.query = query;\n  }\n\n  setParameters(parameters) {\n    this.parameters = parameters;\n  }\n\n  one(oneHandler) {\n    this.oneHandler = oneHandler;\n\n    return this;\n  }\n\n  none(noneHandler) {\n    this.noneHandler = noneHandler;\n\n    return this;\n  }\n\n  many(manyHandler) {\n    this.manyHandler = manyHandler;\n\n    return this;\n  }\n\n  else(elseHandler) {\n    this.elseHandler = elseHandler;\n\n    return this;\n  }\n\n  first(firstHandler) {\n    this.firstHandler = firstHandler;\n\n    return this;\n  }\n\n  catch(errorHandler) {\n    this.errorHandler = errorHandler;\n\n    return this;\n  }\n\n  success(successHandler) {\n    this.successHandler = successHandler;\n\n    return this;\n  }\n\n  set(objectOrArray, ...parameters) {\n    let assignments;\n\n    const objectOrArrayIsArray = Array.isArray(objectOrArray);\n\n    if (objectOrArrayIsArray) {\n      const array = objectOrArray,  ///\n            strings = array;  ///\n\n      assignments = this.assignmentsFromStringsAndParameters(strings, parameters);\n    } else {\n      const object = objectOrArray;  ///\n\n      assignments = this.assignmentsFromObject(object); ///\n    }\n\n    this.sql = ` ${this.sql} SET ${assignments}`;\n\n    return this;\n  }\n\n  where(objectOrArray, ...parameters) {\n    let clause;\n\n    const objectOrArrayIsArray = Array.isArray(objectOrArray);\n\n    if (objectOrArrayIsArray) {\n      const array = objectOrArray,  ///\n            strings = array;  ///\n\n      clause = this.clauseFromStringsAndParameters(strings, parameters);\n    } else {\n      const object = objectOrArray;  ///\n\n      clause = this.clauseFromObject(object); ///\n    }\n\n    this.sql = ` ${this.sql} WHERE ${clause}`;\n\n    return this;\n  }\n\n  values(objectOrArray, ...parameters) {\n    const objectOrArrayIsArray = Array.isArray(objectOrArray);\n\n    let columnsAndValues;\n\n    if (objectOrArrayIsArray) {\n      const array = objectOrArray,  ///\n            strings = array;  ///\n\n      columnsAndValues = this.columnsAndValuesFromStringsAndParameters(strings, parameters);\n    } else {\n      const object = objectOrArray;  ///\n\n      columnsAndValues = this.columnsAndValuesFromObject(object);\n    }\n\n    this.sql = `${this.sql} ${columnsAndValues}`;\n\n    return this;\n  }\n\n  objectFromRow(row) {\n    const values = Object.values(row),\n          columns = Object.keys(row), ///\n          object = columns.reduce((object, column, index) => {\n            const key = this.keyFromColumn(column),\n                  value = values[index];\n\n            object[key] = value;\n\n            return object;\n          }, {});\n\n    return object;\n  }\n\n  clauseFromObject(object) {\n    const keys = Object.keys(object),\n          columns = keys.map((key) => this.columnFromKey(key)),\n          parameters = Object.values(object), ///\n          firstIndex = 0,\n          clause = columns.reduce((clause, column, index) => {\n            const placeholder = this.placeholder();\n\n            clause = (index === firstIndex) ?\n                `${column}=${placeholder}` :\n                ` ${clause} AND ${column}=${placeholder}`;\n\n            return clause;\n          }, EMPTY_STRING);\n\n    this.parameters = [\n      ...this.parameters,\n      ...parameters\n    ];\n\n    return clause;\n  }\n\n  assignmentsFromObject(object) {\n    const keys = Object.keys(object),\n          columns = keys.map((key) => this.columnFromKey(key)),\n          parameters = Object.values(object), ///\n          firstIndex = 0,\n          assignments = columns.reduce((assignments, column, index) => {\n            const placeholder = this.placeholder();\n\n            assignments = (index === firstIndex) ?\n                `${column}=${placeholder}` :\n                ` ${assignments}, ${column}=${placeholder}`;\n\n            return assignments;\n          }, EMPTY_STRING);\n\n    this.parameters = [\n      ...this.parameters,\n      ...parameters\n    ];\n\n    return assignments;\n  }\n\n  columnsAndValuesFromObject(object) {\n    const keys = Object.keys(object),\n          columns = keys.map((key) => this.columnFromKey(key)),\n          parameters = Object.values(object), ///\n          firstIndex = 0,\n          values = columns.reduce((values, column, index) => {\n            const placeholder = this.placeholder();\n\n            values = (index === firstIndex) ?\n                        `${placeholder}` :\n                        ` ${values}, ${placeholder}`;\n\n            return values;\n          }, EMPTY_STRING),\n          columnsAndValues = `(${columns}) VALUES (${values})`;\n\n    this.parameters = [\n      ...this.parameters,\n      ...parameters\n    ];\n\n    return columnsAndValues;\n  }\n\n  clauseFromStringsAndParameters(strings, parameters) {\n    const stringsLength = strings.length,\n          lastIndex = stringsLength - 1,\n          clause = strings.reduce((clause, string, index) => {\n            if (index < lastIndex) {\n              const placeholder = this.placeholder();\n\n              clause = `${clause}${string}${placeholder}`\n            } else {\n              clause = `${clause}${string}`;\n            }\n\n            return clause;\n          }, EMPTY_STRING);\n\n    this.parameters = [\n      ...this.parameters,\n      ...parameters\n    ];\n\n    return clause;\n  }\n\n  assignmentsFromStringsAndParameters(strings, parameters) {\n    const stringsLength = strings.length,\n          lastIndex = stringsLength - 1,\n          assignments = strings.reduce((assignments, string, index) => {\n            if (index < lastIndex) {\n              const placeholder = this.placeholder();\n\n              assignments = `${assignments}${string}${placeholder}`\n            } else {\n              assignments = `${assignments}${string}`;\n            }\n\n            return assignments;\n          }, EMPTY_STRING);\n\n    this.parameters = [\n      ...this.parameters,\n      ...parameters\n    ];\n\n    return assignments;\n  }\n\n  columnsAndValuesFromStringsAndParameters(strings, parameters) {\n    const stringsLength = strings.length,\n          lastIndex = stringsLength - 1,\n          columnsAndValues = strings.reduce((columnsAndValues, string, index) => {\n            if (index < lastIndex) {\n              const placeholder = this.placeholder();\n\n              columnsAndValues = `${columnsAndValues}${string}${placeholder}`\n            } else {\n              columnsAndValues = `${columnsAndValues}${string}`;\n            }\n\n            return columnsAndValues;\n          }, EMPTY_STRING);\n\n    this.parameters = [\n      ...this.parameters,\n      ...parameters\n    ];\n\n    return columnsAndValues;\n  }\n\n  execute() {\n    this.query ?\n      query(this.connection, this.sql, ...this.parameters, this.queryHandler) :\n        command(this.connection, this.sql, ...this.parameters, this.commandHandler);\n  }\n\n  queryHandler = (error, rows) => {\n    if (error) {\n      this.errorHandler(error);\n\n      return;\n    }\n\n    const rowsLength = rows.length;\n\n    if (false) {\n      ///\n    } else if (this.noneHandler !== null) {\n      if (rowsLength === 0) {\n        this.noneHandler();\n\n        return;\n      }\n    } else if (this.firstHandler !== null) {\n      if (rowsLength > 0) {\n        const firstRow = first(rows),\n              row = firstRow, ///\n              object = this.objectFromRow(row);\n\n        this.firstHandler(object);\n\n        return;\n      }\n    } else if (this.oneHandler !== null) {\n      if (rowsLength === 1) {\n        const firstRow = first(rows),\n              row = firstRow, ///\n              object = this.objectFromRow(row);\n\n        this.oneHandler(object);\n\n        return;\n      }\n    } else if (this.manyHandler !== null) {\n      const objects = rows.map((row) => this.objectFromRow(row));\n\n      this.manyHandler(objects);\n\n      return;\n    }\n\n    this.elseHandler(rows);\n  }\n\n  commandHandler = (error) => {\n    if (error) {\n      this.errorHandler(error);\n\n      return;\n    }\n\n    this.successHandler();\n  }\n\n  static fromConnection(Class, connection) {\n    const sql = null,\n          query = false,\n          parameters = [],\n          oneHandler = null,\n          noneHandler = null,\n          manyHandler = null,\n          elseHandler = null,\n          firstHandler = null,\n          errorHandler = null,\n          successHandler = null,\n          statement = new Class(connection, sql, query, parameters, oneHandler, noneHandler, manyHandler, elseHandler, firstHandler, errorHandler, successHandler);\n\n    return statement;\n  }\n}\n"],"names":["Statement","first","arrayUtilities","query","database","execute","command","connection","sql","parameters","oneHandler","noneHandler","manyHandler","elseHandler","firstHandler","errorHandler","successHandler","queryHandler","error","rows","rowsLength","length","firstRow","row","object","objectFromRow","objects","map","commandHandler","getConnection","getSQL","isQuery","getParameters","getOneHandler","getNoneHandler","getManyHandler","getElseHandler","getFirstHandler","getErrorHandler","getSuccessHandler","setSQL","setQuery","setParameters","one","none","many","else","catch","success","set","objectOrArray","assignments","objectOrArrayIsArray","Array","isArray","array","strings","assignmentsFromStringsAndParameters","assignmentsFromObject","where","clause","clauseFromStringsAndParameters","clauseFromObject","values","columnsAndValues","columnsAndValuesFromStringsAndParameters","columnsAndValuesFromObject","Object","columns","keys","reduce","column","index","key","keyFromColumn","value","columnFromKey","firstIndex","placeholder","EMPTY_STRING","stringsLength","lastIndex","string","fromConnection","Class","statement"],"mappings":"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"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: Object.getOwnPropertyDescriptor(all, name).get
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
get createTable () {
|
|
13
|
+
return createTable;
|
|
14
|
+
},
|
|
15
|
+
get insertVersion () {
|
|
16
|
+
return insertVersion;
|
|
17
|
+
},
|
|
18
|
+
get selectMaximumVersion () {
|
|
19
|
+
return selectMaximumVersion;
|
|
20
|
+
},
|
|
21
|
+
get showLikeTables () {
|
|
22
|
+
return showLikeTables;
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
var _database = require("../database");
|
|
26
|
+
function createTable(connection, sql, callback) {
|
|
27
|
+
(0, _database.execute)(connection, sql, function(error) {
|
|
28
|
+
if (error) {
|
|
29
|
+
var log = connection.getLog();
|
|
30
|
+
log.error("createTable() failed.");
|
|
31
|
+
}
|
|
32
|
+
callback(error);
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
function insertVersion(connection, version, sql, callback) {
|
|
36
|
+
(0, _database.execute)(connection, sql, version, function(error) {
|
|
37
|
+
if (error) {
|
|
38
|
+
var log = connection.getLog();
|
|
39
|
+
log.error("insertVersion() failed.");
|
|
40
|
+
}
|
|
41
|
+
callback(error);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
function showLikeTables(connection, sql, callback) {
|
|
45
|
+
(0, _database.query)(connection, sql, function(error, rows) {
|
|
46
|
+
if (error) {
|
|
47
|
+
var log = connection.getLog();
|
|
48
|
+
log.error("showLikeTables() failed.");
|
|
49
|
+
}
|
|
50
|
+
callback(error, rows);
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
function selectMaximumVersion(connection, sql, callback) {
|
|
54
|
+
(0, _database.query)(connection, sql, function(error, rows) {
|
|
55
|
+
if (error) {
|
|
56
|
+
var log = connection.getLog();
|
|
57
|
+
log.error("selectMaximumVersion() failed.");
|
|
58
|
+
}
|
|
59
|
+
callback(error, rows);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90YWJsZS9taWdyYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB7IHF1ZXJ5LCBleGVjdXRlIH0gZnJvbSBcIi4uL2RhdGFiYXNlXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVUYWJsZShjb25uZWN0aW9uLCBzcWwsIGNhbGxiYWNrKSB7XG4gIGV4ZWN1dGUoY29ubmVjdGlvbiwgc3FsLCAoZXJyb3IpID0+IHtcbiAgICBpZiAoZXJyb3IpIHtcbiAgICAgIGNvbnN0IGxvZyA9IGNvbm5lY3Rpb24uZ2V0TG9nKCk7XG5cbiAgICAgIGxvZy5lcnJvcihcImNyZWF0ZVRhYmxlKCkgZmFpbGVkLlwiKTtcbiAgICB9XG4gICAgXG4gICAgY2FsbGJhY2soZXJyb3IpO1xuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluc2VydFZlcnNpb24oY29ubmVjdGlvbiwgdmVyc2lvbiwgc3FsLCBjYWxsYmFjaykge1xuICBleGVjdXRlKGNvbm5lY3Rpb24sIHNxbCwgdmVyc2lvbiwgKGVycm9yKSA9PiB7XG4gICAgaWYgKGVycm9yKSB7XG4gICAgICBjb25zdCBsb2cgPSBjb25uZWN0aW9uLmdldExvZygpO1xuXG4gICAgICBsb2cuZXJyb3IoXCJpbnNlcnRWZXJzaW9uKCkgZmFpbGVkLlwiKTtcbiAgICB9XG5cbiAgICBjYWxsYmFjayhlcnJvcik7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2hvd0xpa2VUYWJsZXMoY29ubmVjdGlvbiwgc3FsLCBjYWxsYmFjaykge1xuICBxdWVyeShjb25uZWN0aW9uLCBzcWwsIChlcnJvciwgcm93cykgPT4ge1xuICAgIGlmIChlcnJvcikge1xuICAgICAgY29uc3QgbG9nID0gY29ubmVjdGlvbi5nZXRMb2coKTtcblxuICAgICAgbG9nLmVycm9yKFwic2hvd0xpa2VUYWJsZXMoKSBmYWlsZWQuXCIpO1xuICAgIH1cbiAgICBcbiAgICBjYWxsYmFjayhlcnJvciwgcm93cyk7XG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2VsZWN0TWF4aW11bVZlcnNpb24oY29ubmVjdGlvbiwgc3FsLCBjYWxsYmFjaykge1xuICBxdWVyeShjb25uZWN0aW9uLCBzcWwsIChlcnJvciwgcm93cykgPT4ge1xuICAgIGlmIChlcnJvcikge1xuICAgICAgY29uc3QgbG9nID0gY29ubmVjdGlvbi5nZXRMb2coKTtcblxuICAgICAgbG9nLmVycm9yKFwic2VsZWN0TWF4aW11bVZlcnNpb24oKSBmYWlsZWQuXCIpO1xuICAgIH1cblxuICAgIGNhbGxiYWNrKGVycm9yLCByb3dzKTtcbiAgfSk7XG59XG4iXSwibmFtZXMiOlsiY3JlYXRlVGFibGUiLCJpbnNlcnRWZXJzaW9uIiwic2VsZWN0TWF4aW11bVZlcnNpb24iLCJzaG93TGlrZVRhYmxlcyIsImNvbm5lY3Rpb24iLCJzcWwiLCJjYWxsYmFjayIsImV4ZWN1dGUiLCJlcnJvciIsImxvZyIsImdldExvZyIsInZlcnNpb24iLCJxdWVyeSIsInJvd3MiXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7OztRQUlnQkE7ZUFBQUE7O1FBWUFDO2VBQUFBOztRQXdCQUM7ZUFBQUE7O1FBWkFDO2VBQUFBOzs7d0JBMUJlO0FBRXhCLFNBQVNILFlBQVlJLFVBQVUsRUFBRUMsR0FBRyxFQUFFQyxRQUFRO0lBQ25EQyxJQUFBQSxpQkFBTyxFQUFDSCxZQUFZQyxLQUFLLFNBQUNHO1FBQ3hCLElBQUlBLE9BQU87WUFDVCxJQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRTtJQUNYO0FBQ0Y7QUFFTyxTQUFTUCxjQUFjRyxVQUFVLEVBQUVPLE9BQU8sRUFBRU4sR0FBRyxFQUFFQyxRQUFRO0lBQzlEQyxJQUFBQSxpQkFBTyxFQUFDSCxZQUFZQyxLQUFLTSxTQUFTLFNBQUNIO1FBQ2pDLElBQUlBLE9BQU87WUFDVCxJQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRTtJQUNYO0FBQ0Y7QUFFTyxTQUFTTCxlQUFlQyxVQUFVLEVBQUVDLEdBQUcsRUFBRUMsUUFBUTtJQUN0RE0sSUFBQUEsZUFBSyxFQUFDUixZQUFZQyxLQUFLLFNBQUNHLE9BQU9LO1FBQzdCLElBQUlMLE9BQU87WUFDVCxJQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRSxPQUFPSztJQUNsQjtBQUNGO0FBRU8sU0FBU1gscUJBQXFCRSxVQUFVLEVBQUVDLEdBQUcsRUFBRUMsUUFBUTtJQUM1RE0sSUFBQUEsZUFBSyxFQUFDUixZQUFZQyxLQUFLLFNBQUNHLE9BQU9LO1FBQzdCLElBQUlMLE9BQU87WUFDVCxJQUFNQyxNQUFNTCxXQUFXTSxNQUFNO1lBRTdCRCxJQUFJRCxLQUFLLENBQUM7UUFDWjtRQUVBRixTQUFTRSxPQUFPSztJQUNsQjtBQUNGIn0=
|