@nlabs/reaktor 0.3.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/lib/config.js +153 -0
  2. package/lib/data/conversations.js +311 -0
  3. package/lib/data/dynamodb.js +206 -0
  4. package/lib/data/email.js +222 -0
  5. package/lib/data/files.js +525 -0
  6. package/lib/data/groups.js +435 -0
  7. package/lib/data/images.d.ts +3 -2
  8. package/lib/data/images.js +1051 -0
  9. package/lib/data/index.js +266 -0
  10. package/lib/data/ios.js +355 -0
  11. package/lib/data/locations.js +172 -0
  12. package/lib/data/messages.js +299 -0
  13. package/lib/data/notifications.d.ts +2 -2
  14. package/lib/data/notifications.js +59 -0
  15. package/lib/data/payments.js +771 -0
  16. package/lib/data/posts.d.ts +1 -1
  17. package/lib/data/posts.js +766 -0
  18. package/lib/data/reactions.js +529 -0
  19. package/lib/data/s3.js +155 -0
  20. package/lib/data/search.js +155 -0
  21. package/lib/data/sms.js +83 -0
  22. package/lib/data/subscription.js +337 -0
  23. package/lib/data/tags.js +397 -0
  24. package/lib/data/users.d.ts +7 -4
  25. package/lib/data/users.js +470 -0
  26. package/lib/data/websockets.js +250 -0
  27. package/lib/index.js +45 -0
  28. package/lib/types/apps.js +2 -0
  29. package/lib/types/arangodb.js +2 -0
  30. package/lib/types/auth.js +2 -0
  31. package/lib/types/conversations.d.ts +2 -0
  32. package/lib/types/conversations.js +2 -0
  33. package/lib/types/email.js +2 -0
  34. package/lib/types/files.js +2 -0
  35. package/lib/types/google.js +2 -0
  36. package/lib/types/groups.js +2 -0
  37. package/lib/types/images.js +2 -0
  38. package/lib/types/index.js +227 -0
  39. package/lib/types/locations.js +2 -0
  40. package/lib/types/messages.js +2 -0
  41. package/lib/types/notifications.js +2 -0
  42. package/lib/types/payments.js +2 -0
  43. package/lib/types/posts.js +2 -0
  44. package/lib/types/reactions.d.ts +2 -0
  45. package/lib/types/reactions.js +2 -0
  46. package/lib/types/tags.js +2 -0
  47. package/lib/types/users.d.ts +1 -0
  48. package/lib/types/users.js +2 -0
  49. package/lib/utils/analytics.js +83 -0
  50. package/lib/utils/arangodb.js +143 -0
  51. package/lib/utils/auth.js +75 -0
  52. package/lib/utils/graphql.js +21 -0
  53. package/lib/utils/index.js +84 -0
  54. package/lib/utils/objects.js +62 -0
  55. package/lib/utils/redis.js +36 -0
  56. package/package.json +30 -30
