@nlabs/reaktor 0.3.0 → 0.4.0

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.
Files changed (56) hide show
  1. package/lib/config.js +153 -0
  2. package/lib/data/conversations.js +311 -0
  3. package/lib/data/dynamodb.js +206 -0
  4. package/lib/data/email.js +222 -0
  5. package/lib/data/files.js +525 -0
  6. package/lib/data/groups.js +435 -0
  7. package/lib/data/images.d.ts +3 -2
  8. package/lib/data/images.js +1051 -0
  9. package/lib/data/index.js +266 -0
  10. package/lib/data/ios.js +355 -0
  11. package/lib/data/locations.js +172 -0
  12. package/lib/data/messages.js +299 -0
  13. package/lib/data/notifications.d.ts +2 -2
  14. package/lib/data/notifications.js +59 -0
  15. package/lib/data/payments.js +771 -0
  16. package/lib/data/posts.d.ts +1 -1
  17. package/lib/data/posts.js +766 -0
  18. package/lib/data/reactions.js +529 -0
  19. package/lib/data/s3.js +155 -0
  20. package/lib/data/search.js +155 -0
  21. package/lib/data/sms.js +83 -0
  22. package/lib/data/subscription.js +337 -0
  23. package/lib/data/tags.js +397 -0
  24. package/lib/data/users.d.ts +7 -4
  25. package/lib/data/users.js +470 -0
  26. package/lib/data/websockets.js +250 -0
  27. package/lib/index.js +45 -0
  28. package/lib/types/apps.js +2 -0
  29. package/lib/types/arangodb.js +2 -0
  30. package/lib/types/auth.js +2 -0
  31. package/lib/types/conversations.d.ts +2 -0
  32. package/lib/types/conversations.js +2 -0
  33. package/lib/types/email.js +2 -0
  34. package/lib/types/files.js +2 -0
  35. package/lib/types/google.js +2 -0
  36. package/lib/types/groups.js +2 -0
  37. package/lib/types/images.js +2 -0
  38. package/lib/types/index.js +227 -0
  39. package/lib/types/locations.js +2 -0
  40. package/lib/types/messages.js +2 -0
  41. package/lib/types/notifications.js +2 -0
  42. package/lib/types/payments.js +2 -0
  43. package/lib/types/posts.js +2 -0
  44. package/lib/types/reactions.d.ts +2 -0
  45. package/lib/types/reactions.js +2 -0
  46. package/lib/types/tags.js +2 -0
  47. package/lib/types/users.d.ts +1 -0
  48. package/lib/types/users.js +2 -0
  49. package/lib/utils/analytics.js +83 -0
  50. package/lib/utils/arangodb.js +143 -0
  51. package/lib/utils/auth.js +75 -0
  52. package/lib/utils/graphql.js +21 -0
  53. package/lib/utils/index.js +84 -0
  54. package/lib/utils/objects.js +62 -0
  55. package/lib/utils/redis.js +36 -0
  56. package/package.json +30 -30
