@nlabs/reaktor 0.5.3 → 0.6.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 (73) hide show
  1. package/README.md +7 -7
  2. package/lib/actions/conversations.js +36 -47
  3. package/lib/actions/dynamodb.js +22 -33
  4. package/lib/actions/email.js +32 -29
  5. package/lib/actions/files.js +46 -56
  6. package/lib/actions/groups.js +33 -28
  7. package/lib/actions/images.js +53 -63
  8. package/lib/actions/index.js +54 -37
  9. package/lib/actions/ios.js +21 -40
  10. package/lib/actions/locations.js +25 -22
  11. package/lib/actions/messages.js +28 -41
  12. package/lib/actions/notifications.d.ts +1 -1
  13. package/lib/actions/notifications.js +13 -20
  14. package/lib/actions/payments.js +37 -48
  15. package/lib/actions/posts.js +19 -42
  16. package/lib/actions/reactions.d.ts +1 -1
  17. package/lib/actions/reactions.js +17 -40
  18. package/lib/actions/s3.js +21 -18
  19. package/lib/actions/search.js +26 -40
  20. package/lib/actions/sms.js +24 -21
  21. package/lib/actions/statistics.js +14 -21
  22. package/lib/actions/subscription.js +27 -24
  23. package/lib/actions/tags.js +47 -54
  24. package/lib/actions/users.js +81 -94
  25. package/lib/actions/websockets.js +26 -39
  26. package/lib/config.js +21 -18
  27. package/lib/index.js +24 -22
  28. package/lib/lambdas/actions/websockets.js +27 -40
  29. package/lib/lambdas/authorizer.js +21 -18
  30. package/lib/lambdas/connection.js +26 -40
  31. package/lib/lambdas/utils/message.js +20 -17
  32. package/lib/lambdas/utils/websocket.js +33 -25
  33. package/lib/templates/email/layout.js +16 -9
  34. package/lib/templates/email/passwordForgot.js +16 -9
  35. package/lib/templates/email/passwordRecovery.js +16 -9
  36. package/lib/templates/email/verifyEmail.js +16 -9
  37. package/lib/templates/email/welcome.js +16 -9
  38. package/lib/templates/sms/passwordForgot.js +16 -9
  39. package/lib/templates/sms/passwordRecovery.js +16 -9
  40. package/lib/templates/sms/verifyEmail.js +16 -9
  41. package/lib/templates/sms/verifyPhone.js +16 -9
  42. package/lib/templates/sms/welcome.js +16 -9
  43. package/lib/types/apps.d.ts +1 -1
  44. package/lib/types/apps.js +14 -5
  45. package/lib/types/arangodb.js +14 -5
  46. package/lib/types/auth.js +14 -5
  47. package/lib/types/connections.js +14 -5
  48. package/lib/types/conversations.js +14 -5
  49. package/lib/types/email.js +14 -5
  50. package/lib/types/files.js +14 -5
  51. package/lib/types/google.js +14 -5
  52. package/lib/types/groups.js +14 -5
  53. package/lib/types/images.js +14 -5
  54. package/lib/types/index.js +50 -35
  55. package/lib/types/locations.js +14 -5
  56. package/lib/types/messages.js +14 -5
  57. package/lib/types/notifications.js +14 -5
  58. package/lib/types/payments.d.ts +1 -1
  59. package/lib/types/payments.js +14 -5
  60. package/lib/types/posts.js +14 -5
  61. package/lib/types/statistics.js +14 -5
  62. package/lib/types/tags.js +14 -5
  63. package/lib/types/users.js +14 -5
  64. package/lib/types/websocket.js +14 -5
  65. package/lib/utils/analytics.js +24 -44
  66. package/lib/utils/arangodb.js +14 -21
  67. package/lib/utils/auth.js +22 -36
  68. package/lib/utils/graphql.js +20 -17
  69. package/lib/utils/index.js +26 -23
  70. package/lib/utils/objects.js +22 -19
  71. package/lib/utils/session.js +20 -17
  72. package/package.json +31 -33
  73. package/.eslintrc +0 -18
@@ -1,47 +1,32 @@
1
1
  var __create = Object.create;
2
2
  var __defProp = Object.defineProperty;
3
- var __defProps = Object.defineProperties;
4
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
7
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
8
5
  var __getProtoOf = Object.getPrototypeOf;
9
6
  var __hasOwnProp = Object.prototype.hasOwnProperty;
10
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
11
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
- var __spreadValues = (a, b) => {
13
- for (var prop in b || (b = {}))
14
- if (__hasOwnProp.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- if (__getOwnPropSymbols)
17
- for (var prop of __getOwnPropSymbols(b)) {
18
- if (__propIsEnum.call(b, prop))
19
- __defNormalProp(a, prop, b[prop]);
20
- }
21
- return a;
22
- };
23
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
24
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
25
- var __require = typeof require !== "undefined" ? require : (x) => {
26
- throw new Error('Dynamic require of "' + x + '" is not supported');
27
- };
28
7
  var __export = (target, all) => {
29
- __markAsModule(target);
30
8
  for (var name in all)
31
9
  __defProp(target, name, { get: all[name], enumerable: true });
32
10
  };
33
- var __reExport = (target, module2, desc) => {
34
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
35
- for (let key of __getOwnPropNames(module2))
36
- if (!__hasOwnProp.call(target, key) && key !== "default")
37
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
38
16
  }
39
- return target;
17
+ return to;
40
18
  };
