@nlabs/reaktor 0.8.0 → 0.9.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/.eslintrc +10 -0
- package/.prettierrc.js +4 -0
- package/README.md +1 -1
- package/coverage/actions/groups.ts.html +1039 -0
- package/coverage/actions/images.ts.html +2500 -0
- package/coverage/actions/index.html +131 -0
- package/coverage/actions/tags.ts.html +1000 -0
- package/coverage/adapters/arangoAdapter.ts.html +151 -0
- package/coverage/adapters/index.html +146 -0
- package/coverage/adapters/reaktorAdapter.ts.html +127 -0
- package/coverage/adapters/tagAdapter.ts.html +160 -0
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/clover.xml +6 -0
- package/coverage/coverage-final.json +1 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +176 -0
- package/coverage/lcov-report/base.css +224 -0
- package/coverage/lcov-report/block-navigation.js +87 -0
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +101 -0
- package/coverage/lcov-report/prettify.css +1 -0
- package/coverage/lcov-report/prettify.js +2 -0
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +196 -0
- package/coverage/lcov.info +0 -0
- package/coverage/mocks/file.ts.html +118 -0
- package/coverage/mocks/group.ts.html +145 -0
- package/coverage/mocks/image.ts.html +136 -0
- package/coverage/mocks/index.html +146 -0
- package/coverage/mocks/post.ts.html +169 -0
- package/coverage/mocks/tag.ts.html +121 -0
- package/coverage/mocks/user.ts.html +268 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +196 -0
- package/coverage/types/error.ts.html +145 -0
- package/coverage/types/index.html +116 -0
- package/coverage/utils/adapterUtils.ts.html +151 -0
- package/coverage/utils/analyticsUtils.ts.html +292 -0
- package/coverage/utils/arangodbUtils.ts.html +463 -0
- package/coverage/utils/index.html +146 -0
- package/jest.setup.js +0 -0
- package/jpg:- +0 -0
- package/lib/actions/apps.d.ts +25 -0
- package/lib/actions/apps.js +252 -0
- package/lib/actions/conversations.d.ts +14 -0
- package/lib/actions/conversations.js +131 -126
- package/lib/actions/dynamodb.d.ts +8 -0
- package/lib/actions/dynamodb.js +35 -32
- package/lib/actions/email.d.ts +5 -0
- package/lib/actions/email.js +23 -53
- package/lib/actions/files.d.ts +19 -0
- package/lib/actions/files.js +188 -202
- package/lib/actions/groups.d.ts +14 -0
- package/lib/actions/groups.js +38 -36
- package/lib/actions/images.d.ts +26 -0
- package/lib/actions/images.js +236 -229
- package/lib/actions/index.d.ts +21 -0
- package/lib/actions/index.js +3 -1
- package/lib/actions/ios.d.ts +7 -0
- package/lib/actions/ios.js +11 -10
- package/lib/actions/locations.d.ts +5 -0
- package/lib/actions/locations.js +29 -37
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +10 -10
- package/lib/actions/notifications.d.ts +5 -0
- package/lib/actions/notifications.js +1 -1
- package/lib/actions/payments.d.ts +10 -0
- package/lib/actions/payments.js +27 -26
- package/lib/actions/posts.d.ts +19 -0
- package/lib/actions/posts.js +176 -156
- package/lib/actions/reactions.d.ts +30 -0
- package/lib/actions/reactions.js +30 -28
- package/lib/actions/s3.d.ts +7 -0
- package/lib/actions/s3.js +37 -32
- package/lib/actions/search.d.ts +3 -0
- package/lib/actions/search.js +11 -9
- package/lib/actions/sms.d.ts +3 -0
- package/lib/actions/sms.js +58 -34
- package/lib/actions/statistics.d.ts +3 -0
- package/lib/actions/statistics.js +21 -18
- package/lib/actions/subscription.d.ts +7 -0
- package/lib/actions/subscription.js +24 -21
- package/lib/actions/tags.d.ts +29 -0
- package/lib/actions/tags.js +129 -198
- package/lib/actions/users.d.ts +47 -0
- package/lib/actions/users.js +188 -194
- package/lib/actions/websockets.d.ts +19 -0
- package/lib/actions/websockets.js +60 -34
- package/lib/adapters/arangoAdapter.d.ts +2 -0
- package/lib/adapters/arangoAdapter.js +46 -0
- package/lib/adapters/fileAdapter.d.ts +3 -0
- package/lib/adapters/fileAdapter.js +76 -0
- package/lib/adapters/postAdapter.d.ts +2 -0
- package/lib/adapters/postAdapter.js +70 -0
- package/lib/adapters/reaktorAdapter.d.ts +6 -0
- package/lib/adapters/reaktorAdapter.js +44 -0
- package/lib/adapters/tagAdapter.d.ts +2 -0
- package/lib/adapters/tagAdapter.js +50 -0
- package/lib/adapters/userAdapter.d.ts +2 -0
- package/lib/adapters/userAdapter.js +110 -0
- package/lib/config.d.ts +20 -0
- package/lib/config.js +14 -15
- package/lib/index.d.ts +5 -0
- package/lib/lambdas/actions/websockets.d.ts +6 -0
- package/lib/lambdas/actions/websockets.js +7 -7
- package/lib/lambdas/authorizer.d.ts +20 -0
- package/lib/lambdas/authorizer.js +1 -1
- package/lib/lambdas/connection.d.ts +12 -0
- package/lib/lambdas/connection.js +5 -4
- package/lib/lambdas/utils/message.d.ts +1 -0
- package/lib/lambdas/utils/websocket.d.ts +7 -0
- package/lib/lambdas/utils/websocket.js +8 -6
- package/lib/mocks/conversation.d.ts +8 -0
- package/lib/mocks/conversation.js +35 -0
- package/lib/mocks/file.d.ts +11 -0
- package/lib/mocks/file.js +38 -0
- package/lib/mocks/group.d.ts +17 -0
- package/lib/mocks/group.js +47 -0
- package/lib/mocks/image.d.ts +3 -0
- package/lib/mocks/image.js +43 -0
- package/lib/mocks/nlabs.png +0 -0
- package/lib/mocks/post.d.ts +38 -0
- package/lib/mocks/post.js +55 -0
- package/lib/mocks/tag.d.ts +2 -0
- package/lib/mocks/tag.js +37 -0
- package/lib/mocks/user.d.ts +4 -0
- package/lib/mocks/user.js +88 -0
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/types/apps.d.ts +46 -0
- package/lib/types/apps.js +17 -1
- package/lib/types/arangodb.d.ts +30 -0
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.d.ts +7 -0
- package/lib/types/auth.js +1 -1
- package/lib/types/connections.d.ts +7 -0
- package/lib/types/connections.js +1 -1
- package/lib/types/conversations.d.ts +29 -0
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.d.ts +13 -0
- package/lib/types/email.js +1 -1
- package/lib/types/error.d.ts +20 -0
- package/lib/types/error.js +44 -0
- package/lib/types/files.d.ts +26 -0
- package/lib/types/files.js +1 -1
- package/lib/types/google.d.ts +29 -0
- package/lib/types/google.js +1 -1
- package/lib/types/groups.d.ts +21 -0
- package/lib/types/groups.js +1 -1
- package/lib/types/images.d.ts +51 -0
- package/lib/types/images.js +1 -1
- package/lib/types/index.d.ts +18 -0
- package/lib/types/locations.d.ts +20 -0
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +16 -0
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.d.ts +17 -0
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.d.ts +112 -0
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.d.ts +31 -0
- package/lib/types/posts.js +1 -1
- package/lib/types/statistics.d.ts +3 -0
- package/lib/types/statistics.js +1 -1
- package/lib/types/tags.d.ts +10 -0
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +76 -0
- package/lib/types/users.js +1 -1
- package/lib/types/websocket.d.ts +13 -0
- package/lib/types/websocket.js +1 -1
- package/lib/utils/adapterUtils.d.ts +1 -0
- package/lib/utils/adapterUtils.js +45 -0
- package/lib/utils/analyticsUtils.d.ts +21 -0
- package/lib/utils/analyticsUtils.js +72 -0
- package/lib/utils/arangodbUtils.d.ts +65 -0
- package/lib/utils/arangodbUtils.js +144 -0
- package/lib/utils/auth.d.ts +20 -0
- package/lib/utils/auth.js +13 -30
- package/lib/utils/index.d.ts +5 -0
- package/lib/utils/index.js +7 -9
- package/lib/utils/session.d.ts +16 -0
- package/lib/utils/session.js +11 -2
- package/package.json +12 -5
- package/lib/utils/analytics.js +0 -88
- package/lib/utils/arangodb.js +0 -118
- package/lib/utils/graphql.js +0 -46
- package/lib/utils/objects.js +0 -59
|
@@ -27,6 +27,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
27
27
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
28
|
var conversations_exports = {};
|
|
29
29
|
__export(conversations_exports, {
|
|
30
|
+
addDirectConversation: () => addDirectConversation,
|
|
30
31
|
addUserToConversation: () => addUserToConversation,
|
|
31
32
|
deleteUserFromConversation: () => deleteUserFromConversation,
|
|
32
33
|
getConnectionUsers: () => getConnectionUsers,
|
|
@@ -34,7 +35,6 @@ __export(conversations_exports, {
|
|
|
34
35
|
getConversationUsers: () => getConversationUsers,
|
|
35
36
|
getConversations: () => getConversations,
|
|
36
37
|
getDirectConversation: () => getDirectConversation,
|
|
37
|
-
getDirectConversationOld: () => getDirectConversationOld,
|
|
38
38
|
parseConversationOptions: () => parseConversationOptions,
|
|
39
39
|
updateConversation: () => updateConversation
|
|
40
40
|
});
|
|
@@ -42,10 +42,11 @@ module.exports = __toCommonJS(conversations_exports);
|
|
|
42
42
|
var import_utils = require("@nlabs/utils");
|
|
43
43
|
var import_arangojs = require("arangojs");
|
|
44
44
|
var import_cloneDeep = __toESM(require("lodash/cloneDeep"));
|
|
45
|
-
var
|
|
46
|
-
var import_analytics = require("../utils/analytics");
|
|
45
|
+
var import_analyticsUtils = require("../utils/analyticsUtils");
|
|
47
46
|
var import_images = require("./images");
|
|
48
47
|
var import_users = require("./users");
|
|
48
|
+
var import_error = require("../types/error");
|
|
49
|
+
var import_arangodbUtils = require("../utils/arangodbUtils");
|
|
49
50
|
const eventCategory = "conversations";
|
|
50
51
|
const parseConversationOptions = (options = {}) => {
|
|
51
52
|
const {
|
|
@@ -53,55 +54,74 @@ const parseConversationOptions = (options = {}) => {
|
|
|
53
54
|
to = 30
|
|
54
55
|
} = options;
|
|
55
56
|
return {
|
|
56
|
-
limit: (0,
|
|
57
|
+
limit: (0, import_arangodbUtils.getLimit)(from, to)
|
|
57
58
|
};
|
|
58
59
|
};
|
|
59
|
-
const getConversations = (context, options) => {
|
|
60
|
+
const getConversations = (context, userId, options) => {
|
|
60
61
|
const action = "getConversations";
|
|
61
|
-
const { database
|
|
62
|
+
const { database } = context;
|
|
62
63
|
const { limit } = parseConversationOptions(options);
|
|
63
|
-
const
|
|
64
|
-
const aqlQry = `FOR c, e IN 1..1 OUTBOUND "${
|
|
64
|
+
const userDocId = `users/${userId}`;
|
|
65
|
+
const aqlQry = `FOR c, e IN 1..1 OUTBOUND "${userDocId}" hasConversation
|
|
65
66
|
${limit.aql}
|
|
66
67
|
LET users = (
|
|
67
68
|
FOR u, uc IN 1..1 INBOUND c._id hasConversation
|
|
68
|
-
FILTER u._id != "${
|
|
69
|
+
FILTER u._id != "${userDocId}"
|
|
69
70
|
RETURN u
|
|
70
71
|
)
|
|
71
72
|
RETURN MERGE(c, {users: users})`;
|
|
72
|
-
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0,
|
|
73
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
73
74
|
action,
|
|
74
75
|
category: eventCategory,
|
|
75
|
-
label:
|
|
76
|
-
}, error, context)
|
|
76
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
77
|
+
}, error, context));
|
|
77
78
|
};
|
|
78
|
-
const getDirectConversation = async (context,
|
|
79
|
+
const getDirectConversation = async (context, {
|
|
80
|
+
fromId,
|
|
81
|
+
toId,
|
|
82
|
+
toUser
|
|
83
|
+
}) => {
|
|
79
84
|
const action = "getDirectConversation";
|
|
80
85
|
const { database } = context;
|
|
81
86
|
try {
|
|
82
87
|
const formatFromId = (0, import_utils.parseId)(fromId);
|
|
83
88
|
const formatToId = (0, import_utils.parseId)(toId);
|
|
84
89
|
const userIds = [formatFromId, formatToId];
|
|
85
|
-
const sortedUserIds =
|
|
86
|
-
if (a < b) {
|
|
87
|
-
return -1;
|
|
88
|
-
}
|
|
89
|
-
if (a > b) {
|
|
90
|
-
return 1;
|
|
91
|
-
}
|
|
92
|
-
return 0;
|
|
93
|
-
});
|
|
90
|
+
const sortedUserIds = (0, import_arangodbUtils.sortIds)(userIds);
|
|
94
91
|
const conversationId = (0, import_utils.createHash)(`conversations-${sortedUserIds.join("-")}`, null);
|
|
95
|
-
const user = await (0, import_users.getUser)(context, { userId: formatToId });
|
|
92
|
+
const user = toUser || await (0, import_users.getUser)(context, { userId: formatToId });
|
|
96
93
|
const aqlQry = import_arangojs.aql`LET c = DOCUMENT(${`conversations/${conversationId}`}) RETURN c`;
|
|
97
|
-
const conversation = await database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0,
|
|
94
|
+
const conversation = await database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
98
95
|
action,
|
|
99
96
|
category: eventCategory,
|
|
100
|
-
label:
|
|
101
|
-
}, error, context)
|
|
97
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
98
|
+
}, error, context));
|
|
102
99
|
if (conversation) {
|
|
103
100
|
return { ...conversation, users: [user] };
|
|
104
101
|
}
|
|
102
|
+
return addDirectConversation(context, { fromId, toId, toUser: user });
|
|
103
|
+
} catch (databaseError) {
|
|
104
|
+
return (0, import_analyticsUtils.logError)({
|
|
105
|
+
action,
|
|
106
|
+
category: eventCategory,
|
|
107
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
108
|
+
}, databaseError, context);
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
const addDirectConversation = async (context, {
|
|
112
|
+
fromId,
|
|
113
|
+
toId,
|
|
114
|
+
toUser
|
|
115
|
+
}) => {
|
|
116
|
+
const action = "getDirectConversation";
|
|
117
|
+
const { database } = context;
|
|
118
|
+
try {
|
|
119
|
+
const formatFromId = (0, import_utils.parseId)(fromId);
|
|
120
|
+
const formatToId = (0, import_utils.parseId)(toId);
|
|
121
|
+
const userIds = [formatFromId, formatToId];
|
|
122
|
+
const sortedUserIds = (0, import_arangodbUtils.sortIds)([formatFromId, formatToId]);
|
|
123
|
+
const user = toUser || await (0, import_users.getUser)(context, { userId: formatToId });
|
|
124
|
+
const conversationId = (0, import_utils.createHash)(`conversations-${sortedUserIds.join("-")}`, null);
|
|
105
125
|
const now = Date.now();
|
|
106
126
|
const insert = {
|
|
107
127
|
_key: conversationId,
|
|
@@ -123,16 +143,20 @@ const getDirectConversation = async (context, fromId, toId) => {
|
|
|
123
143
|
return database.query(insertEdgeQuery);
|
|
124
144
|
}));
|
|
125
145
|
return { ...updatedConversation, users: [user] };
|
|
126
|
-
} catch (
|
|
127
|
-
return (0,
|
|
146
|
+
} catch (databaseError) {
|
|
147
|
+
return (0, import_analyticsUtils.logError)({
|
|
128
148
|
action,
|
|
129
149
|
category: eventCategory,
|
|
130
|
-
label:
|
|
131
|
-
},
|
|
150
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
151
|
+
}, databaseError, context);
|
|
132
152
|
}
|
|
133
153
|
};
|
|
134
|
-
const getConnectionUsers = (context,
|
|
135
|
-
|
|
154
|
+
const getConnectionUsers = (context, {
|
|
155
|
+
conversationId,
|
|
156
|
+
includeAll = false,
|
|
157
|
+
isDirect
|
|
158
|
+
}) => {
|
|
159
|
+
const action = "getConnectionUsers";
|
|
136
160
|
const { database, session: { userId: sessionUserId } } = context;
|
|
137
161
|
const filters = ["c.userId == u._key"];
|
|
138
162
|
if (!includeAll) {
|
|
@@ -146,13 +170,19 @@ const getConnectionUsers = (context, conversationId, includeAll = false, isDirec
|
|
|
146
170
|
FOR c IN connections
|
|
147
171
|
FILTER ${filters.join(" && ")}
|
|
148
172
|
RETURN c`;
|
|
149
|
-
return database.query(aqlQry).then((cursor) => cursor.all()).catch(
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
173
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).catch(
|
|
174
|
+
(error) => (0, import_analyticsUtils.logError)({
|
|
175
|
+
action,
|
|
176
|
+
category: eventCategory,
|
|
177
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
178
|
+
}, error, context)
|
|
179
|
+
);
|
|
154
180
|
};
|
|
155
|
-
const getConversationUsers = (context,
|
|
181
|
+
const getConversationUsers = (context, {
|
|
182
|
+
conversationId,
|
|
183
|
+
includeAll = false,
|
|
184
|
+
isDirect
|
|
185
|
+
}) => {
|
|
156
186
|
const action = "getConversationUsers";
|
|
157
187
|
const { database, session: { userId: sessionUserId } } = context;
|
|
158
188
|
const filters = ["c.userId == u._key"];
|
|
@@ -166,92 +196,61 @@ const getConversationUsers = (context, conversationId, includeAll = false, isDir
|
|
|
166
196
|
OPTIONS {vertexCollections: "users"}
|
|
167
197
|
FILTER ${filters.join(" && ")}
|
|
168
198
|
RETURN u`;
|
|
169
|
-
|
|
170
|
-
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analytics.logError)({
|
|
171
|
-
action,
|
|
172
|
-
category: eventCategory,
|
|
173
|
-
label: "db_error"
|
|
174
|
-
}, error, context).then(() => null));
|
|
175
|
-
};
|
|
176
|
-
const getDirectConversationOld = (context, userId) => {
|
|
177
|
-
const action = "getDirectConversation";
|
|
178
|
-
const { database, session: { userId: sessionId } } = context;
|
|
179
|
-
const sessionDocId = `users/${sessionId}`;
|
|
180
|
-
const formatUserId = (0, import_utils.parseArangoId)(userId);
|
|
181
|
-
const aqlQry = import_arangojs.aql`LET from = (
|
|
182
|
-
FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation
|
|
183
|
-
FILTER c.direct == true
|
|
184
|
-
RETURN c
|
|
185
|
-
)
|
|
186
|
-
LET to = (
|
|
187
|
-
FOR c, e IN 1..1 OUTBOUND ${formatUserId} hasConversation
|
|
188
|
-
FILTER c.direct == true
|
|
189
|
-
RETURN c
|
|
190
|
-
)
|
|
191
|
-
LET conversation = FIRST(INTERSECTION(from, to))
|
|
192
|
-
LET users = !IS_NULL(conversation) && (
|
|
193
|
-
FOR g IN[${sessionDocId}, ${formatUserId}]
|
|
194
|
-
FOR u IN users
|
|
195
|
-
FILTER g == u._id
|
|
196
|
-
RETURN u
|
|
197
|
-
)
|
|
198
|
-
RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})`;
|
|
199
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analytics.logError)({
|
|
199
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
200
200
|
action,
|
|
201
201
|
category: eventCategory,
|
|
202
|
-
label:
|
|
203
|
-
}, error, context)
|
|
202
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
203
|
+
}, error, context));
|
|
204
204
|
};
|
|
205
|
-
const getConversation = (context,
|
|
205
|
+
const getConversation = (context, conversationId) => {
|
|
206
206
|
const action = "getItem";
|
|
207
207
|
const { database, session: { userId: sessionId } } = context;
|
|
208
208
|
const sessionDocId = `users/${sessionId}`;
|
|
209
|
-
const
|
|
209
|
+
const conversationDocId = `conversations/${(0, import_utils.parseId)(conversationId)}`;
|
|
210
210
|
const aqlQry = import_arangojs.aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation
|
|
211
|
-
FILTER c._id == ${
|
|
211
|
+
FILTER c._id == ${conversationDocId}
|
|
212
212
|
LET u = (
|
|
213
|
-
FOR inUser, inEdge IN 1..1 INBOUND ${
|
|
213
|
+
FOR inUser, inEdge IN 1..1 INBOUND ${conversationDocId} hasConversation
|
|
214
214
|
RETURN inUser
|
|
215
215
|
)
|
|
216
216
|
LIMIT 1
|
|
217
217
|
RETURN MERGE(c, {users: u})`;
|
|
218
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation
|
|
219
|
-
if (conversation) {
|
|
220
|
-
|
|
221
|
-
const { imageId, userId } = user;
|
|
222
|
-
const thumbUrlData = {
|
|
223
|
-
imageId,
|
|
224
|
-
isThumb: true,
|
|
225
|
-
userId
|
|
226
|
-
};
|
|
227
|
-
return {
|
|
228
|
-
...user,
|
|
229
|
-
name: (0, import_users.getDisplayName)(user),
|
|
230
|
-
thumb: (0, import_images.getImageUrl)(thumbUrlData)
|
|
231
|
-
};
|
|
232
|
-
});
|
|
233
|
-
return conversation;
|
|
218
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation) => {
|
|
219
|
+
if (!conversation) {
|
|
220
|
+
return {};
|
|
234
221
|
}
|
|
235
|
-
|
|
236
|
-
|
|
222
|
+
conversation.users = conversation.users.map((user) => {
|
|
223
|
+
const { imageId, userId } = user;
|
|
224
|
+
const thumbUrlData = {
|
|
225
|
+
imageId,
|
|
226
|
+
isThumb: true,
|
|
227
|
+
userId
|
|
228
|
+
};
|
|
229
|
+
return {
|
|
230
|
+
...user,
|
|
231
|
+
name: (0, import_users.getDisplayName)(user),
|
|
232
|
+
thumb: (0, import_images.getImageUrl)(thumbUrlData)
|
|
233
|
+
};
|
|
234
|
+
});
|
|
235
|
+
return conversation;
|
|
236
|
+
}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
237
237
|
action,
|
|
238
238
|
category: eventCategory,
|
|
239
|
-
label:
|
|
240
|
-
}, error, context)
|
|
239
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
240
|
+
}, error, context));
|
|
241
241
|
};
|
|
242
242
|
const updateConversation = (context, conversation) => {
|
|
243
243
|
const action = "updateConversation";
|
|
244
244
|
const { database, session: { userId: sessionId } } = context;
|
|
245
245
|
const {
|
|
246
246
|
conversationId = (0, import_utils.createHash)(`conversation-${sessionId} `),
|
|
247
|
-
|
|
247
|
+
isDirect = false,
|
|
248
248
|
name
|
|
249
249
|
} = conversation;
|
|
250
250
|
const formatConversationId = (0, import_utils.parseId)(conversationId);
|
|
251
251
|
const now = Date.now();
|
|
252
252
|
const update = {
|
|
253
|
-
|
|
254
|
-
direct,
|
|
253
|
+
isDirect,
|
|
255
254
|
modified: now,
|
|
256
255
|
name
|
|
257
256
|
};
|
|
@@ -264,62 +263,69 @@ const updateConversation = (context, conversation) => {
|
|
|
264
263
|
INSERT ${insert}
|
|
265
264
|
UPDATE ${update}
|
|
266
265
|
IN conversations RETURN NEW`;
|
|
267
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation2
|
|
266
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation2) => conversation2).catch((error) => (0, import_analyticsUtils.logError)({
|
|
268
267
|
action,
|
|
269
268
|
category: eventCategory,
|
|
270
|
-
label:
|
|
271
|
-
}, error, context)
|
|
269
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
270
|
+
}, error, context));
|
|
272
271
|
};
|
|
273
|
-
const addUserToConversation = (context,
|
|
272
|
+
const addUserToConversation = (context, {
|
|
273
|
+
conversationId,
|
|
274
|
+
userId
|
|
275
|
+
}) => {
|
|
274
276
|
const action = "addUserToConversation";
|
|
275
277
|
const { database } = context;
|
|
276
|
-
const
|
|
278
|
+
const formatConversationId = (0, import_utils.parseId)(conversationId);
|
|
277
279
|
const formatUserId = (0, import_utils.parseId)(userId);
|
|
278
|
-
const
|
|
280
|
+
const conversationDocId = `conversations/${formatConversationId}`;
|
|
279
281
|
const userDocId = `users/${formatUserId}`;
|
|
280
|
-
const aqlQry = import_arangojs.aql`FOR
|
|
281
|
-
FILTER
|
|
282
|
+
const aqlQry = import_arangojs.aql`FOR hc IN hasConversation
|
|
283
|
+
FILTER hc._from == ${userDocId} && hc._to == ${conversationDocId}
|
|
282
284
|
LIMIT 1
|
|
283
|
-
RETURN
|
|
284
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).then((
|
|
285
|
-
if (!!
|
|
286
|
-
return
|
|
285
|
+
RETURN hc`;
|
|
286
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((hasConversationEdge) => {
|
|
287
|
+
if (!!hasConversationEdge) {
|
|
288
|
+
return hasConversationEdge;
|
|
287
289
|
}
|
|
288
290
|
const edgeCollection = database.collection("hasConversation");
|
|
289
|
-
const edgeId = (0, import_utils.createHash)(`convo - ${
|
|
291
|
+
const edgeId = (0, import_utils.createHash)(`convo - ${formatConversationId} -${formatUserId} `);
|
|
290
292
|
const edge = {
|
|
291
293
|
_from: userDocId,
|
|
292
294
|
_key: edgeId,
|
|
293
|
-
_to:
|
|
295
|
+
_to: conversationDocId,
|
|
294
296
|
added: Date.now()
|
|
295
297
|
};
|
|
296
298
|
return edgeCollection.save(edge, { returnNew: true }).then(() => edge);
|
|
297
|
-
}).catch((error) => (0,
|
|
299
|
+
}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
298
300
|
action,
|
|
299
301
|
category: eventCategory,
|
|
300
|
-
label:
|
|
301
|
-
}, error, context)
|
|
302
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
303
|
+
}, error, context));
|
|
302
304
|
};
|
|
303
|
-
const deleteUserFromConversation = (context,
|
|
305
|
+
const deleteUserFromConversation = (context, {
|
|
306
|
+
conversationId,
|
|
307
|
+
userId
|
|
308
|
+
}) => {
|
|
304
309
|
const action = "deleteUserFromConversation";
|
|
305
310
|
const { database } = context;
|
|
306
|
-
const
|
|
311
|
+
const formatConversationId = (0, import_utils.parseId)(conversationId);
|
|
307
312
|
const formatUserId = (0, import_utils.parseId)(userId);
|
|
308
|
-
const
|
|
313
|
+
const conversationDocId = `conversations/${formatConversationId}`;
|
|
309
314
|
const userDocId = `users/${formatUserId}`;
|
|
310
|
-
const aqlQry = import_arangojs.aql`FOR
|
|
311
|
-
FILTER
|
|
315
|
+
const aqlQry = import_arangojs.aql`FOR hc IN hasConversation
|
|
316
|
+
FILTER hc._from == ${userDocId} && hc._to == ${conversationDocId}
|
|
312
317
|
LIMIT 1
|
|
313
|
-
REMOVE
|
|
318
|
+
REMOVE hc IN hasConversation
|
|
314
319
|
RETURN OLD`;
|
|
315
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0,
|
|
320
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
316
321
|
action,
|
|
317
322
|
category: eventCategory,
|
|
318
|
-
label:
|
|
319
|
-
}, error, context)
|
|
323
|
+
label: import_error.ErrorTypes.DATABASE_ERROR
|
|
324
|
+
}, error, context));
|
|
320
325
|
};
|
|
321
326
|
// Annotate the CommonJS export names for ESM import in node:
|
|
322
327
|
0 && (module.exports = {
|
|
328
|
+
addDirectConversation,
|
|
323
329
|
addUserToConversation,
|
|
324
330
|
deleteUserFromConversation,
|
|
325
331
|
getConnectionUsers,
|
|
@@ -327,8 +333,7 @@ const deleteUserFromConversation = (context, convoId, userId) => {
|
|
|
327
333
|
getConversationUsers,
|
|
328
334
|
getConversations,
|
|
329
335
|
getDirectConversation,
|
|
330
|
-
getDirectConversationOld,
|
|
331
336
|
parseConversationOptions,
|
|
332
337
|
updateConversation
|
|
333
338
|
});
|
|
334
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/conversations.ts"],
  "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, parseArangoId, 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';\n\nimport {ConnectionType, ConversationOptions, ConversationType, ImageUrlData, User} from '../types';\nimport {ApiContext} from '../types/auth';\nimport {getLimit} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getImageUrl} from './images';\nimport {getDisplayName, getUser} from './users';\n\nconst eventCategory: string = 'conversations';\n\nexport const parseConversationOptions = (options: ConversationOptions = {}) => {\n  const {\n    from = 0,\n    to = 30,\n  } = options;\n\n  return {\n    limit: getLimit(from, to),\n  };\n};\n\nexport const getConversations = (context: ApiContext, options?): Promise<ConversationType[]> => {\n  const action: string = 'getConversations';\n  const {database, session: {userId: sessionId}} = context;\n  const {limit} = parseConversationOptions(options);\n  const sessionDocId: string = `users/${sessionId}`;\n  const aqlQry: string = `FOR c, e IN 1..1 OUTBOUND \"${sessionDocId}\" hasConversation\n    ${limit.aql}\n    LET users = (\n      FOR u, uc IN 1..1 INBOUND c._id hasConversation\n      FILTER u._id != \"${sessionDocId}\"\n      RETURN u\n    )\n    RETURN MERGE(c, {users: users})`;\n\n  return 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 = async (\n  context: ApiContext,\n  fromId: string,\n  toId: string\n): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database} = context;\n\n  try {\n    const formatFromId: string = parseId(fromId);\n    const formatToId: string = parseId(toId);\n    const userIds: string[] = [formatFromId, formatToId];\n    const sortedUserIds: string[] = userIds.sort((a, b) => {\n      if(a < b) {\n        return -1;\n      }\n      if(a > b) {\n        return 1;\n      }\n      return 0;\n    });\n    const conversationId: string = createHash(`conversations-${sortedUserIds.join('-')}`, null);\n    const user: User = await getUser(context, {userId: formatToId});\n\n    const aqlQry: AqlQuery = aql`LET c = DOCUMENT(${`conversations/${conversationId}`}) RETURN c`;\n    const conversation = await 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    if(conversation) {\n      return {...conversation, users: [user]};\n    }\n\n    const now: number = Date.now();\n    const insert = {\n      _key: conversationId,\n      added: now,\n      isDirect: true,\n      modified: now\n    };\n    const insertQuery: AqlQuery = aql`INSERT ${insert} IN conversations RETURN NEW`;\n    const updatedConversation = await database.query(insertQuery)\n      .then((cursor: ArrayCursor) => cursor.next());\n\n    await Promise.all(userIds.map((userId) => {\n      const edgeId: string = createHash(`hasConversation-${userId}-${conversationId}`);\n      const edge: any = {\n        _from: `users/${userId}`,\n        _key: edgeId,\n        _to: `conversations/${conversationId}`,\n        added: Date.now()\n      };\n      const insertEdgeQuery: AqlQuery = aql`INSERT ${edge} IN hasConversation RETURN NEW`;\n      return database.query(insertEdgeQuery);\n    }));\n\n    return {...updatedConversation, users: [user]};\n  } catch(updateError) {\n    return logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, updateError, context).then(() => null);\n  }\n};\n\nexport const getConnectionUsers = (\n  context: ApiContext,\n  conversationId: string,\n  includeAll: boolean = false,\n  isDirect?: boolean\n): Promise<ConnectionType[]> => {\n  const action: string = 'getConversationUsers';\n  const {database, session: {userId: sessionUserId}} = context;\n  const filters: string[] = ['c.userId == u._key'];\n\n  if(!includeAll) {\n    filters.push(`u._key != ${sessionUserId}`);\n  }\n  if(isDirect) {\n    filters.push(`p.vertices[0].isDirect == ${isDirect}`);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation\n    OPTIONS {vertexCollections: \"users\"}\n    FOR c IN connections\n    FILTER ${filters.join(' && ')}\n    RETURN c`;\n\n  return 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 getConversationUsers = (\n  context: ApiContext,\n  conversationId: string,\n  includeAll: boolean = false,\n  isDirect?: boolean\n): Promise<ConversationType[]> => {\n  const action: string = 'getConversationUsers';\n  const {database, session: {userId: sessionUserId}} = context;\n  const filters: string[] = ['c.userId == u._key'];\n\n  if(!includeAll) {\n    filters.push(`u._key != ${sessionUserId}`);\n  }\n  if(isDirect) {\n    filters.push(`p.vertices[0].isDirect == ${isDirect}`);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation\n    OPTIONS {vertexCollections: \"users\"}\n    FILTER ${filters.join(' && ')}\n    RETURN u`;\n\n  console.log({aqlQry});\n  return 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 getDirectConversationOld = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database, session: {userId: sessionId}} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatUserId: string = parseArangoId(userId);\n\n  const aqlQry: AqlQuery = aql`LET from = (\n      FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET to = (\n      FOR c, e IN 1..1 OUTBOUND ${formatUserId} hasConversation\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}, ${formatUserId}]\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 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, session: {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} hasConversation\n    FILTER c._id == ${convoDocId}\n    LET u = (\n      FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId} hasConversation\n      RETURN inUser\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(conversation) {\n        conversation.users = conversation.users.map((user: any) => {\n          const {imageId, userId} = user;\n          const thumbUrlData: ImageUrlData = {\n            imageId,\n            isThumb: true,\n            userId\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getImageUrl(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, session: {userId: sessionId}} = context;\n  const {\n    conversationId = createHash(`conversation-${sessionId} `),\n    direct = false,\n    name\n  } = conversation;\n  const formatConversationId: string = parseId(conversationId);\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: formatConversationId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatConversationId} }\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return 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 hasConversation\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    RETURN c`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversationEdge) => {\n      if(!!conversationEdge) {\n        return conversationEdge;\n      }\n\n      const edgeCollection: EdgeCollection = database.collection('hasConversation');\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 deleteUserFromConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'deleteUserFromConversation';\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 hasConversation\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    REMOVE c IN hasConversation\n    RETURN OLD`;\n\n  return 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"],
  "mappings": "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",
  "names": ["import_utils", "cloneDeep", "conversation"]
}

