@nlabs/reaktor 0.1.6 → 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.
- package/lib/config.js +20 -11
- package/lib/data/conversations.js +69 -39
- package/lib/data/dynamodb.js +60 -27
- package/lib/data/email.js +50 -19
- package/lib/data/files.js +103 -46
- package/lib/data/groups.js +114 -67
- package/lib/data/images.js +168 -100
- package/lib/data/index.js +234 -24
- package/lib/data/ios.js +48 -23
- package/lib/data/locations.js +45 -29
- package/lib/data/messages.d.ts +2 -2
- package/lib/data/messages.js +105 -72
- package/lib/data/notifications.js +31 -14
- package/lib/data/payments.js +164 -114
- package/lib/data/posts.js +144 -87
- package/lib/data/reactions.js +58 -33
- package/lib/data/s3.js +54 -24
- package/lib/data/search.js +32 -19
- package/lib/data/sms.js +35 -15
- package/lib/data/subscription.js +78 -51
- package/lib/data/tags.js +90 -51
- package/lib/data/users.js +118 -70
- package/lib/index.js +42 -8
- package/lib/types/apps.js +1 -1
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.js +1 -1
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.js +1 -1
- package/lib/types/files.js +1 -1
- package/lib/types/google.js +1 -1
- package/lib/types/groups.js +1 -1
- package/lib/types/images.js +1 -1
- package/lib/types/index.js +210 -22
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +12 -7
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.js +1 -1
- package/lib/types/reactions.js +1 -1
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +0 -1
- package/lib/types/users.js +1 -1
- package/lib/utils/analytics.js +23 -11
- package/lib/utils/arangodb.js +48 -19
- package/lib/utils/auth.js +31 -15
- package/lib/utils/graphql.js +16 -4
- package/lib/utils/index.js +78 -11
- package/lib/utils/objects.js +30 -10
- package/lib/utils/redis.js +21 -8
- package/package.json +5 -5
- package/index.d.ts +0 -1
package/lib/data/locations.js
CHANGED
|
@@ -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
|
-
|
|
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
|
-
|
|
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
|
|
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 =
|
|
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 =
|
|
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:
|
|
89
|
+
formatted: (0, _get.default)(geodata, 'formatted_address'),
|
|
76
90
|
googleId: googleId,
|
|
77
|
-
latitude:
|
|
78
|
-
longitude:
|
|
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"]}
|
package/lib/data/messages.d.ts
CHANGED
|
@@ -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:
|
|
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>;
|
package/lib/data/messages.js
CHANGED
|
@@ -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: ", ",
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
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 (
|
|
91
|
-
throw new Error('
|
|
105
|
+
if (formatConvoId === '') {
|
|
106
|
+
throw new Error('required_convoId');
|
|
92
107
|
}
|
|
93
108
|
|
|
94
|
-
return getConversation(context,
|
|
109
|
+
return (0, _conversations.getConversation)(context, formatConvoId).then(function (conversation) {
|
|
95
110
|
var conversationKey = conversation._key;
|
|
96
|
-
var now =
|
|
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
|
-
|
|
116
|
+
images: images || [],
|
|
101
117
|
modified: now,
|
|
102
|
-
|
|
118
|
+
userId: sessionId
|
|
103
119
|
};
|
|
104
|
-
var
|
|
105
|
-
var updatedId =
|
|
120
|
+
var formatMsgId = (0, _utils.parseId)(msgId);
|
|
121
|
+
var updatedId = formatMsgId === '' ? (0, _utils.createHash)("message-".concat(sessionId)) : formatMsgId;
|
|
106
122
|
|
|
107
|
-
var insert = _objectSpread({},
|
|
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
|
-
|
|
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 (!
|
|
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
|
-
|
|
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 (!
|
|
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
|
-
|
|
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 (!
|
|
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
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
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
|
-
|
|
224
|
-
|
|
225
|
-
|
|
251
|
+
read = data.read,
|
|
252
|
+
saved = data.saved,
|
|
253
|
+
userId = data.userId;
|
|
226
254
|
return {
|
|
227
|
-
added:
|
|
228
|
-
content:
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
read:
|
|
233
|
-
saved:
|
|
234
|
-
|
|
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
|
-
|
|
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"]}
|