@nlabs/reaktor 0.2.3 → 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.
- package/lib/config.js +12 -4
- package/lib/data/conversations.d.ts +3 -1
- package/lib/data/conversations.js +150 -65
- package/lib/data/dynamodb.d.ts +8 -8
- package/lib/data/dynamodb.js +65 -33
- package/lib/data/email.d.ts +2 -2
- package/lib/data/email.js +52 -24
- package/lib/data/files.js +71 -11
- package/lib/data/groups.js +37 -3
- package/lib/data/images.d.ts +3 -2
- package/lib/data/images.js +425 -273
- package/lib/data/index.d.ts +1 -0
- package/lib/data/index.js +33 -1
- package/lib/data/ios.d.ts +5 -5
- package/lib/data/ios.js +47 -21
- package/lib/data/locations.js +28 -4
- package/lib/data/messages.js +89 -73
- package/lib/data/notifications.d.ts +2 -2
- package/lib/data/notifications.js +6 -6
- package/lib/data/payments.d.ts +3 -4
- package/lib/data/payments.js +228 -257
- package/lib/data/posts.d.ts +1 -1
- package/lib/data/posts.js +88 -12
- package/lib/data/reactions.d.ts +1 -1
- package/lib/data/reactions.js +56 -14
- package/lib/data/s3.d.ts +6 -6
- package/lib/data/s3.js +10 -2
- package/lib/data/search.js +46 -4
- package/lib/data/sms.js +5 -1
- package/lib/data/subscription.d.ts +1 -1
- package/lib/data/subscription.js +46 -20
- package/lib/data/tags.js +60 -8
- package/lib/data/users.d.ts +7 -4
- package/lib/data/users.js +83 -32
- package/lib/data/websockets.d.ts +6 -0
- package/lib/data/websockets.js +250 -0
- package/lib/index.js +4 -1
- package/lib/types/conversations.d.ts +2 -0
- package/lib/types/index.js +18 -1
- package/lib/types/payments.d.ts +1 -0
- package/lib/types/posts.d.ts +2 -0
- package/lib/types/reactions.d.ts +2 -0
- package/lib/types/users.d.ts +1 -0
- package/lib/utils/analytics.js +28 -6
- package/lib/utils/arangodb.d.ts +2 -1
- package/lib/utils/arangodb.js +31 -10
- package/lib/utils/auth.js +21 -3
- package/lib/utils/graphql.js +3 -1
- package/lib/utils/index.js +7 -1
- package/lib/utils/objects.js +9 -1
- package/lib/utils/redis.js +6 -2
- package/package.json +33 -31
package/lib/data/reactions.js
CHANGED
|
@@ -1,5 +1,39 @@
|
|
|
1
1
|
"use strict";
|
|
2
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
|
+
|
|
3
37
|
Object.defineProperty(exports, "__esModule", {
|
|
4
38
|
value: true
|
|
5
39
|
});
|
|
@@ -43,7 +77,7 @@ function _templateObject4() {
|
|
|
43
77
|
|
|
44
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; }
|
|
45
79
|
|
|
46
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
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; }
|
|
47
81
|
|
|
48
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; }
|
|
49
83
|
|
|
@@ -120,12 +154,14 @@ var addReaction = function addReaction(context, itemId) {
|
|
|
120
154
|
var formatItemType = (0, _utils.parseChar)(itemType, 32);
|
|
121
155
|
var formatReactionName = (0, _utils.parseChar)(itemName, 32);
|
|
122
156
|
var formatValue = (0, _utils.parseString)(itemValue, 32);
|
|
123
|
-
var edgeCollection = (0, _utils2.useDb)(database).
|
|
157
|
+
var edgeCollection = (0, _utils2.useDb)(database).collection('hasReactions');
|
|
124
158
|
var typeDocId = "".concat(formatItemType, "/").concat(formatItemId);
|
|
125
159
|
var sessionDocId = "users/".concat(sessionId);
|
|
126
160
|
var edgeId = (0, _utils.createHash)("reaction-".concat(formatItemId, "-").concat(sessionId));
|
|
127
161
|
var edge = {
|
|
162
|
+
_from: sessionDocId,
|
|
128
163
|
_key: edgeId,
|
|
164
|
+
_to: typeDocId,
|
|
129
165
|
added: Date.now(),
|
|
130
166
|
name: formatReactionName,
|
|
131
167
|
type: formatItemType,
|
|
@@ -142,10 +178,14 @@ var addReaction = function addReaction(context, itemId) {
|
|
|
142
178
|
return reaction;
|
|
143
179
|
}
|
|
144
180
|
|
|
145
|
-
return edgeCollection.save(edge,
|
|
181
|
+
return edgeCollection.save(edge, {
|
|
182
|
+
returnNew: true
|
|
183
|
+
}).then(function () {
|
|
184
|
+
console.log('addReaction::edge', edge);
|
|
146
185
|
return edge;
|
|
147
186
|
});
|
|
148
187
|
})["catch"](function (error) {
|
|
188
|
+
console.log('addReaction::error', error);
|
|
149
189
|
return (0, _utils2.logError)({
|
|
150
190
|
action: action,
|
|
151
191
|
category: eventCategory,
|
|
@@ -156,7 +196,9 @@ var addReaction = function addReaction(context, itemId) {
|
|
|
156
196
|
});
|
|
157
197
|
}
|
|
158
198
|
|
|
159
|
-
return edgeCollection.save(edge,
|
|
199
|
+
return edgeCollection.save(edge, {
|
|
200
|
+
returnNew: true
|
|
201
|
+
}).then(function () {
|
|
160
202
|
return edge;
|
|
161
203
|
});
|
|
162
204
|
};
|
|
@@ -179,10 +221,10 @@ var removeReaction = function removeReaction(context, reactionId) {
|
|
|
179
221
|
});
|
|
180
222
|
}
|
|
181
223
|
|
|
182
|
-
var
|
|
224
|
+
var formatSessionId = "users/".concat((0, _utils.parseId)(sessionId));
|
|
183
225
|
var formatReactionId = "hasReactions/".concat((0, _utils.parseId)(reactionId)); // Query
|
|
184
226
|
|
|
185
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatReactionId,
|
|
227
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatReactionId, formatSessionId);
|
|
186
228
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
187
229
|
return cursor.next();
|
|
188
230
|
})["catch"](function (error) {
|
|
@@ -267,7 +309,7 @@ var updateReaction = function updateReaction(context) {
|
|
|
267
309
|
value: formatValue
|
|
268
310
|
};
|
|
269
311
|
|
|
270
|
-
var insert = _objectSpread({}, update, {
|
|
312
|
+
var insert = _objectSpread(_objectSpread({}, update), {}, {
|
|
271
313
|
_key: edgeId,
|
|
272
314
|
added: Date.now()
|
|
273
315
|
}); // Query
|
|
@@ -308,7 +350,7 @@ var getReactionCount = function getReactionCount(context, itemId, itemType, reac
|
|
|
308
350
|
category: eventCategory,
|
|
309
351
|
label: 'db_error'
|
|
310
352
|
}, error, context).then(function () {
|
|
311
|
-
return
|
|
353
|
+
return undefined;
|
|
312
354
|
});
|
|
313
355
|
});
|
|
314
356
|
};
|
|
@@ -334,7 +376,7 @@ var getReactionCountByUser = function getReactionCountByUser(context, itemId, it
|
|
|
334
376
|
category: eventCategory,
|
|
335
377
|
label: 'db_error'
|
|
336
378
|
}, error, context).then(function () {
|
|
337
|
-
return
|
|
379
|
+
return [];
|
|
338
380
|
});
|
|
339
381
|
});
|
|
340
382
|
};
|
|
@@ -392,7 +434,7 @@ var getGroupUsersByReaction = function getGroupUsersByReaction(context) {
|
|
|
392
434
|
category: eventCategory,
|
|
393
435
|
label: 'db_error'
|
|
394
436
|
}, error, context).then(function () {
|
|
395
|
-
return
|
|
437
|
+
return [];
|
|
396
438
|
});
|
|
397
439
|
});
|
|
398
440
|
};
|
|
@@ -419,7 +461,7 @@ var getReactionsByItem = function getReactionsByItem(context, itemId, itemType,
|
|
|
419
461
|
category: eventCategory,
|
|
420
462
|
label: 'db_error'
|
|
421
463
|
}, error, context).then(function () {
|
|
422
|
-
return
|
|
464
|
+
return [];
|
|
423
465
|
});
|
|
424
466
|
});
|
|
425
467
|
};
|
|
@@ -447,7 +489,7 @@ var getItemsByReaction = function getItemsByReaction(context, itemId, itemType,
|
|
|
447
489
|
category: eventCategory,
|
|
448
490
|
label: 'db_error'
|
|
449
491
|
}, error, context).then(function () {
|
|
450
|
-
return
|
|
492
|
+
return [];
|
|
451
493
|
});
|
|
452
494
|
});
|
|
453
495
|
};
|
|
@@ -478,10 +520,10 @@ var hasReaction = function hasReaction(context, itemId, itemType, reactionName)
|
|
|
478
520
|
category: eventCategory,
|
|
479
521
|
label: 'db_error'
|
|
480
522
|
}, error, context).then(function () {
|
|
481
|
-
return
|
|
523
|
+
return false;
|
|
482
524
|
});
|
|
483
525
|
});
|
|
484
526
|
};
|
|
485
527
|
|
|
486
528
|
exports.hasReaction = hasReaction;
|
|
487
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["eventCategory","parseReactionOptions","options","from","to","limit","addReaction","context","itemId","itemType","reaction","allowDuplicate","action","database","sessionId","userId","category","label","value","then","name","itemName","itemValue","formatItemId","formatItemType","formatReactionName","formatValue","edgeCollection","typeDocId","sessionDocId","edgeId","edge","_key","added","Date","now","type","undefined","aqlQry","aql","query","cursor","next","save","error","removeReaction","reactionId","formatSessionnId","formatReactionId","removeReactionByItem","reactionName","formatSessionId","formatItemDocId","updateReaction","id","formatId","formatName","formatType","update","insert","getReactionCount","itemDocId","getReactionCountByUser","all","getGroupUsersByReaction","params","filters","groupId","groupDocId","filterStr","map","filter","conditional","queryValue","filterCond","concat","join","getReactionsByItem","getItemsByReaction","hasReaction","direction","formatDirection","itemDirection","reactions","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {\n  ApiContext,\n  QueryFilter,\n  ReactionDirection,\n  ReactionOptions,\n  ReactionType,\n  UserReactionQuery,\n  UserType\n} from '../types';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string = 'users',\n  reaction: ReactionType = {},\n  allowDuplicate: boolean = false\n): Promise<ReactionType> => {\n  const action: string = 'addReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: any = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReactions');\n  const typeDocId: string = `${formatItemType}/${formatItemId}`;\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: ReactionType = {\n    _key: edgeId,\n    added: Date.now(),\n    name: formatReactionName,\n    type: formatItemType,\n    value: itemValue !== undefined ? formatValue : undefined\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n      FILTER r._from == ${sessionDocId} && r._to == ${typeDocId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return useDb(database).query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n      })\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error'\n      }, error, context).then(() => null));\n  }\n\n  return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n};\n\nexport const removeReaction = (context: ApiContext, reactionId: string): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionnId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReactions/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionnId}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const removeReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatItemDocId: string = `${formatItemType}/${parseId(itemId)}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n    FILTER r._from == ${formatSessionId}\n      && r._to == ${formatItemDocId}\n      && r.type == ${formatItemType}\n      && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateReaction = (context: ApiContext, reaction: ReactionType = {}): Promise<ReactionType> => {\n  const action: string = 'updateReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    id: itemId,\n    name: itemName,\n    type: itemType,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatType: any = parseChar(itemType, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: ReactionType = {\n    name: formatName,\n    type: formatType,\n    value: formatValue\n  };\n  const insert: ReactionType = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_key: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n    FILTER r.name == ${formatReactionName} && r.type == ${formatItemType}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getUsersByReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = `groups/${parseId(groupId)}`;\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReactions\n      FOR u IN users\n      FILTER  ${filterStr}\n      RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByReactions';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: r}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<ReactionType[]> => {\n  const action: string = 'getUserReactionsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReactions\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${itemDocId}\"\n    RETURN MERGE(i, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((reactions = []) => !!reactions.length)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
|
529
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["eventCategory","parseReactionOptions","options","from","to","limit","addReaction","context","itemId","itemType","reaction","allowDuplicate","action","database","sessionId","userId","category","label","value","then","name","itemName","itemValue","formatItemId","formatItemType","formatReactionName","formatValue","edgeCollection","collection","typeDocId","sessionDocId","edgeId","edge","_from","_key","_to","added","Date","now","type","undefined","aqlQry","aql","query","cursor","next","save","returnNew","console","log","error","removeReaction","reactionId","formatSessionId","formatReactionId","removeReactionByItem","reactionName","formatItemDocId","updateReaction","id","formatId","formatName","formatType","update","insert","getReactionCount","itemDocId","getReactionCountByUser","all","getGroupUsersByReaction","params","filters","groupId","groupDocId","filterStr","map","filter","conditional","queryValue","filterCond","concat","join","getReactionsByItem","getItemsByReaction","hasReaction","direction","formatDirection","itemDirection","reactions","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\n\nimport {\n  ApiContext,\n  QueryFilter,\n  ReactionDirection,\n  ReactionOptions,\n  ReactionType,\n  UserReactionQuery,\n  UserType\n} from '../types';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string = 'users',\n  reaction: ReactionType = {},\n  allowDuplicate: boolean = false\n): Promise<ReactionType> => {\n  const action: string = 'addReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: any = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection: EdgeCollection = useDb(database).collection('hasReactions');\n  const typeDocId: string = `${formatItemType}/${formatItemId}`;\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: ReactionType = {\n    _from: sessionDocId,\n    _key: edgeId,\n    _to: typeDocId,\n    added: Date.now(),\n    name: formatReactionName,\n    type: formatItemType,\n    value: itemValue !== undefined ? formatValue : undefined\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n      FILTER r._from == ${sessionDocId} && r._to == ${typeDocId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return useDb(database).query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, {returnNew: true}).then(() => {\n          console.log('addReaction::edge', edge);\n          return edge;\n        });\n      })\n      .catch((error: Error) => {\n        console.log('addReaction::error', error);\n        return logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, context).then(() => null);\n      });\n  }\n\n  return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n};\n\nexport const removeReaction = (context: ApiContext, reactionId: string): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReactions/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionId}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const removeReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatItemDocId: string = `${formatItemType}/${parseId(itemId)}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n    FILTER r._from == ${formatSessionId}\n      && r._to == ${formatItemDocId}\n      && r.type == ${formatItemType}\n      && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReactions\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateReaction = (context: ApiContext, reaction: ReactionType = {}): Promise<ReactionType> => {\n  const action: string = 'updateReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    id: itemId,\n    name: itemName,\n    type: itemType,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatType: any = parseChar(itemType, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: ReactionType = {\n    name: formatName,\n    type: formatType,\n    value: formatValue\n  };\n  const insert: ReactionType = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_key: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n    FILTER r.name == ${formatReactionName} && r.type == ${formatItemType}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => undefined));\n};\n\nexport const getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getGroupUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getUsersByReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = `groups/${parseId(groupId)}`;\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReactions\n      FOR u IN users\n      FILTER  ${filterStr}\n      RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByReactions';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: r}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<ReactionType[]> => {\n  const action: string = 'getUserReactionsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => []));\n};\n\nexport const hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<boolean> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReactions\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${itemDocId}\"\n    RETURN MERGE(i, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((reactions = []) => !!reactions.length)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => false));\n};\n"]}
|
package/lib/data/s3.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export declare const s3Get: (params:
|
|
3
|
-
export declare const s3Head: (params:
|
|
4
|
-
export declare const s3Put: (params:
|
|
5
|
-
export declare const s3Delete: (params:
|
|
6
|
-
export declare const s3DeleteList: (params:
|
|
1
|
+
import { DeleteObjectOutput, DeleteObjectRequest, DeleteObjectsOutput, DeleteObjectsRequest, GetObjectOutput, GetObjectRequest, HeadObjectOutput, HeadObjectRequest, PutObjectOutput, PutObjectRequest } from 'aws-sdk/clients/s3';
|
|
2
|
+
export declare const s3Get: (params: GetObjectRequest) => Promise<GetObjectOutput>;
|
|
3
|
+
export declare const s3Head: (params: HeadObjectRequest) => Promise<HeadObjectOutput>;
|
|
4
|
+
export declare const s3Put: (params: PutObjectRequest) => Promise<PutObjectOutput>;
|
|
5
|
+
export declare const s3Delete: (params: DeleteObjectRequest) => Promise<DeleteObjectOutput>;
|
|
6
|
+
export declare const s3DeleteList: (params: DeleteObjectsRequest) => Promise<DeleteObjectsOutput>;
|
|
7
7
|
export declare const s3GetSignedUrl: (params: any) => string;
|
package/lib/data/s3.js
CHANGED
|
@@ -1,5 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.object.to-string");
|
|
6
|
+
|
|
7
|
+
require("core-js/modules/es.promise");
|
|
8
|
+
|
|
3
9
|
Object.defineProperty(exports, "__esModule", {
|
|
4
10
|
value: true
|
|
5
11
|
});
|
|
@@ -9,7 +15,9 @@ var _awsSdk = _interopRequireWildcard(require("aws-sdk"));
|
|
|
9
15
|
|
|
10
16
|
var _config = require("../config");
|
|
11
17
|
|
|
12
|
-
function
|
|
18
|
+
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
|
|
19
|
+
|
|
20
|
+
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
13
21
|
|
|
14
22
|
/**
|
|
15
23
|
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
@@ -144,4 +152,4 @@ var s3GetSignedUrl = function s3GetSignedUrl(params) {
|
|
|
144
152
|
};
|
|
145
153
|
|
|
146
154
|
exports.s3GetSignedUrl = s3GetSignedUrl;
|
|
147
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
155
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/s3.ts"],"names":["s3Get","params","Promise","resolve","reject","aws","config","update","Config","get","s3","S3","Bucket","getObject","error","output","s3Head","headObject","s3Put","StorageClass","putObject","s3Delete","deleteObject","s3DeleteList","deleteObjects","s3GetSignedUrl","getSignedUrl"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport aws, {S3} from 'aws-sdk';\nimport {\n  DeleteObjectOutput,\n  DeleteObjectRequest,\n  DeleteObjectsOutput,\n  DeleteObjectsRequest,\n  GetObjectOutput,\n  GetObjectRequest,\n  HeadObjectOutput,\n  HeadObjectRequest,\n  PutObjectOutput,\n  PutObjectRequest\n} from 'aws-sdk/clients/s3';\n\nimport {Config} from '../config';\n\n// AWS S3\n// const eventCategory: string = 's3';\n\nexport const s3Get = (params: GetObjectRequest): Promise<GetObjectOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.getObject(params, (error: Error, output: GetObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n\n      return resolve(output);\n    });\n  });\n\nexport const s3Head = (params: HeadObjectRequest): Promise<HeadObjectOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.headObject(params, (error: Error, output: HeadObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\n\nexport const s3Put = (params: PutObjectRequest): Promise<PutObjectOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3 = new aws.S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    if(!params.StorageClass) {\n      params.StorageClass = 'REDUCED_REDUNDANCY';\n    }\n\n    s3.putObject(params, (error: Error, output: PutObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3Delete = (params: DeleteObjectRequest): Promise<DeleteObjectOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.deleteObject(params, (error, output: DeleteObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3DeleteList = (params: DeleteObjectsRequest): Promise<DeleteObjectsOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.deleteObjects(params, (error: Error, output: DeleteObjectsOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3GetSignedUrl = (params: any): string => {\n  aws.config.update(Config.get('aws'));\n  const s3: S3 = new S3();\n\n  if(!params.Bucket) {\n    params.Bucket = Config.get('aws.Bucket');\n  }\n\n  return s3.getSignedUrl('getObject', params);\n};\n"]}
|
package/lib/data/search.js
CHANGED
|
@@ -1,5 +1,47 @@
|
|
|
1
1
|
"use strict";
|
|
2
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.iterator");
|
|
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.function.name");
|
|
18
|
+
|
|
19
|
+
require("core-js/modules/es.object.define-properties");
|
|
20
|
+
|
|
21
|
+
require("core-js/modules/es.object.define-property");
|
|
22
|
+
|
|
23
|
+
require("core-js/modules/es.object.freeze");
|
|
24
|
+
|
|
25
|
+
require("core-js/modules/es.object.get-own-property-descriptor");
|
|
26
|
+
|
|
27
|
+
require("core-js/modules/es.object.get-own-property-descriptors");
|
|
28
|
+
|
|
29
|
+
require("core-js/modules/es.object.keys");
|
|
30
|
+
|
|
31
|
+
require("core-js/modules/es.object.to-string");
|
|
32
|
+
|
|
33
|
+
require("core-js/modules/es.promise");
|
|
34
|
+
|
|
35
|
+
require("core-js/modules/es.regexp.exec");
|
|
36
|
+
|
|
37
|
+
require("core-js/modules/es.string.iterator");
|
|
38
|
+
|
|
39
|
+
require("core-js/modules/es.string.split");
|
|
40
|
+
|
|
41
|
+
require("core-js/modules/web.dom-collections.for-each");
|
|
42
|
+
|
|
43
|
+
require("core-js/modules/web.dom-collections.iterator");
|
|
44
|
+
|
|
3
45
|
Object.defineProperty(exports, "__esModule", {
|
|
4
46
|
value: true
|
|
5
47
|
});
|
|
@@ -19,7 +61,7 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "d
|
|
|
19
61
|
|
|
20
62
|
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; }
|
|
21
63
|
|
|
22
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
64
|
+
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; }
|
|
23
65
|
|
|
24
66
|
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; }
|
|
25
67
|
|
|
@@ -73,7 +115,7 @@ var getSearchList = function getSearchList(context, query, from, to) {
|
|
|
73
115
|
var collectionIdList = itemId.split('/');
|
|
74
116
|
var collection = collectionIdList[0];
|
|
75
117
|
var name = collection === 'users' ? (0, _users.getDisplayName)(item) : itemName;
|
|
76
|
-
return _objectSpread({}, item, {
|
|
118
|
+
return _objectSpread(_objectSpread({}, item), {}, {
|
|
77
119
|
name: name
|
|
78
120
|
});
|
|
79
121
|
});
|
|
@@ -93,7 +135,7 @@ var getSearchList = function getSearchList(context, query, from, to) {
|
|
|
93
135
|
var collectionIdList = itemId.split('/');
|
|
94
136
|
var collection = collectionIdList[0];
|
|
95
137
|
var name = collection === 'users' ? (0, _users.getDisplayName)(item) : itemName;
|
|
96
|
-
return _objectSpread({}, item, {
|
|
138
|
+
return _objectSpread(_objectSpread({}, item), {}, {
|
|
97
139
|
name: name
|
|
98
140
|
});
|
|
99
141
|
});
|
|
@@ -110,4 +152,4 @@ var getSearchList = function getSearchList(context, query, from, to) {
|
|
|
110
152
|
};
|
|
111
153
|
|
|
112
154
|
exports.getSearchList = getSearchList;
|
|
113
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
155
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL3NlYXJjaC50cyJdLCJuYW1lcyI6WyJldmVudENhdGVnb3J5IiwiZ2V0U2VhcmNoTGlzdCIsImNvbnRleHQiLCJxdWVyeSIsImZyb20iLCJ0byIsImFjdGlvbiIsImRhdGFiYXNlIiwiaXNTdHJpbmciLCJmaWVsZHMiLCJjb2xsZWN0aW9uIiwiZmllbGQiLCJQcm9taXNlIiwiYWxsIiwibWFwIiwib2JqIiwicXJ5IiwidXNlclFyeSIsImFxbCIsInRoZW4iLCJjdXJzb3IiLCJyZXN1bHRzIiwibGlzdCIsIml0ZW0iLCJpdGVtSWQiLCJfaWQiLCJpdGVtTmFtZSIsIm5hbWUiLCJjb2xsZWN0aW9uSWRMaXN0Iiwic3BsaXQiLCJsaW1pdCIsImFxbFFyeSIsImVycm9yIiwiY2F0ZWdvcnkiLCJsYWJlbCIsInZhbHVlIiwibWVzc2FnZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUlBOztBQUdBOztBQUNBOztBQUtBOztBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsSUFBTUEsYUFBcUIsR0FBRyxRQUE5Qjs7QUFFTyxJQUFNQyxhQUFhLEdBQUcsU0FBaEJBLGFBQWdCLENBQUNDLE9BQUQsRUFBc0JDLEtBQXRCLEVBQXFDQyxJQUFyQyxFQUFtREMsRUFBbkQsRUFBdUY7QUFDbEgsTUFBTUMsTUFBYyxHQUFHLFNBQXZCO0FBRGtILE1BRTNHQyxRQUYyRyxHQUUvRkwsT0FGK0YsQ0FFM0dLLFFBRjJHO0FBR2xILE1BQU1DLFFBQWlCLEdBQUcsSUFBMUI7O0FBRUEsTUFBR0EsUUFBSCxFQUFhO0FBQ1gsUUFBTUMsTUFBYSxHQUFHLENBQ3BCO0FBQUNDLE1BQUFBLFVBQVUsRUFBRSxPQUFiO0FBQXNCQyxNQUFBQSxLQUFLLEVBQUU7QUFBN0IsS0FEb0IsRUFFcEI7QUFBQ0QsTUFBQUEsVUFBVSxFQUFFLE9BQWI7QUFBc0JDLE1BQUFBLEtBQUssRUFBRTtBQUE3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QUFFcEMyQixNQUFBQSxRQUFRLEVBQUVqQyxhQUYwQjtBQUdwQ2tDLE1BQUFBLEtBQUssRUFBRSxVQUg2QjtBQUlwQ0MsTUFBQUEsS0FBSyxFQUFFSCxLQUFLLENBQUNJO0FBSnVCLEtBQWIsRUFLdEJsQyxPQUxzQixFQUtiaUIsSUFMYSxDQUtSO0FBQUEsYUFBTSxJQUFOO0FBQUEsS0FMUSxDQUFsQjtBQUFBLEdBVkYsQ0FBUDtBQWdCRCxDQXZETSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2FxbH0gZnJvbSAnYXJhbmdvanMnO1xuaW1wb3J0IHtBcWxRdWVyeX0gZnJvbSAnYXJhbmdvanMvYXFsJztcbmltcG9ydCB7QXJyYXlDdXJzb3J9IGZyb20gJ2FyYW5nb2pzL2N1cnNvcic7XG5pbXBvcnQgZmxhdHRlbiBmcm9tICdsb2Rhc2gvZmxhdHRlbic7XG5pbXBvcnQgdW5pcUJ5IGZyb20gJ2xvZGFzaC91bmlxQnknO1xuXG5pbXBvcnQge0FyYW5nb0RCTGltaXR9IGZyb20gJy4uL3R5cGVzL2FyYW5nb2RiJztcbmltcG9ydCB7QXBpQ29udGV4dH0gZnJvbSAnLi4vdHlwZXMvYXV0aCc7XG5pbXBvcnQge1VzZXJUeXBlfSBmcm9tICcuLi90eXBlcy91c2Vycyc7XG5pbXBvcnQge2dldExpbWl0LCBsb2dFeGNlcHRpb24sIHVzZURifSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQge2dldERpc3BsYXlOYW1lfSBmcm9tICcuL3VzZXJzJztcblxuY29uc3QgZXZlbnRDYXRlZ29yeTogc3RyaW5nID0gJ3NlYXJjaCc7XG5cbmV4cG9ydCBjb25zdCBnZXRTZWFyY2hMaXN0ID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHF1ZXJ5OiBzdHJpbmcsIGZyb206IG51bWJlciwgdG86IG51bWJlcik6IFByb21pc2U8VXNlclR5cGVbXT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRMaXN0JztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGlzU3RyaW5nOiBib29sZWFuID0gdHJ1ZTtcblxuICBpZihpc1N0cmluZykge1xuICAgIGNvbnN0IGZpZWxkczogYW55W10gPSBbXG4gICAgICB7Y29sbGVjdGlvbjogJ3VzZXJzJywgZmllbGQ6ICdmaXJzdCd9LFxuICAgICAge2NvbGxlY3Rpb246ICd1c2VycycsIGZpZWxkOiAnbGFzdCd9LFxuICAgICAge2NvbGxlY3Rpb246ICd1c2VycycsIGZpZWxkOiAnZW1haWwnfSxcbiAgICAgIHtjb2xsZWN0aW9uOiAndXNlcnMnLCBmaWVsZDogJ3VzZXJuYW1lJ30sXG4gICAgICB7Y29sbGVjdGlvbjogJ3VzZXJzJywgZmllbGQ6ICduYW1lJ31cbiAgICBdO1xuXG4gICAgcmV0dXJuIFByb21pc2UuYWxsKGZpZWxkcy5tYXAoKG9iaikgPT4ge1xuICAgICAgY29uc3QgcXJ5OiBzdHJpbmcgPSBgcHJlZml4OiR7cXVlcnl9YDtcbiAgICAgIGNvbnN0IHVzZXJRcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiB1IElOIEZVTExURVhUKCR7b2JqLmNvbGxlY3Rpb259LCAke29iai5maWVsZH0sICR7cXJ5fSwgNTApIFJFVFVSTiB1YDtcbiAgICAgIHJldHVybiB1c2VEYihkYXRhYmFzZSkucXVlcnkodXNlclFyeSkudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKTtcbiAgICB9KSlcbiAgICAgIC50aGVuKChyZXN1bHRzKSA9PiB7XG4gICAgICAgIGNvbnN0IGxpc3QgPSB1bmlxQnkoZmxhdHRlbihyZXN1bHRzKSwgJ19rZXknKTtcblxuICAgICAgICByZXR1cm4gbGlzdC5tYXAoKGl0ZW06IFVzZXJUeXBlKSA9PiB7XG4gICAgICAgICAgY29uc3Qge19pZDogaXRlbUlkLCBuYW1lOiBpdGVtTmFtZX0gPSBpdGVtO1xuICAgICAgICAgIGNvbnN0IGNvbGxlY3Rpb25JZExpc3Q6IHN0cmluZ1tdID0gaXRlbUlkLnNwbGl0KCcvJyk7XG4gICAgICAgICAgY29uc3QgY29sbGVjdGlvbjogc3RyaW5nID0gY29sbGVjdGlvbklkTGlzdFswXTtcbiAgICAgICAgICBjb25zdCBuYW1lOiBzdHJpbmcgPSBjb2xsZWN0aW9uID09PSAndXNlcnMnID8gZ2V0RGlzcGxheU5hbWUoaXRlbSkgOiBpdGVtTmFtZTtcblxuICAgICAgICAgIHJldHVybiB7Li4uaXRlbSwgbmFtZX07XG4gICAgICAgIH0pO1xuICAgICAgfSk7XG4gIH1cblxuICBjb25zdCBsaW1pdDogQXJhbmdvREJMaW1pdCA9IGdldExpbWl0KGZyb20sIHRvKTtcbiAgY29uc3QgYXFsUXJ5OiBzdHJpbmcgPSBgRk9SIHUgSU4gdXNlcnNcbiAgICAgICAgRklMVEVSIHUucGhvbmUgPT0gXCIke3F1ZXJ5fVwiXG4gICAgICAgICR7bGltaXQuYXFsfVxuICAgICAgICBSRVRVUk4gdWA7XG5cbiAgcmV0dXJuIHVzZURiKGRhdGFiYXNlKS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5hbGwoKSlcbiAgICAudGhlbigobGlzdDogVXNlclR5cGVbXSA9IFtdKSA9PiBsaXN0Lm1hcCgoaXRlbSA9IHt9KSA9PiB7XG4gICAgICBjb25zdCB7X2lkOiBpdGVtSWQsIG5hbWU6IGl0ZW1OYW1lfSA9IGl0ZW07XG4gICAgICBjb25zdCBjb2xsZWN0aW9uSWRMaXN0OiBzdHJpbmdbXSA9IGl0ZW1JZC5zcGxpdCgnLycpO1xuICAgICAgY29uc3QgY29sbGVjdGlvbjogc3RyaW5nID0gY29sbGVjdGlvbklkTGlzdFswXTtcbiAgICAgIGNvbnN0IG5hbWU6IHN0cmluZyA9IGNvbGxlY3Rpb24gPT09ICd1c2VycycgPyBnZXREaXNwbGF5TmFtZShpdGVtKSA6IGl0ZW1OYW1lO1xuXG4gICAgICByZXR1cm4gey4uLml0ZW0sIG5hbWV9O1xuICAgIH0pKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFeGNlcHRpb24oe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJyxcbiAgICAgIHZhbHVlOiBlcnJvci5tZXNzYWdlXG4gICAgfSwgY29udGV4dCkudGhlbigoKSA9PiBudWxsKSk7XG59O1xuIl19
|
package/lib/data/sms.js
CHANGED
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
require("core-js/modules/es.object.to-string");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.promise");
|
|
6
|
+
|
|
3
7
|
Object.defineProperty(exports, "__esModule", {
|
|
4
8
|
value: true
|
|
5
9
|
});
|
|
@@ -76,4 +80,4 @@ var sendSmsTemplate = function sendSmsTemplate(templateName, smsParams) {
|
|
|
76
80
|
};
|
|
77
81
|
|
|
78
82
|
exports.sendSmsTemplate = sendSmsTemplate;
|
|
79
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL3Ntcy50cyJdLCJuYW1lcyI6WyJzZW5kU21zIiwicGFyYW1zIiwiYXBwIiwiY29udGVudCIsInVzZXIiLCJjb3VudHJ5IiwicGhvbmUiLCJ0ZW1wbGF0ZUNvbnRlbnQiLCJ0d2lsaW8iLCJDb25maWciLCJnZXQiLCJjZmciLCJib2R5IiwiZnJvbSIsInRvIiwiUHJvbWlzZSIsInJlc29sdmUiLCJyZWplY3QiLCJzZW5kTWVzc2FnZSIsImVycm9yIiwiZGF0YSIsIkVycm9yIiwiZXJyb3JfbWVzc2FnZSIsInNlbmRTbXNUZW1wbGF0ZSIsInRlbXBsYXRlTmFtZSIsInNtc1BhcmFtcyIsInZhcnMiLCJmcyIsInJlYWRGaWxlU3luYyIsInRleHQiLCJ0aGVuIiwicmVzIiwic3RhdHVzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUlBOztBQUNBOztBQUNBOztBQUVBOztBQUVBOzs7O0FBVkE7QUFDQTtBQUNBO0FBQ0E7QUFTQTtBQUVBO0FBQ08sSUFBTUEsT0FBTyxHQUFHLFNBQVZBLE9BQVUsQ0FBQ0MsTUFBRCxFQUFnQztBQUFBLG9CQUtqREEsTUFMaUQsQ0FFbkRDLEdBRm1EO0FBQUEsTUFFbkRBLEdBRm1ELDRCQUU3QyxFQUY2QztBQUFBLE1BR25EQyxPQUhtRCxHQUtqREYsTUFMaUQsQ0FHbkRFLE9BSG1EO0FBQUEscUJBS2pERixNQUxpRCxDQUluREcsSUFKbUQ7QUFBQSxNQUluREEsSUFKbUQsNkJBSTVDLEVBSjRDO0FBT3JELE1BQU1DLE9BQU8sR0FBR0QsSUFBSSxDQUFDQyxPQUFMLElBQWdCLElBQWhDO0FBQ0EsTUFBTUMsS0FBSyxHQUFHLHVCQUFXRixJQUFJLENBQUNFLEtBQWhCLEVBQXVCRCxPQUF2QixDQUFkO0FBQ0EsTUFBTUUsZUFBdUIsR0FBRyx3QkFBWUwsR0FBWixFQUFpQkMsT0FBakIsQ0FBaEM7QUFFQSxNQUFNSyxNQUFXLEdBQUcsd0JBQVVDLGVBQU9DLEdBQVAsQ0FBVyxZQUFYLENBQVYsRUFBb0NELGVBQU9DLEdBQVAsQ0FBVyxjQUFYLENBQXBDLENBQXBCO0FBQ0EsTUFBTUMsR0FBc0IsR0FBRztBQUM3QkMsSUFBQUEsSUFBSSxFQUFFTCxlQUR1QjtBQUU3Qk0sSUFBQUEsSUFBSSxFQUFFSixlQUFPQyxHQUFQLENBQVcsZUFBWCxDQUZ1QjtBQUc3QkksSUFBQUEsRUFBRSxFQUFFUjtBQUh5QixHQUEvQjtBQU1BLFNBQU8sSUFBSVMsT0FBSixDQUFZLFVBQUNDLE9BQUQsRUFBVUMsTUFBVixFQUFxQjtBQUN0Q1QsSUFBQUEsTUFBTSxDQUFDVSxXQUFQLENBQW1CUCxHQUFuQixFQUF3QixVQUFDUSxLQUFELEVBQVFDLElBQVIsRUFBaUI7QUFDdkMsVUFBR0QsS0FBSCxFQUFVO0FBQ1JGLFFBQUFBLE1BQU0sQ0FBQyxJQUFJSSxLQUFKLENBQVVGLEtBQUssQ0FBQ0csYUFBaEIsQ0FBRCxDQUFOO0FBQ0QsT0FGRCxNQUVPO0FBQ0xOLFFBQUFBLE9BQU8sQ0FBQ0ksSUFBRCxDQUFQO0FBQ0Q7QUFDRixLQU5EO0FBT0QsR0FSTSxDQUFQO0FBU0QsQ0EzQk07Ozs7QUE2QkEsSUFBTUcsZUFBZSxHQUFHLFNBQWxCQSxlQUFrQixDQUFDQyxZQUFELEVBQXVCQyxTQUF2QixFQUFzRTtBQUFBLE1BQzVGdkIsR0FENEYsR0FDekV1QixTQUR5RSxDQUM1RnZCLEdBRDRGO0FBQUEsTUFDdkZFLElBRHVGLEdBQ3pFcUIsU0FEeUUsQ0FDdkZyQixJQUR1RjtBQUFBLE1BQ2pGc0IsSUFEaUYsR0FDekVELFNBRHlFLENBQ2pGQyxJQURpRjs7QUFFbkcsTUFBSTtBQUNGLFFBQU1OLElBQUksR0FBR08sZUFBR0MsWUFBSCwyQkFBbUNKLFlBQW5DLFdBQXVELE1BQXZELENBQWI7O0FBQ0EsUUFBTUssSUFBSSxHQUFHLHdCQUFZM0IsR0FBWixFQUFpQmtCLElBQWpCLEVBQXVCTSxJQUF2QixDQUFiO0FBQ0EsUUFBTXpCLE1BQU0sR0FBRztBQUFDQyxNQUFBQSxHQUFHLEVBQUhBLEdBQUQ7QUFBTTJCLE1BQUFBLElBQUksRUFBSkEsSUFBTjtBQUFZekIsTUFBQUEsSUFBSSxFQUFKQTtBQUFaLEtBQWY7QUFFQSxXQUFPSixPQUFPLENBQUNDLE1BQUQsQ0FBUCxDQUNKNkIsSUFESSxDQUNDLFVBQUNDLEdBQUQ7QUFBQSxhQUFTQSxHQUFHLENBQUNDLE1BQUosS0FBZSxRQUF4QjtBQUFBLEtBREQsV0FFRSxVQUFDYixLQUFELEVBQWtCO0FBQ3ZCLFlBQU1BLEtBQU47QUFDRCxLQUpJLENBQVA7QUFLRCxHQVZELENBVUUsT0FBTUEsS0FBTixFQUFhO0FBQ2IsV0FBT0osT0FBTyxDQUFDRSxNQUFSLENBQWVFLEtBQWYsQ0FBUDtBQUNEO0FBQ0YsQ0FmTSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge3BhcnNlUGhvbmV9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQgZnMgZnJvbSAnZnMnO1xuaW1wb3J0IHR3aWxpb1NkayBmcm9tICd0d2lsaW8nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7U01TUGFyYW1zVHlwZSwgVHdpbGlvT3B0aW9uc1R5cGV9IGZyb20gJy4uL3R5cGVzL25vdGlmaWNhdGlvbnMnO1xuaW1wb3J0IHthcHBUZW1wbGF0ZX0gZnJvbSAnLi9lbWFpbCc7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdzbXMnO1xuXG4vLyBUd2lsaW9cbmV4cG9ydCBjb25zdCBzZW5kU21zID0gKHBhcmFtczogU01TUGFyYW1zVHlwZSk6IGFueSA9PiB7XG4gIGNvbnN0IHtcbiAgICBhcHAgPSB7fSxcbiAgICBjb250ZW50LFxuICAgIHVzZXIgPSB7fVxuICB9ID0gcGFyYW1zO1xuXG4gIGNvbnN0IGNvdW50cnkgPSB1c2VyLmNvdW50cnkgfHwgJ1VTJztcbiAgY29uc3QgcGhvbmUgPSBwYXJzZVBob25lKHVzZXIucGhvbmUsIGNvdW50cnkpO1xuICBjb25zdCB0ZW1wbGF0ZUNvbnRlbnQ6IHN0cmluZyA9IGFwcFRlbXBsYXRlKGFwcCwgY29udGVudCk7XG5cbiAgY29uc3QgdHdpbGlvOiBhbnkgPSB0d2lsaW9TZGsoQ29uZmlnLmdldCgndHdpbGlvLnNpZCcpLCBDb25maWcuZ2V0KCd0d2lsaW8udG9rZW4nKSk7XG4gIGNvbnN0IGNmZzogVHdpbGlvT3B0aW9uc1R5cGUgPSB7XG4gICAgYm9keTogdGVtcGxhdGVDb250ZW50LFxuICAgIGZyb206IENvbmZpZy5nZXQoJ3R3aWxpby5udW1iZXInKSxcbiAgICB0bzogcGhvbmVcbiAgfTtcblxuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIHR3aWxpby5zZW5kTWVzc2FnZShjZmcsIChlcnJvciwgZGF0YSkgPT4ge1xuICAgICAgaWYoZXJyb3IpIHtcbiAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihlcnJvci5lcnJvcl9tZXNzYWdlKSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXNvbHZlKGRhdGEpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBzZW5kU21zVGVtcGxhdGUgPSAodGVtcGxhdGVOYW1lOiBzdHJpbmcsIHNtc1BhcmFtczogU01TUGFyYW1zVHlwZSk6IFByb21pc2U8Ym9vbGVhbj4gPT4ge1xuICBjb25zdCB7YXBwLCB1c2VyLCB2YXJzfSA9IHNtc1BhcmFtcztcbiAgdHJ5IHtcbiAgICBjb25zdCBkYXRhID0gZnMucmVhZEZpbGVTeW5jKGAuL3RlbXBsYXRlcy9zbXMvJHt0ZW1wbGF0ZU5hbWV9LnR4dGAsICd1dGY4Jyk7XG4gICAgY29uc3QgdGV4dCA9IGFwcFRlbXBsYXRlKGFwcCwgZGF0YSwgdmFycyk7XG4gICAgY29uc3QgcGFyYW1zID0ge2FwcCwgdGV4dCwgdXNlcn07XG5cbiAgICByZXR1cm4gc2VuZFNtcyhwYXJhbXMpXG4gICAgICAudGhlbigocmVzKSA9PiByZXMuc3RhdHVzID09PSAncXVldWVkJylcbiAgICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgIHRocm93IGVycm9yO1xuICAgICAgfSk7XG4gIH0gY2F0Y2goZXJyb3IpIHtcbiAgICByZXR1cm4gUHJvbWlzZS5yZWplY3QoZXJyb3IpO1xuICB9XG59O1xuIl19
|
|
@@ -4,4 +4,4 @@ export declare const getPlanList: (context: ApiContext, from?: number, to?: numb
|
|
|
4
4
|
export declare const getSubscription: (context: ApiContext) => Promise<PaymentSubscription>;
|
|
5
5
|
export declare const addPlan: (context: ApiContext, item: PaymentPlan) => Promise<PaymentPlan>;
|
|
6
6
|
export declare const addSubscription: (context: ApiContext, item: any) => Promise<PaymentSubscription>;
|
|
7
|
-
export declare const deleteSubscription: (context: ApiContext
|
|
7
|
+
export declare const deleteSubscription: (context: ApiContext) => Promise<boolean>;
|