@@ -0,0 +1,172 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.array.concat");
4
+
5
+ require("core-js/modules/es.array.filter");
6
+
7
+ require("core-js/modules/es.array.find");
8
+
9
+ require("core-js/modules/es.array.find-index");
10
+
11
+ require("core-js/modules/es.array.join");
12
+
13
+ require("core-js/modules/es.array.slice");
14
+
15
+ require("core-js/modules/es.date.now");
16
+
17
+ require("core-js/modules/es.date.to-string");
18
+
19
+ require("core-js/modules/es.object.define-properties");
20
+
21
+ require("core-js/modules/es.object.freeze");
22
+
23
+ Object.defineProperty(exports, "__esModule", {
24
+ value: true
25
+ });
26
+ exports.addLocation = void 0;
27
+
28
+ var _ripHunter = require("@nlabs/rip-hunter");
29
+
30
+ var _utils = require("@nlabs/utils");
31
+
32
+ var _arangojs = require("arangojs");
33
+
34
+ var _get = _interopRequireDefault(require("lodash/get"));
35
+
36
+ var _config = require("../config");
37
+
38
+ var _utils2 = require("../utils");
39
+
40
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
41
+
42
+ function _templateObject() {
43
+ var data = _taggedTemplateLiteral(["UPSERT {googleId: ", "}\n INSERT ", "\n UPDATE ", "\n IN locations RETURN NEW"]);
44
+
45
+ _templateObject = function _templateObject() {
46
+ return data;
47
+ };
48
+
49
+ return data;
50
+ }
51
+
52
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
53
+
54
+ var eventCategory = 'locations';
55
+
56
+ var addLocation = function addLocation(context, location) {
57
+ var action = 'add';
58
+ var database = context.database,
59
+ sessionId = context.userId;
60
+ var address = location.address,
61
+ itemId = location.itemId,
62
+ itemType = location.itemType;
63
+
64
+ var geocodeUrl = _config.Config.get('google.geocode.url');
65
+
66
+ var params = {
67
+ address: address,
68
+ key: _config.Config.get('google.geocode.key')
69
+ };
70
+ var url = "".concat(geocodeUrl, "?").concat((0, _ripHunter.queryString)(params));
71
+ return (0, _ripHunter.get)(url).then(function (json) {
72
+ var _json$results = json.results,
73
+ results = _json$results === void 0 ? [] : _json$results,
74
+ _json$status = json.status,
75
+ status = _json$status === void 0 ? '' : _json$status;
76
+
77
+ if (status === 'OK' && results.length) {
78
+ var geodata = results[0];
79
+ var addressComponents = (0, _get["default"])(geodata, 'address_components');
80
+
81
+ var getFieldVal = function getFieldVal(name) {
82
+ var _ref = addressComponents.find(function (addressField) {
83
+ var types = addressField.types || [];
84
+ return types.findIndex(function (fieldType) {
85
+ return fieldType === name;
86
+ }) >= 0;
87
+ }) || {},
88
+ _ref$short_name = _ref.short_name,
89
+ shortName = _ref$short_name === void 0 ? '' : _ref$short_name;
90
+
91
+ return shortName;
92
+ }; // Street
93
+
94
+
95
+ var streetNumber = getFieldVal('street_number');
96
+ var route = getFieldVal('route'); // Location
97
+
98
+ var now = Date.now(); // Item
99
+
100
+ var formatItemType = (0, _utils.parseChar)(itemType).toLowerCase();
101
+ var formatItemId = (0, _utils.parseId)(itemId);
102
+ var googleId = (0, _get["default"])(geodata, 'place_id');
103
+ var update = {};
104
+ var insert = {
105
+ _key: (0, _utils.createHash)("post-".concat(sessionId)),
106
+ added: now,
107
+ city: getFieldVal('locality'),
108
+ country: getFieldVal('country'),
109
+ formatted: (0, _get["default"])(geodata, 'formatted_address'),
110
+ googleId: googleId,
111
+ latitude: (0, _get["default"])(geodata, 'geometry.location.lat'),
112
+ longitude: (0, _get["default"])(geodata, 'geometry.location.lng'),
113
+ state: getFieldVal('administrative_area_level_1'),
114
+ street: [streetNumber, route].filter(function (obj) {
115
+ return obj;
116
+ }).join(' '),
117
+ zip: getFieldVal('postal_code')
118
+ };
119
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), googleId, insert, update);
120
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
121
+ return cursor.next();
122
+ }).then(function () {
123
+ var updatedLocation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
124
+ var itemDocId;
125
+ var updatedLocationKey = updatedLocation._key;
126
+
127
+ switch (formatItemType) {
128
+ case 'posts':
129
+ itemDocId = "posts/".concat(formatItemId);
130
+ break;
131
+
132
+ default:
133
+ itemDocId = '';
134
+ } // If there is a valid item doc id, create an edge
135
+
136
+
137
+ if (itemDocId) {
138
+ var edgeCollection = (0, _utils2.useDb)(database).collection('hasLocation');
139
+ var locationId = updatedLocationKey;
140
+ var locationDocId = "locations/".concat(locationId);
141
+ var edgeId = (0, _utils.createHash)("hasLocation-".concat(locationId, "-").concat(sessionId));
142
+ var edge = {
143
+ _from: itemDocId,
144
+ _key: edgeId,
145
+ _to: locationDocId
146
+ };
147
+ return edgeCollection.save(edge, {
148
+ returnNew: true
149
+ }).then(function () {
150
+ return updatedLocation;
151
+ });
152
+ } // Otherwise just return the new location
153
+
154
+
155
+ return updatedLocation;
156
+ })["catch"](function (error) {
157
+ return (0, _utils2.logError)({
158
+ action: action,
159
+ category: eventCategory,
160
+ label: 'db_error'
161
+ }, error, context).then(function () {
162
+ return null;
163
+ });
164
+ });
165
+ }
166
+
167
+ return {};
168
+ });
169
+ };
170
+
171
+ exports.addLocation = addLocation;
172
+ //# 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","collection","locationId","locationDocId","edgeId","edge","_from","_to","save","returnNew","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/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/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: EdgeCollection = useDb(database).collection('hasLocation');\n              const locationId: string = updatedLocationKey;\n              const locationDocId: string = `locations/${locationId}`;\n              const edgeId = createHash(`hasLocation-${locationId}-${sessionId}`);\n              const edge: any = {_from: itemDocId, _key: edgeId, _to: locationDocId};\n\n              return edgeCollection.save(edge, {returnNew: true}).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,299 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.symbol");
4
+
5
+ require("core-js/modules/es.array.concat");
6
+
7
+ require("core-js/modules/es.array.filter");
8
+
9
+ require("core-js/modules/es.array.for-each");
10
+
11
+ require("core-js/modules/es.array.slice");
12
+
13
+ require("core-js/modules/es.date.now");
14
+
15
+ require("core-js/modules/es.date.to-string");
16
+
17
+ require("core-js/modules/es.object.define-properties");
18
+
19
+ require("core-js/modules/es.object.define-property");
20
+
21
+ require("core-js/modules/es.object.freeze");
22
+
23
+ require("core-js/modules/es.object.get-own-property-descriptor");
24
+
25
+ require("core-js/modules/es.object.get-own-property-descriptors");
26
+
27
+ require("core-js/modules/es.object.keys");
28
+
29
+ require("core-js/modules/web.dom-collections.for-each");
30
+
31
+ Object.defineProperty(exports, "__esModule", {
32
+ value: true
33
+ });
34
+ exports.cleanMessages = exports.getMessage = exports.deleteMessage = exports.unsaveMessage = exports.saveMessage = exports.updateMessage = exports.getMessageList = void 0;
35
+
36
+ var _utils = require("@nlabs/utils");
37
+
38
+ var _arangojs = require("arangojs");
39
+
40
+ var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
41
+
42
+ var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
43
+
44
+ var _utils2 = require("../utils");
45
+
46
+ var _conversations = require("./conversations");
47
+
48
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
49
+
50
+ function _templateObject6() {
51
+ 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"]);
52
+
53
+ _templateObject6 = function _templateObject6() {
54
+ return data;
55
+ };
56
+
57
+ return data;
58
+ }
59
+
60
+ function _templateObject5() {
61
+ var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", " && m.from == ", "\n REMOVE m IN messages\n RETURN OLD"]);
62
+
63
+ _templateObject5 = function _templateObject5() {
64
+ return data;
65
+ };
66
+
67
+ return data;
68
+ }
69
+
70
+ function _templateObject4() {
71
+ 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"]);
72
+
73
+ _templateObject4 = function _templateObject4() {
74
+ return data;
75
+ };
76
+
77
+ return data;
78
+ }
79
+
80
+ function _templateObject3() {
81
+ 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"]);
82
+
83
+ _templateObject3 = function _templateObject3() {
84
+ return data;
85
+ };
86
+
87
+ return data;
88
+ }
89
+
90
+ function _templateObject2() {
91
+ var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", convoId: ", ", userId: ", "}\n INSERT ", "\n UPDATE ", " IN messages\n RETURN NEW"]);
92
+
93
+ _templateObject2 = function _templateObject2() {
94
+ return data;
95
+ };
96
+
97
+ return data;
98
+ }
99
+
100
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
101
+
102
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
103
+
104
+ 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; }
105
+
106
+ function _templateObject() {
107
+ var data = _taggedTemplateLiteral(["FOR e IN hasConversations\n FILTER e._from == ", " && e._to == ", "\n LIMIT 1\n RETURN e"]);
108
+
109
+ _templateObject = function _templateObject() {
110
+ return data;
111
+ };
112
+
113
+ return data;
114
+ }
115
+
116
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
117
+
118
+ // const eventCategory: string = 'messages';
119
+ var getMessageList = function getMessageList(context, convoId, from, to) {
120
+ var database = context.database,
121
+ sessionId = context.userId;
122
+ var formatConvoId = (0, _utils.parseId)(convoId);
123
+ var sessionDocId = "users/".concat(sessionId);
124
+ var convoDocId = "conversations/".concat(formatConvoId);
125
+ var convoQry = (0, _arangojs.aql)(_templateObject(), sessionDocId, convoDocId);
126
+ return (0, _utils2.useDb)(database).query(convoQry).then(function (cursor) {
127
+ return cursor.all();
128
+ }).then(function (conversations) {
129
+ if (!conversations.length) {
130
+ return [];
131
+ }
132
+
133
+ var limit = (0, _utils2.getLimit)(from, to);
134
+ var aqlQry = "FOR m IN messages\n FILTER m.convoId == \"".concat(formatConvoId, "\"\n SORT m.added DESC\n ").concat(limit.aql, "\n SORT m.added ASC\n LET user = FIRST(\n FOR u IN users\n FILTER u._key == m.userId\n LIMIT 1\n RETURN u\n )\n RETURN MERGE(m, {user: user})");
135
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
136
+ return cursor.all();
137
+ })["catch"](function (error) {
138
+ throw error;
139
+ });
140
+ });
141
+ };
142
+
143
+ exports.getMessageList = getMessageList;
144
+
145
+ var updateMessage = function updateMessage(context, message) {
146
+ var database = context.database,
147
+ sessionId = context.userId;
148
+ var convoId = message.convoId,
149
+ files = message.files,
150
+ images = message.images,
151
+ _message$msgId = message.msgId,
152
+ msgId = _message$msgId === void 0 ? (0, _utils.createHash)("message-".concat(sessionId)) : _message$msgId;
153
+ var formatConvoId = (0, _utils.parseId)(convoId);
154
+
155
+ if (formatConvoId === '') {
156
+ throw new Error('required_convoId');
157
+ }
158
+
159
+ var now = Date.now();
160
+ var update = {
161
+ content: (0, _utils.parseVarChar)(message.content, 640),
162
+ files: files || [],
163
+ images: images || [],
164
+ modified: now
165
+ };
166
+ var formatMsgId = (0, _utils.parseId)(msgId);
167
+
168
+ var insert = _objectSpread(_objectSpread({}, (0, _cloneDeep["default"])(update)), {}, {
169
+ _key: formatMsgId,
170
+ added: now,
171
+ convoId: formatConvoId,
172
+ userId: sessionId
173
+ });
174
+
175
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatMsgId, formatConvoId, sessionId, insert, update);
176
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
177
+ return cursor.next();
178
+ })["catch"](function (error) {
179
+ throw error;
180
+ });
181
+ };
182
+
183
+ exports.updateMessage = updateMessage;
184
+
185
+ var saveMessage = function saveMessage(context, msgId, convoId) {
186
+ var database = context.database,
187
+ sessionId = context.userId;
188
+ var formatId = (0, _utils.parseId)(msgId);
189
+ return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
190
+ var conversationKey = conversation._key;
191
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatId, conversationKey, sessionId);
192
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
193
+ return cursor.next();
194
+ }).then(function () {
195
+ var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
196
+
197
+ if (!(0, _isEmpty["default"])(message)) {// Broadcast to message box
198
+ // const msg: MessageType = Messages.getMessageObject(message);
199
+ // io.to(message.toId).emit('message_save', msg);
200
+ }
201
+
202
+ return message;
203
+ })["catch"](function (error) {
204
+ throw error;
205
+ });
206
+ });
207
+ };
208
+
209
+ exports.saveMessage = saveMessage;
210
+
211
+ var unsaveMessage = function unsaveMessage(context, msgId, convoId) {
212
+ var database = context.database,
213
+ sessionId = context.userId;
214
+ var formatId = (0, _utils.parseId)(msgId);
215
+ return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
216
+ var conversationKey = conversation._key;
217
+ var aqlQry = (0, _arangojs.aql)(_templateObject4(), formatId, conversationKey, sessionId);
218
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
219
+ return cursor.next();
220
+ }).then(function () {
221
+ var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
222
+
223
+ if (!(0, _isEmpty["default"])(message)) {// Broadcast to message box
224
+ // const msg: MessageType = Messages.getMessageObject(message);
225
+ // io.to(message.id).emit('message_unsave', msg);
226
+ }
227
+
228
+ return message;
229
+ })["catch"](function (error) {
230
+ throw error;
231
+ });
232
+ });
233
+ };
234
+
235
+ exports.unsaveMessage = unsaveMessage;
236
+
237
+ var deleteMessage = function deleteMessage(context, msgId, convoId) {
238
+ var database = context.database,
239
+ sessionId = context.userId;
240
+ var formatId = (0, _utils.parseId)(msgId);
241
+ return (0, _conversations.getConversation)(context, convoId).then(function (conversation) {
242
+ var conversationKey = conversation._key;
243
+ var aqlQry = (0, _arangojs.aql)(_templateObject5(), formatId, conversationKey, sessionId);
244
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
245
+ return cursor.next();
246
+ }).then(function () {
247
+ var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
248
+
249
+ if (!(0, _isEmpty["default"])(message)) {// Broadcast to message box
250
+ // const msg: MessageType = Messages.getMessageObject(message);
251
+ // io.to(message.toId).emit('message_delete', msg);
252
+ }
253
+
254
+ return message;
255
+ })["catch"](function (error) {
256
+ throw error;
257
+ });
258
+ });
259
+ };
260
+
261
+ exports.deleteMessage = deleteMessage;
262
+
263
+ var getMessage = function getMessage(data) {
264
+ var added = data.added,
265
+ content = data.content,
266
+ convoId = data.convoId,
267
+ files = data.files,
268
+ msgId = data._key,
269
+ read = data.read,
270
+ saved = data.saved,
271
+ userId = data.userId;
272
+ return {
273
+ added: added,
274
+ content: content,
275
+ convoId: convoId,
276
+ files: files,
277
+ msgId: msgId,
278
+ read: read,
279
+ saved: saved,
280
+ userId: userId
281
+ };
282
+ };
283
+
284
+ exports.getMessage = getMessage;
285
+
286
+ var cleanMessages = function cleanMessages(database) {
287
+ // Remove all messages that are over 60 days and not saved
288
+ var aqlQry = (0, _arangojs.aql)(_templateObject6());
289
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
290
+ return cursor.all();
291
+ }).then(function (list) {
292
+ return list.length;
293
+ })["catch"](function (error) {
294
+ throw error;
295
+ });
296
+ };
297
+
298
+ exports.cleanMessages = cleanMessages;
299
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/messages.ts"],"names":["getMessageList","context","convoId","from","to","database","sessionId","userId","formatConvoId","sessionDocId","convoDocId","convoQry","aql","query","then","cursor","all","conversations","length","limit","aqlQry","error","updateMessage","message","files","images","msgId","Error","now","Date","update","content","modified","formatMsgId","insert","_key","added","next","saveMessage","formatId","conversation","conversationKey","unsaveMessage","deleteMessage","getMessage","data","read","saved","cleanMessages","list"],"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/aql';\nimport {ArrayCursor} from 'arangojs/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, userId: sessionId} = context;\n  const formatConvoId: string = parseId(convoId);\n  const sessionDocId: string = `users/${sessionId}`;\n  const convoDocId: string = `conversations/${formatConvoId}`;\n\n  const convoQry = aql`FOR e IN hasConversations\n    FILTER e._from == ${sessionDocId} && e._to == ${convoDocId}\n    LIMIT 1\n    RETURN e`;\n\n  return useDb(database).query(convoQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((conversations) => {\n      if(!conversations.length) {\n        return [];\n      }\n\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR m IN messages\n          FILTER m.convoId == \"${formatConvoId}\"\n          SORT m.added DESC\n          ${limit.aql}\n          SORT m.added ASC\n          LET user = FIRST(\n            FOR u IN users\n            FILTER u._key == m.userId\n            LIMIT 1\n            RETURN u\n          )\n          RETURN MERGE(m, {user: user})`;\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 {\n    convoId,\n    files,\n    images,\n    msgId = createHash(`message-${sessionId}`)\n  } = message;\n  const formatConvoId: string = parseId(convoId);\n\n  if(formatConvoId === '') {\n    throw new Error('required_convoId');\n  }\n\n  const now: number = Date.now();\n  const update: MessageType = {\n    content: parseVarChar(message.content, 640),\n    files: files || [],\n    images: images || [],\n    modified: now\n  };\n  const formatMsgId: string = parseId(msgId);\n  const insert: MessageType = {\n    ...cloneDeep(update),\n    _key: formatMsgId,\n    added: now,\n    convoId: formatConvoId,\n    userId: sessionId\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatMsgId}, convoId: ${formatConvoId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update} IN messages\n    RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\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"]}
@@ -1,5 +1,5 @@
1
- import { Provider, Responses } from 'apn';
1
+ import { Responses } from 'apn';
2
2
  import { NotificationType } from '../types/notifications';
3
- export declare const getApnProvider: () => Provider;
3
+ export declare const getApnProvider: () => any;
4
4
  export declare const pushNotification: (deviceTokens: string[], note: NotificationType) => Promise<Responses>;
5
5
  export declare const clearBadges: (deviceTokens: string[]) => Promise<Responses>;
@@ -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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL25vdGlmaWNhdGlvbnMudHMiXSwibmFtZXMiOlsiZ2V0QXBuUHJvdmlkZXIiLCJQcm92aWRlciIsImNhIiwiQ29uZmlnIiwiZ2V0IiwiY2VydCIsImtleSIsInByb2R1Y3Rpb24iLCJwdXNoTm90aWZpY2F0aW9uIiwiZGV2aWNlVG9rZW5zIiwibm90ZSIsInByb3ZpZGVyIiwibm90aWZpY2F0aW9uIiwiQVBOTm90aWZpY2F0aW9uIiwidG9waWMiLCJhbGVydCIsIm1lc3NhZ2UiLCJkYXRhIiwibXV0YWJsZUNvbnRlbnQiLCJwYXlsb2FkIiwiYmFkZ2UiLCJ1bmRlZmluZWQiLCJzZW5kIiwiY2xlYXJCYWRnZXMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFJQTs7QUFFQTs7QUFOQTtBQUNBO0FBQ0E7QUFDQTtBQU1BO0FBRUE7QUFDTyxJQUFNQSxjQUFjLEdBQUcsU0FBakJBLGNBQWlCO0FBQUEsU0FBZ0IsSUFBSUMsYUFBSixDQUFhO0FBQ3pEQyxJQUFBQSxFQUFFLEVBQUVDLGVBQU9DLEdBQVAsQ0FBVyxZQUFYLENBRHFEO0FBRXpEQyxJQUFBQSxJQUFJLEVBQUVGLGVBQU9DLEdBQVAsQ0FBVyxjQUFYLENBRm1EO0FBR3pERSxJQUFBQSxHQUFHLEVBQUVILGVBQU9DLEdBQVAsQ0FBVyxhQUFYLENBSG9EO0FBSXpERyxJQUFBQSxVQUFVLEVBQUVKLGVBQU9DLEdBQVAsQ0FBVyxhQUFYLE1BQThCO0FBSmUsR0FBYixDQUFoQjtBQUFBLENBQXZCOzs7O0FBT0EsSUFBTUksZ0JBQWdCLEdBQUcsU0FBbkJBLGdCQUFtQixDQUFDQyxZQUFELEVBQXlCQyxJQUF6QixFQUF3RTtBQUN0RztBQUNBLE1BQU1DLFFBQWtCLEdBQUdYLGNBQWMsRUFBekM7QUFDQSxNQUFNWSxZQUE2QixHQUFHLElBQUlDLGlCQUFKLEVBQXRDO0FBQ0FELEVBQUFBLFlBQVksQ0FBQ0UsS0FBYixHQUFxQlgsZUFBT0MsR0FBUCxDQUFXLFlBQVgsQ0FBckI7QUFDQVEsRUFBQUEsWUFBWSxDQUFDRyxLQUFiLEdBQXFCTCxJQUFJLENBQUNNLE9BQTFCOztBQUVBLE1BQUdOLElBQUksQ0FBQ08sSUFBUixFQUFjO0FBQ1pMLElBQUFBLFlBQVksQ0FBQ00sY0FBYixHQUE4QixJQUE5QjtBQUNBTixJQUFBQSxZQUFZLENBQUNPLE9BQWIsR0FBdUJULElBQUksQ0FBQ08sSUFBNUI7QUFDRDs7QUFFRCxNQUFHUCxJQUFJLENBQUNVLEtBQUwsS0FBZUMsU0FBbEIsRUFBNkI7QUFDM0JULElBQUFBLFlBQVksQ0FBQ1EsS0FBYixHQUFxQlYsSUFBSSxDQUFDVSxLQUExQjtBQUNEOztBQUVELFNBQU9ULFFBQVEsQ0FBQ1csSUFBVCxDQUFjVixZQUFkLEVBQTRCSCxZQUE1QixDQUFQO0FBQ0QsQ0FqQk07Ozs7QUFtQkEsSUFBTWMsV0FBVyxHQUFHLFNBQWRBLFdBQWMsQ0FBQ2QsWUFBRCxFQUFnRDtBQUN6RTtBQUNBLE1BQU1FLFFBQVEsR0FBR1gsY0FBYyxFQUEvQjtBQUNBLE1BQU1ZLFlBQVksR0FBRyxJQUFJQyxpQkFBSixFQUFyQjtBQUNBRCxFQUFBQSxZQUFZLENBQUNRLEtBQWIsR0FBcUIsQ0FBckI7QUFFQSxTQUFPVCxRQUFRLENBQUNXLElBQVQsQ0FBY1YsWUFBZCxFQUE0QkgsWUFBNUIsQ0FBUDtBQUNELENBUE0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtOb3RpZmljYXRpb24gYXMgQVBOTm90aWZpY2F0aW9uLCBQcm92aWRlciwgUmVzcG9uc2VzfSBmcm9tICdhcG4nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7Tm90aWZpY2F0aW9uVHlwZX0gZnJvbSAnLi4vdHlwZXMvbm90aWZpY2F0aW9ucyc7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdub3RpZmljYXRpb25zJztcblxuLy8gUHVzaCBOb3RpZmljYXRpb25zXG5leHBvcnQgY29uc3QgZ2V0QXBuUHJvdmlkZXIgPSAoKTogUHJvdmlkZXIgPT4gbmV3IFByb3ZpZGVyKHtcbiAgY2E6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2EnKSxcbiAgY2VydDogQ29uZmlnLmdldCgnYXBwLmFwbi5jZXJ0JyksXG4gIGtleTogQ29uZmlnLmdldCgnYXBwLmFwbi5rZXknKSxcbiAgcHJvZHVjdGlvbjogQ29uZmlnLmdldCgnZW52aXJvbm1lbnQnKSA9PT0gJ3Byb2QnXG59KTtcblxuZXhwb3J0IGNvbnN0IHB1c2hOb3RpZmljYXRpb24gPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSwgbm90ZTogTm90aWZpY2F0aW9uVHlwZSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlcjogUHJvdmlkZXIgPSBnZXRBcG5Qcm92aWRlcigpO1xuICBjb25zdCBub3RpZmljYXRpb246IEFQTk5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLnRvcGljID0gQ29uZmlnLmdldCgnYXBwLmFwbi5pZCcpO1xuICBub3RpZmljYXRpb24uYWxlcnQgPSBub3RlLm1lc3NhZ2U7XG5cbiAgaWYobm90ZS5kYXRhKSB7XG4gICAgbm90aWZpY2F0aW9uLm11dGFibGVDb250ZW50ID0gdHJ1ZTtcbiAgICBub3RpZmljYXRpb24ucGF5bG9hZCA9IG5vdGUuZGF0YTtcbiAgfVxuXG4gIGlmKG5vdGUuYmFkZ2UgIT09IHVuZGVmaW5lZCkge1xuICAgIG5vdGlmaWNhdGlvbi5iYWRnZSA9IG5vdGUuYmFkZ2U7XG4gIH1cblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuXG5leHBvcnQgY29uc3QgY2xlYXJCYWRnZXMgPSAoZGV2aWNlVG9rZW5zOiBzdHJpbmdbXSk6IFByb21pc2U8UmVzcG9uc2VzPiA9PiB7XG4gIC8vIFB1c2ggbm90aWZpY2F0aW9uIHRvIGRldmljZVxuICBjb25zdCBwcm92aWRlciA9IGdldEFwblByb3ZpZGVyKCk7XG4gIGNvbnN0IG5vdGlmaWNhdGlvbiA9IG5ldyBBUE5Ob3RpZmljYXRpb24oKTtcbiAgbm90aWZpY2F0aW9uLmJhZGdlID0gMDtcblxuICByZXR1cm4gcHJvdmlkZXIuc2VuZChub3RpZmljYXRpb24sIGRldmljZVRva2Vucyk7XG59O1xuIl19