|
|
339
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/conversations.ts"],
  "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';\n\nimport type {\n  ArangoDbLimit,\n  ConnectionType,\n  ConversationOptions,\n  ConversationType,\n  ConversationUsersParams,\n  DirectConversationParams,\n  ImageUrlData,\n  UpdateConversationUserParams,\n  UserType\n} from '../types';\nimport type {ApiContext} from '../types/auth';\nimport {logError} from '../utils/analyticsUtils';\nimport {getImageUrl} from './images';\nimport {getDisplayName, getUser} from './users';\nimport {ErrorTypes} from '../types/error';\nimport {getLimit, sortIds} from '../utils/arangodbUtils';\n\nconst eventCategory: string = 'conversations';\n\nexport const parseConversationOptions = (options: ConversationOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to) as ArangoDbLimit\n  };\n};\n\nexport const getConversations = (context: ApiContext, userId: string, options?): Promise<ConversationType[]> => {\n  const action: string = 'getConversations';\n  const {database} = context;\n  const {limit} = parseConversationOptions(options);\n  const userDocId: string = `users/${userId}`;\n  const aqlQry: string = `FOR c, e IN 1..1 OUTBOUND \"${userDocId}\" hasConversation\n    ${limit.aql}\n    LET users = (\n      FOR u, uc IN 1..1 INBOUND c._id hasConversation\n      FILTER u._id != \"${userDocId}\"\n      RETURN u\n    )\n    RETURN MERGE(c, {users: users})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\nexport const getDirectConversation = async (\n  context: ApiContext,\n  {\n    fromId,\n    toId,\n    toUser\n  }: DirectConversationParams\n): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database} = context;\n\n  try {\n    const formatFromId = parseId(fromId);\n    const formatToId = parseId(toId);\n    const userIds = [formatFromId, formatToId];\n    const sortedUserIds = sortIds(userIds);\n    const conversationId = createHash(`conversations-${sortedUserIds.join('-')}`, null);\n    const user: UserType = toUser || await getUser(context, {userId: formatToId});\n    const aqlQry: AqlQuery = aql`LET c = DOCUMENT(${`conversations/${conversationId}`}) RETURN c`;\n    const conversation = await database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR\n      }, error, context));\n\n    if(conversation) {\n      return {...conversation, users: [user]};\n    }\n\n    return addDirectConversation(context, {fromId, toId, toUser: user});\n  } catch(databaseError) {\n    return logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, databaseError, context);\n  }\n};\n\nexport const addDirectConversation = async (\n  context: ApiContext,\n  {\n    fromId,\n    toId,\n    toUser\n  }: DirectConversationParams\n): Promise<ConversationType> => {\n  const action: string = 'getDirectConversation';\n  const {database} = context;\n\n  try {\n    const formatFromId = parseId(fromId);\n    const formatToId = parseId(toId);\n    const userIds = [formatFromId, formatToId];\n    const sortedUserIds = sortIds([formatFromId, formatToId]);\n    const user: UserType = toUser || await getUser(context, {userId: formatToId});\n    const conversationId = createHash(`conversations-${sortedUserIds.join('-')}`, null);\n    const now = Date.now();\n    const insert = {\n      _key: conversationId,\n      added: now,\n      isDirect: true,\n      modified: now\n    };\n    const insertQuery: AqlQuery = aql`INSERT ${insert} IN conversations RETURN NEW`;\n    const updatedConversation = await database.query(insertQuery)\n      .then((cursor: ArrayCursor) => cursor.next());\n\n    await Promise.all(userIds.map((userId) => {\n      const edgeId: string = createHash(`hasConversation-${userId}-${conversationId}`);\n      const edge: any = {\n        _from: `users/${userId}`,\n        _key: edgeId,\n        _to: `conversations/${conversationId}`,\n        added: Date.now()\n      };\n      const insertEdgeQuery: AqlQuery = aql`INSERT ${edge} IN hasConversation RETURN NEW`;\n      return database.query(insertEdgeQuery);\n    }));\n\n    return {...updatedConversation, users: [user]};\n  } catch(databaseError) {\n    return logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, databaseError, context);\n  }\n};\n\nexport const getConnectionUsers = (\n  context: ApiContext,\n  {\n    conversationId,\n    includeAll = false,\n    isDirect\n  }: ConversationUsersParams\n): Promise<ConnectionType[]> => {\n  const action: string = 'getConnectionUsers';\n  const {database, session: {userId: sessionUserId}} = context;\n  const filters: string[] = ['c.userId == u._key'];\n\n  if(!includeAll) {\n    filters.push(`u._key != ${sessionUserId}`);\n  }\n  if(isDirect) {\n    filters.push(`p.vertices[0].isDirect == ${isDirect}`);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation\n    OPTIONS {vertexCollections: \"users\"}\n    FOR c IN connections\n    FILTER ${filters.join(' && ')}\n    RETURN c`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context)\n    );\n};\n\nexport const getConversationUsers = (\n  context: ApiContext,\n  {\n    conversationId,\n    includeAll = false,\n    isDirect\n  }: ConversationUsersParams\n): Promise<ConversationType[]> => {\n  const action: string = 'getConversationUsers';\n  const {database, session: {userId: sessionUserId}} = context;\n  const filters: string[] = ['c.userId == u._key'];\n\n  if(!includeAll) {\n    filters.push(`u._key != ${sessionUserId}`);\n  }\n  if(isDirect) {\n    filters.push(`p.vertices[0].isDirect == ${isDirect}`);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation\n    OPTIONS {vertexCollections: \"users\"}\n    FILTER ${filters.join(' && ')}\n    RETURN u`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\n// export const getDirectConversationOld = (context: ApiContext, userId: string): Promise<ConversationType> => {\n//   const action: string = 'getDirectConversation';\n//   const {database, session: {userId: sessionId}} = context;\n//   const sessionDocId: string = `users/${sessionId}`;\n//   const formatUserId: string = parseArangoId(userId);\n\n//   const aqlQry: AqlQuery = aql`LET from = (\n//       FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation\n//       FILTER c.direct == true\n//       RETURN c\n//     )\n//     LET to = (\n//       FOR c, e IN 1..1 OUTBOUND ${formatUserId} hasConversation\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}, ${formatUserId}]\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 database.query(aqlQry)\n//     .then((cursor: ArrayCursor) => cursor.next())\n//     .catch((error: Error) => logError({\n//       action,\n//       category: eventCategory,\n//       label: ErrorTypes.DATABASE_ERROR\n//     }, error, context));\n// };\n\nexport const getConversation = (context: ApiContext, conversationId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, session: {userId: sessionId}} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const conversationDocId: string = `conversations/${parseId(conversationId)}`;\n\n  const aqlQry: AqlQuery = aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation\n    FILTER c._id == ${conversationDocId}\n    LET u = (\n      FOR inUser, inEdge IN 1..1 INBOUND ${conversationDocId} hasConversation\n      RETURN inUser\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType) => {\n      if(!conversation) {\n        return {};\n      }\n\n      conversation.users = conversation.users.map((user: UserType) => {\n        const {imageId, userId} = user;\n        const thumbUrlData: ImageUrlData = {\n          imageId,\n          isThumb: true,\n          userId\n        };\n\n        return {\n          ...user,\n          name: getDisplayName(user),\n          thumb: getImageUrl(thumbUrlData)\n        };\n      });\n\n      return conversation;\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\nexport const updateConversation = (\n  context: ApiContext,\n  conversation: ConversationType\n): Promise<ConversationType> => {\n  const action: string = 'updateConversation';\n  const {database, session: {userId: sessionId}} = context;\n  const {\n    conversationId = createHash(`conversation-${sessionId} `),\n    isDirect = false,\n    name\n  } = conversation;\n  const formatConversationId: string = parseId(conversationId);\n  const now: number = Date.now();\n  const update: any = {\n    isDirect,\n    modified: now,\n    name\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatConversationId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatConversationId} }\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return 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: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\nexport const addUserToConversation = (\n  context: ApiContext,\n  {\n    conversationId,\n    userId\n  }: UpdateConversationUserParams\n): Promise<ConversationType> => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConversationId: string = parseId(conversationId);\n  const formatUserId: string = parseId(userId);\n  const conversationDocId: string = `conversations/${formatConversationId}`;\n  const userDocId: string = `users/${formatUserId}`;\n\n  const aqlQry: AqlQuery = aql`FOR hc IN hasConversation\n    FILTER hc._from == ${userDocId} && hc._to == ${conversationDocId}\n    LIMIT 1\n    RETURN hc`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((hasConversationEdge) => {\n      if(!!hasConversationEdge) {\n        return hasConversationEdge;\n      }\n\n      const edgeCollection: EdgeCollection = database.collection('hasConversation');\n      const edgeId: string = createHash(`convo - ${formatConversationId} -${formatUserId} `);\n\n      const edge: ConversationType = {\n        _from: userDocId,\n        _key: edgeId,\n        _to: conversationDocId,\n        added: Date.now()\n      };\n\n      return edgeCollection\n        .save(edge, {returnNew: true})\n        .then(() => edge);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\nexport const deleteUserFromConversation = (\n  context: ApiContext,\n  {\n    conversationId,\n    userId\n  }: UpdateConversationUserParams\n): Promise<ConversationType> => {\n  const action: string = 'deleteUserFromConversation';\n  const {database} = context;\n  const formatConversationId: string = parseId(conversationId);\n  const formatUserId: string = parseId(userId);\n  const conversationDocId: string = `conversations/${formatConversationId}`;\n  const userDocId: string = `users/${formatUserId}`;\n\n  const aqlQry: AqlQuery = aql`FOR hc IN hasConversation\n    FILTER hc._from == ${userDocId} && hc._to == ${conversationDocId}\n    LIMIT 1\n    REMOVE hc IN hasConversation\n    RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n"],
  "mappings": "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",
  "names": ["cloneDeep", "conversation"]
}

