@nlabs/reaktor 0.1.5 → 0.1.7

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 (52) hide show
  1. package/lib/config.js +20 -11
  2. package/lib/data/conversations.js +69 -39
  3. package/lib/data/dynamodb.js +60 -27
  4. package/lib/data/email.js +50 -19
  5. package/lib/data/files.js +103 -46
  6. package/lib/data/groups.js +114 -67
  7. package/lib/data/images.js +169 -102
  8. package/lib/data/index.js +234 -24
  9. package/lib/data/ios.js +48 -23
  10. package/lib/data/locations.js +45 -29
  11. package/lib/data/messages.d.ts +2 -2
  12. package/lib/data/messages.js +105 -72
  13. package/lib/data/notifications.js +31 -14
  14. package/lib/data/payments.js +164 -114
  15. package/lib/data/posts.js +144 -87
  16. package/lib/data/reactions.js +58 -33
  17. package/lib/data/s3.js +54 -24
  18. package/lib/data/search.js +32 -19
  19. package/lib/data/sms.js +35 -15
  20. package/lib/data/subscription.js +78 -51
  21. package/lib/data/tags.js +90 -51
  22. package/lib/data/users.js +119 -72
  23. package/lib/index.js +42 -8
  24. package/lib/types/apps.js +1 -1
  25. package/lib/types/arangodb.js +1 -1
  26. package/lib/types/auth.js +1 -1
  27. package/lib/types/conversations.js +1 -1
  28. package/lib/types/email.js +1 -1
  29. package/lib/types/files.js +1 -1
  30. package/lib/types/google.js +1 -1
  31. package/lib/types/groups.js +1 -1
  32. package/lib/types/images.js +1 -1
  33. package/lib/types/index.js +210 -22
  34. package/lib/types/locations.js +1 -1
  35. package/lib/types/messages.d.ts +12 -7
  36. package/lib/types/messages.js +1 -1
  37. package/lib/types/notifications.js +1 -1
  38. package/lib/types/payments.js +1 -1
  39. package/lib/types/posts.js +1 -1
  40. package/lib/types/reactions.js +1 -1
  41. package/lib/types/tags.js +1 -1
  42. package/lib/types/users.d.ts +0 -1
  43. package/lib/types/users.js +1 -1
  44. package/lib/utils/analytics.js +23 -11
  45. package/lib/utils/arangodb.js +48 -19
  46. package/lib/utils/auth.js +31 -15
  47. package/lib/utils/graphql.js +16 -4
  48. package/lib/utils/index.js +78 -11
  49. package/lib/utils/objects.js +30 -10
  50. package/lib/utils/redis.js +21 -8
  51. package/package.json +5 -5
  52. package/index.d.ts +0 -1