@@ -0,0 +1,529 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.symbol");
4
+
5
+ require("core-js/modules/es.array.concat");
6
+
7
+ require("core-js/modules/es.array.filter");
8
+
9
+ require("core-js/modules/es.array.for-each");
10
+
11
+ require("core-js/modules/es.array.join");
12
+
13
+ require("core-js/modules/es.array.map");
14
+
15
+ require("core-js/modules/es.array.slice");
16
+
17
+ require("core-js/modules/es.date.now");
18
+
19
+ require("core-js/modules/es.date.to-string");
20
+
21
+ require("core-js/modules/es.function.name");
22
+
23
+ require("core-js/modules/es.object.define-properties");
24
+
25
+ require("core-js/modules/es.object.define-property");
26
+
27
+ require("core-js/modules/es.object.freeze");
28
+
29
+ require("core-js/modules/es.object.get-own-property-descriptor");
30
+
31
+ require("core-js/modules/es.object.get-own-property-descriptors");
32
+
33
+ require("core-js/modules/es.object.keys");
34
+
35
+ require("core-js/modules/web.dom-collections.for-each");
36
+
37
+ Object.defineProperty(exports, "__esModule", {
38
+ value: true
39
+ });
40
+ exports.hasReaction = exports.getItemsByReaction = exports.getReactionsByItem = exports.getGroupUsersByReaction = exports.getReactionCountByUser = exports.getReactionCount = exports.updateReaction = exports.removeReactionByItem = exports.removeReaction = exports.addReaction = exports.parseReactionOptions = void 0;
41
+
42
+ var _utils = require("@nlabs/utils");
43
+
44
+ var _arangojs = require("arangojs");
45
+
46
+ var _utils2 = require("../utils");
47
+
48
+ function _templateObject6() {
49
+ var data = _taggedTemplateLiteral(["FOR i, r IN INBOUND ", " hasReactions\n FILTER r.name == ", " && r._from == ", "\n COLLECT reactionValue = r.value INTO reactionItems\n RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})"]);
50
+
51
+ _templateObject6 = function _templateObject6() {
52
+ return data;
53
+ };
54
+
55
+ return data;
56
+ }
57
+
58
+ function _templateObject5() {
59
+ var data = _taggedTemplateLiteral(["FOR i, r IN INBOUND ", " hasReactions\n FILTER r.name == ", " && r.type == ", "\n COLLECT WITH COUNT INTO count\n RETURN count"]);
60
+
61
+ _templateObject5 = function _templateObject5() {
62
+ return data;
63
+ };
64
+
65
+ return data;
66
+ }
67
+
68
+ function _templateObject4() {
69
+ var data = _taggedTemplateLiteral(["UPSERT ", "\n INSERT ", "\n UPDATE ", "\n LIMIT 1\n RETURN NEW"]);
70
+
71
+ _templateObject4 = function _templateObject4() {
72
+ return data;
73
+ };
74
+
75
+ return data;
76
+ }
77
+
78
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
79
+
80
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
81
+
82
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
83
+
84
+ function _templateObject3() {
85
+ var data = _taggedTemplateLiteral(["FOR r IN hasReactions\n FILTER r._from == ", "\n && r._to == ", "\n && r.type == ", "\n && r.name == ", "\n LIMIT 1\n REMOVE r IN hasReactions\n RETURN OLD"]);
86
+
87
+ _templateObject3 = function _templateObject3() {
88
+ return data;
89
+ };
90
+
91
+ return data;
92
+ }
93
+
94
+ function _templateObject2() {
95
+ var data = _taggedTemplateLiteral(["LET r = DOCUMENT(", ")\n FILTER r._from == ", "\n LIMIT 1\n REMOVE r IN hasReactions\n RETURN OLD"]);
96
+
97
+ _templateObject2 = function _templateObject2() {
98
+ return data;
99
+ };
100
+
101
+ return data;
102
+ }
103
+
104
+ function _templateObject() {
105
+ var data = _taggedTemplateLiteral(["FOR r IN hasReactions\n FILTER r._from == ", " && r._to == ", " && r.name == ", "\n LIMIT 1\n RETURN r"]);
106
+
107
+ _templateObject = function _templateObject() {
108
+ return data;
109
+ };
110
+
111
+ return data;
112
+ }
113
+
114
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
115
+
116
+ var eventCategory = 'reactions';
117
+
118
+ var parseReactionOptions = function parseReactionOptions() {
119
+ var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
120
+ var _options$from = options.from,
121
+ from = _options$from === void 0 ? 0 : _options$from,
122
+ _options$to = options.to,
123
+ to = _options$to === void 0 ? 30 : _options$to;
124
+ return {
125
+ limit: (0, _utils2.getLimit)(from, to)
126
+ };
127
+ };
128
+
129
+ exports.parseReactionOptions = parseReactionOptions;
130
+
131
+ var addReaction = function addReaction(context, itemId) {
132
+ var itemType = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'users';
133
+ var reaction = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
134
+ var allowDuplicate = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;
135
+ var action = 'addReaction';
136
+ var database = context.database,
137
+ sessionId = context.userId;
138
+
139
+ if (!sessionId) {
140
+ return (0, _utils2.logException)({
141
+ action: action,
142
+ category: eventCategory,
143
+ label: 'unauthorized',
144
+ value: 'invalid_session'
145
+ }, context).then(function () {
146
+ return null;
147
+ });
148
+ }
149
+
150
+ var _reaction$name = reaction.name,
151
+ itemName = _reaction$name === void 0 ? 'like' : _reaction$name,
152
+ itemValue = reaction.value;
153
+ var formatItemId = (0, _utils.parseId)(itemId);
154
+ var formatItemType = (0, _utils.parseChar)(itemType, 32);
155
+ var formatReactionName = (0, _utils.parseChar)(itemName, 32);
156
+ var formatValue = (0, _utils.parseString)(itemValue, 32);
157
+ var edgeCollection = (0, _utils2.useDb)(database).collection('hasReactions');
158
+ var typeDocId = "".concat(formatItemType, "/").concat(formatItemId);
159
+ var sessionDocId = "users/".concat(sessionId);
160
+ var edgeId = (0, _utils.createHash)("reaction-".concat(formatItemId, "-").concat(sessionId));
161
+ var edge = {
162
+ _from: sessionDocId,
163
+ _key: edgeId,
164
+ _to: typeDocId,
165
+ added: Date.now(),
166
+ name: formatReactionName,
167
+ type: formatItemType,
168
+ value: itemValue !== undefined ? formatValue : undefined
169
+ }; // Check for duplicates if not allowed
170
+
171
+ if (!allowDuplicate) {
172
+ // Query
173
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionDocId, typeDocId, formatReactionName);
174
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
175
+ return cursor.next();
176
+ }).then(function (reaction) {
177
+ if (!!reaction) {
178
+ return reaction;
179
+ }
180
+
181
+ return edgeCollection.save(edge, {
182
+ returnNew: true
183
+ }).then(function () {
184
+ console.log('addReaction::edge', edge);
185
+ return edge;
186
+ });
187
+ })["catch"](function (error) {
188
+ console.log('addReaction::error', error);
189
+ return (0, _utils2.logError)({
190
+ action: action,
191
+ category: eventCategory,
192
+ label: 'db_error'
193
+ }, error, context).then(function () {
194
+ return null;
195
+ });
196
+ });
197
+ }
198
+
199
+ return edgeCollection.save(edge, {
200
+ returnNew: true
201
+ }).then(function () {
202
+ return edge;
203
+ });
204
+ };
205
+
206
+ exports.addReaction = addReaction;
207
+
208
+ var removeReaction = function removeReaction(context, reactionId) {
209
+ var action = 'removeReaction';
210
+ var database = context.database,
211
+ sessionId = context.userId;
212
+
213
+ if (!sessionId) {
214
+ return (0, _utils2.logException)({
215
+ action: action,
216
+ category: eventCategory,
217
+ label: 'unauthorized',
218
+ value: 'invalid_session'
219
+ }, context).then(function () {
220
+ return null;
221
+ });
222
+ }
223
+
224
+ var formatSessionId = "users/".concat((0, _utils.parseId)(sessionId));
225
+ var formatReactionId = "hasReactions/".concat((0, _utils.parseId)(reactionId)); // Query
226
+
227
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatReactionId, formatSessionId);
228
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
229
+ return cursor.next();
230
+ })["catch"](function (error) {
231
+ return (0, _utils2.logError)({
232
+ action: action,
233
+ category: eventCategory,
234
+ label: 'db_error'
235
+ }, error, context).then(function () {
236
+ return null;
237
+ });
238
+ });
239
+ };
240
+
241
+ exports.removeReaction = removeReaction;
242
+
243
+ var removeReactionByItem = function removeReactionByItem(context, itemId, itemType, reactionName) {
244
+ var action = 'removeReaction';
245
+ var database = context.database,
246
+ sessionId = context.userId;
247
+
248
+ if (!sessionId) {
249
+ return (0, _utils2.logException)({
250
+ action: action,
251
+ category: eventCategory,
252
+ label: 'unauthorized',
253
+ value: 'invalid_session'
254
+ }, context).then(function () {
255
+ return null;
256
+ });
257
+ }
258
+
259
+ var formatSessionId = "users/".concat((0, _utils.parseId)(sessionId));
260
+ var formatItemType = (0, _utils.parseChar)(itemType, 32);
261
+ var formatItemDocId = "".concat(formatItemType, "/").concat((0, _utils.parseId)(itemId));
262
+ var formatReactionName = (0, _utils.parseChar)(reactionName, 32); // Query
263
+
264
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatSessionId, formatItemDocId, formatItemType, formatReactionName);
265
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
266
+ return cursor.next();
267
+ })["catch"](function (error) {
268
+ return (0, _utils2.logError)({
269
+ action: action,
270
+ category: eventCategory,
271
+ label: 'db_error'
272
+ }, error, context).then(function () {
273
+ return null;
274
+ });
275
+ });
276
+ };
277
+
278
+ exports.removeReactionByItem = removeReactionByItem;
279
+
280
+ var updateReaction = function updateReaction(context) {
281
+ var reaction = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
282
+ var action = 'updateReaction';
283
+ var database = context.database,
284
+ sessionId = context.userId;
285
+
286
+ if (!sessionId) {
287
+ return (0, _utils2.logException)({
288
+ action: action,
289
+ category: eventCategory,
290
+ label: 'unauthorized',
291
+ value: 'invalid_session'
292
+ }, context).then(function () {
293
+ return null;
294
+ });
295
+ }
296
+
297
+ var itemId = reaction.id,
298
+ itemName = reaction.name,
299
+ itemType = reaction.type,
300
+ itemValue = reaction.value;
301
+ var formatId = (0, _utils.parseId)(itemId);
302
+ var formatName = (0, _utils.parseChar)(itemName, 32);
303
+ var formatType = (0, _utils.parseChar)(itemType, 32);
304
+ var formatValue = (0, _utils.parseString)(itemValue, 32);
305
+ var edgeId = (0, _utils.createHash)("reaction-".concat(formatId, "-").concat(sessionId));
306
+ var update = {
307
+ name: formatName,
308
+ type: formatType,
309
+ value: formatValue
310
+ };
311
+
312
+ var insert = _objectSpread(_objectSpread({}, update), {}, {
313
+ _key: edgeId,
314
+ added: Date.now()
315
+ }); // Query
316
+
317
+
318
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), {
319
+ _key: formatId
320
+ }, insert, update);
321
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
322
+ return cursor.next();
323
+ })["catch"](function (error) {
324
+ return (0, _utils2.logError)({
325
+ action: action,
326
+ category: eventCategory,
327
+ label: 'db_error'
328
+ }, error, context).then(function () {
329
+ return null;
330
+ });
331
+ });
332
+ };
333
+
334
+ exports.updateReaction = updateReaction;
335
+
336
+ var getReactionCount = function getReactionCount(context, itemId, itemType, reactionName) {
337
+ var action = 'getReactionCount';
338
+ var database = context.database;
339
+ var formatItemId = (0, _utils.parseId)(itemId);
340
+ var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
341
+ var formatItemType = (0, _utils.parseChar)(itemType, 32);
342
+ var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
343
+
344
+ var aqlQry = (0, _arangojs.aql)(_templateObject5(), itemDocId, formatReactionName, formatItemType);
345
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
346
+ return cursor.next();
347
+ })["catch"](function (error) {
348
+ return (0, _utils2.logError)({
349
+ action: action,
350
+ category: eventCategory,
351
+ label: 'db_error'
352
+ }, error, context).then(function () {
353
+ return undefined;
354
+ });
355
+ });
356
+ };
357
+
358
+ exports.getReactionCount = getReactionCount;
359
+
360
+ var getReactionCountByUser = function getReactionCountByUser(context, itemId, itemType, reactionName) {
361
+ var action = 'getReactionsByUser';
362
+ var database = context.database,
363
+ sessionId = context.userId;
364
+ var formatItemId = (0, _utils.parseId)(itemId);
365
+ var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
366
+ var formatItemType = (0, _utils.parseChar)(itemType, 32);
367
+ var sessionDocId = "users/".concat(sessionId);
368
+ var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
369
+
370
+ var aqlQry = (0, _arangojs.aql)(_templateObject6(), itemDocId, formatReactionName, sessionDocId);
371
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
372
+ return cursor.all();
373
+ })["catch"](function (error) {
374
+ return (0, _utils2.logError)({
375
+ action: action,
376
+ category: eventCategory,
377
+ label: 'db_error'
378
+ }, error, context).then(function () {
379
+ return [];
380
+ });
381
+ });
382
+ };
383
+
384
+ exports.getReactionCountByUser = getReactionCountByUser;
385
+
386
+ var getGroupUsersByReaction = function getGroupUsersByReaction(context) {
387
+ var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
388
+ var action = 'getUsersByReaction';
389
+ var database = context.database,
390
+ sessionId = context.userId;
391
+
392
+ if (!sessionId) {
393
+ return (0, _utils2.logException)({
394
+ action: action,
395
+ category: eventCategory,
396
+ label: 'unauthorized',
397
+ value: 'invalid_session'
398
+ }, context).then(function () {
399
+ return null;
400
+ });
401
+ }
402
+
403
+ var _params$filters = params.filters,
404
+ filters = _params$filters === void 0 ? [] : _params$filters,
405
+ groupId = params.id,
406
+ value = params.value;
407
+ var reaction = (0, _utils.parseChar)(value, 32);
408
+ var groupDocId = "groups/".concat((0, _utils.parseId)(groupId));
409
+ var filterStr = filters.map(function (filter) {
410
+ var conditional = filter.conditional,
411
+ name = filter.name,
412
+ queryValue = filter.value;
413
+ var filterCond = conditional;
414
+
415
+ if (conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {
416
+ filterCond = '==';
417
+ }
418
+
419
+ switch (name) {
420
+ case 'added':
421
+ return "r.added ".concat(filterCond, " ").concat((0, _utils.parseNum)(queryValue));
422
+
423
+ default:
424
+ return '';
425
+ }
426
+ }).concat(["r.value == \"".concat(reaction, "\""), 'u._id == r._from']).join(' && '); // Query
427
+
428
+ var aqlQry = "FOR g, r IN INBOUND \"".concat(groupDocId, "\" hasReactions\n FOR u IN users\n FILTER ").concat(filterStr, "\n RETURN u");
429
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
430
+ return cursor.all();
431
+ })["catch"](function (error) {
432
+ return (0, _utils2.logError)({
433
+ action: action,
434
+ category: eventCategory,
435
+ label: 'db_error'
436
+ }, error, context).then(function () {
437
+ return [];
438
+ });
439
+ });
440
+ };
441
+
442
+ exports.getGroupUsersByReaction = getGroupUsersByReaction;
443
+
444
+ var getReactionsByItem = function getReactionsByItem(context, itemId, itemType, reactionName, options) {
445
+ var action = 'getUsersByReactions';
446
+ var database = context.database;
447
+ var formatItemId = (0, _utils.parseId)(itemId);
448
+ var formatItemType = (0, _utils.parseChar)(itemType, 32);
449
+ var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
450
+ var itemDocId = "".concat(formatItemType, "/").concat(formatItemId);
451
+
452
+ var _parseReactionOptions = parseReactionOptions(options),
453
+ limit = _parseReactionOptions.limit;
454
+
455
+ var aqlQry = "FOR i, r IN INBOUND \"".concat(itemDocId, "\" hasReactions\n FILTER r.name == \"").concat(formatReactionName, "\"\n ").concat(limit.aql, "\n RETURN MERGE(i, {reaction: r}");
456
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
457
+ return cursor.all();
458
+ })["catch"](function (error) {
459
+ return (0, _utils2.logError)({
460
+ action: action,
461
+ category: eventCategory,
462
+ label: 'db_error'
463
+ }, error, context).then(function () {
464
+ return [];
465
+ });
466
+ });
467
+ };
468
+
469
+ exports.getReactionsByItem = getReactionsByItem;
470
+
471
+ var getItemsByReaction = function getItemsByReaction(context, itemId, itemType, reactionName, options) {
472
+ var action = 'getUserReactionsByReaction';
473
+ var database = context.database;
474
+ var formatItemId = (0, _utils.parseId)(itemId);
475
+ var formatItemType = (0, _utils.parseChar)(itemType, 32);
476
+ var formatReactionName = (0, _utils.parseChar)(reactionName, 32);
477
+ var itemDocId = "".concat(formatItemType, "/").concat(formatItemId);
478
+
479
+ var _parseReactionOptions2 = parseReactionOptions(options),
480
+ limit = _parseReactionOptions2.limit; // Query
481
+
482
+
483
+ var aqlQry = "FOR u, r IN OUTBOUND \"".concat(itemDocId, "\" hasReactions\n FILTER r.name == ").concat(formatReactionName, "\n ").concat(limit.aql, "\n RETURN MERGE(u, {reaction: r})");
484
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
485
+ return cursor.all();
486
+ })["catch"](function (error) {
487
+ return (0, _utils2.logError)({
488
+ action: action,
489
+ category: eventCategory,
490
+ label: 'db_error'
491
+ }, error, context).then(function () {
492
+ return [];
493
+ });
494
+ });
495
+ };
496
+
497
+ exports.getItemsByReaction = getItemsByReaction;
498
+
499
+ var hasReaction = function hasReaction(context, itemId, itemType, reactionName) {
500
+ var direction = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 'OUTBOUND';
501
+ var action = 'getReactionsByUser';
502
+ var database = context.database,
503
+ sessionId = context.userId;
504
+ var sessionDocId = "users/".concat(sessionId);
505
+ var formatItemId = (0, _utils.parseId)(itemId);
506
+ var formatItemType = (0, _utils.parseChar)(itemType, 32);
507
+ var formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';
508
+ var itemDirection = direction === 'OUTBOUND' ? 'r._to' : 'r._from';
509
+ var itemDocId = "".concat(formatItemType, "/").concat(formatItemId); // Query
510
+
511
+ var aqlQry = "FOR i, r IN ".concat(formatDirection, " \"").concat(sessionDocId, "\" hasReactions\n FILTER r.name == \"").concat(reactionName, "\" && ").concat(itemDirection, " == \"").concat(itemDocId, "\"\n RETURN MERGE(i, {reaction: r})");
512
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
513
+ return cursor.all();
514
+ }).then(function () {
515
+ var reactions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
516
+ return !!reactions.length;
517
+ })["catch"](function (error) {
518
+ return (0, _utils2.logError)({
519
+ action: action,
520
+ category: eventCategory,
521
+ label: 'db_error'
522
+ }, error, context).then(function () {
523
+ return false;
524
+ });
525
+ });
526
+ };
527
+
528
+ exports.hasReaction = hasReaction;
529
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL3JlYWN0aW9ucy50cyJdLCJuYW1lcyI6WyJldmVudENhdGVnb3J5IiwicGFyc2VSZWFjdGlvbk9wdGlvbnMiLCJvcHRpb25zIiwiZnJvbSIsInRvIiwibGltaXQiLCJhZGRSZWFjdGlvbiIsImNvbnRleHQiLCJpdGVtSWQiLCJpdGVtVHlwZSIsInJlYWN0aW9uIiwiYWxsb3dEdXBsaWNhdGUiLCJhY3Rpb24iLCJkYXRhYmFzZSIsInNlc3Npb25JZCIsInVzZXJJZCIsImNhdGVnb3J5IiwibGFiZWwiLCJ2YWx1ZSIsInRoZW4iLCJuYW1lIiwiaXRlbU5hbWUiLCJpdGVtVmFsdWUiLCJmb3JtYXRJdGVtSWQiLCJmb3JtYXRJdGVtVHlwZSIsImZvcm1hdFJlYWN0aW9uTmFtZSIsImZvcm1hdFZhbHVlIiwiZWRnZUNvbGxlY3Rpb24iLCJjb2xsZWN0aW9uIiwidHlwZURvY0lkIiwic2Vzc2lvbkRvY0lkIiwiZWRnZUlkIiwiZWRnZSIsIl9mcm9tIiwiX2tleSIsIl90byIsImFkZGVkIiwiRGF0ZSIsIm5vdyIsInR5cGUiLCJ1bmRlZmluZWQiLCJhcWxRcnkiLCJhcWwiLCJxdWVyeSIsImN1cnNvciIsIm5leHQiLCJzYXZlIiwicmV0dXJuTmV3IiwiY29uc29sZSIsImxvZyIsImVycm9yIiwicmVtb3ZlUmVhY3Rpb24iLCJyZWFjdGlvbklkIiwiZm9ybWF0U2Vzc2lvbklkIiwiZm9ybWF0UmVhY3Rpb25JZCIsInJlbW92ZVJlYWN0aW9uQnlJdGVtIiwicmVhY3Rpb25OYW1lIiwiZm9ybWF0SXRlbURvY0lkIiwidXBkYXRlUmVhY3Rpb24iLCJpZCIsImZvcm1hdElkIiwiZm9ybWF0TmFtZSIsImZvcm1hdFR5cGUiLCJ1cGRhdGUiLCJpbnNlcnQiLCJnZXRSZWFjdGlvbkNvdW50IiwiaXRlbURvY0lkIiwiZ2V0UmVhY3Rpb25Db3VudEJ5VXNlciIsImFsbCIsImdldEdyb3VwVXNlcnNCeVJlYWN0aW9uIiwicGFyYW1zIiwiZmlsdGVycyIsImdyb3VwSWQiLCJncm91cERvY0lkIiwiZmlsdGVyU3RyIiwibWFwIiwiZmlsdGVyIiwiY29uZGl0aW9uYWwiLCJxdWVyeVZhbHVlIiwiZmlsdGVyQ29uZCIsImNvbmNhdCIsImpvaW4iLCJnZXRSZWFjdGlvbnNCeUl0ZW0iLCJnZXRJdGVtc0J5UmVhY3Rpb24iLCJoYXNSZWFjdGlvbiIsImRpcmVjdGlvbiIsImZvcm1hdERpcmVjdGlvbiIsIml0ZW1EaXJlY3Rpb24iLCJyZWFjdGlvbnMiLCJsZW5ndGgiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBY0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQSxJQUFNQSxhQUFxQixHQUFHLFdBQTlCOztBQUVPLElBQU1DLG9CQUFvQixHQUFHLFNBQXZCQSxvQkFBdUIsR0FBbUM7QUFBQSxNQUFsQ0MsT0FBa0MsdUVBQVAsRUFBTztBQUFBLHNCQUlqRUEsT0FKaUUsQ0FFbkVDLElBRm1FO0FBQUEsTUFFbkVBLElBRm1FLDhCQUU1RCxDQUY0RDtBQUFBLG9CQUlqRUQsT0FKaUUsQ0FHbkVFLEVBSG1FO0FBQUEsTUFHbkVBLEVBSG1FLDRCQUc5RCxFQUg4RDtBQU1yRSxTQUFPO0FBQ0xDLElBQUFBLEtBQUssRUFBRSxzQkFBU0YsSUFBVCxFQUFlQyxFQUFmO0FBREYsR0FBUDtBQUdELENBVE07Ozs7QUFXQSxJQUFNRSxXQUFXLEdBQUcsU0FBZEEsV0FBYyxDQUN6QkMsT0FEeUIsRUFFekJDLE1BRnlCLEVBTUM7QUFBQSxNQUgxQkMsUUFHMEIsdUVBSFAsT0FHTztBQUFBLE1BRjFCQyxRQUUwQix1RUFGRCxFQUVDO0FBQUEsTUFEMUJDLGNBQzBCLHVFQURBLEtBQ0E7QUFDMUIsTUFBTUMsTUFBYyxHQUFHLGFBQXZCO0FBRDBCLE1BRW5CQyxRQUZtQixHQUVZTixPQUZaLENBRW5CTSxRQUZtQjtBQUFB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V0FHRSxVQUFDdkMsS0FBRDtBQUFBLFdBQWtCLHNCQUFTO0FBQ2hDdEMsTUFBQUEsTUFBTSxFQUFOQSxNQURnQztBQUVoQ0ksTUFBQUEsUUFBUSxFQUFFaEIsYUFGc0I7QUFHaENpQixNQUFBQSxLQUFLLEVBQUU7QUFIeUIsS0FBVCxFQUl0QmlDLEtBSnNCLEVBSWYzQyxPQUplLEVBSU5ZLElBSk0sQ0FJRDtBQUFBLGFBQU0sS0FBTjtBQUFBLEtBSkMsQ0FBbEI7QUFBQSxHQUhGLENBQVA7QUFRRCxDQTdCTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Y3JlYXRlSGFzaCwgcGFyc2VDaGFyLCBwYXJzZUlkLCBwYXJzZU51bSwgcGFyc2VTdHJpbmd9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQge2FxbH0gZnJvbSAnYXJhbmdvanMnO1xuaW1wb3J0IHtBcWxRdWVyeX0gZnJvbSAnYXJhbmdvanMvYXFsJztcbmltcG9ydCB7RWRnZUNvbGxlY3Rpb259IGZyb20gJ2FyYW5nb2pzL2NvbGxlY3Rpb24nO1xuaW1wb3J0IHtBcnJheUN1cnNvcn0gZnJvbSAnYXJhbmdvanMvY3Vyc29yJztcblxuaW1wb3J0IHtcbiAgQXBpQ29udGV4dCxcbiAgUXVlcnlGaWx0ZXIsXG4gIFJlYWN0aW9uRGlyZWN0aW9uLFxuICBSZWFjdGlvbk9wdGlvbnMsXG4gIFJlYWN0aW9uVHlwZSxcbiAgVXNlclJlYWN0aW9uUXVlcnksXG4gIFVzZXJUeXBlXG59IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7Z2V0TGltaXQsIGxvZ0Vycm9yLCBsb2dFeGNlcHRpb24sIHVzZURifSBmcm9tICcuLi91dGlscyc7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdyZWFjdGlvbnMnO1xuXG5leHBvcnQgY29uc3QgcGFyc2VSZWFjdGlvbk9wdGlvbnMgPSAob3B0aW9uczogUmVhY3Rpb25PcHRpb25zID0ge30pID0+IHtcbiAgY29uc3Qge1xuICAgIGZyb20gPSAwLFxuICAgIHRvID0gMzBcbiAgfSA9IG9wdGlvbnM7XG5cbiAgcmV0dXJuIHtcbiAgICBsaW1pdDogZ2V0TGltaXQoZnJvbSwgdG8pXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgYWRkUmVhY3Rpb24gPSAoXG4gIGNvbnRleHQ6IEFwaUNvbnRleHQsXG4gIGl0ZW1JZDogc3RyaW5nLFxuICBpdGVtVHlwZTogc3RyaW5nID0gJ3VzZXJzJyxcbiAgcmVhY3Rpb246IFJlYWN0aW9uVHlwZSA9IHt9LFxuICBhbGxvd0R1cGxpY2F0ZTogYm9vbGVhbiA9IGZhbHNlXG4pOiBQcm9taXNlPFJlYWN0aW9uVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdhZGRSZWFjdGlvbic7XG4gIGNvbnN0IHtkYXRhYmFzZSwgdXNlcklkOiBzZXNzaW9uSWR9ID0gY29udGV4dDtcblxuICBpZighc2Vzc2lvbklkKSB7XG4gICAgcmV0dXJuIGxvZ0V4Y2VwdGlvbih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAndW5hdXRob3JpemVkJyxcbiAgICAgIHZhbHVlOiAnaW52YWxpZF9zZXNzaW9uJ1xuICAgIH0sIGNvbnRleHQpLnRoZW4oKCkgPT4gbnVsbCk7XG4gIH1cblxuICBjb25zdCB7XG4gICAgbmFtZTogaXRlbU5hbWUgPSAnbGlrZScsXG4gICAgdmFsdWU6IGl0ZW1WYWx1ZVxuICB9ID0gcmVhY3Rpb247XG4gIGNvbnN0IGZvcm1hdEl0ZW1JZDogc3RyaW5nID0gcGFyc2VJZChpdGVtSWQpO1xuICBjb25zdCBmb3JtYXRJdGVtVHlwZTogYW55ID0gcGFyc2VDaGFyKGl0ZW1UeXBlLCAzMik7XG4gIGNvbnN0IGZvcm1hdFJlYWN0aW9uTmFtZTogc3RyaW5nID0gcGFyc2VDaGFyKGl0ZW1OYW1lLCAzMik7XG4gIGNvbnN0IGZvcm1hdFZhbHVlOiBzdHJpbmcgPSBwYXJzZVN0cmluZyhpdGVtVmFsdWUsIDMyKTtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb246IEVkZ2VDb2xsZWN0aW9uID0gdXNlRGIoZGF0YWJhc2UpLmNvbGxlY3Rpb24oJ2hhc1JlYWN0aW9ucycpO1xuICBjb25zdCB0eXBlRG9jSWQ6IHN0cmluZyA9IGAke2Zvcm1hdEl0ZW1UeXBlfS8ke2Zvcm1hdEl0ZW1JZH1gO1xuICBjb25zdCBzZXNzaW9uRG9jSWQ6IHN0cmluZyA9IGB1c2Vycy8ke3Nlc3Npb25JZH1gO1xuICBjb25zdCBlZGdlSWQ6IHN0cmluZyA9IGNyZWF0ZUhhc2goYHJlYWN0aW9uLSR7Zm9ybWF0SXRlbUlkfS0ke3Nlc3Npb25JZH1gKTtcbiAgY29uc3QgZWRnZTogUmVhY3Rpb25UeXBlID0ge1xuICAgIF9mcm9tOiBzZXNzaW9uRG9jSWQsXG4gICAgX2tleTogZWRnZUlkLFxuICAgIF90bzogdHlwZURvY0lkLFxuICAgIGFkZGVkOiBEYXRlLm5vdygpLFxuICAgIG5hbWU6IGZvcm1hdFJlYWN0aW9uTmFtZSxcbiAgICB0eXBlOiBmb3JtYXRJdGVtVHlwZSxcbiAgICB2YWx1ZTogaXRlbVZhbHVlICE9PSB1bmRlZmluZWQgPyBmb3JtYXRWYWx1ZSA6IHVuZGVmaW5lZFxuICB9O1xuXG4gIC8vIENoZWNrIGZvciBkdXBsaWNhdGVzIGlmIG5vdCBhbGxvd2VkXG4gIGlmKCFhbGxvd0R1cGxpY2F0ZSkge1xuICAgIC8vIFF1ZXJ5XG4gICAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBGT1IgciBJTiBoYXNSZWFjdGlvbnNcbiAgICAgIEZJTFRFUiByLl9mcm9tID09ICR7c2Vzc2lvbkRvY0lkfSAmJiByLl90byA9PSAke3R5cGVEb2NJZH0gJiYgci5uYW1lID09ICR7Zm9ybWF0UmVhY3Rpb25OYW1lfVxuICAgICAgTElNSVQgMVxuICAgICAgUkVUVVJOIHJgO1xuXG4gICAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAgIC50aGVuKChyZWFjdGlvbikgPT4ge1xuICAgICAgICBpZighIXJlYWN0aW9uKSB7XG4gICAgICAgICAgcmV0dXJuIHJlYWN0aW9uO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIGVkZ2VDb2xsZWN0aW9uLnNhdmUoZWRnZSwge3JldHVybk5ldzogdHJ1ZX0pLnRoZW4oKCkgPT4ge1xuICAgICAgICAgIGNvbnNvbGUubG9nKCdhZGRSZWFjdGlvbjo6ZWRnZScsIGVkZ2UpO1xuICAgICAgICAgIHJldHVybiBlZGdlO1xuICAgICAgICB9KTtcbiAgICAgIH0pXG4gICAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgICBjb25zb2xlLmxvZygnYWRkUmVhY3Rpb246OmVycm9yJywgZXJyb3IpO1xuICAgICAgICByZXR1cm4gbG9nRXJyb3Ioe1xuICAgICAgICAgIGFjdGlvbixcbiAgICAgICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgICAgICBsYWJlbDogJ2RiX2Vycm9yJ1xuICAgICAgICB9LCBlcnJvciwgY29udGV4dCkudGhlbigoKSA9PiBudWxsKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgcmV0dXJuIGVkZ2VDb2xsZWN0aW9uLnNhdmUoZWRnZSwge3JldHVybk5ldzogdHJ1ZX0pLnRoZW4oKCkgPT4gZWRnZSk7XG59O1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlUmVhY3Rpb24gPSAoY29udGV4dDogQXBpQ29udGV4dCwgcmVhY3Rpb25JZDogc3RyaW5nKTogUHJvbWlzZTxSZWFjdGlvblR5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAncmVtb3ZlUmVhY3Rpb24nO1xuICBjb25zdCB7ZGF0YWJhc2UsIHVzZXJJZDogc2Vzc2lvbklkfSA9IGNvbnRleHQ7XG5cbiAgaWYoIXNlc3Npb25JZCkge1xuICAgIHJldHVybiBsb2dFeGNlcHRpb24oe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ3VuYXV0aG9yaXplZCcsXG4gICAgICB2YWx1ZTogJ2ludmFsaWRfc2Vzc2lvbidcbiAgICB9LCBjb250ZXh0KS50aGVuKCgpID0+IG51bGwpO1xuICB9XG5cbiAgY29uc3QgZm9ybWF0U2Vzc2lvbklkOiBzdHJpbmcgPSBgdXNlcnMvJHtwYXJzZUlkKHNlc3Npb25JZCl9YDtcbiAgY29uc3QgZm9ybWF0UmVhY3Rpb25JZDogc3RyaW5nID0gYGhhc1JlYWN0aW9ucy8ke3BhcnNlSWQocmVhY3Rpb25JZCl9YDtcblxuICAvLyBRdWVyeVxuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYExFVCByID0gRE9DVU1FTlQoJHtmb3JtYXRSZWFjdGlvbklkfSlcbiAgICBGSUxURVIgci5fZnJvbSA9PSAke2Zvcm1hdFNlc3Npb25JZH1cbiAgICBMSU1JVCAxXG4gICAgUkVNT1ZFIHIgSU4gaGFzUmVhY3Rpb25zXG4gICAgUkVUVVJOIE9MRGA7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwgY29udGV4dCkudGhlbigoKSA9PiBudWxsKSk7XG59O1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlUmVhY3Rpb25CeUl0ZW0gPSAoXG4gIGNvbnRleHQ6IEFwaUNvbnRleHQsXG4gIGl0ZW1JZDogc3RyaW5nLFxuICBpdGVtVHlwZTogc3RyaW5nLFxuICByZWFjdGlvbk5hbWU6IHN0cmluZ1xuKTogUHJvbWlzZTxSZWFjdGlvblR5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAncmVtb3ZlUmVhY3Rpb24nO1xuICBjb25zdCB7ZGF0YWJhc2UsIHVzZXJJZDogc2Vzc2lvbklkfSA9IGNvbnRleHQ7XG5cbiAgaWYoIXNlc3Npb25JZCkge1xuICAgIHJldHVybiBsb2dFeGNlcHRpb24oe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ3VuYXV0aG9yaXplZCcsXG4gICAgICB2YWx1ZTogJ2ludmFsaWRfc2Vzc2lvbidcbiAgICB9LCBjb250ZXh0KS50aGVuKCgpID0+IG51bGwpO1xuICB9XG5cbiAgY29uc3QgZm9ybWF0U2Vzc2lvbklkOiBzdHJpbmcgPSBgdXNlcnMvJHtwYXJzZUlkKHNlc3Npb25JZCl9YDtcbiAgY29uc3QgZm9ybWF0SXRlbVR5cGU6IHN0cmluZyA9IHBhcnNlQ2hhcihpdGVtVHlwZSwgMzIpO1xuICBjb25zdCBmb3JtYXRJdGVtRG9jSWQ6IHN0cmluZyA9IGAke2Zvcm1hdEl0ZW1UeXBlfS8ke3BhcnNlSWQoaXRlbUlkKX1gO1xuICBjb25zdCBmb3JtYXRSZWFjdGlvbk5hbWU6IHN0cmluZyA9IHBhcnNlQ2hhcihyZWFjdGlvbk5hbWUsIDMyKTtcblxuICAvLyBRdWVyeVxuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiByIElOIGhhc1JlYWN0aW9uc1xuICAgIEZJTFRFUiByLl9mcm9tID09ICR7Zm9ybWF0U2Vzc2lvbklkfVxuICAgICAgJiYgci5fdG8gPT0gJHtmb3JtYXRJdGVtRG9jSWR9XG4gICAgICAmJiByLnR5cGUgPT0gJHtmb3JtYXRJdGVtVHlwZX1cbiAgICAgICYmIHIubmFtZSA9PSAke2Zvcm1hdFJlYWN0aW9uTmFtZX1cbiAgICBMSU1JVCAxXG4gICAgUkVNT1ZFIHIgSU4gaGFzUmVhY3Rpb25zXG4gICAgUkVUVVJOIE9MRGA7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwgY29udGV4dCkudGhlbigoKSA9PiBudWxsKSk7XG59O1xuXG5leHBvcnQgY29uc3QgdXBkYXRlUmVhY3Rpb24gPSAoY29udGV4dDogQXBpQ29udGV4dCwgcmVhY3Rpb246IFJlYWN0aW9uVHlwZSA9IHt9KTogUHJvbWlzZTxSZWFjdGlvblR5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAndXBkYXRlUmVhY3Rpb24nO1xuICBjb25zdCB7ZGF0YWJhc2UsIHVzZXJJZDogc2Vzc2lvbklkfSA9IGNvbnRleHQ7XG5cbiAgaWYoIXNlc3Npb25JZCkge1xuICAgIHJldHVybiBsb2dFeGNlcHRpb24oe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ3VuYXV0aG9yaXplZCcsXG4gICAgICB2YWx1ZTogJ2ludmFsaWRfc2Vzc2lvbidcbiAgICB9LCBjb250ZXh0KS50aGVuKCgpID0+IG51bGwpO1xuICB9XG5cbiAgY29uc3Qge1xuICAgIGlkOiBpdGVtSWQsXG4gICAgbmFtZTogaXRlbU5hbWUsXG4gICAgdHlwZTogaXRlbVR5cGUsXG4gICAgdmFsdWU6IGl0ZW1WYWx1ZVxuICB9ID0gcmVhY3Rpb247XG4gIGNvbnN0IGZvcm1hdElkOiBzdHJpbmcgPSBwYXJzZUlkKGl0ZW1JZCk7XG4gIGNvbnN0IGZvcm1hdE5hbWU6IHN0cmluZyA9IHBhcnNlQ2hhcihpdGVtTmFtZSwgMzIpO1xuICBjb25zdCBmb3JtYXRUeXBlOiBhbnkgPSBwYXJzZUNoYXIoaXRlbVR5cGUsIDMyKTtcbiAgY29uc3QgZm9ybWF0VmFsdWU6IHN0cmluZyA9IHBhcnNlU3RyaW5nKGl0ZW1WYWx1ZSwgMzIpO1xuICBjb25zdCBlZGdlSWQ6IHN0cmluZyA9IGNyZWF0ZUhhc2goYHJlYWN0aW9uLSR7Zm9ybWF0SWR9LSR7c2Vzc2lvbklkfWApO1xuICBjb25zdCB1cGRhdGU6IFJlYWN0aW9uVHlwZSA9IHtcbiAgICBuYW1lOiBmb3JtYXROYW1lLFxuICAgIHR5cGU6IGZvcm1hdFR5cGUsXG4gICAgdmFsdWU6IGZvcm1hdFZhbHVlXG4gIH07XG4gIGNvbnN0IGluc2VydDogUmVhY3Rpb25UeXBlID0ge1xuICAgIC4uLnVwZGF0ZSxcbiAgICBfa2V5OiBlZGdlSWQsXG4gICAgYWRkZWQ6IERhdGUubm93KClcbiAgfTtcblxuICAvLyBRdWVyeVxuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQU0VSVCAke3tfa2V5OiBmb3JtYXRJZH19XG4gICAgSU5TRVJUICR7aW5zZXJ0fVxuICAgIFVQREFURSAke3VwZGF0ZX1cbiAgICBMSU1JVCAxXG4gICAgUkVUVVJOIE5FV2A7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwgY29udGV4dCkudGhlbigoKSA9PiBudWxsKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0UmVhY3Rpb25Db3VudCA9IChcbiAgY29udGV4dDogQXBpQ29udGV4dCxcbiAgaXRlbUlkOiBzdHJpbmcsXG4gIGl0ZW1UeXBlOiBzdHJpbmcsXG4gIHJlYWN0aW9uTmFtZTogc3RyaW5nXG4pOiBQcm9taXNlPFJlYWN0aW9uVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRSZWFjdGlvbkNvdW50JztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGZvcm1hdEl0ZW1JZDogc3RyaW5nID0gcGFyc2VJZChpdGVtSWQpO1xuICBjb25zdCBmb3JtYXRSZWFjdGlvbk5hbWU6IGFueSA9IHBhcnNlQ2hhcihyZWFjdGlvbk5hbWUsIDMyKTtcbiAgY29uc3QgZm9ybWF0SXRlbVR5cGU6IGFueSA9IHBhcnNlQ2hhcihpdGVtVHlwZSwgMzIpO1xuICBjb25zdCBpdGVtRG9jSWQ6IHN0cmluZyA9IGAke2Zvcm1hdEl0ZW1UeXBlfS8ke2Zvcm1hdEl0ZW1JZH1gO1xuXG4gIC8vIFF1ZXJ5XG4gIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgRk9SIGksIHIgSU4gSU5CT1VORCAke2l0ZW1Eb2NJZH0gaGFzUmVhY3Rpb25zXG4gICAgRklMVEVSIHIubmFtZSA9PSAke2Zvcm1hdFJlYWN0aW9uTmFtZX0gJiYgci50eXBlID09ICR7Zm9ybWF0SXRlbVR5cGV9XG4gICAgQ09MTEVDVCBXSVRIIENPVU5UIElOVE8gY291bnRcbiAgICBSRVRVUk4gY291bnRgO1xuXG4gIHJldHVybiB1c2VEYihkYXRhYmFzZSkucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpLnRoZW4oKCkgPT4gdW5kZWZpbmVkKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0UmVhY3Rpb25Db3VudEJ5VXNlciA9IChcbiAgY29udGV4dDogQXBpQ29udGV4dCxcbiAgaXRlbUlkOiBzdHJpbmcsXG4gIGl0ZW1UeXBlOiBzdHJpbmcsXG4gIHJlYWN0aW9uTmFtZTogc3RyaW5nXG4pOiBQcm9taXNlPFJlYWN0aW9uVHlwZVtdPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldFJlYWN0aW9uc0J5VXNlcic7XG4gIGNvbnN0IHtkYXRhYmFzZSwgdXNlcklkOiBzZXNzaW9uSWR9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0SXRlbUlkOiBzdHJpbmcgPSBwYXJzZUlkKGl0ZW1JZCk7XG4gIGNvbnN0IGZvcm1hdFJlYWN0aW9uTmFtZTogYW55ID0gcGFyc2VDaGFyKHJlYWN0aW9uTmFtZSwgMzIpO1xuICBjb25zdCBmb3JtYXRJdGVtVHlwZTogYW55ID0gcGFyc2VDaGFyKGl0ZW1UeXBlLCAzMik7XG4gIGNvbnN0IHNlc3Npb25Eb2NJZDogc3RyaW5nID0gYHVzZXJzLyR7c2Vzc2lvbklkfWA7XG4gIGNvbnN0IGl0ZW1Eb2NJZDogc3RyaW5nID0gYCR7Zm9ybWF0SXRlbVR5cGV9LyR7Zm9ybWF0SXRlbUlkfWA7XG5cbiAgLy8gUXVlcnlcbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBGT1IgaSwgciBJTiBJTkJPVU5EICR7aXRlbURvY0lkfSBoYXNSZWFjdGlvbnNcbiAgICAgIEZJTFRFUiByLm5hbWUgPT0gJHtmb3JtYXRSZWFjdGlvbk5hbWV9ICYmIHIuX2Zyb20gPT0gJHtzZXNzaW9uRG9jSWR9XG4gICAgICBDT0xMRUNUIHJlYWN0aW9uVmFsdWUgPSByLnZhbHVlIElOVE8gcmVhY3Rpb25JdGVtc1xuICAgICAgUkVUVVJOIE1FUkdFKHIsIHtjb3VudDogTEVOR1RIKHJlYWN0aW9uSXRlbXNbKl0uci52YWx1ZSl9KWA7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5hbGwoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJ1xuICAgIH0sIGVycm9yLCBjb250ZXh0KS50aGVuKCgpID0+IFtdKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R3JvdXBVc2Vyc0J5UmVhY3Rpb24gPSAoY29udGV4dDogQXBpQ29udGV4dCwgcGFyYW1zOiBVc2VyUmVhY3Rpb25RdWVyeSA9IHt9KTogUHJvbWlzZTxVc2VyVHlwZVtdPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldFVzZXJzQnlSZWFjdGlvbic7XG4gIGNvbnN0IHtkYXRhYmFzZSwgdXNlcklkOiBzZXNzaW9uSWR9ID0gY29udGV4dDtcblxuICBpZighc2Vzc2lvbklkKSB7XG4gICAgcmV0dXJuIGxvZ0V4Y2VwdGlvbih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAndW5hdXRob3JpemVkJyxcbiAgICAgIHZhbHVlOiAnaW52YWxpZF9zZXNzaW9uJ1xuICAgIH0sIGNvbnRleHQpLnRoZW4oKCkgPT4gbnVsbCk7XG4gIH1cblxuICBjb25zdCB7ZmlsdGVycyA9IFtdLCBpZDogZ3JvdXBJZCwgdmFsdWV9OiBVc2VyUmVhY3Rpb25RdWVyeSA9IHBhcmFtcztcbiAgY29uc3QgcmVhY3Rpb24gPSBwYXJzZUNoYXIodmFsdWUsIDMyKTtcbiAgY29uc3QgZ3JvdXBEb2NJZCA9IGBncm91cHMvJHtwYXJzZUlkKGdyb3VwSWQpfWA7XG4gIGNvbnN0IGZpbHRlclN0cjogc3RyaW5nID0gZmlsdGVyc1xuICAgIC5tYXAoKGZpbHRlcjogUXVlcnlGaWx0ZXIpID0+IHtcbiAgICAgIGNvbnN0IHtjb25kaXRpb25hbCwgbmFtZSwgdmFsdWU6IHF1ZXJ5VmFsdWV9OiBRdWVyeUZpbHRlciA9IGZpbHRlcjtcbiAgICAgIGxldCBmaWx0ZXJDb25kOiBzdHJpbmcgPSBjb25kaXRpb25hbDtcblxuICAgICAgaWYoY29uZGl0aW9uYWwgIT09ICc+PScgJiYgY29uZGl0aW9uYWwgIT09ICc8PScgJiYgY29uZGl0aW9uYWwgIT09ICc+JyAmJiBjb25kaXRpb25hbCAhPT0gJzwnKSB7XG4gICAgICAgIGZpbHRlckNvbmQgPSAnPT0nO1xuICAgICAgfVxuXG4gICAgICBzd2l0Y2gobmFtZSkge1xuICAgICAgICBjYXNlICdhZGRlZCc6XG4gICAgICAgICAgcmV0dXJuIGByLmFkZGVkICR7ZmlsdGVyQ29uZH0gJHtwYXJzZU51bShxdWVyeVZhbHVlKX1gO1xuICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgIHJldHVybiAnJztcbiAgICAgIH1cbiAgICB9KVxuICAgIC5jb25jYXQoW1xuICAgICAgYHIudmFsdWUgPT0gXCIke3JlYWN0aW9ufVwiYCxcbiAgICAgICd1Ll9pZCA9PSByLl9mcm9tJ1xuICAgIF0pXG4gICAgLmpvaW4oJyAmJiAnKTtcblxuICAvLyBRdWVyeVxuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgZywgciBJTiBJTkJPVU5EIFwiJHtncm91cERvY0lkfVwiIGhhc1JlYWN0aW9uc1xuICAgICAgRk9SIHUgSU4gdXNlcnNcbiAgICAgIEZJTFRFUiAgJHtmaWx0ZXJTdHJ9XG4gICAgICBSRVRVUk4gdWA7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5hbGwoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJ1xuICAgIH0sIGVycm9yLCBjb250ZXh0KS50aGVuKCgpID0+IFtdKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0UmVhY3Rpb25zQnlJdGVtID0gKFxuICBjb250ZXh0OiBBcGlDb250ZXh0LFxuICBpdGVtSWQ6IHN0cmluZyxcbiAgaXRlbVR5cGU6IHN0cmluZyxcbiAgcmVhY3Rpb25OYW1lOiBzdHJpbmcsXG4gIG9wdGlvbnM6IFJlYWN0aW9uT3B0aW9uc1xuKTogUHJvbWlzZTxVc2VyVHlwZVtdPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldFVzZXJzQnlSZWFjdGlvbnMnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0SXRlbUlkOiBzdHJpbmcgPSBwYXJzZUlkKGl0ZW1JZCk7XG4gIGNvbnN0IGZvcm1hdEl0ZW1UeXBlOiBzdHJpbmcgPSBwYXJzZUNoYXIoaXRlbVR5cGUsIDMyKTtcbiAgY29uc3QgZm9ybWF0UmVhY3Rpb25OYW1lOiBzdHJpbmcgPSBwYXJzZUNoYXIocmVhY3Rpb25OYW1lLCAzMik7XG4gIGNvbnN0IGl0ZW1Eb2NJZCA9IGAke2Zvcm1hdEl0ZW1UeXBlfS8ke2Zvcm1hdEl0ZW1JZH1gO1xuICBjb25zdCB7bGltaXR9ID0gcGFyc2VSZWFjdGlvbk9wdGlvbnMob3B0aW9ucyk7XG4gIGNvbnN0IGFxbFFyeTogc3RyaW5nID0gYEZPUiBpLCByIElOIElOQk9VTkQgXCIke2l0ZW1Eb2NJZH1cIiBoYXNSZWFjdGlvbnNcbiAgICBGSUxURVIgci5uYW1lID09IFwiJHtmb3JtYXRSZWFjdGlvbk5hbWV9XCJcbiAgICAke2xpbWl0LmFxbH1cbiAgICBSRVRVUk4gTUVSR0UoaSwge3JlYWN0aW9uOiByfWA7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5hbGwoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJ1xuICAgIH0sIGVycm9yLCBjb250ZXh0KS50aGVuKCgpID0+IFtdKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0SXRlbXNCeVJlYWN0aW9uID0gKFxuICBjb250ZXh0OiBBcGlDb250ZXh0LFxuICBpdGVtSWQ6IHN0cmluZyxcbiAgaXRlbVR5cGU6IHN0cmluZyxcbiAgcmVhY3Rpb25OYW1lOiBzdHJpbmcsXG4gIG9wdGlvbnM6IFJlYWN0aW9uT3B0aW9uc1xuKTogUHJvbWlzZTxSZWFjdGlvblR5cGVbXT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRVc2VyUmVhY3Rpb25zQnlSZWFjdGlvbic7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBmb3JtYXRJdGVtSWQ6IHN0cmluZyA9IHBhcnNlSWQoaXRlbUlkKTtcbiAgY29uc3QgZm9ybWF0SXRlbVR5cGU6IHN0cmluZyA9IHBhcnNlQ2hhcihpdGVtVHlwZSwgMzIpO1xuICBjb25zdCBmb3JtYXRSZWFjdGlvbk5hbWU6IHN0cmluZyA9IHBhcnNlQ2hhcihyZWFjdGlvbk5hbWUsIDMyKTtcbiAgY29uc3QgaXRlbURvY0lkID0gYCR7Zm9ybWF0SXRlbVR5cGV9LyR7Zm9ybWF0SXRlbUlkfWA7XG4gIGNvbnN0IHtsaW1pdH0gPSBwYXJzZVJlYWN0aW9uT3B0aW9ucyhvcHRpb25zKTtcblxuICAvLyBRdWVyeVxuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgdSwgciBJTiBPVVRCT1VORCBcIiR7aXRlbURvY0lkfVwiIGhhc1JlYWN0aW9uc1xuICAgIEZJTFRFUiByLm5hbWUgPT0gJHtmb3JtYXRSZWFjdGlvbk5hbWV9XG4gICAgJHtsaW1pdC5hcWx9XG4gICAgUkVUVVJOIE1FUkdFKHUsIHtyZWFjdGlvbjogcn0pYDtcblxuICByZXR1cm4gdXNlRGIoZGF0YWJhc2UpLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpLnRoZW4oKCkgPT4gW10pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBoYXNSZWFjdGlvbiA9IChcbiAgY29udGV4dDogQXBpQ29udGV4dCxcbiAgaXRlbUlkOiBzdHJpbmcsXG4gIGl0ZW1UeXBlOiBzdHJpbmcsXG4gIHJlYWN0aW9uTmFtZTogc3RyaW5nLFxuICBkaXJlY3Rpb246IFJlYWN0aW9uRGlyZWN0aW9uID0gJ09VVEJPVU5EJ1xuKTogUHJvbWlzZTxib29sZWFuPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldFJlYWN0aW9uc0J5VXNlcic7XG4gIGNvbnN0IHtkYXRhYmFzZSwgdXNlcklkOiBzZXNzaW9uSWR9ID0gY29udGV4dDtcbiAgY29uc3Qgc2Vzc2lvbkRvY0lkOiBzdHJpbmcgPSBgdXNlcnMvJHtzZXNzaW9uSWR9YDtcbiAgY29uc3QgZm9ybWF0SXRlbUlkOiBzdHJpbmcgPSBwYXJzZUlkKGl0ZW1JZCk7XG4gIGNvbnN0IGZvcm1hdEl0ZW1UeXBlOiBzdHJpbmcgPSBwYXJzZUNoYXIoaXRlbVR5cGUsIDMyKTtcbiAgY29uc3QgZm9ybWF0RGlyZWN0aW9uID0gZGlyZWN0aW9uID09PSAnT1VUQk9VTkQnID8gJ09VVEJPVU5EJyA6ICdJTkJPVU5EJztcbiAgY29uc3QgaXRlbURpcmVjdGlvbjogc3RyaW5nID0gZGlyZWN0aW9uID09PSAnT1VUQk9VTkQnID8gJ3IuX3RvJyA6ICdyLl9mcm9tJztcbiAgY29uc3QgaXRlbURvY0lkOiBzdHJpbmcgPSBgJHtmb3JtYXRJdGVtVHlwZX0vJHtmb3JtYXRJdGVtSWR9YDtcblxuICAvLyBRdWVyeVxuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgaSwgciBJTiAke2Zvcm1hdERpcmVjdGlvbn0gXCIke3Nlc3Npb25Eb2NJZH1cIiBoYXNSZWFjdGlvbnNcbiAgICBGSUxURVIgci5uYW1lID09IFwiJHtyZWFjdGlvbk5hbWV9XCIgJiYgJHtpdGVtRGlyZWN0aW9ufSA9PSBcIiR7aXRlbURvY0lkfVwiXG4gICAgUkVUVVJOIE1FUkdFKGksIHtyZWFjdGlvbjogcn0pYDtcblxuICByZXR1cm4gdXNlRGIoZGF0YWJhc2UpLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKVxuICAgIC50aGVuKChyZWFjdGlvbnMgPSBbXSkgPT4gISFyZWFjdGlvbnMubGVuZ3RoKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIGNvbnRleHQpLnRoZW4oKCkgPT4gZmFsc2UpKTtcbn07XG4iXX0=