@nlabs/reaktor 0.1.12 → 0.1.14

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