41
- var __toModule = (module2) => {
42
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
43
- };
44
- __export(exports, {
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var images_exports = {};
29
+ __export(images_exports, {
45
30
  addImage: () => addImage,
46
31
  addImageEdge: () => addImageEdge,
47
32
  deleteImage: () => deleteImage,
@@ -59,18 +44,19 @@ __export(exports, {
59
44
  resizeSaveImage: () => resizeSaveImage,
60
45
  updateImage: () => updateImage
61
46
  });
62
- var import_rip_hunter = __toModule(require("@nlabs/rip-hunter"));
63
- var import_utils = __toModule(require("@nlabs/utils"));
64
- var import_arangojs = __toModule(require("arangojs"));
65
- var import_file_type = __toModule(require("file-type"));
66
- var import_gm = __toModule(require("gm"));
67
- var import_cloneDeep = __toModule(require("lodash/cloneDeep"));
68
- var import_isEmpty = __toModule(require("lodash/isEmpty"));
69
- var import_luxon = __toModule(require("luxon"));
70
- var import_config = __toModule(require("../config"));
71
- var import_utils2 = __toModule(require("../utils"));
72
- var import_groups = __toModule(require("./groups"));
73
- var import_s32 = __toModule(require("./s3"));
47
+ module.exports = __toCommonJS(images_exports);
48
+ var import_rip_hunter = require("@nlabs/rip-hunter");
49
+ var import_utils = require("@nlabs/utils");
50
+ var import_arangojs = require("arangojs");
51
+ var import_file_type = __toESM(require("file-type"));
52
+ var import_gm = __toESM(require("gm"));
53
+ var import_cloneDeep = __toESM(require("lodash/cloneDeep"));
54
+ var import_isEmpty = __toESM(require("lodash/isEmpty"));
55
+ var import_luxon = require("luxon");
56
+ var import_config = require("../config");
57
+ var import_utils2 = require("../utils");
58
+ var import_groups = require("./groups");
59
+ var import_s32 = require("./s3");
74
60
  const eventCategory = "images";
75
61
  const parseImageOptions = (options = {}) => {
76
62
  const {
@@ -335,11 +321,12 @@ const resizeSaveImage = (context, imageId, buffer, type = "image/jpeg", s3Option
335
321
  } else {
336
322
  const formatVals = (0, import_utils2.lowerCaseKeys)(val);
337
323
  const { make: cameraMake, model: cameraModel, datetimeoriginal: taken } = formatVals;
338
- photo = __spreadProps(__spreadValues({}, (0, import_cloneDeep.default)(photo)), {
324
+ photo = {
325
+ ...(0, import_cloneDeep.default)(photo),
339
326
  make: cameraMake,
340
327
  model: cameraModel,
341
328
  taken: taken ? import_luxon.DateTime.fromMillis(taken).millisecond : null
342
- });
329
+ };
343
330
  const stats = formatVals["channel statistics"];
344
331
  if (stats) {
345
332
  let { red, green, blue, mean } = stats;
@@ -382,21 +369,21 @@ const resizeSaveImage = (context, imageId, buffer, type = "image/jpeg", s3Option
382
369
  });
383
370
  stdout.on("end", () => {
384
371
  photo.fileSize = imageBuffer.length;
385
- const imageObj = __spreadProps(__spreadValues({
372
+ const imageObj = {
386
373
  ACL: "authenticated-read",
387
374
  Body: imageBuffer,
388
375
  Bucket: null,
389
- ContentType: type
390
- }, s3Options || {}), {
376
+ ContentType: type,
377
+ ...s3Options || {},
391
378
  Key: getPathUserImages(sessionId, imageId, type, "images")
392
- });
379
+ };
393
380
  (0, import_s32.s3Put)(imageObj).then(() => {
394
381
  const thmW = import_config.Config.get("image.thmSize");
395
382
  const thmQ = import_config.Config.get("image.thmQuality");
396
383
  (0, import_gm.default)(imageBuffer, "img").setFormat("jpeg").size((thumbError, resizeVal) => {
397
384
  if (!thumbError) {
398
385
  const { height, width } = resizeVal;
399
- photo = __spreadProps(__spreadValues({}, (0, import_cloneDeep.default)(photo)), { height, width });
386
+ photo = { ...(0, import_cloneDeep.default)(photo), height, width };
400
387
  }
401
388
  }).gravity("Center").resize(thmW, thmW, "^").extent(thmW, thmW).quality(thmQ).stream((streamError, thumbStdout) => {
402
389
  if (streamError) {
@@ -414,14 +401,14 @@ const resizeSaveImage = (context, imageId, buffer, type = "image/jpeg", s3Option
414
401
  thumbBuffer = Buffer.concat([thumbBuffer, data]);
415
402
  });
416
403
  thumbStdout.on("end", () => {
417
- const thumbObj = __spreadProps(__spreadValues({
404
+ const thumbObj = {
418
405
  ACL: "authenticated-read",
419
406
  Body: thumbBuffer,
420
407
  Bucket: null,
421
- ContentType: type
422
- }, s3Options || {}), {
408
+ ContentType: type,
409
+ ...s3Options || {},
423
410
  Key: getPathUserImages(sessionId, imageId, type, "thumbs")
424
- });
411
+ };
425
412
  (0, import_s32.s3Put)(thumbObj).then(() => {
426
413
  resolve(photo);
427
414
  }).catch((s3PutError) => (0, import_utils2.logError)({
@@ -453,14 +440,15 @@ const addImage = (context, image, s3Options) => {
453
440
  const { imageId, description, buffer, fileType } = image;
454
441
  const now = Date.now();
455
442
  return resizeSaveImage(context, imageId, buffer, fileType, s3Options).then((resizedImage) => {
456
- const insert = __spreadProps(__spreadValues({}, resizedImage), {
443
+ const insert = {
444
+ ...resizedImage,
457
445
  _key: imageId,
458
446
  added: now,
459
447
  description,
460
448
  fileType,
461
449
  modified: now,
462
450
  userId: sessionId
463
- });
451
+ };
464
452
  const aqlQry = import_arangojs.aql`INSERT ${insert} IN images RETURN NEW`;
465
453
  return database.query(aqlQry).then((cursor) => cursor.next()).then(import_utils2.defaultObject).catch((error) => (0, import_utils2.logError)({
466
454
  action,
@@ -557,14 +545,15 @@ const updateImage = async (context, image, s3Options) => {
557
545
  }
558
546
  let updatedFileType = fileType;
559
547
  if (!fileType) {
560
- const fileMime = await import_file_type.default.fromBuffer(buffer);
548
+ const fileMime = await import_file_type.default.fileTypeFromBuffer(buffer);
561
549
  const { mime } = fileMime;
562
550
  updatedFileType = mime;
563
551
  }
564
- const imgParams = __spreadProps(__spreadValues({}, customParams), {
552
+ const imgParams = {
553
+ ...customParams,
565
554
  buffer,
566
555
  fileType: updatedFileType
567
- });
556
+ };
568
557
  return addImage(context, imgParams, s3Options).then((image2) => {
569
558
  if (formatItemId && formatItemType) {
570
559
  const imageEdge = {
@@ -594,10 +583,11 @@ const updateImage = async (context, image, s3Options) => {
594
583
  contentType = res.headers.get("content-type");
595
584
  return res;
596
585
  }).then((res) => res.buffer()).then((buffer) => {
597
- const imgParams = __spreadProps(__spreadValues({}, customParams), {
586
+ const imgParams = {
587
+ ...customParams,
598
588
  buffer,
599
589
  fileType: contentType
600
- });
590
+ };
601
591
  return addImage(context, imgParams, s3Options).then((image2) => {
602
592
  if (formatItemId && formatItemType) {
603
593
  const imageEdge = { imageId: formatImageId, itemId: formatItemId, itemType: formatItemType };
@@ -682,4 +672,4 @@ const deleteImage = async (context, imageId) => {
682
672
  resizeSaveImage,
683
673
  updateImage
684
674
  });
685
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/images.ts"],
  "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 {get as httpGet} from '@nlabs/rip-hunter';\nimport {createHash, parseArangoId, parseChar, parseId, parseNum} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {DeleteObjectsRequest, PutObjectRequest} from 'aws-sdk/clients/s3';\nimport FileType, {FileTypeResult} from 'file-type';\nimport gm from 'gm';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEmpty from 'lodash/isEmpty';\nimport {DateTime} from 'luxon';\n\nimport {Config} from '../config';\nimport {\n  ApiContext,\n  ArangoDBLimit,\n  GroupType,\n  GroupUser,\n  ImageEdgeType,\n  ImageIdentifyType,\n  ImageOptions,\n  ImageType,\n  ImageUrlData,\n  QueryFilter\n} from '../types';\nimport {defaultObject, getLimit, logError, logException, lowerCaseKeys, selectReactionCountByType} from '../utils';\nimport {getGroupDetails, isGrouped} from './groups';\nimport {s3DeleteList, s3GetSignedUrl, s3Put} from './s3';\n\nconst eventCategory: string = 'images';\n\nexport const parseImageOptions = (options: ImageOptions = {}) => {\n  const {\n    from = 0,\n    to = 30,\n    type = 'default'\n  } = options;\n\n  return {\n    limit: getLimit(from, to),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getImageOptional = (fields: string[] = []) =>\n  fields.reduce((selects: any, field: string) => {\n    if(field.includes('Count')) {\n      return selectReactionCountByType('images', 'i', field, selects);\n    }\n\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR image, r IN INBOUND i._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND i._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER i.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getImagesByUser = (\n  context: ApiContext,\n  userId: string,\n  from: number,\n  to: number\n): Promise<ImageType[]> => {\n  const action: string = 'getImagesByUser';\n  const {database} = context;\n  const formatUserId: string = parseId(userId);\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR i IN images\n      FILTER i.userId == \"${formatUserId}\"\n      LET user = FIRST(\n        FOR u IN users\n        FILTER u._key == i.userId\n        LIMIT 1\n        RETURN u\n      )\n      ${limit.aql}\n      SORT i.added\n      RETURN MERGE(i, {user:user})`;\n\n  return 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 getImageCountByItem = (context: ApiContext, itemId: string): Promise<number> => {\n  const action: string = 'getImageCountByItem';\n  const {database} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const aqlQry: AqlQuery = aql`FOR i IN hasImages\n      FILTER i._to == ${formatItemId}\n      RETURN {count: COUNT(i)}`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then(({count} = {count: 0}) => count)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => 0));\n};\n\nexport const getImagesByItem = async (\n  context: ApiContext,\n  itemId: string,\n  options: ImageOptions = {}\n): Promise<ImageType[]> => {\n  const action: string = 'getImagesByItem';\n  const {database, fields = []} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const {limit} = parseImageOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getImageOptional(fields);\n  const aqlQry: string = `FOR i, l IN 1..1 OUTBOUND \"${formatItemId}\" hasImages\n    FILTER NOT IS_NULL(i)\n    ${selectQueries.join('\\n')}\n    SORT i.added\n    ${limit.aql}\n    RETURN MERGE(i, {${selectObjects.join(', ')}})`;\n\n  return 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 getImagesByGroup = (context: ApiContext, params): Promise<ImageType[]> => {\n  const action: string = 'getImagesByGroup';\n  const {database, session: {userId: sessionId}} = context;\n  const {filters = [], groupId, from, to} = params;\n  const formatGroupId: string = parseId(groupId);\n  const limit = getLimit(from, to);\n\n  filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value} = filter;\n      let formatCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        formatCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `p.added ${formatCond} ${parseNum(value)}`;\n        default:\n          return '';\n      }\n    });\n\n  return getGroupDetails(context, formatGroupId)\n    .then((group: GroupType) => {\n      if(group.privacy === 'public') {\n        filters.push(`p.groupId == \"${groupId}\"`);\n        const filterStr = filters.join(' && ');\n        const aqlQry: string = `FOR i IN\n          FLATTEN(\n            FOR p IN posts\n            FILTER ${filterStr}\n            LET images = (\n              FOR i, e IN INBOUND p._id hasImages\n              RETURN i\n            )\n            SORT p.added DESC\n            RETURN images\n          )\n          SORT i.added DESC\n          ${limit.aql}\n          RETURN i`;\n\n        return 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      return isGrouped(database, sessionId, groupId)\n        .then((grouped: GroupUser) => {\n          if(grouped.isValid) {\n            filters.push(`p.groupId == \"${grouped.groupId}\"`);\n            const filterList: string = filters.join(' && ');\n            const aqlQry: string = `FOR p IN post\n                FILTER ${filterList}\n                FOR f IN p.files\n                FILTER f.type == \"image/jpeg\" || f.type == \"image/png\"\n                ${limit.aql}\n                SORT p.added DESC\n                RETURN f`;\n\n            return 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          return [];\n        });\n    });\n};\n\nexport const getImagesByReactions = (\n  context: ApiContext,\n  reactions: string[] = [],\n  options?: ImageOptions\n): Promise<ImageType[]> => {\n  const action: string = 'getUsersByImage';\n  const {database, fields = [], session: {userId: sessionId}} = context;\n  const {limit} = parseImageOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getImageOptional(fields);\n\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactions: string[] = reactions.map((reactionName) => parseChar(reactionName, 32));\n  const filterBy: string[] = [\n    'r.type == \"images\"',\n    `POSITION(${JSON.stringify(formatReactions)}, LOWER(r.name))`];\n\n  // Get data from database\n  const aqlQry: string = `FOR i, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    OPTIONS {vertexCollections: \"images\"}\n    ${selectQueries.join('\\n')}\n    FILTER ${filterBy.join(' && ')}\n    ${limit.aql}\n    RETURN MERGE(i, {${selectObjects.join(', ')}})`;\n\n  return 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 getImage = (context: ApiContext, id: string): Promise<ImageType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const formatId: string = parseId(id);\n  const aqlQry: AqlQuery = aql`FOR i IN images\n    FILTER i._key==${formatId}\n    LIMIT 1\n    RETURN i`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((image: ImageType = {}) => image)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getPathUserImages = (userId: string, imageId: string, type: string, dir: string = 'images'): string => {\n  let filename: string = imageId;\n\n  switch(type) {\n    case 'image/png':\n      filename = `${imageId}.png`;\n      break;\n    default:\n      filename = `${imageId}.jpg`;\n      break;\n  }\n\n  return `users/${userId}/${dir}/${filename}`;\n};\n\nexport const getAppImageUrl = (data: ImageUrlData): string => {\n  const {imageId, directory = 'images', imageType = 'profile', isThumb, type, typeId} = data;\n  const host: string = Config.get('environment') === 'prod'\n    ? `https://box.${Config.get('app.url')}`\n    : `https://s3.amazonaws.com/dev.${Config.get('app.url')}`;\n  const suffix: string = isThumb ? '-th' : '';\n\n  if(imageId) {\n    switch(type) {\n      case 'apps':\n        // https://box.reaktor.io/myApp/app/images/123.jpg\n        return `${host}/${type}/${directory}/${imageId}${suffix}.jpg`;\n      case 'users':\n        // https://box.reaktor.io/myApp/users/demoUser/images/123.jpg\n        return `${host}/${type}/${typeId}/${directory}/${imageId}${suffix}.jpg`;\n    }\n\n    if(imageType === 'profile') {\n      return `${host}/defaults/${type}_bk${suffix}.jpg`;\n    }\n\n    return `${host}/defaults/${type}_wh${suffix}.jpg`;\n  }\n\n  return '';\n};\n\nexport const getUserImageUrl = (data: ImageUrlData): string => {\n  const {bucket, imageId, isThumb = false, userId} = data;\n  const imgDir: string = isThumb ? 'thumbs' : 'images';\n\n  if(imageId) {\n    const imageKey: string = `users/${userId}/${imgDir}/${imageId}.jpg`;\n    return s3GetSignedUrl({Bucket: bucket, Key: imageKey, Expires: 900});\n  }\n\n  return '';\n};\n\nexport const resizeSaveImage = (\n  context: ApiContext,\n  imageId: string,\n  buffer: Buffer,\n  type: string = 'image/jpeg', s3Options?: PutObjectRequest): Promise<ImageType> => {\n  const action: string = 'resizeSaveImage';\n  const {session: {userId: sessionId}} = context;\n  const imgW: number = Config.get('image.imgSize');\n  const imgQ: number = Config.get('image.imgQuality');\n  let photo: ImageType = {};\n  const format: string = (type.split('/'))[1];\n\n  console.log({buffer, format, imgW, imgQ});\n  return new Promise((resolve) => {\n    gm(buffer, 'img')\n      .setFormat(format)\n      .quality(imgQ)\n      .autoOrient()\n      .resize(imgW, imgW, '>')\n      .identify({bufferStream: true}, (error: Error, val: ImageIdentifyType = {}): any => {\n        if(error) {\n          logError({\n            action,\n            category: eventCategory,\n            label: 'image_save',\n            value: 'gm_image_identify'\n          }, error, context).catch((error) => {\n            throw error;\n          });\n        } else {\n          const formatVals = lowerCaseKeys(val);\n          const {make: cameraMake, model: cameraModel, datetimeoriginal: taken}: ImageIdentifyType = formatVals;\n          photo = {\n            ...cloneDeep(photo),\n            make: cameraMake,\n            model: cameraModel,\n            taken: taken ? DateTime.fromMillis(taken).millisecond : null\n          };\n\n          // If no background color, get the mean color value\n          const stats = formatVals['channel statistics'];\n\n          if(stats) {\n            let {red, green, blue, mean} = stats;\n\n            if(red) {\n              mean = red['standard deviation'] || red.mean;\n              red = mean ? +((mean.split(' ')[0]).substring(0, 3)) : 0;\n            } else {\n              red = 0;\n            }\n\n            if(green) {\n              mean = green['standard deviation'] || green.mean;\n              green = mean ? +((mean.split(' ')[0]).substring(0, 3)) : 0;\n            } else {\n              green = 0;\n            }\n\n            if(blue) {\n              mean = blue['standard deviation'] || blue.mean;\n              blue = mean ? +((mean.split(' ')[0]).substring(0, 3)) : 0;\n            } else {\n              blue = 0;\n            }\n\n            const rgb = blue | (green << 8) | (red << 16);\n            const color = rgb.toString(16);\n            photo.color = color === '0' ? '000000' : color;\n          }\n        }\n      })\n      .stream((error: Error, stdout): any => {\n        if(error) {\n          logError({\n            action,\n            category: eventCategory,\n            isInternal: true,\n            label: 'image_save',\n            value: 'gm_image_stream'\n          }, error, context).then(() => null);\n        } else {\n          let imageBuffer: Buffer = Buffer.from('');\n\n          stdout.on('data', (data) => {\n            imageBuffer = Buffer.concat([imageBuffer, data]);\n          });\n\n          stdout.on('end', () => {\n            // Get file size\n            photo.fileSize = imageBuffer.length;\n\n            // Upload data\n            const imageObj: PutObjectRequest = {\n              ACL: 'authenticated-read',\n              Body: imageBuffer,\n              Bucket: null,\n              ContentType: type,\n              ...s3Options || {},\n              Key: getPathUserImages(sessionId, imageId, type, 'images')\n            };\n\n            s3Put(imageObj)\n              .then(() => {\n                const thmW = Config.get('image.thmSize');\n                const thmQ = Config.get('image.thmQuality');\n\n                // Upload thumbnail\n                gm(imageBuffer, 'img')\n                  .setFormat('jpeg')\n                  .size((thumbError: Error, resizeVal) => {\n                    if(!thumbError) {\n                      // Get updated resize values\n                      const {height, width} = resizeVal;\n                      photo = {...cloneDeep(photo), height, width};\n                    }\n                  })\n                  .gravity('Center')\n                  .resize(thmW, thmW, '^')\n                  .extent(thmW, thmW)\n                  .quality(thmQ)\n                  .stream((streamError: Error, thumbStdout): any => {\n                    if(streamError) {\n                      logError({\n                        action,\n                        category: eventCategory,\n                        label: 'image_save',\n                        value: 'gm_thumbnail_steam'\n                      }, streamError, context)\n                        .catch((error) => {\n                          throw error;\n                        });\n                    } else {\n                      let thumbBuffer: Buffer = Buffer.from('');\n\n                      thumbStdout.on('data', (data) => {\n                        thumbBuffer = Buffer.concat([thumbBuffer, data]);\n                      });\n\n                      thumbStdout.on('end', () => {\n                        // Upload data\n                        const thumbObj: PutObjectRequest = {\n                          ACL: 'authenticated-read',\n                          Body: thumbBuffer,\n                          Bucket: null,\n                          ContentType: type,\n                          ...s3Options || {},\n                          Key: getPathUserImages(sessionId, imageId, type, 'thumbs')\n                        };\n\n                        s3Put(thumbObj)\n                          .then(() => {\n                            resolve(photo);\n                          })\n                          .catch((s3PutError) => logError({\n                            action,\n                            category: eventCategory,\n                            label: 'image_save',\n                            value: 's3_put_image'\n                          }, s3PutError, context)\n                            .catch((error) => {\n                              throw error;\n                            }));\n                      });\n                    }\n                  });\n              })\n              .catch((s3Error) => logError({\n                action,\n                category: eventCategory,\n                isInternal: true,\n                label: 'image_save',\n                value: 's3_image_save'\n              }, s3Error, context).then(() => null));\n          });\n        }\n      });\n  });\n};\n\nexport const addImage = (context: ApiContext, image: ImageType, s3Options?: PutObjectRequest): Promise<ImageType> => {\n  const action: string = 'addImage';\n  const {database, session: {userId: sessionId}} = context;\n  const {imageId, description, buffer, fileType} = image;\n  const now: number = Date.now();\n\n  return resizeSaveImage(context, imageId, buffer, fileType, s3Options)\n    .then((resizedImage: any) => {\n      const insert: ImageType = {\n        ...resizedImage,\n        _key: imageId,\n        added: now,\n        description,\n        fileType,\n        modified: now,\n        userId: sessionId\n      };\n\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN images RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then(defaultObject)\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          isInternal: true,\n          label: 'db_error'\n        }, error, context).then(() => null));\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      isInternal: true,\n      label: 'image_resize'\n    }, error, context).then(() => null));\n};\n\nexport const addImageEdge = async (context: ApiContext, imageEdge: ImageEdgeType): Promise<object> => {\n  const action: string = 'addImageEdge';\n  const {database, session: {userId: sessionId}} = context;\n  const {imageId, itemId, itemType} = imageEdge;\n  const now: number = Date.now();\n  const edgeCollection: EdgeCollection = database.collection('hasImages');\n  const edgeId: string = createHash(`hasImages-${imageId}-${itemId}-${sessionId}`);\n  const formatItemType: string = parseChar(itemType).toLowerCase();\n  const formatItemId: string = parseId(itemId);\n  let itemDocId: string;\n  const formatImgId: string = parseId(imageId);\n  const fileDocId: string = `images/${formatImgId}`;\n\n  switch(formatItemType) {\n    case 'groups':\n      itemDocId = `groups/${formatItemId}`;\n      break;\n    case 'posts':\n      itemDocId = `posts/${formatItemId}`;\n      break;\n    case 'users':\n    case 'profile':\n      itemDocId = `users/${formatItemId}`;\n      break;\n    default:\n      itemDocId = '';\n      break;\n  }\n  const edge: any = {\n    _from: itemDocId,\n    _key: edgeId,\n    _to: fileDocId,\n    added: now,\n    type: itemType\n  };\n\n  if(!isEmpty(itemDocId)) {\n    return edgeCollection.save(edge, {returnNew: true})\n      .then((fileEdge) => edgeCollection.document(fileEdge))\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        isInternal: true,\n        label: 'db_error',\n        params: {\n          edge,\n          fileDocId,\n          imageId,\n          itemDocId,\n          itemId,\n          itemType\n        }\n      }, error, context).then(() => null));\n  }\n\n  return {};\n};\n\nexport const updateImage = async (\n  context: ApiContext,\n  image: ImageType,\n  s3Options?: PutObjectRequest\n): Promise<ImageType> => {\n  const action: string = 'updateImage';\n  const {database, session: {userId: sessionId}} = context;\n\n  // Item props\n  const {\n    base64 = '',\n    buffer: imageBuffer,\n    description = '',\n    imageId,\n    itemId,\n    itemType,\n    fileType,\n    url = ''\n  } = image;\n\n  // Save Base64 data\n  const now: number = Date.now();\n  const formatImageId: string = imageId || createHash(`image-${sessionId}`);\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 16).toLowerCase();\n  const customParams: ImageType = {\n    description,\n    imageId: formatImageId,\n    userId: sessionId\n  };\n\n  if(!isEmpty(base64) || imageBuffer) {\n    let buffer: Buffer = imageBuffer;\n\n    // Parse Base64 data\n    if(!isEmpty(base64)) {\n      const formatBase64: string = base64.substr(base64.indexOf(',') + 1);\n      buffer = Buffer.from(formatBase64, 'base64');\n    }\n\n    let updatedFileType = fileType;\n\n    if(!fileType) {\n      const fileMime: FileTypeResult = await FileType.fromBuffer(buffer);\n      const {mime} = fileMime;\n      updatedFileType = mime;\n    }\n\n    const imgParams: ImageType = {\n      ...customParams,\n      buffer,\n      fileType: updatedFileType\n    };\n\n    return addImage(context, imgParams, s3Options)\n      .then((image: ImageType) => {\n        if(formatItemId && formatItemType) {\n          const imageEdge: ImageEdgeType = {\n            imageId: formatImageId,\n            itemId: formatItemId,\n            itemType: formatItemType\n          };\n          return addImageEdge(context, imageEdge).then(() => image);\n        }\n\n        return image;\n      })\n      .catch((error) => logError({\n        action,\n        category: eventCategory,\n        label: 'image_save_error'\n      }, error, context).then(() => null));\n  } else if(url !== '') {\n    // Download image from the web\n    let contentType: string;\n\n    return httpGet(url)\n      .then((res: Response) => {\n        if(res.status !== 200) {\n          return logException({\n            action,\n            category: eventCategory,\n            label: 'fetch_image_url',\n            value: res.statusText\n          }, context).then(() => null);\n        }\n\n        contentType = res.headers.get('content-type');\n\n        return res;\n      })\n      .then((res) => res.buffer())\n      .then((buffer: Buffer) => {\n        const imgParams: ImageType = {\n          ...customParams,\n          buffer,\n          fileType: contentType\n        };\n\n        return addImage(context, imgParams, s3Options).then((image: ImageType) => {\n          if(formatItemId && formatItemType) {\n            const imageEdge: ImageEdgeType = {imageId: formatImageId, itemId: formatItemId, itemType: formatItemType};\n            return addImageEdge(context, imageEdge).then(() => image);\n          }\n\n          return image;\n        });\n      })\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'fetch_error'\n      }, error, context).then(() => null));\n  } else if(imageId !== '') {\n    // Update metadata\n    const update: any = {\n      description,\n      modified: now\n    };\n    const aqlQry: AqlQuery = aql`UPDATE {_key: ${formatImageId}} WITH ${update} IN images RETURN NEW`;\n\n    return database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error',\n        params: {\n          aqlQry,\n          formatImageId,\n          update\n        }\n      }, error, context).then(() => null));\n  }\n\n  return null;\n};\n\nexport const deleteImage = async (context: ApiContext, imageId: string): Promise<ImageType> => {\n  const action: string = 'delete';\n  const {database, session: {userId: sessionId}} = context;\n  const formatImageId = parseId(imageId);\n\n  const removeEdgeQuery = aql`FOR hi IN hasImages\n    FILTER hi._from == ${formatImageId}\n    REMOVE hi IN hasImages\n    RETURN OLD`;\n\n  await database.query(removeEdgeQuery);\n\n  const aqlQuery = aql`FOR i IN images\n    FILTER i._key == ${formatImageId} && i.userId == ${sessionId}\n    REMOVE i IN images\n    RETURN OLD`;\n\n  const image = await database.query(aqlQuery)\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  if(!isEmpty(image)) {\n    const {_key: imageKey} = image;\n    const params: DeleteObjectsRequest = {\n      Bucket: null,\n      Delete: {\n        Objects: [\n          {Key: `users/${sessionId}/images/${imageKey}.jpg`},\n          {Key: `users/${sessionId}/thumbs/${imageKey}.jpg`}\n        ],\n        Quiet: true\n      }\n    };\n\n    return s3DeleteList(params).then(() => image);\n  }\n\n  return {};\n};\n"],
  "mappings": "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",
  "names": []
}

675
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/images.ts"],
  "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 {get as httpGet} from '@nlabs/rip-hunter';\nimport {createHash, parseArangoId, parseChar, parseId, parseNum} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {DeleteObjectsRequest, PutObjectRequest} from 'aws-sdk/clients/s3';\nimport FileType, {FileTypeResult} from 'file-type';\nimport gm from 'gm';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEmpty from 'lodash/isEmpty';\nimport {DateTime} from 'luxon';\n\nimport {Config} from '../config';\nimport {\n  ApiContext,\n  ArangoDBLimit,\n  GroupType,\n  GroupUser,\n  ImageEdgeType,\n  ImageIdentifyType,\n  ImageOptions,\n  ImageType,\n  ImageUrlData,\n  QueryFilter\n} from '../types';\nimport {defaultObject, getLimit, logError, logException, lowerCaseKeys, selectReactionCountByType} from '../utils';\nimport {getGroupDetails, isGrouped} from './groups';\nimport {s3DeleteList, s3GetSignedUrl, s3Put} from './s3';\n\nconst eventCategory: string = 'images';\n\nexport const parseImageOptions = (options: ImageOptions = {}) => {\n  const {\n    from = 0,\n    to = 30,\n    type = 'default'\n  } = options;\n\n  return {\n    limit: getLimit(from, to),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getImageOptional = (fields: string[] = []) =>\n  fields.reduce((selects: any, field: string) => {\n    if(field.includes('Count')) {\n      return selectReactionCountByType('images', 'i', field, selects);\n    }\n\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR image, r IN INBOUND i._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND i._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER i.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getImagesByUser = (\n  context: ApiContext,\n  userId: string,\n  from: number,\n  to: number\n): Promise<ImageType[]> => {\n  const action: string = 'getImagesByUser';\n  const {database} = context;\n  const formatUserId: string = parseId(userId);\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR i IN images\n      FILTER i.userId == \"${formatUserId}\"\n      LET user = FIRST(\n        FOR u IN users\n        FILTER u._key == i.userId\n        LIMIT 1\n        RETURN u\n      )\n      ${limit.aql}\n      SORT i.added\n      RETURN MERGE(i, {user:user})`;\n\n  return 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 getImageCountByItem = (context: ApiContext, itemId: string): Promise<number> => {\n  const action: string = 'getImageCountByItem';\n  const {database} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const aqlQry: AqlQuery = aql`FOR i IN hasImages\n      FILTER i._to == ${formatItemId}\n      RETURN {count: COUNT(i)}`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then(({count} = {count: 0}) => count)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => 0));\n};\n\nexport const getImagesByItem = async (\n  context: ApiContext,\n  itemId: string,\n  options: ImageOptions = {}\n): Promise<ImageType[]> => {\n  const action: string = 'getImagesByItem';\n  const {database, fields = []} = context;\n  const formatItemId: string = parseArangoId(itemId);\n  const {limit} = parseImageOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getImageOptional(fields);\n  const aqlQry: string = `FOR i, l IN 1..1 OUTBOUND \"${formatItemId}\" hasImages\n    FILTER NOT IS_NULL(i)\n    ${selectQueries.join('\\n')}\n    SORT i.added\n    ${limit.aql}\n    RETURN MERGE(i, {${selectObjects.join(', ')}})`;\n\n  return 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 getImagesByGroup = (context: ApiContext, params): Promise<ImageType[]> => {\n  const action: string = 'getImagesByGroup';\n  const {database, session: {userId: sessionId}} = context;\n  const {filters = [], groupId, from, to} = params;\n  const formatGroupId: string = parseId(groupId);\n  const limit = getLimit(from, to);\n\n  filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value} = filter;\n      let formatCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        formatCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `p.added ${formatCond} ${parseNum(value)}`;\n        default:\n          return '';\n      }\n    });\n\n  return getGroupDetails(context, formatGroupId)\n    .then((group: GroupType) => {\n      if(group.privacy === 'public') {\n        filters.push(`p.groupId == \"${groupId}\"`);\n        const filterStr = filters.join(' && ');\n        const aqlQry: string = `FOR i IN\n          FLATTEN(\n            FOR p IN posts\n            FILTER ${filterStr}\n            LET images = (\n              FOR i, e IN INBOUND p._id hasImages\n              RETURN i\n            )\n            SORT p.added DESC\n            RETURN images\n          )\n          SORT i.added DESC\n          ${limit.aql}\n          RETURN i`;\n\n        return 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      return isGrouped(database, sessionId, groupId)\n        .then((grouped: GroupUser) => {\n          if(grouped.isValid) {\n            filters.push(`p.groupId == \"${grouped.groupId}\"`);\n            const filterList: string = filters.join(' && ');\n            const aqlQry: string = `FOR p IN post\n                FILTER ${filterList}\n                FOR f IN p.files\n                FILTER f.type == \"image/jpeg\" || f.type == \"image/png\"\n                ${limit.aql}\n                SORT p.added DESC\n                RETURN f`;\n\n            return 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          return [];\n        });\n    });\n};\n\nexport const getImagesByReactions = (\n  context: ApiContext,\n  reactions: string[] = [],\n  options?: ImageOptions\n): Promise<ImageType[]> => {\n  const action: string = 'getUsersByImage';\n  const {database, fields = [], session: {userId: sessionId}} = context;\n  const {limit} = parseImageOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getImageOptional(fields);\n\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactions: string[] = reactions.map((reactionName) => parseChar(reactionName, 32));\n  const filterBy: string[] = [\n    'r.type == \"images\"',\n    `POSITION(${JSON.stringify(formatReactions)}, LOWER(r.name))`];\n\n  // Get data from database\n  const aqlQry: string = `FOR i, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    OPTIONS {vertexCollections: \"images\"}\n    ${selectQueries.join('\\n')}\n    FILTER ${filterBy.join(' && ')}\n    ${limit.aql}\n    RETURN MERGE(i, {${selectObjects.join(', ')}})`;\n\n  return 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 getImage = (context: ApiContext, id: string): Promise<ImageType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const formatId: string = parseId(id);\n  const aqlQry: AqlQuery = aql`FOR i IN images\n    FILTER i._key==${formatId}\n    LIMIT 1\n    RETURN i`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((image: ImageType = {}) => image)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getPathUserImages = (userId: string, imageId: string, type: string, dir: string = 'images'): string => {\n  let filename: string = imageId;\n\n  switch(type) {\n    case 'image/png':\n      filename = `${imageId}.png`;\n      break;\n    default:\n      filename = `${imageId}.jpg`;\n      break;\n  }\n\n  return `users/${userId}/${dir}/${filename}`;\n};\n\nexport const getAppImageUrl = (data: ImageUrlData): string => {\n  const {imageId, directory = 'images', imageType = 'profile', isThumb, type, typeId} = data;\n  const host: string = Config.get('environment') === 'prod'\n    ? `https://box.${Config.get('app.url')}`\n    : `https://s3.amazonaws.com/dev.${Config.get('app.url')}`;\n  const suffix: string = isThumb ? '-th' : '';\n\n  if(imageId) {\n    switch(type) {\n      case 'apps':\n        // https://box.reaktor.io/myApp/app/images/123.jpg\n        return `${host}/${type}/${directory}/${imageId}${suffix}.jpg`;\n      case 'users':\n        // https://box.reaktor.io/myApp/users/demoUser/images/123.jpg\n        return `${host}/${type}/${typeId}/${directory}/${imageId}${suffix}.jpg`;\n    }\n\n    if(imageType === 'profile') {\n      return `${host}/defaults/${type}_bk${suffix}.jpg`;\n    }\n\n    return `${host}/defaults/${type}_wh${suffix}.jpg`;\n  }\n\n  return '';\n};\n\nexport const getUserImageUrl = (data: ImageUrlData): string => {\n  const {bucket, imageId, isThumb = false, userId} = data;\n  const imgDir: string = isThumb ? 'thumbs' : 'images';\n\n  if(imageId) {\n    const imageKey: string = `users/${userId}/${imgDir}/${imageId}.jpg`;\n    return s3GetSignedUrl({Bucket: bucket, Key: imageKey, Expires: 900});\n  }\n\n  return '';\n};\n\nexport const resizeSaveImage = (\n  context: ApiContext,\n  imageId: string,\n  buffer: Buffer,\n  type: string = 'image/jpeg', s3Options?: PutObjectRequest): Promise<ImageType> => {\n  const action: string = 'resizeSaveImage';\n  const {session: {userId: sessionId}} = context;\n  const imgW: number = Config.get('image.imgSize');\n  const imgQ: number = Config.get('image.imgQuality');\n  let photo: ImageType = {};\n  const format: string = (type.split('/'))[1];\n\n  console.log({buffer, format, imgW, imgQ});\n  return new Promise((resolve) => {\n    gm(buffer, 'img')\n      .setFormat(format)\n      .quality(imgQ)\n      .autoOrient()\n      .resize(imgW, imgW, '>')\n      .identify({bufferStream: true}, (error: Error, val: ImageIdentifyType = {}): any => {\n        if(error) {\n          logError({\n            action,\n            category: eventCategory,\n            label: 'image_save',\n            value: 'gm_image_identify'\n          }, error, context).catch((error) => {\n            throw error;\n          });\n        } else {\n          const formatVals = lowerCaseKeys(val);\n          const {make: cameraMake, model: cameraModel, datetimeoriginal: taken}: ImageIdentifyType = formatVals;\n          photo = {\n            ...cloneDeep(photo),\n            make: cameraMake,\n            model: cameraModel,\n            taken: taken ? DateTime.fromMillis(taken).millisecond : null\n          };\n\n          // If no background color, get the mean color value\n          const stats = formatVals['channel statistics'];\n\n          if(stats) {\n            let {red, green, blue, mean} = stats;\n\n            if(red) {\n              mean = red['standard deviation'] || red.mean;\n              red = mean ? +((mean.split(' ')[0]).substring(0, 3)) : 0;\n            } else {\n              red = 0;\n            }\n\n            if(green) {\n              mean = green['standard deviation'] || green.mean;\n              green = mean ? +((mean.split(' ')[0]).substring(0, 3)) : 0;\n            } else {\n              green = 0;\n            }\n\n            if(blue) {\n              mean = blue['standard deviation'] || blue.mean;\n              blue = mean ? +((mean.split(' ')[0]).substring(0, 3)) : 0;\n            } else {\n              blue = 0;\n            }\n\n            const rgb = blue | (green << 8) | (red << 16);\n            const color = rgb.toString(16);\n            photo.color = color === '0' ? '000000' : color;\n          }\n        }\n      })\n      .stream((error: Error, stdout): any => {\n        if(error) {\n          logError({\n            action,\n            category: eventCategory,\n            isInternal: true,\n            label: 'image_save',\n            value: 'gm_image_stream'\n          }, error, context).then(() => null);\n        } else {\n          let imageBuffer: Buffer = Buffer.from('');\n\n          stdout.on('data', (data) => {\n            imageBuffer = Buffer.concat([imageBuffer, data]);\n          });\n\n          stdout.on('end', () => {\n            // Get file size\n            photo.fileSize = imageBuffer.length;\n\n            // Upload data\n            const imageObj: PutObjectRequest = {\n              ACL: 'authenticated-read',\n              Body: imageBuffer,\n              Bucket: null,\n              ContentType: type,\n              ...s3Options || {},\n              Key: getPathUserImages(sessionId, imageId, type, 'images')\n            };\n\n            s3Put(imageObj)\n              .then(() => {\n                const thmW = Config.get('image.thmSize');\n                const thmQ = Config.get('image.thmQuality');\n\n                // Upload thumbnail\n                gm(imageBuffer, 'img')\n                  .setFormat('jpeg')\n                  .size((thumbError: Error, resizeVal) => {\n                    if(!thumbError) {\n                      // Get updated resize values\n                      const {height, width} = resizeVal;\n                      photo = {...cloneDeep(photo), height, width};\n                    }\n                  })\n                  .gravity('Center')\n                  .resize(thmW, thmW, '^')\n                  .extent(thmW, thmW)\n                  .quality(thmQ)\n                  .stream((streamError: Error, thumbStdout): any => {\n                    if(streamError) {\n                      logError({\n                        action,\n                        category: eventCategory,\n                        label: 'image_save',\n                        value: 'gm_thumbnail_steam'\n                      }, streamError, context)\n                        .catch((error) => {\n                          throw error;\n                        });\n                    } else {\n                      let thumbBuffer: Buffer = Buffer.from('');\n\n                      thumbStdout.on('data', (data) => {\n                        thumbBuffer = Buffer.concat([thumbBuffer, data]);\n                      });\n\n                      thumbStdout.on('end', () => {\n                        // Upload data\n                        const thumbObj: PutObjectRequest = {\n                          ACL: 'authenticated-read',\n                          Body: thumbBuffer,\n                          Bucket: null,\n                          ContentType: type,\n                          ...s3Options || {},\n                          Key: getPathUserImages(sessionId, imageId, type, 'thumbs')\n                        };\n\n                        s3Put(thumbObj)\n                          .then(() => {\n                            resolve(photo);\n                          })\n                          .catch((s3PutError) => logError({\n                            action,\n                            category: eventCategory,\n                            label: 'image_save',\n                            value: 's3_put_image'\n                          }, s3PutError, context)\n                            .catch((error) => {\n                              throw error;\n                            }));\n                      });\n                    }\n                  });\n              })\n              .catch((s3Error) => logError({\n                action,\n                category: eventCategory,\n                isInternal: true,\n                label: 'image_save',\n                value: 's3_image_save'\n              }, s3Error, context).then(() => null));\n          });\n        }\n      });\n  });\n};\n\nexport const addImage = (context: ApiContext, image: ImageType, s3Options?: PutObjectRequest): Promise<ImageType> => {\n  const action: string = 'addImage';\n  const {database, session: {userId: sessionId}} = context;\n  const {imageId, description, buffer, fileType} = image;\n  const now: number = Date.now();\n\n  return resizeSaveImage(context, imageId, buffer, fileType, s3Options)\n    .then((resizedImage: any) => {\n      const insert: ImageType = {\n        ...resizedImage,\n        _key: imageId,\n        added: now,\n        description,\n        fileType,\n        modified: now,\n        userId: sessionId\n      };\n\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN images RETURN NEW`;\n\n      return database.query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then(defaultObject)\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          isInternal: true,\n          label: 'db_error'\n        }, error, context).then(() => null));\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      isInternal: true,\n      label: 'image_resize'\n    }, error, context).then(() => null));\n};\n\nexport const addImageEdge = async (context: ApiContext, imageEdge: ImageEdgeType): Promise<object> => {\n  const action: string = 'addImageEdge';\n  const {database, session: {userId: sessionId}} = context;\n  const {imageId, itemId, itemType} = imageEdge;\n  const now: number = Date.now();\n  const edgeCollection: EdgeCollection = database.collection('hasImages');\n  const edgeId: string = createHash(`hasImages-${imageId}-${itemId}-${sessionId}`);\n  const formatItemType: string = parseChar(itemType).toLowerCase();\n  const formatItemId: string = parseId(itemId);\n  let itemDocId: string;\n  const formatImgId: string = parseId(imageId);\n  const fileDocId: string = `images/${formatImgId}`;\n\n  switch(formatItemType) {\n    case 'groups':\n      itemDocId = `groups/${formatItemId}`;\n      break;\n    case 'posts':\n      itemDocId = `posts/${formatItemId}`;\n      break;\n    case 'users':\n    case 'profile':\n      itemDocId = `users/${formatItemId}`;\n      break;\n    default:\n      itemDocId = '';\n      break;\n  }\n  const edge: any = {\n    _from: itemDocId,\n    _key: edgeId,\n    _to: fileDocId,\n    added: now,\n    type: itemType\n  };\n\n  if(!isEmpty(itemDocId)) {\n    return edgeCollection.save(edge, {returnNew: true})\n      .then((fileEdge) => edgeCollection.document(fileEdge))\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        isInternal: true,\n        label: 'db_error',\n        params: {\n          edge,\n          fileDocId,\n          imageId,\n          itemDocId,\n          itemId,\n          itemType\n        }\n      }, error, context).then(() => null));\n  }\n\n  return {};\n};\n\nexport const updateImage = async (\n  context: ApiContext,\n  image: ImageType,\n  s3Options?: PutObjectRequest\n): Promise<ImageType> => {\n  const action: string = 'updateImage';\n  const {database, session: {userId: sessionId}} = context;\n\n  // Item props\n  const {\n    base64 = '',\n    buffer: imageBuffer,\n    description = '',\n    imageId,\n    itemId,\n    itemType,\n    fileType,\n    url = ''\n  } = image;\n\n  // Save Base64 data\n  const now: number = Date.now();\n  const formatImageId: string = imageId || createHash(`image-${sessionId}`);\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 16).toLowerCase();\n  const customParams: ImageType = {\n    description,\n    imageId: formatImageId,\n    userId: sessionId\n  };\n\n  if(!isEmpty(base64) || imageBuffer) {\n    let buffer: Buffer = imageBuffer;\n\n    // Parse Base64 data\n    if(!isEmpty(base64)) {\n      const formatBase64: string = base64.substr(base64.indexOf(',') + 1);\n      buffer = Buffer.from(formatBase64, 'base64');\n    }\n\n    let updatedFileType = fileType;\n\n    if(!fileType) {\n      const fileMime: FileTypeResult = await FileType.fileTypeFromBuffer(buffer);\n      const {mime} = fileMime;\n      updatedFileType = mime;\n    }\n\n    const imgParams: ImageType = {\n      ...customParams,\n      buffer,\n      fileType: updatedFileType\n    };\n\n    return addImage(context, imgParams, s3Options)\n      .then((image: ImageType) => {\n        if(formatItemId && formatItemType) {\n          const imageEdge: ImageEdgeType = {\n            imageId: formatImageId,\n            itemId: formatItemId,\n            itemType: formatItemType\n          };\n          return addImageEdge(context, imageEdge).then(() => image);\n        }\n\n        return image;\n      })\n      .catch((error) => logError({\n        action,\n        category: eventCategory,\n        label: 'image_save_error'\n      }, error, context).then(() => null));\n  } else if(url !== '') {\n    // Download image from the web\n    let contentType: string;\n\n    return httpGet(url)\n      .then((res: Response) => {\n        if(res.status !== 200) {\n          return logException({\n            action,\n            category: eventCategory,\n            label: 'fetch_image_url',\n            value: res.statusText\n          }, context).then(() => null);\n        }\n\n        contentType = res.headers.get('content-type');\n\n        return res;\n      })\n      .then((res) => res.buffer())\n      .then((buffer: Buffer) => {\n        const imgParams: ImageType = {\n          ...customParams,\n          buffer,\n          fileType: contentType\n        };\n\n        return addImage(context, imgParams, s3Options).then((image: ImageType) => {\n          if(formatItemId && formatItemType) {\n            const imageEdge: ImageEdgeType = {imageId: formatImageId, itemId: formatItemId, itemType: formatItemType};\n            return addImageEdge(context, imageEdge).then(() => image);\n          }\n\n          return image;\n        });\n      })\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'fetch_error'\n      }, error, context).then(() => null));\n  } else if(imageId !== '') {\n    // Update metadata\n    const update: any = {\n      description,\n      modified: now\n    };\n    const aqlQry: AqlQuery = aql`UPDATE {_key: ${formatImageId}} WITH ${update} IN images RETURN NEW`;\n\n    return database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error',\n        params: {\n          aqlQry,\n          formatImageId,\n          update\n        }\n      }, error, context).then(() => null));\n  }\n\n  return null;\n};\n\nexport const deleteImage = async (context: ApiContext, imageId: string): Promise<ImageType> => {\n  const action: string = 'delete';\n  const {database, session: {userId: sessionId}} = context;\n  const formatImageId = parseId(imageId);\n\n  const removeEdgeQuery = aql`FOR hi IN hasImages\n    FILTER hi._from == ${formatImageId}\n    REMOVE hi IN hasImages\n    RETURN OLD`;\n\n  await database.query(removeEdgeQuery);\n\n  const aqlQuery = aql`FOR i IN images\n    FILTER i._key == ${formatImageId} && i.userId == ${sessionId}\n    REMOVE i IN images\n    RETURN OLD`;\n\n  const image = await database.query(aqlQuery)\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  if(!isEmpty(image)) {\n    const {_key: imageKey} = image;\n    const params: DeleteObjectsRequest = {\n      Bucket: null,\n      Delete: {\n        Objects: [\n          {Key: `users/${sessionId}/images/${imageKey}.jpg`},\n          {Key: `users/${sessionId}/thumbs/${imageKey}.jpg`}\n        ],\n        Quiet: true\n      }\n    };\n\n    return s3DeleteList(params).then(() => image);\n  }\n\n  return {};\n};\n"],
  "mappings": "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",
  "names": ["import_utils", "import_s3", "gm", "error", "cloneDeep", "isEmpty", "FileType", "image", "httpGet"]
}

@@ -1,43 +1,60 @@
1
- var __create = Object.create;
2
1
  var __defProp = Object.defineProperty;
3
2
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
3
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __getProtoOf = Object.getPrototypeOf;
6
4
  var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
- var __require = typeof require !== "undefined" ? require : (x) => {
9
- throw new Error('Dynamic require of "' + x + '" is not supported');
10
- };
11
- var __reExport = (target, module2, desc) => {
12
- if (module2 && typeof module2 === "object" || typeof module2 === "function") {
13
- for (let key of __getOwnPropNames(module2))
14
- if (!__hasOwnProp.call(target, key) && key !== "default")
15
- __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
5
+ var __copyProps = (to, from, except, desc) => {
6
+ if (from && typeof from === "object" || typeof from === "function") {
7
+ for (let key of __getOwnPropNames(from))
8
+ if (!__hasOwnProp.call(to, key) && key !== except)
9
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
10
  }
17
- return target;
18
- };
19
- var __toModule = (module2) => {
20
- return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
11
+ return to;
21
12
  };
22
- __markAsModule(exports);
23
- __reExport(exports, __toModule(require("./conversations")));
24
- __reExport(exports, __toModule(require("./dynamodb")));
25
- __reExport(exports, __toModule(require("./email")));
26
- __reExport(exports, __toModule(require("./files")));
27
- __reExport(exports, __toModule(require("./groups")));
28
- __reExport(exports, __toModule(require("./images")));
29
- __reExport(exports, __toModule(require("./ios")));
30
- __reExport(exports, __toModule(require("./locations")));
31
- __reExport(exports, __toModule(require("./messages")));
32
- __reExport(exports, __toModule(require("./notifications")));
33
- __reExport(exports, __toModule(require("./payments")));
34
- __reExport(exports, __toModule(require("./posts")));
35
- __reExport(exports, __toModule(require("./reactions")));
36
- __reExport(exports, __toModule(require("./s3")));
37
- __reExport(exports, __toModule(require("./search")));
38
- __reExport(exports, __toModule(require("./sms")));
39
- __reExport(exports, __toModule(require("./subscription")));
40
- __reExport(exports, __toModule(require("./tags")));
41
- __reExport(exports, __toModule(require("./users")));
42
- __reExport(exports, __toModule(require("./websockets")));
43
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2NvbnZlcnNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9keW5hbW9kYic7XG5leHBvcnQgKiBmcm9tICcuL2VtYWlsJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9ncm91cHMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbWFnZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9pb3MnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2NhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9tZXNzYWdlcyc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9wYXltZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3Bvc3RzJztcbmV4cG9ydCAqIGZyb20gJy4vcmVhY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vczMnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWFyY2gnO1xuZXhwb3J0ICogZnJvbSAnLi9zbXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi90YWdzJztcbmV4cG9ydCAqIGZyb20gJy4vdXNlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi93ZWJzb2NrZXRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBSUEsb0JBQWM7QUFDZCxvQkFBYztBQUNkLG9CQUFjO0FBQ2Qsb0JBQWM7QUFDZCxvQkFBYztBQUNkLG9CQUFjO0FBQ2Qsb0JBQWM7QUFDZCxvQkFBYztBQUNkLG9CQUFjO0FBQ2Qsb0JBQWM7QUFDZCxvQkFBYztBQUNkLG9CQUFjO0FBQ2Qsb0JBQWM7QUFDZCxvQkFBYztBQUNkLG9CQUFjO0FBQ2Qsb0JBQWM7QUFDZCxvQkFBYztBQUNkLG9CQUFjO0FBQ2Qsb0JBQWM7QUFDZCxvQkFBYzsiLAogICJuYW1lcyI6IFtdCn0K
13
+ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
14
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
15
+ var actions_exports = {};
16
+ module.exports = __toCommonJS(actions_exports);
17
+ __reExport(actions_exports, require("./conversations"), module.exports);
18
+ __reExport(actions_exports, require("./dynamodb"), module.exports);
19
+ __reExport(actions_exports, require("./email"), module.exports);
20
+ __reExport(actions_exports, require("./files"), module.exports);
21
+ __reExport(actions_exports, require("./groups"), module.exports);
22
+ __reExport(actions_exports, require("./images"), module.exports);
23
+ __reExport(actions_exports, require("./ios"), module.exports);
24
+ __reExport(actions_exports, require("./locations"), module.exports);
25
+ __reExport(actions_exports, require("./messages"), module.exports);
26
+ __reExport(actions_exports, require("./notifications"), module.exports);
27
+ __reExport(actions_exports, require("./payments"), module.exports);
28
+ __reExport(actions_exports, require("./posts"), module.exports);
29
+ __reExport(actions_exports, require("./reactions"), module.exports);
30
+ __reExport(actions_exports, require("./s3"), module.exports);
31
+ __reExport(actions_exports, require("./search"), module.exports);
32
+ __reExport(actions_exports, require("./sms"), module.exports);
33
+ __reExport(actions_exports, require("./subscription"), module.exports);
34
+ __reExport(actions_exports, require("./tags"), module.exports);
35
+ __reExport(actions_exports, require("./users"), module.exports);
36
+ __reExport(actions_exports, require("./websockets"), module.exports);
37
+ // Annotate the CommonJS export names for ESM import in node:
38
+ 0 && (module.exports = {
39
+ ...require("./conversations"),
40
+ ...require("./dynamodb"),
41
+ ...require("./email"),
42
+ ...require("./files"),
43
+ ...require("./groups"),
44
+ ...require("./images"),
45
+ ...require("./ios"),
46
+ ...require("./locations"),
47
+ ...require("./messages"),
48
+ ...require("./notifications"),
49
+ ...require("./payments"),
50
+ ...require("./posts"),
51
+ ...require("./reactions"),
52
+ ...require("./s3"),
53
+ ...require("./search"),
54
+ ...require("./sms"),
55
+ ...require("./subscription"),
56
+ ...require("./tags"),
57
+ ...require("./users"),
58
+ ...require("./websockets")
59
+ });
60
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2NvbnZlcnNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9keW5hbW9kYic7XG5leHBvcnQgKiBmcm9tICcuL2VtYWlsJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9ncm91cHMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbWFnZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9pb3MnO1xuZXhwb3J0ICogZnJvbSAnLi9sb2NhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9tZXNzYWdlcyc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9wYXltZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3Bvc3RzJztcbmV4cG9ydCAqIGZyb20gJy4vcmVhY3Rpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vczMnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWFyY2gnO1xuZXhwb3J0ICogZnJvbSAnLi9zbXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi90YWdzJztcbmV4cG9ydCAqIGZyb20gJy4vdXNlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi93ZWJzb2NrZXRzJztcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUlBLDRCQUFjLDRCQUpkO0FBS0EsNEJBQWMsdUJBTGQ7QUFNQSw0QkFBYyxvQkFOZDtBQU9BLDRCQUFjLG9CQVBkO0FBUUEsNEJBQWMscUJBUmQ7QUFTQSw0QkFBYyxxQkFUZDtBQVVBLDRCQUFjLGtCQVZkO0FBV0EsNEJBQWMsd0JBWGQ7QUFZQSw0QkFBYyx1QkFaZDtBQWFBLDRCQUFjLDRCQWJkO0FBY0EsNEJBQWMsdUJBZGQ7QUFlQSw0QkFBYyxvQkFmZDtBQWdCQSw0QkFBYyx3QkFoQmQ7QUFpQkEsNEJBQWMsaUJBakJkO0FBa0JBLDRCQUFjLHFCQWxCZDtBQW1CQSw0QkFBYyxrQkFuQmQ7QUFvQkEsNEJBQWMsMkJBcEJkO0FBcUJBLDRCQUFjLG1CQXJCZDtBQXNCQSw0QkFBYyxvQkF0QmQ7QUF1QkEsNEJBQWMseUJBdkJkOyIsCiAgIm5hbWVzIjogW10KfQo=