@@ -1,3 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.addLocation = void 0;
7
+
8
+ var _ripHunter = require("@nlabs/rip-hunter");
9
+
10
+ var _utils = require("@nlabs/utils");
11
+
12
+ var _arangojs = require("arangojs");
13
+
14
+ var _get = _interopRequireDefault(require("lodash/get"));
15
+
16
+ var _config = require("../config");
17
+
18
+ var _utils2 = require("../utils");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+
1
22
  function _templateObject() {
2
23
  var data = _taggedTemplateLiteral(["UPSERT {googleId: ", "}\n INSERT ", "\n UPDATE ", "\n IN locations RETURN NEW"]);
3
24
 
@@ -10,31 +31,24 @@ function _templateObject() {
10
31
 
11
32
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
12
33
 
13
- /**
14
- * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
15
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
16
- */
17
- import { get as httpGet, queryString } from '@nlabs/rip-hunter';
18
- import { createHash, parseChar, parseId } from '@nlabs/utils';
19
- import { aql } from 'arangojs';
20
- import get from 'lodash/get';
21
- import { Config } from '../config';
22
- import { logError, useDb } from '../utils';
23
34
  var eventCategory = 'locations';
24
- export var addLocation = function addLocation(context, location) {
35
+
36
+ var addLocation = function addLocation(context, location) {
25
37
  var action = 'add';
26
38
  var database = context.database,
27
39
  sessionId = context.userId;
28
40
  var address = location.address,
29
41
  itemId = location.itemId,
30
42
  itemType = location.itemType;
31
- var geocodeUrl = Config.get('google.geocode.url');
43
+
44
+ var geocodeUrl = _config.Config.get('google.geocode.url');
45
+
32
46
  var params = {
33
47
  address: address,
34
- key: Config.get('google.geocode.key')
48
+ key: _config.Config.get('google.geocode.key')
35
49
  };
36
- var url = "".concat(geocodeUrl, "?").concat(queryString(params));
37
- return httpGet(url).then(function (json) {
50
+ var url = "".concat(geocodeUrl, "?").concat((0, _ripHunter.queryString)(params));
51
+ return (0, _ripHunter.get)(url).then(function (json) {
38
52
  var _json$results = json.results,
39
53
  results = _json$results === void 0 ? [] : _json$results,
40
54
  _json$status = json.status,
@@ -42,7 +56,7 @@ export var addLocation = function addLocation(context, location) {
42
56
 
43
57
  if (status === 'OK' && results.length) {
44
58
  var geodata = results[0];
45
- var addressComponents = get(geodata, 'address_components');
59
+ var addressComponents = (0, _get.default)(geodata, 'address_components');
46
60
 
47
61
  var getFieldVal = function getFieldVal(name) {
48
62
  var _ref = addressComponents.find(function (addressField) {
@@ -63,27 +77,27 @@ export var addLocation = function addLocation(context, location) {
63
77
 
64
78
  var now = Date.now(); // Item
65
79
 
66
- var formatItemType = parseChar(itemType).toLowerCase();
67
- var formatItemId = parseId(itemId);
68
- var googleId = get(geodata, 'place_id');
80
+ var formatItemType = (0, _utils.parseChar)(itemType).toLowerCase();
81
+ var formatItemId = (0, _utils.parseId)(itemId);
82
+ var googleId = (0, _get.default)(geodata, 'place_id');
69
83
  var update = {};
70
84
  var insert = {
71
- _key: createHash("post-".concat(sessionId)),
85
+ _key: (0, _utils.createHash)("post-".concat(sessionId)),
72
86
  added: now,
73
87
  city: getFieldVal('locality'),
74
88
  country: getFieldVal('country'),
75
- formatted: get(geodata, 'formatted_address'),
89
+ formatted: (0, _get.default)(geodata, 'formatted_address'),
76
90
  googleId: googleId,
77
- latitude: get(geodata, 'geometry.location.lat'),
78
- longitude: get(geodata, 'geometry.location.lng'),
91
+ latitude: (0, _get.default)(geodata, 'geometry.location.lat'),
92
+ longitude: (0, _get.default)(geodata, 'geometry.location.lng'),
79
93
  state: getFieldVal('administrative_area_level_1'),
80
94
  street: [streetNumber, route].filter(function (obj) {
81
95
  return obj;
82
96
  }).join(' '),
83
97
  zip: getFieldVal('postal_code')
84
98
  };
85
- var aqlQry = aql(_templateObject(), googleId, insert, update);
86
- return useDb(database).query(aqlQry).then(function (cursor) {
99
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), googleId, insert, update);
100
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
87
101
  return cursor.next();
88
102
  }).then(function () {
89
103
  var updatedLocation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
@@ -101,10 +115,10 @@ export var addLocation = function addLocation(context, location) {
101
115
 
102
116
 
103
117
  if (itemDocId) {
104
- var edgeCollection = useDb(database).edgeCollection('hasLocation');
118
+ var edgeCollection = (0, _utils2.useDb)(database).edgeCollection('hasLocation');
105
119
  var locationId = updatedLocationKey;
106
120
  var locationDocId = "locations/".concat(locationId);
107
- var edgeId = createHash("hasLocation-".concat(locationId, "-").concat(sessionId));
121
+ var edgeId = (0, _utils.createHash)("hasLocation-".concat(locationId, "-").concat(sessionId));
108
122
  var edge = {
109
123
  _key: edgeId
110
124
  };
@@ -116,7 +130,7 @@ export var addLocation = function addLocation(context, location) {
116
130
 
117
131
  return updatedLocation;
118
132
  }).catch(function (error) {
119
- return logError({
133
+ return (0, _utils2.logError)({
120
134
  action: action,
121
135
  category: eventCategory,
122
136
  label: 'db_error'
@@ -129,4 +143,6 @@ export var addLocation = function addLocation(context, location) {
129
143
  return {};
130
144
  });
131
145
  };
132
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/locations.ts"],"names":["get","httpGet","queryString","createHash","parseChar","parseId","aql","Config","logError","useDb","eventCategory","addLocation","context","location","action","database","sessionId","userId","address","itemId","itemType","geocodeUrl","params","key","url","then","json","results","status","length","geodata","addressComponents","getFieldVal","name","find","addressField","types","findIndex","fieldType","short_name","shortName","streetNumber","route","now","Date","formatItemType","toLowerCase","formatItemId","googleId","update","insert","_key","added","city","country","formatted","latitude","longitude","state","street","filter","obj","join","zip","aqlQry","query","cursor","next","updatedLocation","itemDocId","updatedLocationKey","edgeCollection","locationId","locationDocId","edgeId","edge","save","catch","error","category","label"],"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 {get as httpGet, queryString} from '@nlabs/rip-hunter';\nimport {createHash, parseChar, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport get from 'lodash/get';\n\nimport {Config} from '../config';\nimport {ApiContext} from '../types/auth';\nimport {GoogleMapsAddressType} from '../types/google';\nimport {LocationType} from '../types/locations';\nimport {logError, useDb} from '../utils';\n\nconst eventCategory: string = 'locations';\n\nexport const addLocation = (context: ApiContext, location: LocationType): Promise<LocationType> => {\n  const action: string = 'add';\n  const {database, userId: sessionId} = context;\n  const {address, itemId, itemType} = location;\n  const geocodeUrl: string = Config.get('google.geocode.url');\n  const params: object = {\n    address,\n    key: Config.get('google.geocode.key')\n  };\n  const url: string = `${geocodeUrl}?${queryString(params)}`;\n\n  return httpGet(url)\n    .then((json) => {\n      const {results = [], status = ''} = json;\n\n      if(status === 'OK' && results.length) {\n        const geodata: object = results[0];\n        const addressComponents: GoogleMapsAddressType[] = get(geodata, 'address_components');\n        const getFieldVal = (name: string): string => {\n          const {short_name: shortName = ''} = addressComponents.find((addressField: GoogleMapsAddressType) => {\n            const types = addressField.types || [];\n            return types.findIndex((fieldType: string) => fieldType === name) >= 0;\n          }) || {};\n\n          return shortName;\n        };\n\n        // Street\n        const streetNumber: string = getFieldVal('street_number');\n        const route: string = getFieldVal('route');\n\n        // Location\n        const now: number = Date.now();\n\n        // Item\n        const formatItemType: string = parseChar(itemType).toLowerCase();\n        const formatItemId: string = parseId(itemId);\n        const googleId: string = get(geodata, 'place_id');\n        const update: LocationType = {};\n        const insert: LocationType = {\n          _key: createHash(`post-${sessionId}`),\n          added: now,\n          city: getFieldVal('locality'),\n          country: getFieldVal('country'),\n          formatted: get(geodata, 'formatted_address'),\n          googleId,\n          latitude: get(geodata, 'geometry.location.lat'),\n          longitude: get(geodata, 'geometry.location.lng'),\n          state: getFieldVal('administrative_area_level_1'),\n          street: [streetNumber, route].filter((obj) => obj).join(' '),\n          zip: getFieldVal('postal_code')\n        };\n        const aqlQry: AqlQuery = aql`UPSERT {googleId: ${googleId}}\n            INSERT ${insert}\n            UPDATE ${update}\n            IN locations RETURN NEW`;\n\n        return useDb(database).query(aqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((updatedLocation: LocationType = {}) => {\n            let itemDocId: string;\n            const {_key: updatedLocationKey} = updatedLocation;\n\n            switch(formatItemType) {\n              case 'posts':\n                itemDocId = `posts/${formatItemId}`;\n                break;\n              default:\n                itemDocId = '';\n            }\n\n            // If there is a valid item doc id, create an edge\n            if(itemDocId) {\n              const edgeCollection = useDb(database).edgeCollection('hasLocation');\n              const locationId: string = updatedLocationKey;\n              const locationDocId: string = `locations/${locationId}`;\n              const edgeId = createHash(`hasLocation-${locationId}-${sessionId}`);\n              const edge: any = {_key: edgeId};\n\n              return edgeCollection.save(edge, itemDocId, locationDocId).then(() => updatedLocation);\n            }\n\n            // Otherwise just return the new location\n            return updatedLocation;\n          })\n          .catch((error: Error) => logError({\n            action,\n            category: eventCategory,\n            label: 'db_error'\n          }, error, context).then(() => null));\n      }\n\n      return {};\n    });\n};\n"]}
146
+
147
+ exports.addLocation = addLocation;
148
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/locations.ts"],"names":["eventCategory","addLocation","context","location","action","database","sessionId","userId","address","itemId","itemType","geocodeUrl","Config","get","params","key","url","then","json","results","status","length","geodata","addressComponents","getFieldVal","name","find","addressField","types","findIndex","fieldType","short_name","shortName","streetNumber","route","now","Date","formatItemType","toLowerCase","formatItemId","googleId","update","insert","_key","added","city","country","formatted","latitude","longitude","state","street","filter","obj","join","zip","aqlQry","aql","query","cursor","next","updatedLocation","itemDocId","updatedLocationKey","edgeCollection","locationId","locationDocId","edgeId","edge","save","catch","error","category","label"],"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 {get as httpGet, queryString} from '@nlabs/rip-hunter';\nimport {createHash, parseChar, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport get from 'lodash/get';\n\nimport {Config} from '../config';\nimport {ApiContext} from '../types/auth';\nimport {GoogleMapsAddressType} from '../types/google';\nimport {LocationType} from '../types/locations';\nimport {logError, useDb} from '../utils';\n\nconst eventCategory: string = 'locations';\n\nexport const addLocation = (context: ApiContext, location: LocationType): Promise<LocationType> => {\n  const action: string = 'add';\n  const {database, userId: sessionId} = context;\n  const {address, itemId, itemType} = location;\n  const geocodeUrl: string = Config.get('google.geocode.url');\n  const params: object = {\n    address,\n    key: Config.get('google.geocode.key')\n  };\n  const url: string = `${geocodeUrl}?${queryString(params)}`;\n\n  return httpGet(url)\n    .then((json) => {\n      const {results = [], status = ''} = json;\n\n      if(status === 'OK' && results.length) {\n        const geodata: object = results[0];\n        const addressComponents: GoogleMapsAddressType[] = get(geodata, 'address_components');\n        const getFieldVal = (name: string): string => {\n          const {short_name: shortName = ''} = addressComponents.find((addressField: GoogleMapsAddressType) => {\n            const types = addressField.types || [];\n            return types.findIndex((fieldType: string) => fieldType === name) >= 0;\n          }) || {};\n\n          return shortName;\n        };\n\n        // Street\n        const streetNumber: string = getFieldVal('street_number');\n        const route: string = getFieldVal('route');\n\n        // Location\n        const now: number = Date.now();\n\n        // Item\n        const formatItemType: string = parseChar(itemType).toLowerCase();\n        const formatItemId: string = parseId(itemId);\n        const googleId: string = get(geodata, 'place_id');\n        const update: LocationType = {};\n        const insert: LocationType = {\n          _key: createHash(`post-${sessionId}`),\n          added: now,\n          city: getFieldVal('locality'),\n          country: getFieldVal('country'),\n          formatted: get(geodata, 'formatted_address'),\n          googleId,\n          latitude: get(geodata, 'geometry.location.lat'),\n          longitude: get(geodata, 'geometry.location.lng'),\n          state: getFieldVal('administrative_area_level_1'),\n          street: [streetNumber, route].filter((obj) => obj).join(' '),\n          zip: getFieldVal('postal_code')\n        };\n        const aqlQry: AqlQuery = aql`UPSERT {googleId: ${googleId}}\n            INSERT ${insert}\n            UPDATE ${update}\n            IN locations RETURN NEW`;\n\n        return useDb(database).query(aqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((updatedLocation: LocationType = {}) => {\n            let itemDocId: string;\n            const {_key: updatedLocationKey} = updatedLocation;\n\n            switch(formatItemType) {\n              case 'posts':\n                itemDocId = `posts/${formatItemId}`;\n                break;\n              default:\n                itemDocId = '';\n            }\n\n            // If there is a valid item doc id, create an edge\n            if(itemDocId) {\n              const edgeCollection = useDb(database).edgeCollection('hasLocation');\n              const locationId: string = updatedLocationKey;\n              const locationDocId: string = `locations/${locationId}`;\n              const edgeId = createHash(`hasLocation-${locationId}-${sessionId}`);\n              const edge: any = {_key: edgeId};\n\n              return edgeCollection.save(edge, itemDocId, locationDocId).then(() => updatedLocation);\n            }\n\n            // Otherwise just return the new location\n            return updatedLocation;\n          })\n          .catch((error: Error) => logError({\n            action,\n            category: eventCategory,\n            label: 'db_error'\n          }, error, context).then(() => null));\n      }\n\n      return {};\n    });\n};\n"]}
@@ -1,7 +1,7 @@
1
1
  import { ApiContext } from '../types/auth';
2
- import { MessageType } from '../types/messages';
2
+ import { MessageInputType, MessageType } from '../types/messages';
3
3
  export declare const getMessageList: (context: ApiContext, convoId: string, from: number, to: number) => Promise<MessageType[]>;
4
- export declare const updateMessage: (context: ApiContext, message: MessageType) => Promise<MessageType>;
4
+ export declare const updateMessage: (context: ApiContext, message: MessageInputType) => Promise<MessageType>;
5
5
  export declare const saveMessage: (context: ApiContext, msgId: string, convoId: string) => Promise<MessageType>;
6
6
  export declare const unsaveMessage: (context: ApiContext, msgId: string, convoId: string) => Promise<MessageType>;
7
7
  export declare const deleteMessage: (context: ApiContext, msgId: string, convoId: string) => Promise<MessageType>;
@@ -1,3 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.cleanMessages = exports.getMessage = exports.deleteMessage = exports.unsaveMessage = exports.saveMessage = exports.updateMessage = exports.getMessageList = void 0;
7
+
8
+ var _utils = require("@nlabs/utils");
9
+
10
+ var _arangojs = require("arangojs");
11
+
12
+ var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
13
+
14
+ var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
15
+
16
+ var _utils2 = require("../utils");
17
+
18
+ var _conversations = require("./conversations");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+
1
22
  function _templateObject5() {
2
23
  var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n REMOVE m IN messages\n RETURN OLD"]);
3
24
 
@@ -39,7 +60,7 @@ function _templateObject2() {
39
60
  }
40
61
 
41
62
  function _templateObject() {
42
- var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", to: ", "}\n INSERT ", "\n UPDATE ", "\n IN messages RETURN NEW"]);
63
+ var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", convoId: ", "}\n INSERT ", "\n UPDATE ", "\n IN messages RETURN NEW"]);
43
64
 
44
65
  _templateObject = function _templateObject() {
45
66
  return data;
@@ -54,63 +75,58 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
54
75
 
55
76
  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; }
56
77
 
57
- /**
58
- * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
59
- * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
60
- */
61
- import { createHash, parseId, parseVarChar } from '@nlabs/utils';
62
- import { aql } from 'arangojs';
63
- import cloneDeep from 'lodash/cloneDeep';
64
- import isEmpty from 'lodash/isEmpty';
65
- import { getLimit, useDb } from '../utils';
66
- import { getConversation } from './conversations'; // const eventCategory: string = 'messages';
67
-
68
- export var getMessageList = function getMessageList(context, convoId, from, to) {
78
+ // const eventCategory: string = 'messages';
79
+ var getMessageList = function getMessageList(context, convoId, from, to) {
69
80
  var database = context.database;
70
- var formatConvoId = parseId(convoId);
71
- return getConversation(context, formatConvoId).then(function (conversation) {
81
+ var formatConvoId = (0, _utils.parseId)(convoId);
82
+ return (0, _conversations.getConversation)(context, formatConvoId).then(function (conversation) {
72
83
  var conversationKey = conversation._key;
73
- var limit = getLimit(from, to);
84
+ var limit = (0, _utils2.getLimit)(from, to);
74
85
  var aqlQry = "FOR m IN messages\n FILTER m.to == \"".concat(conversationKey, "\"\n ").concat(limit.aql, "\n SORT m.added\n RETURN m");
75
- return useDb(database).query(aqlQry).then(function (cursor) {
86
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
76
87
  return cursor.all();
77
88
  }).catch(function (error) {
78
89
  throw error;
79
90
  });
80
91
  });
81
92
  };
82
- export var updateMessage = function updateMessage(context, message) {
93
+
94
+ exports.getMessageList = getMessageList;
95
+
96
+ var updateMessage = function updateMessage(context, message) {
83
97
  var database = context.database,
84
98
  sessionId = context.userId;
85
- var files = message.files,
86
- messageId = message.id,
87
- toId = message.toId;
88
- var formatToId = parseId(toId);
99
+ var convoId = message.convoId,
100
+ files = message.files,
101
+ images = message.images,
102
+ msgId = message.msgId;
103
+ var formatConvoId = (0, _utils.parseId)(convoId);
89
104
 
90
- if (formatToId === '') {
91
- throw new Error('required_to');
105
+ if (formatConvoId === '') {
106
+ throw new Error('required_convoId');
92
107
  }
93
108
 
94
- return getConversation(context, formatToId).then(function (conversation) {
109
+ return (0, _conversations.getConversation)(context, formatConvoId).then(function (conversation) {
95
110
  var conversationKey = conversation._key;
96
- var now = new Date().getTime();
111
+ var now = Date.now();
97
112
  var update = {
98
- content: parseVarChar(message.content, 640),
113
+ content: (0, _utils.parseVarChar)(message.content, 640),
114
+ convoId: formatConvoId,
99
115
  files: files || [],
100
- fromId: sessionId,
116
+ images: images || [],
101
117
  modified: now,
102
- toId: formatToId
118
+ userId: sessionId
103
119
  };
104
- var formatId = parseId(messageId);
105
- var updatedId = formatId === '' ? createHash("message-".concat(sessionId)) : formatId;
120
+ var formatMsgId = (0, _utils.parseId)(msgId);
121
+ var updatedId = formatMsgId === '' ? (0, _utils.createHash)("message-".concat(sessionId)) : formatMsgId;
106
122
 
107
- var insert = _objectSpread({}, cloneDeep(update), {
123
+ var insert = _objectSpread({}, (0, _cloneDeep.default)(update), {
108
124
  _key: updatedId,
109
125
  added: now
110
126
  });
111
127
 
112
- var aqlQry = aql(_templateObject(), updatedId, conversationKey, insert, update);
113
- return useDb(database).query(aqlQry).then(function (cursor) {
128
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), updatedId, conversationKey, insert, update);
129
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
114
130
  return cursor.next();
115
131
  }).then(function () {
116
132
  var updatedMessage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
@@ -145,19 +161,22 @@ export var updateMessage = function updateMessage(context, message) {
145
161
  });
146
162
  });
147
163
  };
148
- export var saveMessage = function saveMessage(context, msgId, convoId) {
164
+
165
+ exports.updateMessage = updateMessage;
166
+
167
+ var saveMessage = function saveMessage(context, msgId, convoId) {
149
168
  var database = context.database,
150
169
  sessionId = context.userId;
151
- var formatId = parseId(msgId);
152
- return getConversation(context, convoId).then(function (conversation) {
170
+ var formatId = (0, _utils.parseId)(msgId);
171
+ return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
153
172
  var conversationKey = conversation._key;
154
- var aqlQry = aql(_templateObject2(), formatId, conversationKey, sessionId);
155
- return useDb(database).query(aqlQry).then(function (cursor) {
173
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatId, conversationKey, sessionId);
174
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
156
175
  return cursor.next();
157
176
  }).then(function () {
158
177
  var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
159
178
 
160
- if (!isEmpty(message)) {// Broadcast to message box
179
+ if (!(0, _isEmpty.default)(message)) {// Broadcast to message box
161
180
  // const msg: MessageType = Messages.getMessageObject(message);
162
181
  // io.to(message.toId).emit('message_save', msg);
163
182
  }
@@ -168,19 +187,22 @@ export var saveMessage = function saveMessage(context, msgId, convoId) {
168
187
  });
169
188
  });
170
189
  };
171
- export var unsaveMessage = function unsaveMessage(context, msgId, convoId) {
190
+
191
+ exports.saveMessage = saveMessage;
192
+
193
+ var unsaveMessage = function unsaveMessage(context, msgId, convoId) {
172
194
  var database = context.database,
173
195
  sessionId = context.userId;
174
- var formatId = parseId(msgId);
175
- return getConversation(context, convoId).then(function (conversation) {
196
+ var formatId = (0, _utils.parseId)(msgId);
197
+ return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
176
198
  var conversationKey = conversation._key;
177
- var aqlQry = aql(_templateObject3(), formatId, conversationKey, sessionId);
178
- return useDb(database).query(aqlQry).then(function (cursor) {
199
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatId, conversationKey, sessionId);
200
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
179
201
  return cursor.next();
180
202
  }).then(function () {
181
203
  var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
182
204
 
183
- if (!isEmpty(message)) {// Broadcast to message box
205
+ if (!(0, _isEmpty.default)(message)) {// Broadcast to message box
184
206
  // const msg: MessageType = Messages.getMessageObject(message);
185
207
  // io.to(message.id).emit('message_unsave', msg);
186
208
  }
@@ -191,19 +213,22 @@ export var unsaveMessage = function unsaveMessage(context, msgId, convoId) {
191
213
  });
192
214
  });
193
215
  };
194
- export var deleteMessage = function deleteMessage(context, msgId, convoId) {
216
+
217
+ exports.unsaveMessage = unsaveMessage;
218
+
219
+ var deleteMessage = function deleteMessage(context, msgId, convoId) {
195
220
  var database = context.database,
196
221
  sessionId = context.userId;
197
- var formatId = parseId(msgId);
198
- return getConversation(context, convoId).then(function (conversation) {
222
+ var formatId = (0, _utils.parseId)(msgId);
223
+ return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
199
224
  var conversationKey = conversation._key;
200
- var aqlQry = aql(_templateObject4(), formatId, conversationKey, sessionId);
201
- return useDb(database).query(aqlQry).then(function (cursor) {
225
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), formatId, conversationKey, sessionId);
226
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
202
227
  return cursor.next();
203
228
  }).then(function () {
204
229
  var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
205
230
 
206
- if (!isEmpty(message)) {// Broadcast to message box
231
+ if (!(0, _isEmpty.default)(message)) {// Broadcast to message box
207
232
  // const msg: MessageType = Messages.getMessageObject(message);
208
233
  // io.to(message.toId).emit('message_delete', msg);
209
234
  }
@@ -214,30 +239,36 @@ export var deleteMessage = function deleteMessage(context, msgId, convoId) {
214
239
  });
215
240
  });
216
241
  };
217
- export var getMessage = function getMessage(data) {
218
- var msgAdded = data.added,
219
- msgContent = data.content,
220
- msgFiles = data.files,
221
- msgFromId = data.fromId,
242
+
243
+ exports.deleteMessage = deleteMessage;
244
+
245
+ var getMessage = function getMessage(data) {
246
+ var added = data.added,
247
+ content = data.content,
248
+ convoId = data.convoId,
249
+ files = data.files,
222
250
  msgId = data._key,
223
- msgRead = data.read,
224
- msgSaved = data.saved,
225
- msgToId = data.toId;
251
+ read = data.read,
252
+ saved = data.saved,
253
+ userId = data.userId;
226
254
  return {
227
- added: msgAdded,
228
- content: msgContent,
229
- files: msgFiles,
230
- fromId: msgFromId,
231
- id: msgId,
232
- read: msgRead,
233
- saved: msgSaved,
234
- toId: msgToId
255
+ added: added,
256
+ content: content,
257
+ convoId: convoId,
258
+ files: files,
259
+ msgId: msgId,
260
+ read: read,
261
+ saved: saved,
262
+ userId: userId
235
263
  };
236
264
  };
237
- export var cleanMessages = function cleanMessages(database) {
265
+
266
+ exports.getMessage = getMessage;
267
+
268
+ var cleanMessages = function cleanMessages(database) {
238
269
  // Remove all messages that are over 60 days and not saved
239
- var aqlQry = aql(_templateObject5());
240
- return useDb(database).query(aqlQry).then(function (cursor) {
270
+ var aqlQry = (0, _arangojs.aql)(_templateObject5());
271
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
241
272
  return cursor.all();
242
273
  }).then(function (list) {
243
274
  return list.length;
@@ -245,4 +276,6 @@ export var cleanMessages = function cleanMessages(database) {
245
276
  throw error;
246
277
  });
247
278
  };
248
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/messages.ts"],"names":["createHash","parseId","parseVarChar","aql","cloneDeep","isEmpty","getLimit","useDb","getConversation","getMessageList","context","convoId","from","to","database","formatConvoId","then","conversation","conversationKey","_key","limit","aqlQry","query","cursor","all","catch","error","updateMessage","message","sessionId","userId","files","messageId","id","toId","formatToId","Error","now","Date","getTime","update","content","fromId","modified","formatId","updatedId","insert","added","next","updatedMessage","console","log","saveMessage","msgId","unsaveMessage","deleteMessage","getMessage","data","msgAdded","msgContent","msgFiles","msgFromId","msgRead","read","msgSaved","saved","msgToId","cleanMessages","list","length"],"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 {createHash, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEmpty from 'lodash/isEmpty';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {ConversationType} from '../types/conversations';\nimport {MessageType} from '../types/messages';\nimport {getLimit, useDb} from '../utils';\nimport {getConversation} from './conversations';\n\n// const eventCategory: string = 'messages';\n\nexport const getMessageList = (\n  context: ApiContext,\n  convoId: string,\n  from: number,\n  to: number\n): Promise<MessageType[]> => {\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  return getConversation(context, formatConvoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR m IN messages\n          FILTER m.to == \"${conversationKey}\"\n          ${limit.aql}\n          SORT m.added\n          RETURN m`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const updateMessage = (context: ApiContext, message: MessageType): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const {files, id: messageId, toId} = message;\n  const formatToId: string = parseId(toId);\n\n  if(formatToId === '') {\n    throw new Error('required_to');\n  }\n\n  return getConversation(context, formatToId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const now: number = (new Date()).getTime();\n      const update: MessageType = {\n        content: parseVarChar(message.content, 640),\n        files: files || [],\n        fromId: sessionId,\n        modified: now,\n        toId: formatToId\n      };\n      const formatId: string = parseId(messageId);\n      const updatedId: string = formatId === '' ? createHash(`message-${sessionId}`) : formatId;\n      const insert: MessageType = {\n        ...cloneDeep(update),\n        _key: updatedId,\n        added: now\n      };\n      const aqlQry: AqlQuery = aql`UPSERT {_key: ${updatedId}, to: ${conversationKey}}\n          INSERT ${insert}\n          UPDATE ${update}\n          IN messages RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedMessage: MessageType = {}) => {\n          // const {\n          //   _key: msgId,\n          //   added: msgAdded,\n          //   content: msgContent,\n          //   files: msgFiles,\n          //   fromId: msgFromId,\n          //   read: msgRead,\n          //   saved: msgSaved,\n          //   toId: msgToId\n          // } = updatedMessage;\n\n          // Broadcast to message box\n          // if(io) {\n          //   const msg: MessageType = {\n          //     added: msgAdded,\n          //     content: msgContent,\n          //     files: msgFiles,\n          //     fromId: msgFromId,\n          //     id: msgId,\n          //     read: msgRead,\n          //     saved: msgSaved,\n          //     toId: msgToId\n          //   };\n\n          //   io.to(msgToId).emit('message_update', msg);\n          // }\n\n          console.log('updatedMessage', updatedMessage);\n          return updatedMessage;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const saveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey}\n        UPDATE m WITH {saved: APPEND(m.saved, ${sessionId}, true)} IN messages\n        RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_save', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const unsaveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry: AqlQuery = aql`FOR m IN messages\n          FILTER m._key == ${formatId} && m.to == ${conversationKey}\n          UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ${sessionId})} IN messages\n          RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.id).emit('message_unsave', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const deleteMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey} && m.from == ${sessionId}\n        REMOVE m IN messages\n        RETURN OLD`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_delete', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const getMessage = (data: MessageType): MessageType => {\n  const {\n    added: msgAdded,\n    content: msgContent,\n    files: msgFiles,\n    fromId: msgFromId,\n    _key: msgId,\n    read: msgRead,\n    saved: msgSaved,\n    toId: msgToId\n  } = data;\n\n  return {\n    added: msgAdded,\n    content: msgContent,\n    files: msgFiles,\n    fromId: msgFromId,\n    id: msgId,\n    read: msgRead,\n    saved: msgSaved,\n    toId: msgToId\n  };\n};\n\nexport const cleanMessages = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry = aql`FOR m IN messages\n      FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n      REMOVE m IN messages\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: MessageType[]) => list.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
279
+
280
+ exports.cleanMessages = cleanMessages;
281
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/messages.ts"],"names":["getMessageList","context","convoId","from","to","database","formatConvoId","then","conversation","conversationKey","_key","limit","aqlQry","aql","query","cursor","all","catch","error","updateMessage","message","sessionId","userId","files","images","msgId","Error","now","Date","update","content","modified","formatMsgId","updatedId","insert","added","next","updatedMessage","console","log","saveMessage","formatId","unsaveMessage","deleteMessage","getMessage","data","read","saved","cleanMessages","list","length"],"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 {createHash, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEmpty from 'lodash/isEmpty';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {ConversationType} from '../types/conversations';\nimport {MessageInputType, MessageType} from '../types/messages';\nimport {getLimit, useDb} from '../utils';\nimport {getConversation} from './conversations';\n\n// const eventCategory: string = 'messages';\n\nexport const getMessageList = (\n  context: ApiContext,\n  convoId: string,\n  from: number,\n  to: number\n): Promise<MessageType[]> => {\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  return getConversation(context, formatConvoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR m IN messages\n          FILTER m.to == \"${conversationKey}\"\n          ${limit.aql}\n          SORT m.added\n          RETURN m`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const updateMessage = (context: ApiContext, message: MessageInputType): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const {convoId, files, images, msgId} = message;\n  const formatConvoId: string = parseId(convoId);\n\n  if(formatConvoId === '') {\n    throw new Error('required_convoId');\n  }\n\n  return getConversation(context, formatConvoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const now: number = Date.now();\n      const update: MessageType = {\n        content: parseVarChar(message.content, 640),\n        convoId: formatConvoId,\n        files: files || [],\n        images: images || [],\n        modified: now,\n        userId: sessionId\n      };\n      const formatMsgId: string = parseId(msgId);\n      const updatedId: string = formatMsgId === '' ? createHash(`message-${sessionId}`) : formatMsgId;\n      const insert: MessageType = {\n        ...cloneDeep(update),\n        _key: updatedId,\n        added: now\n      };\n      const aqlQry: AqlQuery = aql`UPSERT {_key: ${updatedId}, convoId: ${conversationKey}}\n          INSERT ${insert}\n          UPDATE ${update}\n          IN messages RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedMessage: MessageType = {}) => {\n          // const {\n          //   _key: msgId,\n          //   added: msgAdded,\n          //   content: msgContent,\n          //   files: msgFiles,\n          //   fromId: msgFromId,\n          //   read: msgRead,\n          //   saved: msgSaved,\n          //   toId: msgToId\n          // } = updatedMessage;\n\n          // Broadcast to message box\n          // if(io) {\n          //   const msg: MessageType = {\n          //     added: msgAdded,\n          //     content: msgContent,\n          //     files: msgFiles,\n          //     fromId: msgFromId,\n          //     id: msgId,\n          //     read: msgRead,\n          //     saved: msgSaved,\n          //     toId: msgToId\n          //   };\n\n          //   io.to(msgToId).emit('message_update', msg);\n          // }\n\n          console.log('updatedMessage', updatedMessage);\n          return updatedMessage;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const saveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey}\n        UPDATE m WITH {saved: APPEND(m.saved, ${sessionId}, true)} IN messages\n        RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_save', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const unsaveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry: AqlQuery = aql`FOR m IN messages\n          FILTER m._key == ${formatId} && m.to == ${conversationKey}\n          UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ${sessionId})} IN messages\n          RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.id).emit('message_unsave', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const deleteMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey} && m.from == ${sessionId}\n        REMOVE m IN messages\n        RETURN OLD`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_delete', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const getMessage = (data: MessageType): MessageType => {\n  const {\n    added,\n    content,\n    convoId,\n    files,\n    _key: msgId,\n    read,\n    saved,\n    userId\n  } = data;\n\n  return {\n    added,\n    content,\n    convoId,\n    files,\n    msgId,\n    read,\n    saved,\n    userId\n  };\n};\n\nexport const cleanMessages = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry = aql`FOR m IN messages\n      FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n      REMOVE m IN messages\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: MessageType[]) => list.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}