@nlabs/reaktor 0.2.3 → 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.
- package/lib/config.js +12 -4
- package/lib/data/conversations.d.ts +3 -1
- package/lib/data/conversations.js +150 -65
- package/lib/data/dynamodb.d.ts +8 -8
- package/lib/data/dynamodb.js +65 -33
- package/lib/data/email.d.ts +2 -2
- package/lib/data/email.js +52 -24
- package/lib/data/files.js +71 -11
- package/lib/data/groups.js +37 -3
- package/lib/data/images.d.ts +3 -2
- package/lib/data/images.js +425 -273
- package/lib/data/index.d.ts +1 -0
- package/lib/data/index.js +33 -1
- package/lib/data/ios.d.ts +5 -5
- package/lib/data/ios.js +47 -21
- package/lib/data/locations.js +28 -4
- package/lib/data/messages.js +89 -73
- package/lib/data/notifications.d.ts +2 -2
- package/lib/data/notifications.js +6 -6
- package/lib/data/payments.d.ts +3 -4
- package/lib/data/payments.js +228 -257
- package/lib/data/posts.d.ts +1 -1
- package/lib/data/posts.js +88 -12
- package/lib/data/reactions.d.ts +1 -1
- package/lib/data/reactions.js +56 -14
- package/lib/data/s3.d.ts +6 -6
- package/lib/data/s3.js +10 -2
- package/lib/data/search.js +46 -4
- package/lib/data/sms.js +5 -1
- package/lib/data/subscription.d.ts +1 -1
- package/lib/data/subscription.js +46 -20
- package/lib/data/tags.js +60 -8
- package/lib/data/users.d.ts +7 -4
- package/lib/data/users.js +83 -32
- package/lib/data/websockets.d.ts +6 -0
- package/lib/data/websockets.js +250 -0
- package/lib/index.js +4 -1
- package/lib/types/conversations.d.ts +2 -0
- package/lib/types/index.js +18 -1
- package/lib/types/payments.d.ts +1 -0
- package/lib/types/posts.d.ts +2 -0
- package/lib/types/reactions.d.ts +2 -0
- package/lib/types/users.d.ts +1 -0
- package/lib/utils/analytics.js +28 -6
- package/lib/utils/arangodb.d.ts +2 -1
- package/lib/utils/arangodb.js +31 -10
- package/lib/utils/auth.js +21 -3
- package/lib/utils/graphql.js +3 -1
- package/lib/utils/index.js +7 -1
- package/lib/utils/objects.js +9 -1
- package/lib/utils/redis.js +6 -2
- package/package.json +33 -31
package/lib/config.js
CHANGED
|
@@ -1,5 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
require("core-js/modules/es.array.concat");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.array.iterator");
|
|
6
|
+
|
|
7
|
+
require("core-js/modules/es.object.define-property");
|
|
8
|
+
|
|
9
|
+
require("core-js/modules/es.object.to-string");
|
|
10
|
+
|
|
11
|
+
require("core-js/modules/web.dom-collections.iterator");
|
|
12
|
+
|
|
3
13
|
Object.defineProperty(exports, "__esModule", {
|
|
4
14
|
value: true
|
|
5
15
|
});
|
|
@@ -32,9 +42,7 @@ var _process$env = process.env,
|
|
|
32
42
|
_process$env$arangodb4 = _process$env.arangodbUsername,
|
|
33
43
|
arangodbUsername = _process$env$arangodb4 === void 0 ? 'reaktor' : _process$env$arangodb4;
|
|
34
44
|
|
|
35
|
-
var Config =
|
|
36
|
-
/*#__PURE__*/
|
|
37
|
-
function () {
|
|
45
|
+
var Config = /*#__PURE__*/function () {
|
|
38
46
|
function Config() {
|
|
39
47
|
_classCallCheck(this, Config);
|
|
40
48
|
}
|
|
@@ -142,4 +150,4 @@ _defineProperty(Config, "values", {
|
|
|
142
150
|
},
|
|
143
151
|
test: {}
|
|
144
152
|
});
|
|
145
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
153
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/config.ts"],"names":["appPackage","require","process","env","arangodbDatabase","arangodbPassword","arangodbPort","arangodbUrl","arangodbUsername","Config","path","environment","stage","configValues","values","app","name","url","version","arangodb","database","dump","password","port","restore","username","aws","Bucket","accessKeyId","maxRetries","region","secretAccessKey","signatureVersion","giphy","key","google","analytics","accountId","trackingId","geocode","image","imgQuality","imgSize","thmQuality","thmSize","redis","host","stripe","token","twilio","number","sid","dev","prod","test"],"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 from 'lodash/get';\nimport merge from 'lodash/merge';\n\nexport interface AppConfig {\n  readonly app?: object;\n  readonly arangodb?: object;\n  readonly aws?: object;\n  readonly giphy?: object;\n  readonly google?: object;\n  readonly image?: object;\n  readonly redis?: object;\n  readonly stripe?: object;\n  readonly twilio?: object;\n}\n\nexport interface EnvConfig {\n  readonly default: AppConfig;\n  readonly dev: AppConfig;\n  readonly prod: AppConfig;\n  readonly test: AppConfig;\n}\n\nconst appPackage: any = require('../package.json');\n\nconst {\n  arangodbDatabase = 'reaktor',\n  arangodbPassword,\n  arangodbPort = '8529',\n  arangodbUrl = 'db.reaktor.io',\n  arangodbUsername = 'reaktor'\n} = process.env;\n\nexport class Config {\n  static values: EnvConfig = {\n    default: {\n      app: {\n        name: 'reaktor',\n        url: 'reaktor.io',\n        version: appPackage.version\n      },\n      arangodb: {\n        database: arangodbDatabase,\n        dump: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangodump',\n        password: arangodbPassword,\n        port: arangodbPort,\n        restore: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangorestore',\n        url: `${arangodbUrl}:${arangodbPort}`,\n        username: arangodbUsername\n      },\n      aws: {\n        Bucket: 'dev.reaktor.io',\n        accessKeyId: 'AKIAJIYDT3EA2ZFMTJNA',\n        maxRetries: 3,\n        region: 'us-east-1',\n        secretAccessKey: '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',\n        signatureVersion: 'v4'\n      },\n      giphy: {\n        key: 'dc6zaTOxFJmzC'\n      },\n      google: {\n        analytics: {\n          accountId: '78158717',\n          trackingId: 'UA-78158717-1'\n        },\n        geocode: {\n          key: 'AIzaSyBwjmpBjWhiJoBCZiYzRurM9m4WnCxslv0',\n          url: 'https://maps.googleapis.com/maps/api/geocode/json'\n        },\n        key: 'AIzaSyC3_f2Us3y0qjbyMJ-4t5ObtCzfq_FHIgQ'\n      },\n      image: {\n        imgQuality: 90,\n        imgSize: 1500,\n        thmQuality: 80,\n        thmSize: 150\n      },\n      redis: {\n        host: '127.0.0.1',\n        port: 6379\n      },\n      stripe: {\n        token: 'sk_test_LS956be57YUXTB5a4sLGb5BQ'\n      },\n      twilio: {\n        number: '+15005550006',\n        sid: 'AC6bd7f513cbed2e5134c650be06cc732e',\n        token: '520ae739e761bab759b147f1ad28278f'\n      }\n    },\n    dev: {\n      aws: {\n        Bucket: 'dev.reaktor.io'\n      },\n      redis: {\n        host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'\n      }\n    },\n    prod: {\n      arangodb: {\n        dump: '/usr/bin/arangodump',\n        restore: '/usr/bin/arangorestore'\n      },\n      aws: {\n        Bucket: 'box.reaktor.io'\n      },\n      redis: {\n        host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'\n      },\n      stripe: {\n        token: 'sk_live_bElZl8RLhMCJy33KG4lyLD4o'\n      },\n      twilio: {\n        number: '+18554165227',\n        sid: 'AC90b0528a911e652d643329a4d7b4d2c7',\n        token: 'a7941d173bd4846d0966a186e9865b72'\n      }\n    },\n    test: {\n    }\n  };\n\n  static get(path: string | string[]): any {\n    const environment: string = process.env.stage || 'dev';\n    const configValues: object = merge(this.values.default, this.values[environment], {environment});\n    return get(configValues, path);\n  }\n}\n"]}
|
|
@@ -3,4 +3,6 @@ import { ConversationType } from '../types';
|
|
|
3
3
|
export declare const getConversationList: (context: ApiContext, from: number, to: number) => Promise<ConversationType[]>;
|
|
4
4
|
export declare const getDirectConversation: (context: ApiContext, userId: string) => Promise<ConversationType>;
|
|
5
5
|
export declare const getConversation: (context: ApiContext, convoId: string) => Promise<ConversationType>;
|
|
6
|
-
export declare const updateConversation: (context: ApiContext,
|
|
6
|
+
export declare const updateConversation: (context: ApiContext, conversation: any) => Promise<ConversationType>;
|
|
7
|
+
export declare const addUserToConversation: (context: ApiContext, convoId: string, userId: string) => Promise<any>;
|
|
8
|
+
export declare const removeUserToConversation: (context: ApiContext, convoId: string, userId: string) => Promise<any>;
|
|
@@ -1,9 +1,43 @@
|
|
|
1
1
|
"use strict";
|
|
2
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.map");
|
|
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.function.name");
|
|
20
|
+
|
|
21
|
+
require("core-js/modules/es.object.define-properties");
|
|
22
|
+
|
|
23
|
+
require("core-js/modules/es.object.define-property");
|
|
24
|
+
|
|
25
|
+
require("core-js/modules/es.object.freeze");
|
|
26
|
+
|
|
27
|
+
require("core-js/modules/es.object.get-own-property-descriptor");
|
|
28
|
+
|
|
29
|
+
require("core-js/modules/es.object.get-own-property-descriptors");
|
|
30
|
+
|
|
31
|
+
require("core-js/modules/es.object.keys");
|
|
32
|
+
|
|
33
|
+
require("core-js/modules/es.string.sub");
|
|
34
|
+
|
|
35
|
+
require("core-js/modules/web.dom-collections.for-each");
|
|
36
|
+
|
|
3
37
|
Object.defineProperty(exports, "__esModule", {
|
|
4
38
|
value: true
|
|
5
39
|
});
|
|
6
|
-
exports.updateConversation = exports.getConversation = exports.getDirectConversation = exports.getConversationList = void 0;
|
|
40
|
+
exports.removeUserToConversation = exports.addUserToConversation = exports.updateConversation = exports.getConversation = exports.getDirectConversation = exports.getConversationList = void 0;
|
|
7
41
|
|
|
8
42
|
var _utils = require("@nlabs/utils");
|
|
9
43
|
|
|
@@ -11,12 +45,8 @@ var _arangojs = require("arangojs");
|
|
|
11
45
|
|
|
12
46
|
var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
|
|
13
47
|
|
|
14
|
-
var _identity = _interopRequireDefault(require("lodash/identity"));
|
|
15
|
-
|
|
16
48
|
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
17
49
|
|
|
18
|
-
var _pick2 = _interopRequireDefault(require("lodash/pick"));
|
|
19
|
-
|
|
20
50
|
var _utils2 = require("../utils");
|
|
21
51
|
|
|
22
52
|
var _analytics = require("../utils/analytics");
|
|
@@ -27,20 +57,30 @@ var _users = require("./users");
|
|
|
27
57
|
|
|
28
58
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
29
59
|
|
|
30
|
-
function
|
|
31
|
-
var data = _taggedTemplateLiteral(["
|
|
60
|
+
function _templateObject5() {
|
|
61
|
+
var data = _taggedTemplateLiteral(["FOR c IN hasConversations\n FILTER c._from == ", " && c._to == ", "\n LIMIT 1\n REMOVE c IN hasConversations\n RETURN OLD"]);
|
|
32
62
|
|
|
33
|
-
|
|
63
|
+
_templateObject5 = function _templateObject5() {
|
|
34
64
|
return data;
|
|
35
65
|
};
|
|
36
66
|
|
|
37
67
|
return data;
|
|
38
68
|
}
|
|
39
69
|
|
|
40
|
-
function
|
|
41
|
-
var data = _taggedTemplateLiteral(["FOR c IN
|
|
70
|
+
function _templateObject4() {
|
|
71
|
+
var data = _taggedTemplateLiteral(["FOR c IN hasConversations\n FILTER c._from == ", " && c._to == ", "\n LIMIT 1\n RETURN c"]);
|
|
42
72
|
|
|
43
|
-
|
|
73
|
+
_templateObject4 = function _templateObject4() {
|
|
74
|
+
return data;
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
return data;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
function _templateObject3() {
|
|
81
|
+
var data = _taggedTemplateLiteral(["UPSERT {_key: ", " }\n INSERT ", "\n UPDATE ", "\n IN conversations RETURN NEW"]);
|
|
82
|
+
|
|
83
|
+
_templateObject3 = function _templateObject3() {
|
|
44
84
|
return data;
|
|
45
85
|
};
|
|
46
86
|
|
|
@@ -49,12 +89,22 @@ function _templateObject2() {
|
|
|
49
89
|
|
|
50
90
|
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; }
|
|
51
91
|
|
|
52
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
92
|
+
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; }
|
|
53
93
|
|
|
54
94
|
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; }
|
|
55
95
|
|
|
96
|
+
function _templateObject2() {
|
|
97
|
+
var data = _taggedTemplateLiteral(["FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c._id == ", "\n LET u = (\n FOR inUser, inEdge IN 1..1 INBOUND ", " hasConversations\n RETURN inUser\n )\n LIMIT 1\n RETURN MERGE(c, {users: u})"]);
|
|
98
|
+
|
|
99
|
+
_templateObject2 = function _templateObject2() {
|
|
100
|
+
return data;
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
return data;
|
|
104
|
+
}
|
|
105
|
+
|
|
56
106
|
function _templateObject() {
|
|
57
|
-
var data = _taggedTemplateLiteral(["FOR c IN
|
|
107
|
+
var data = _taggedTemplateLiteral(["LET from = (\n FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c.direct == true\n RETURN c\n )\n LET to = (\n FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c.direct == true\n RETURN c\n )\n LET conversation = FIRST(INTERSECTION(from, to))\n LET users = !IS_NULL(conversation) && (\n FOR g IN[", ", ", "]\n FOR u IN users\n FILTER g == u._id\n RETURN u\n )\n RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})"]);
|
|
58
108
|
|
|
59
109
|
_templateObject = function _templateObject() {
|
|
60
110
|
return data;
|
|
@@ -65,10 +115,6 @@ function _templateObject() {
|
|
|
65
115
|
|
|
66
116
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
67
117
|
|
|
68
|
-
/**
|
|
69
|
-
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
70
|
-
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
71
|
-
*/
|
|
72
118
|
var eventCategory = 'conversations';
|
|
73
119
|
|
|
74
120
|
var getConversationList = function getConversationList(context, from, to) {
|
|
@@ -76,7 +122,8 @@ var getConversationList = function getConversationList(context, from, to) {
|
|
|
76
122
|
var database = context.database,
|
|
77
123
|
sessionId = context.userId;
|
|
78
124
|
var limit = (0, _utils2.getLimit)(from, to);
|
|
79
|
-
var
|
|
125
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
126
|
+
var aqlQry = "FOR c, e IN 1..1 OUTBOUND \"".concat(sessionDocId, "\" hasConversations\n ").concat(limit.aql, "\n LET users = (\n FOR u, uc IN 1..1 INBOUND c._id hasConversations\n FILTER u._id != \"").concat(sessionDocId, "\"\n RETURN u\n )\n RETURN MERGE(c, {users: users})");
|
|
80
127
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
81
128
|
return cursor.all();
|
|
82
129
|
})["catch"](function (error) {
|
|
@@ -93,35 +140,14 @@ var getConversationList = function getConversationList(context, from, to) {
|
|
|
93
140
|
exports.getConversationList = getConversationList;
|
|
94
141
|
|
|
95
142
|
var getDirectConversation = function getDirectConversation(context, userId) {
|
|
96
|
-
var action = '
|
|
143
|
+
var action = 'getDirectConversation';
|
|
97
144
|
var database = context.database,
|
|
98
145
|
sessionId = context.userId;
|
|
99
|
-
var
|
|
100
|
-
var
|
|
146
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
147
|
+
var userDocId = "users/".concat((0, _utils.parseId)(userId));
|
|
148
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionDocId, userDocId, sessionDocId, userDocId);
|
|
101
149
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
102
150
|
return cursor.next();
|
|
103
|
-
}).then(function () {
|
|
104
|
-
var conversation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
105
|
-
var _conversation$users = conversation.users,
|
|
106
|
-
users = _conversation$users === void 0 ? [] : _conversation$users;
|
|
107
|
-
|
|
108
|
-
if (users.length) {
|
|
109
|
-
conversation.users = users.map(function (user) {
|
|
110
|
-
var imgId = user.imgId,
|
|
111
|
-
sub = user.sub;
|
|
112
|
-
var thumbUrlData = {
|
|
113
|
-
imgId: imgId,
|
|
114
|
-
isThumb: true,
|
|
115
|
-
sub: sub
|
|
116
|
-
};
|
|
117
|
-
return _objectSpread({}, user, {
|
|
118
|
-
name: (0, _users.getDisplayName)(user),
|
|
119
|
-
thumb: (0, _images.getUserImageUrl)(thumbUrlData)
|
|
120
|
-
});
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
return conversation;
|
|
125
151
|
})["catch"](function (error) {
|
|
126
152
|
return (0, _analytics.logError)({
|
|
127
153
|
action: action,
|
|
@@ -139,8 +165,9 @@ var getConversation = function getConversation(context, convoId) {
|
|
|
139
165
|
var action = 'getItem';
|
|
140
166
|
var database = context.database,
|
|
141
167
|
sessionId = context.userId;
|
|
142
|
-
var
|
|
143
|
-
var
|
|
168
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
169
|
+
var convoDocId = "conversations/".concat((0, _utils.parseId)(convoId));
|
|
170
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), sessionDocId, convoDocId, convoDocId);
|
|
144
171
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
145
172
|
return cursor.next();
|
|
146
173
|
}).then(function () {
|
|
@@ -155,7 +182,7 @@ var getConversation = function getConversation(context, convoId) {
|
|
|
155
182
|
isThumb: true,
|
|
156
183
|
sub: sub
|
|
157
184
|
};
|
|
158
|
-
return _objectSpread({}, user, {
|
|
185
|
+
return _objectSpread(_objectSpread({}, user), {}, {
|
|
159
186
|
name: (0, _users.getDisplayName)(user),
|
|
160
187
|
thumb: (0, _images.getUserImageUrl)(thumbUrlData)
|
|
161
188
|
});
|
|
@@ -177,35 +204,29 @@ var getConversation = function getConversation(context, convoId) {
|
|
|
177
204
|
|
|
178
205
|
exports.getConversation = getConversation;
|
|
179
206
|
|
|
180
|
-
var updateConversation = function updateConversation(context,
|
|
181
|
-
var action = '
|
|
207
|
+
var updateConversation = function updateConversation(context, conversation) {
|
|
208
|
+
var action = 'updateConversation';
|
|
182
209
|
var database = context.database,
|
|
183
210
|
sessionId = context.userId;
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
users = _pick.users;
|
|
190
|
-
|
|
191
|
-
var rcpt = users || [];
|
|
192
|
-
var formatId = item.id || (0, _utils.createHash)("convo-".concat(sessionId, "-").concat(rcpt.join('')));
|
|
211
|
+
var direct = conversation.direct,
|
|
212
|
+
_conversation$convoId = conversation.convoId,
|
|
213
|
+
convoId = _conversation$convoId === void 0 ? (0, _utils.createHash)("convo - ".concat(sessionId, " ")) : _conversation$convoId,
|
|
214
|
+
name = conversation.name;
|
|
215
|
+
var formatConvoId = (0, _utils.parseId)(convoId);
|
|
193
216
|
var now = Date.now();
|
|
194
217
|
var update = {
|
|
195
218
|
// Direct message
|
|
196
|
-
direct:
|
|
219
|
+
direct: direct,
|
|
197
220
|
modified: now,
|
|
198
|
-
name:
|
|
199
|
-
// Users
|
|
200
|
-
users: !!users ? users : undefined
|
|
221
|
+
name: name
|
|
201
222
|
};
|
|
202
223
|
|
|
203
|
-
var insert = _objectSpread({}, (0, _cloneDeep["default"])(update), {
|
|
204
|
-
_key:
|
|
224
|
+
var insert = _objectSpread(_objectSpread({}, (0, _cloneDeep["default"])(update)), {}, {
|
|
225
|
+
_key: formatConvoId,
|
|
205
226
|
added: now
|
|
206
227
|
});
|
|
207
228
|
|
|
208
|
-
var aqlQry = (0, _arangojs.aql)(_templateObject3(),
|
|
229
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatConvoId, insert, update);
|
|
209
230
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
210
231
|
return cursor.next();
|
|
211
232
|
}).then(function () {
|
|
@@ -223,4 +244,68 @@ var updateConversation = function updateConversation(context, item) {
|
|
|
223
244
|
};
|
|
224
245
|
|
|
225
246
|
exports.updateConversation = updateConversation;
|
|
226
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/conversations.ts"],"names":["eventCategory","getConversationList","context","from","to","action","database","sessionId","userId","limit","aqlQry","aql","query","then","cursor","all","error","category","label","getDirectConversation","formatUserId","next","conversation","users","length","map","user","imgId","sub","thumbUrlData","isThumb","name","thumb","getConversation","convoId","formatConvoId","updateConversation","item","identity","direct","id","rcpt","formatId","join","now","Date","update","undefined","modified","insert","_key","added"],"mappings":"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","sourcesContent":["import {createHash, parseId} 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 identity from 'lodash/identity';\nimport isEmpty from 'lodash/isEmpty';\nimport pick from 'lodash/pick';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUserImageUrl} from './images';\nimport {getDisplayName} from './users';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nconst eventCategory: string = 'conversations';\n\nexport const getConversationList = (context: ApiContext, from: number, to: number): Promise<ConversationType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR c IN conversations\n    FILTER POSITION(c.users, \"${sessionId}\", false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    ${limit.aql}\n    RETURN {_key:c._key, name: c.name, direct: c.direct, users: u}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirect';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER LENGTH(c.users) == 2 &&\n    POSITION(c.users, ${sessionId}, true) &&\n    POSITION(c.users, ${formatUserId}, true)\n    LET u = (\n      FOR g IN c.users\n      FOR user IN users\n      FILTER user._key == g\n      RETURN user\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      const {users = []} = conversation;\n\n      if(users.length) {\n        conversation.users = users.map((user: UserType) => {\n          const {imgId, sub} = user;\n          const thumbUrlData: ImageUrlData = {\n            imgId,\n            isThumb: true,\n            sub\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUserImageUrl(thumbUrlData)\n          };\n        });\n      }\n\n      return conversation;\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER c._key == ${formatConvoId} && IS_LIST(c.users) && POSITION(c.users, ${sessionId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {imgId, sub} = user;\n          const thumbUrlData: ImageUrlData = {\n            imgId,\n            isThumb: true,\n            sub\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUserImageUrl(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, item): Promise<ConversationType> => {\n  const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const {direct, id, name, users} = pick(item, identity);\n  const rcpt: UserType[] = users || [];\n  const formatId: string = item.id || createHash(`convo-${sessionId}-${rcpt.join('')}`);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct: !!direct ? direct : undefined,\n    modified: now,\n    name: !!name ? name : undefined,\n    // Users\n    users: !!users ? users : undefined\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${id}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
|
247
|
+
|
|
248
|
+
var addUserToConversation = function addUserToConversation(context, convoId, userId) {
|
|
249
|
+
var action = 'addUserToConversation';
|
|
250
|
+
var database = context.database;
|
|
251
|
+
var formatConvoId = (0, _utils.parseId)(convoId);
|
|
252
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
253
|
+
var convoDocId = "conversations/".concat(formatConvoId, " ");
|
|
254
|
+
var userDocId = "users/".concat(formatUserId, " ");
|
|
255
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), userDocId, convoDocId);
|
|
256
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
257
|
+
return cursor.next();
|
|
258
|
+
}).then(function (conversationEdge) {
|
|
259
|
+
if (!!conversationEdge) {
|
|
260
|
+
return conversationEdge;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
var edgeCollection = (0, _utils2.useDb)(database).collection('hasConversations');
|
|
264
|
+
var edgeId = (0, _utils.createHash)("convo - ".concat(formatConvoId, " -").concat(formatUserId, " "));
|
|
265
|
+
var edge = {
|
|
266
|
+
_from: userDocId,
|
|
267
|
+
_key: edgeId,
|
|
268
|
+
_to: convoDocId,
|
|
269
|
+
added: Date.now()
|
|
270
|
+
};
|
|
271
|
+
return edgeCollection.save(edge, {
|
|
272
|
+
returnNew: true
|
|
273
|
+
}).then(function () {
|
|
274
|
+
return edge;
|
|
275
|
+
});
|
|
276
|
+
})["catch"](function (error) {
|
|
277
|
+
return (0, _analytics.logError)({
|
|
278
|
+
action: action,
|
|
279
|
+
category: eventCategory,
|
|
280
|
+
label: 'db_error'
|
|
281
|
+
}, error, context).then(function () {
|
|
282
|
+
return null;
|
|
283
|
+
});
|
|
284
|
+
});
|
|
285
|
+
};
|
|
286
|
+
|
|
287
|
+
exports.addUserToConversation = addUserToConversation;
|
|
288
|
+
|
|
289
|
+
var removeUserToConversation = function removeUserToConversation(context, convoId, userId) {
|
|
290
|
+
var action = 'addUserToConversation';
|
|
291
|
+
var database = context.database;
|
|
292
|
+
var formatConvoId = (0, _utils.parseId)(convoId);
|
|
293
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
294
|
+
var convoDocId = "conversations / ".concat(formatConvoId, " ");
|
|
295
|
+
var userDocId = "users/".concat(formatUserId, " ");
|
|
296
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject5(), userDocId, convoDocId);
|
|
297
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
298
|
+
return cursor.next();
|
|
299
|
+
})["catch"](function (error) {
|
|
300
|
+
return (0, _analytics.logError)({
|
|
301
|
+
action: action,
|
|
302
|
+
category: eventCategory,
|
|
303
|
+
label: 'db_error'
|
|
304
|
+
}, error, context).then(function () {
|
|
305
|
+
return null;
|
|
306
|
+
});
|
|
307
|
+
});
|
|
308
|
+
};
|
|
309
|
+
|
|
310
|
+
exports.removeUserToConversation = removeUserToConversation;
|
|
311
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/conversations.ts"],"names":["eventCategory","getConversationList","context","from","to","action","database","sessionId","userId","limit","sessionDocId","aqlQry","aql","query","then","cursor","all","error","category","label","getDirectConversation","userDocId","next","getConversation","convoId","convoDocId","conversation","users","map","user","imgId","sub","thumbUrlData","isThumb","name","thumb","updateConversation","direct","formatConvoId","now","Date","update","modified","insert","_key","added","addUserToConversation","formatUserId","conversationEdge","edgeCollection","collection","edgeId","edge","_from","_to","save","returnNew","removeUserToConversation"],"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} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEmpty from 'lodash/isEmpty';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUserImageUrl} from './images';\nimport {getDisplayName} from './users';\n\nconst eventCategory: string = 'conversations';\n\nexport const getConversationList = (context: ApiContext, from: number, to: number): Promise<ConversationType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const sessionDocId: string = `users/${sessionId}`;\n  const aqlQry: string = `FOR c, e IN 1..1 OUTBOUND \"${sessionDocId}\" hasConversations\n    ${limit.aql}\n    LET users = (\n      FOR u, uc IN 1..1 INBOUND c._id hasConversations\n      FILTER u._id != \"${sessionDocId}\"\n      RETURN u\n    )\n    RETURN MERGE(c, {users: users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const userDocId: string = `users/${parseId(userId)}`;\n\n  const aqlQry: AqlQuery = aql`LET from = (\n      FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversations\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET to = (\n      FOR c, e IN 1..1 OUTBOUND ${userDocId} hasConversations\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET conversation = FIRST(INTERSECTION(from, to))\n    LET users = !IS_NULL(conversation) && (\n      FOR g IN[${sessionDocId}, ${userDocId}]\n      FOR u IN users\n      FILTER g == u._id\n      RETURN u\n    )\n    RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const convoDocId: string = `conversations/${parseId(convoId)}`;\n\n  const aqlQry: AqlQuery = aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversations\n    FILTER c._id == ${convoDocId}\n    LET u = (\n      FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId} hasConversations\n      RETURN inUser\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {imgId, sub} = user;\n          const thumbUrlData: ImageUrlData = {\n            imgId,\n            isThumb: true,\n            sub\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUserImageUrl(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, conversation): Promise<ConversationType> => {\n  const action: string = 'updateConversation';\n  const {database, userId: sessionId} = context;\n  const {\n    direct,\n    convoId = createHash(`convo - ${sessionId} `),\n    name\n  } = conversation;\n  const formatConvoId: string = parseId(convoId);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct,\n    modified: now,\n    name\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatConvoId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatConvoId} }\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const addUserToConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n  const formatUserId: string = parseId(userId);\n  const convoDocId: string = `conversations/${formatConvoId} `;\n  const userDocId: string = `users/${formatUserId} `;\n\n  const aqlQry: AqlQuery = aql`FOR c IN hasConversations\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    RETURN c`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversationEdge) => {\n      if(!!conversationEdge) {\n        return conversationEdge;\n      }\n\n      const edgeCollection: EdgeCollection = useDb(database).collection('hasConversations');\n      const edgeId: string = createHash(`convo - ${formatConvoId} -${formatUserId} `);\n\n      const edge: ConversationType = {\n        _from: userDocId,\n        _key: edgeId,\n        _to: convoDocId,\n        added: Date.now()\n      };\n\n      return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const removeUserToConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n  const formatUserId: string = parseId(userId);\n  const convoDocId: string = `conversations / ${formatConvoId} `;\n  const userDocId: string = `users/${formatUserId} `;\n\n  const aqlQry: AqlQuery = aql`FOR c IN hasConversations\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    REMOVE c IN hasConversations\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
package/lib/data/dynamodb.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export declare const dynamoGet: (params:
|
|
3
|
-
export declare const
|
|
4
|
-
export declare const
|
|
5
|
-
export declare const
|
|
6
|
-
export declare const
|
|
7
|
-
export declare const
|
|
8
|
-
export declare const
|
|
1
|
+
import { BatchWriteItemInput, BatchWriteItemOutput, DeleteItemInput, DeleteItemOutput, GetItemInput, GetItemOutput, PutItemInput, PutItemOutput, QueryInput, QueryOutput, UpdateItemInput, UpdateItemOutput } from 'aws-sdk/clients/dynamodb';
|
|
2
|
+
export declare const dynamoGet: (params: GetItemInput) => Promise<GetItemOutput>;
|
|
3
|
+
export declare const parseDynamo: (results: QueryOutput) => any[];
|
|
4
|
+
export declare const dynamoGetList: (params: QueryInput, index: any) => Promise<GetItemOutput[]>;
|
|
5
|
+
export declare const dynamoPut: (params: PutItemInput) => Promise<PutItemOutput>;
|
|
6
|
+
export declare const dynamoUpdate: (params: UpdateItemInput) => Promise<UpdateItemOutput>;
|
|
7
|
+
export declare const dynamoPutList: (params: BatchWriteItemInput) => Promise<BatchWriteItemOutput>;
|
|
8
|
+
export declare const dynamoDel: (params: DeleteItemInput) => Promise<DeleteItemOutput>;
|