|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { BatchWriteItemCommandInput, BatchWriteItemCommandOutput, DeleteItemCommandInput, DeleteItemCommandOutput, GetItemCommandInput, GetItemCommandOutput, PutItemCommandInput, PutItemCommandOutput, QueryCommandInput, QueryCommandOutput, UpdateItemCommandInput, UpdateItemCommandOutput } from '@aws-sdk/client-dynamodb';
|
|
2
|
+
export declare const dynamoGet: (params: GetItemCommandInput) => Promise<GetItemCommandOutput>;
|
|
3
|
+
export declare const parseDynamoList: (results: QueryCommandOutput) => any[];
|
|
4
|
+
export declare const dynamoGetList: (params: QueryCommandInput, startItem?: any) => Promise<GetItemCommandOutput[]>;
|
|
5
|
+
export declare const dynamoPut: (params: PutItemCommandInput) => Promise<PutItemCommandOutput>;
|
|
6
|
+
export declare const dynamoUpdate: (params: UpdateItemCommandInput) => Promise<UpdateItemCommandOutput>;
|
|
7
|
+
export declare const dynamoPutList: (params: BatchWriteItemCommandInput) => Promise<BatchWriteItemCommandOutput>;
|
|
8
|
+
export declare const dynamoDel: (params: DeleteItemCommandInput) => Promise<DeleteItemCommandOutput>;
|