@nlabs/reaktor 0.6.0 → 0.8.1
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/actions/conversations.d.ts +5 -5
- package/lib/actions/conversations.js +34 -24
- package/lib/actions/email.js +2 -3
- package/lib/actions/files.js +4 -15
- package/lib/actions/images.d.ts +1 -1
- package/lib/actions/images.js +20 -21
- package/lib/actions/messages.js +5 -6
- package/lib/actions/payments.js +5 -6
- package/lib/actions/posts.d.ts +4 -2
- package/lib/actions/posts.js +50 -7
- package/lib/actions/reactions.d.ts +1 -1
- package/lib/actions/reactions.js +13 -13
- package/lib/actions/tags.d.ts +6 -1
- package/lib/actions/tags.js +3 -3
- package/lib/actions/users.d.ts +1 -1
- package/lib/actions/users.js +13 -14
- package/lib/actions/websockets.js +3 -3
- package/lib/lambdas/actions/websockets.js +4 -15
- package/lib/lambdas/authorizer.js +5 -16
- package/lib/lambdas/connection.js +2 -13
- package/lib/lambdas/utils/websocket.js +2 -1
- package/lib/types/conversations.d.ts +5 -0
- package/lib/types/conversations.js +1 -1
- package/lib/types/users.d.ts +1 -1
- package/lib/types/users.js +1 -1
- package/lib/utils/arangodb.js +2 -2
- package/package.json +12 -12
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { ConnectionType, ConversationType } from '../types';
|
|
1
|
+
import { ConnectionType, ConversationOptions, ConversationType } from '../types';
|
|
2
2
|
import { ApiContext } from '../types/auth';
|
|
3
|
-
export declare const
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
3
|
+
export declare const parseConversationOptions: (options?: ConversationOptions) => {
|
|
4
|
+
limit: import("types/arangodb").ArangoDBLimit;
|
|
5
|
+
};
|
|
6
|
+
export declare const getConversations: (context: ApiContext, options?: any) => Promise<ConversationType[]>;
|
|
7
7
|
export declare const getDirectConversation: (context: ApiContext, fromId: string, toId: string) => Promise<ConversationType>;
|
|
8
8
|
export declare const getConnectionUsers: (context: ApiContext, conversationId: string, includeAll?: boolean, isDirect?: boolean) => Promise<ConnectionType[]>;
|
|
9
9
|
export declare const getConversationUsers: (context: ApiContext, conversationId: string, includeAll?: boolean, isDirect?: boolean) => Promise<ConversationType[]>;
|
|
@@ -35,27 +35,36 @@ __export(conversations_exports, {
|
|
|
35
35
|
getConversations: () => getConversations,
|
|
36
36
|
getDirectConversation: () => getDirectConversation,
|
|
37
37
|
getDirectConversationOld: () => getDirectConversationOld,
|
|
38
|
+
parseConversationOptions: () => parseConversationOptions,
|
|
38
39
|
updateConversation: () => updateConversation
|
|
39
40
|
});
|
|
40
41
|
module.exports = __toCommonJS(conversations_exports);
|
|
41
42
|
var import_utils = require("@nlabs/utils");
|
|
42
43
|
var import_arangojs = require("arangojs");
|
|
43
44
|
var import_cloneDeep = __toESM(require("lodash/cloneDeep"));
|
|
44
|
-
var import_isEmpty = __toESM(require("lodash/isEmpty"));
|
|
45
45
|
var import_utils2 = require("../utils");
|
|
46
46
|
var import_analytics = require("../utils/analytics");
|
|
47
47
|
var import_images = require("./images");
|
|
48
48
|
var import_users = require("./users");
|
|
49
49
|
const eventCategory = "conversations";
|
|
50
|
-
const
|
|
50
|
+
const parseConversationOptions = (options = {}) => {
|
|
51
|
+
const {
|
|
52
|
+
from = 0,
|
|
53
|
+
to = 30
|
|
54
|
+
} = options;
|
|
55
|
+
return {
|
|
56
|
+
limit: (0, import_utils2.getLimit)(from, to)
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
const getConversations = (context, options) => {
|
|
51
60
|
const action = "getConversations";
|
|
52
61
|
const { database, session: { userId: sessionId } } = context;
|
|
53
|
-
const limit = (
|
|
62
|
+
const { limit } = parseConversationOptions(options);
|
|
54
63
|
const sessionDocId = `users/${sessionId}`;
|
|
55
|
-
const aqlQry = `FOR c, e IN 1..1 OUTBOUND "${sessionDocId}"
|
|
64
|
+
const aqlQry = `FOR c, e IN 1..1 OUTBOUND "${sessionDocId}" hasConversation
|
|
56
65
|
${limit.aql}
|
|
57
66
|
LET users = (
|
|
58
|
-
FOR u, uc IN 1..1 INBOUND c._id
|
|
67
|
+
FOR u, uc IN 1..1 INBOUND c._id hasConversation
|
|
59
68
|
FILTER u._id != "${sessionDocId}"
|
|
60
69
|
RETURN u
|
|
61
70
|
)
|
|
@@ -103,14 +112,14 @@ const getDirectConversation = async (context, fromId, toId) => {
|
|
|
103
112
|
const insertQuery = import_arangojs.aql`INSERT ${insert} IN conversations RETURN NEW`;
|
|
104
113
|
const updatedConversation = await database.query(insertQuery).then((cursor) => cursor.next());
|
|
105
114
|
await Promise.all(userIds.map((userId) => {
|
|
106
|
-
const edgeId = (0, import_utils.createHash)(`
|
|
115
|
+
const edgeId = (0, import_utils.createHash)(`hasConversation-${userId}-${conversationId}`);
|
|
107
116
|
const edge = {
|
|
108
117
|
_from: `users/${userId}`,
|
|
109
118
|
_key: edgeId,
|
|
110
119
|
_to: `conversations/${conversationId}`,
|
|
111
120
|
added: Date.now()
|
|
112
121
|
};
|
|
113
|
-
const insertEdgeQuery = import_arangojs.aql`INSERT ${edge} IN
|
|
122
|
+
const insertEdgeQuery = import_arangojs.aql`INSERT ${edge} IN hasConversation RETURN NEW`;
|
|
114
123
|
return database.query(insertEdgeQuery);
|
|
115
124
|
}));
|
|
116
125
|
return { ...updatedConversation, users: [user] };
|
|
@@ -132,7 +141,7 @@ const getConnectionUsers = (context, conversationId, includeAll = false, isDirec
|
|
|
132
141
|
if (isDirect) {
|
|
133
142
|
filters.push(`p.vertices[0].isDirect == ${isDirect}`);
|
|
134
143
|
}
|
|
135
|
-
const aqlQry = import_arangojs.aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`}
|
|
144
|
+
const aqlQry = import_arangojs.aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation
|
|
136
145
|
OPTIONS {vertexCollections: "users"}
|
|
137
146
|
FOR c IN connections
|
|
138
147
|
FILTER ${filters.join(" && ")}
|
|
@@ -153,7 +162,7 @@ const getConversationUsers = (context, conversationId, includeAll = false, isDir
|
|
|
153
162
|
if (isDirect) {
|
|
154
163
|
filters.push(`p.vertices[0].isDirect == ${isDirect}`);
|
|
155
164
|
}
|
|
156
|
-
const aqlQry = import_arangojs.aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`}
|
|
165
|
+
const aqlQry = import_arangojs.aql`FOR u, e,p IN 1..1 INBOUND ${`conversations/${conversationId}`} hasConversation
|
|
157
166
|
OPTIONS {vertexCollections: "users"}
|
|
158
167
|
FILTER ${filters.join(" && ")}
|
|
159
168
|
RETURN u`;
|
|
@@ -170,12 +179,12 @@ const getDirectConversationOld = (context, userId) => {
|
|
|
170
179
|
const sessionDocId = `users/${sessionId}`;
|
|
171
180
|
const formatUserId = (0, import_utils.parseArangoId)(userId);
|
|
172
181
|
const aqlQry = import_arangojs.aql`LET from = (
|
|
173
|
-
FOR c, e IN 1..1 OUTBOUND ${sessionDocId}
|
|
182
|
+
FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation
|
|
174
183
|
FILTER c.direct == true
|
|
175
184
|
RETURN c
|
|
176
185
|
)
|
|
177
186
|
LET to = (
|
|
178
|
-
FOR c, e IN 1..1 OUTBOUND ${formatUserId}
|
|
187
|
+
FOR c, e IN 1..1 OUTBOUND ${formatUserId} hasConversation
|
|
179
188
|
FILTER c.direct == true
|
|
180
189
|
RETURN c
|
|
181
190
|
)
|
|
@@ -198,16 +207,16 @@ const getConversation = (context, convoId) => {
|
|
|
198
207
|
const { database, session: { userId: sessionId } } = context;
|
|
199
208
|
const sessionDocId = `users/${sessionId}`;
|
|
200
209
|
const convoDocId = `conversations/${(0, import_utils.parseId)(convoId)}`;
|
|
201
|
-
const aqlQry = import_arangojs.aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId}
|
|
210
|
+
const aqlQry = import_arangojs.aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversation
|
|
202
211
|
FILTER c._id == ${convoDocId}
|
|
203
212
|
LET u = (
|
|
204
|
-
FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId}
|
|
213
|
+
FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId} hasConversation
|
|
205
214
|
RETURN inUser
|
|
206
215
|
)
|
|
207
216
|
LIMIT 1
|
|
208
217
|
RETURN MERGE(c, {users: u})`;
|
|
209
218
|
return database.query(aqlQry).then((cursor) => cursor.next()).then((conversation = {}) => {
|
|
210
|
-
if (
|
|
219
|
+
if (conversation) {
|
|
211
220
|
conversation.users = conversation.users.map((user) => {
|
|
212
221
|
const { imageId, userId } = user;
|
|
213
222
|
const thumbUrlData = {
|
|
@@ -218,7 +227,7 @@ const getConversation = (context, convoId) => {
|
|
|
218
227
|
return {
|
|
219
228
|
...user,
|
|
220
229
|
name: (0, import_users.getDisplayName)(user),
|
|
221
|
-
thumb: (0, import_images.
|
|
230
|
+
thumb: (0, import_images.getImageUrl)(thumbUrlData)
|
|
222
231
|
};
|
|
223
232
|
});
|
|
224
233
|
return conversation;
|
|
@@ -266,9 +275,9 @@ const addUserToConversation = (context, convoId, userId) => {
|
|
|
266
275
|
const { database } = context;
|
|
267
276
|
const formatConvoId = (0, import_utils.parseId)(convoId);
|
|
268
277
|
const formatUserId = (0, import_utils.parseId)(userId);
|
|
269
|
-
const convoDocId = `conversations/${formatConvoId}
|
|
270
|
-
const userDocId = `users/${formatUserId}
|
|
271
|
-
const aqlQry = import_arangojs.aql`FOR c IN
|
|
278
|
+
const convoDocId = `conversations/${formatConvoId}`;
|
|
279
|
+
const userDocId = `users/${formatUserId}`;
|
|
280
|
+
const aqlQry = import_arangojs.aql`FOR c IN hasConversation
|
|
272
281
|
FILTER c._from == ${userDocId} && c._to == ${convoDocId}
|
|
273
282
|
LIMIT 1
|
|
274
283
|
RETURN c`;
|
|
@@ -276,7 +285,7 @@ const addUserToConversation = (context, convoId, userId) => {
|
|
|
276
285
|
if (!!conversationEdge) {
|
|
277
286
|
return conversationEdge;
|
|
278
287
|
}
|
|
279
|
-
const edgeCollection = database.collection("
|
|
288
|
+
const edgeCollection = database.collection("hasConversation");
|
|
280
289
|
const edgeId = (0, import_utils.createHash)(`convo - ${formatConvoId} -${formatUserId} `);
|
|
281
290
|
const edge = {
|
|
282
291
|
_from: userDocId,
|
|
@@ -296,12 +305,12 @@ const deleteUserFromConversation = (context, convoId, userId) => {
|
|
|
296
305
|
const { database } = context;
|
|
297
306
|
const formatConvoId = (0, import_utils.parseId)(convoId);
|
|
298
307
|
const formatUserId = (0, import_utils.parseId)(userId);
|
|
299
|
-
const convoDocId = `conversations
|
|
300
|
-
const userDocId = `users/${formatUserId}
|
|
301
|
-
const aqlQry = import_arangojs.aql`FOR c IN
|
|
308
|
+
const convoDocId = `conversations/${formatConvoId}`;
|
|
309
|
+
const userDocId = `users/${formatUserId}`;
|
|
310
|
+
const aqlQry = import_arangojs.aql`FOR c IN hasConversation
|
|
302
311
|
FILTER c._from == ${userDocId} && c._to == ${convoDocId}
|
|
303
312
|
LIMIT 1
|
|
304
|
-
REMOVE c IN
|
|
313
|
+
REMOVE c IN hasConversation
|
|
305
314
|
RETURN OLD`;
|
|
306
315
|
return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analytics.logError)({
|
|
307
316
|
action,
|
|
@@ -319,6 +328,7 @@ const deleteUserFromConversation = (context, convoId, userId) => {
|
|
|
319
328
|
getConversations,
|
|
320
329
|
getDirectConversation,
|
|
321
330
|
getDirectConversationOld,
|
|
331
|
+
parseConversationOptions,
|
|
322
332
|
updateConversation
|
|
323
333
|
});
|
|
324
|
-
//# 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';\nimport isEmpty from 'lodash/isEmpty';\n\nimport {ArangoDBLimit, ConnectionType, ConversationType, ImageUrlData, User} from '../types';\nimport {ApiContext} from '../types/auth';\nimport {getLimit} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUserImageUrl} from './images';\nimport {getDisplayName, getUser} from './users';\n\nconst eventCategory: string = 'conversations';\n\nexport const getConversations = (context: ApiContext, {from, to}): Promise<ConversationType[]> => {\n  const action: string = 'getConversations';\n  const {database, session: {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 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(`hasConversations-${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 hasConversations 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}`} hasConversations\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}`} hasConversations\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} hasConversations\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET to = (\n      FOR c, e IN 1..1 OUTBOUND ${formatUserId} 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}, ${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} 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 database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(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: 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, 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 hasConversations\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('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 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 hasConversations\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    REMOVE c IN hasConversations\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", "isEmpty", "cloneDeep", "conversation"]
}

|
|
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"]
}

|
package/lib/actions/email.js
CHANGED
|
@@ -34,7 +34,6 @@ __export(email_exports, {
|
|
|
34
34
|
});
|
|
35
35
|
module.exports = __toCommonJS(email_exports);
|
|
36
36
|
var import_aws_sdk = __toESM(require("aws-sdk"));
|
|
37
|
-
var import_isEmpty = __toESM(require("lodash/isEmpty"));
|
|
38
37
|
var import_config = require("../config");
|
|
39
38
|
var import_layout = __toESM(require("../templates/email/layout"));
|
|
40
39
|
var import_passwordForgot = __toESM(require("../templates/email/passwordForgot"));
|
|
@@ -48,7 +47,7 @@ var import_welcome2 = __toESM(require("../templates/sms/welcome"));
|
|
|
48
47
|
var import_s32 = require("./s3");
|
|
49
48
|
const appTemplate = (app, message = "", vars = {}) => {
|
|
50
49
|
let updatedMessage = "";
|
|
51
|
-
if (
|
|
50
|
+
if (app) {
|
|
52
51
|
updatedMessage = message.replace(/\[appName\]/g, app.name).replace(/\[appUrl\]/g, app.url).replace(/\[appEmail\]/g, app.email);
|
|
53
52
|
}
|
|
54
53
|
Object.keys(vars).forEach((key) => {
|
|
@@ -180,4 +179,4 @@ const sendTemplate = (templateName, emailParams) => {
|
|
|
180
179
|
sendTemplate,
|
|
181
180
|
sesSend
|
|
182
181
|
});
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/email.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 aws, {SES} from 'aws-sdk';\nimport {GetObjectRequest} from 'aws-sdk/clients/s3';\nimport {SendEmailRequest, SendEmailResponse} from 'aws-sdk/clients/ses';\nimport isEmpty from 'lodash/isEmpty';\n\nimport {Config} from '../config';\nimport layoutTemplate from '../templates/email/layout';\nimport forgotEmailTemplate from '../templates/email/passwordForgot';\nimport recoveryEmailTemplate from '../templates/email/passwordRecovery';\nimport verifyEmailTemplate from '../templates/email/verifyEmail';\nimport welcomeEmailTemplate from '../templates/email/welcome';\nimport forgotSmsTemplate from '../templates/sms/passwordForgot';\nimport recoverySmsTemplate from '../templates/sms/passwordRecovery';\nimport verifySmsTemplate from '../templates/sms/verifyEmail';\nimport welcomeSmsTemplate from '../templates/sms/welcome';\nimport {AppType} from '../types/apps';\nimport {EmailType} from '../types/email';\nimport {s3Get} from './s3';\n\n// const eventCategory: string = 'email';\n\nexport const appTemplate = (app: AppType, message: string = '', vars = {}): string => {\n  let updatedMessage: string = '';\n\n  if(!isEmpty(app)) {\n    updatedMessage = message.replace(/\\[appName\\]/g, app.name)\n      .replace(/\\[appUrl\\]/g, app.url)\n      .replace(/\\[appEmail\\]/g, app.email);\n  }\n\n  Object.keys(vars).forEach((key: string) => {\n    if(vars[key]) {\n      updatedMessage = message.replace(new RegExp(`\\\\[${key}\\\\]`, 'g'), vars[key]);\n    }\n  });\n\n  return updatedMessage;\n};\n\n// AWS::SES\nexport const sesSend = (params: SendEmailRequest): Promise<SendEmailResponse> => new Promise((resolve, reject) => {\n  aws.config.update(Config.get('aws'));\n  const ses: SES = new SES();\n\n  ses.sendEmail(params, (error: Error, response: SendEmailResponse) => {\n    if(error) {\n      return reject(error);\n    }\n\n    return resolve(response);\n  });\n});\n\nexport const sendEmail = (params: EmailType): Promise<boolean> => {\n  const {\n    app = {},\n    html,\n    subject,\n    subTitle = '',\n    text,\n    title = '',\n    user = {}\n  } = params;\n\n  const to = [user.email];\n  let promise;\n\n  const formatSubject: string = appTemplate(app, subject);\n  const formatSubTitle: string = appTemplate(app, subTitle);\n  const formatTitle: string = appTemplate(app, title);\n  const formatText: string = appTemplate(app, text);\n  const formatHtml: string = appTemplate(app, html);\n  const {_key: hasCustomEmail, urlFacebook, urlTwitter} = app;\n\n  const parseTemplate = (body: string) => {\n    const templateBody: string = appTemplate(app, body || '');\n\n    // Links\n    let links: string = '';\n    const spacer = '<td width=\"5\"><img width=\"1\" height=\"1\" border=\"0\" title=\"\" alt=\"\" ' +\n      'src=\"https://box.reaktor.io/images/email/spacer.gif\"/></td>';\n\n    if(urlFacebook) {\n      links = `<td width=\"30\"><a href=\"${urlFacebook}\"><img width=\"30\" height=\"30\" border=\"0\" ` +\n        'title=\"Facebook\" alt=\"Facebook\" src=\"https://box.reaktor.io/images/email/icon-facebook.png\"/></a></td>';\n    }\n\n    if(urlTwitter) {\n      if(urlFacebook) {\n        links += spacer;\n      }\n\n      links += `<td width=\"30\"><a href=\"${urlTwitter}\"><img width=\"30\" height=\"30\" border=\"0\" ` +\n        'title=\"Twitter\" alt=\"Twitter\" src=\"https://box.reaktor.io/images/email/icon-twitter.png\"/></a></td>';\n    }\n\n    if(!links.length) {\n      links += spacer;\n    }\n\n    return templateBody.replace(/\\[title\\]/g, formatTitle)\n      .replace(/\\[subTitle\\]/g, formatSubTitle)\n      .replace(/\\[subject\\]/g, formatSubject)\n      .replace(/\\[message\\]/g, formatHtml)\n      .replace(/\\[links\\]/g, links);\n  };\n\n  if(hasCustomEmail) {\n    const s3Params: GetObjectRequest = {Bucket: null, Key: 'apps/templates/email.html'};\n    promise = s3Get(s3Params).then((results) => parseTemplate(results.Body.toString()));\n  } else {\n    promise = Promise.resolve(parseTemplate(layoutTemplate));\n  }\n\n  return promise.then((parsedHtml: string) => {\n    const emailParams: SendEmailRequest = {\n      Destination: {ToAddresses: to},\n      Message: {\n        Body: {\n          Html: {Data: parsedHtml},\n          Text: {Data: formatText}\n        },\n        Subject: {Data: formatSubject}\n      },\n      Source: `\"${app.supportName}\" <noreply@${Config.get('app.url')}>`\n    };\n\n    return sesSend(emailParams);\n  });\n};\n\nexport const sendTemplate = (templateName: string, emailParams: EmailType): Promise<boolean> => {\n  const {app, user, subject, subTitle, title, vars}: EmailType = emailParams;\n  let html: string;\n  let text: string;\n\n  try {\n    switch(templateName) {\n      case 'passwordForgot': {\n        html = forgotEmailTemplate;\n        text = forgotSmsTemplate;\n        break;\n      }\n      case 'passwordRecovery': {\n        html = recoveryEmailTemplate;\n        text = recoverySmsTemplate;\n        break;\n      }\n      case 'verifyRecovery': {\n        html = verifyEmailTemplate;\n        text = verifySmsTemplate;\n        break;\n      }\n      case 'verifyEmail': {\n        html = verifyEmailTemplate;\n        text = verifySmsTemplate;\n        break;\n      }\n      case 'welcome': {\n        html = welcomeEmailTemplate;\n        text = welcomeSmsTemplate;\n        break;\n      }\n    }\n\n    const templateHtml: string = appTemplate(app, html, vars);\n    const templateText: string = appTemplate(app, text, vars);\n\n    const params = {\n      app,\n      html: templateHtml,\n      subTitle,\n      subject,\n      text: templateText,\n      title,\n      user\n    };\n\n    return sendEmail(params)\n      .then(() => true)\n      .catch(() => false);\n  } catch(error) {\n    return Promise.reject(error);\n  }\n};\n"],
  "mappings": "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",
  "names": ["import_passwordForgot", "import_passwordRecovery", "import_verifyEmail", "import_welcome", "import_s3", "isEmpty", "aws", "layoutTemplate", "forgotEmailTemplate", "forgotSmsTemplate", "recoveryEmailTemplate", "recoverySmsTemplate", "verifyEmailTemplate", "verifySmsTemplate", "welcomeEmailTemplate", "welcomeSmsTemplate"]
}

|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/email.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 aws, {SES} from 'aws-sdk';\nimport {GetObjectRequest} from 'aws-sdk/clients/s3';\nimport {SendEmailRequest, SendEmailResponse} from 'aws-sdk/clients/ses';\n\nimport {Config} from '../config';\nimport layoutTemplate from '../templates/email/layout';\nimport forgotEmailTemplate from '../templates/email/passwordForgot';\nimport recoveryEmailTemplate from '../templates/email/passwordRecovery';\nimport verifyEmailTemplate from '../templates/email/verifyEmail';\nimport welcomeEmailTemplate from '../templates/email/welcome';\nimport forgotSmsTemplate from '../templates/sms/passwordForgot';\nimport recoverySmsTemplate from '../templates/sms/passwordRecovery';\nimport verifySmsTemplate from '../templates/sms/verifyEmail';\nimport welcomeSmsTemplate from '../templates/sms/welcome';\nimport {AppType} from '../types/apps';\nimport {EmailType} from '../types/email';\nimport {s3Get} from './s3';\n\n// const eventCategory: string = 'email';\n\nexport const appTemplate = (app: AppType, message: string = '', vars = {}): string => {\n  let updatedMessage: string = '';\n\n  if(app) {\n    updatedMessage = message.replace(/\\[appName\\]/g, app.name)\n      .replace(/\\[appUrl\\]/g, app.url)\n      .replace(/\\[appEmail\\]/g, app.email);\n  }\n\n  Object.keys(vars).forEach((key: string) => {\n    if(vars[key]) {\n      updatedMessage = message.replace(new RegExp(`\\\\[${key}\\\\]`, 'g'), vars[key]);\n    }\n  });\n\n  return updatedMessage;\n};\n\n// AWS::SES\nexport const sesSend = (params: SendEmailRequest): Promise<SendEmailResponse> => new Promise((resolve, reject) => {\n  aws.config.update(Config.get('aws'));\n  const ses: SES = new SES();\n\n  ses.sendEmail(params, (error: Error, response: SendEmailResponse) => {\n    if(error) {\n      return reject(error);\n    }\n\n    return resolve(response);\n  });\n});\n\nexport const sendEmail = (params: EmailType): Promise<boolean> => {\n  const {\n    app = {},\n    html,\n    subject,\n    subTitle = '',\n    text,\n    title = '',\n    user = {}\n  } = params;\n\n  const to = [user.email];\n  let promise;\n\n  const formatSubject: string = appTemplate(app, subject);\n  const formatSubTitle: string = appTemplate(app, subTitle);\n  const formatTitle: string = appTemplate(app, title);\n  const formatText: string = appTemplate(app, text);\n  const formatHtml: string = appTemplate(app, html);\n  const {_key: hasCustomEmail, urlFacebook, urlTwitter} = app;\n\n  const parseTemplate = (body: string) => {\n    const templateBody: string = appTemplate(app, body || '');\n\n    // Links\n    let links: string = '';\n    const spacer = '<td width=\"5\"><img width=\"1\" height=\"1\" border=\"0\" title=\"\" alt=\"\" ' +\n      'src=\"https://box.reaktor.io/images/email/spacer.gif\"/></td>';\n\n    if(urlFacebook) {\n      links = `<td width=\"30\"><a href=\"${urlFacebook}\"><img width=\"30\" height=\"30\" border=\"0\" ` +\n        'title=\"Facebook\" alt=\"Facebook\" src=\"https://box.reaktor.io/images/email/icon-facebook.png\"/></a></td>';\n    }\n\n    if(urlTwitter) {\n      if(urlFacebook) {\n        links += spacer;\n      }\n\n      links += `<td width=\"30\"><a href=\"${urlTwitter}\"><img width=\"30\" height=\"30\" border=\"0\" ` +\n        'title=\"Twitter\" alt=\"Twitter\" src=\"https://box.reaktor.io/images/email/icon-twitter.png\"/></a></td>';\n    }\n\n    if(!links.length) {\n      links += spacer;\n    }\n\n    return templateBody.replace(/\\[title\\]/g, formatTitle)\n      .replace(/\\[subTitle\\]/g, formatSubTitle)\n      .replace(/\\[subject\\]/g, formatSubject)\n      .replace(/\\[message\\]/g, formatHtml)\n      .replace(/\\[links\\]/g, links);\n  };\n\n  if(hasCustomEmail) {\n    const s3Params: GetObjectRequest = {Bucket: null, Key: 'apps/templates/email.html'};\n    promise = s3Get(s3Params).then((results) => parseTemplate(results.Body.toString()));\n  } else {\n    promise = Promise.resolve(parseTemplate(layoutTemplate));\n  }\n\n  return promise.then((parsedHtml: string) => {\n    const emailParams: SendEmailRequest = {\n      Destination: {ToAddresses: to},\n      Message: {\n        Body: {\n          Html: {Data: parsedHtml},\n          Text: {Data: formatText}\n        },\n        Subject: {Data: formatSubject}\n      },\n      Source: `\"${app.supportName}\" <noreply@${Config.get('app.url')}>`\n    };\n\n    return sesSend(emailParams);\n  });\n};\n\nexport const sendTemplate = (templateName: string, emailParams: EmailType): Promise<boolean> => {\n  const {app, user, subject, subTitle, title, vars}: EmailType = emailParams;\n  let html: string;\n  let text: string;\n\n  try {\n    switch(templateName) {\n      case 'passwordForgot': {\n        html = forgotEmailTemplate;\n        text = forgotSmsTemplate;\n        break;\n      }\n      case 'passwordRecovery': {\n        html = recoveryEmailTemplate;\n        text = recoverySmsTemplate;\n        break;\n      }\n      case 'verifyRecovery': {\n        html = verifyEmailTemplate;\n        text = verifySmsTemplate;\n        break;\n      }\n      case 'verifyEmail': {\n        html = verifyEmailTemplate;\n        text = verifySmsTemplate;\n        break;\n      }\n      case 'welcome': {\n        html = welcomeEmailTemplate;\n        text = welcomeSmsTemplate;\n        break;\n      }\n    }\n\n    const templateHtml: string = appTemplate(app, html, vars);\n    const templateText: string = appTemplate(app, text, vars);\n\n    const params = {\n      app,\n      html: templateHtml,\n      subTitle,\n      subject,\n      text: templateText,\n      title,\n      user\n    };\n\n    return sendEmail(params)\n      .then(() => true)\n      .catch(() => false);\n  } catch(error) {\n    return Promise.reject(error);\n  }\n};\n"],
  "mappings": "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",
  "names": ["import_passwordForgot", "import_passwordRecovery", "import_verifyEmail", "import_welcome", "import_s3", "aws", "layoutTemplate", "forgotEmailTemplate", "forgotSmsTemplate", "recoveryEmailTemplate", "recoverySmsTemplate", "verifyEmailTemplate", "verifySmsTemplate", "welcomeEmailTemplate", "welcomeSmsTemplate"]
}

|
package/lib/actions/files.js
CHANGED
|
@@ -1,8 +1,6 @@
|
|
|
1
|
-
var __create = Object.create;
|
|
2
1
|
var __defProp = Object.defineProperty;
|
|
3
2
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
3
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
6
4
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
5
|
var __export = (target, all) => {
|
|
8
6
|
for (var name in all)
|
|
@@ -16,14 +14,6 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
14
|
}
|
|
17
15
|
return to;
|
|
18
16
|
};
|
|
19
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
21
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
22
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
23
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
24
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
25
|
-
mod
|
|
26
|
-
));
|
|
27
17
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
18
|
var files_exports = {};
|
|
29
19
|
__export(files_exports, {
|
|
@@ -45,7 +35,6 @@ var import_rip_hunter = require("@nlabs/rip-hunter");
|
|
|
45
35
|
var import_utils = require("@nlabs/utils");
|
|
46
36
|
var import_arangojs = require("arangojs");
|
|
47
37
|
var import_googleapis = require("googleapis");
|
|
48
|
-
var import_isEmpty = __toESM(require("lodash/isEmpty"));
|
|
49
38
|
var import_config = require("../config");
|
|
50
39
|
var import_analytics = require("../utils/analytics");
|
|
51
40
|
var import_images = require("./images");
|
|
@@ -61,7 +50,7 @@ const addFile = (context, item = {}) => {
|
|
|
61
50
|
url
|
|
62
51
|
} = item;
|
|
63
52
|
const formatFileId = fileId ? (0, import_utils.parseId)(fileId) : (0, import_utils.createHash)(`file-${sessionId}`);
|
|
64
|
-
const isUrl =
|
|
53
|
+
const isUrl = !!url;
|
|
65
54
|
let formatName = (0, import_utils.parseString)(name, 160);
|
|
66
55
|
let formatType = (0, import_utils.parseString)(fileType, 16);
|
|
67
56
|
if (formatName === "" && isUrl) {
|
|
@@ -147,7 +136,7 @@ const addFile = (context, item = {}) => {
|
|
|
147
136
|
};
|
|
148
137
|
const getGiphyTrends = (context, limit = 30) => {
|
|
149
138
|
const gifUrl = `http://api.giphy.com/v1/gifs/trending?api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
|
|
150
|
-
return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json
|
|
139
|
+
return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json?.data?.map((gifImage = { id: null, images: null }) => {
|
|
151
140
|
const {
|
|
152
141
|
id,
|
|
153
142
|
images: {
|
|
@@ -166,7 +155,7 @@ const getGiphyTrends = (context, limit = 30) => {
|
|
|
166
155
|
const getGiphySearch = (context, query, limit = 30) => {
|
|
167
156
|
const formatQuery = encodeURI(query);
|
|
168
157
|
const gifUrl = `http://api.giphy.com/v1/gifs/search?q=${formatQuery}&api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
|
|
169
|
-
return fetch(gifUrl).then((res) => res.json()).then((json) => json
|
|
158
|
+
return fetch(gifUrl).then((res) => res.json()).then((json) => json?.data?.map((gifImage = { id: null, images: null }) => {
|
|
170
159
|
const {
|
|
171
160
|
id,
|
|
172
161
|
images: {
|
|
@@ -309,4 +298,4 @@ const decodeBase64 = (dataString) => {
|
|
|
309
298
|
linkFiles,
|
|
310
299
|
updateFiles
|
|
311
300
|
});
|
|
312
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/files.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 {get as httpGet} from '@nlabs/rip-hunter';\nimport {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {google} from 'googleapis';\nimport isEmpty from 'lodash/isEmpty';\n\nimport {Config} from '../config';\nimport {ApiContext} from '../types/auth';\nimport {FileType} from '../types/files';\nimport {UserError} from '../utils/analytics';\nimport {resizeSaveImage} from './images';\nimport {createPostEdge} from './posts';\n\nconst youtube = google.youtube({auth: Config.get('google.key'), version: 'v3'});\n\n// const eventCategory: string = 'files';\n\n// Upload file\nexport const addFile = (context: ApiContext, item: FileType = {}): Promise<FileType> => {\n  const {database, session: {userId: sessionId, userAccess}} = context;\n  const {\n    description,\n    fileId,\n    fileType,\n    name,\n    url\n  } = item;\n\n  // Id\n  const formatFileId: string = fileId ? parseId(fileId) : createHash(`file-${sessionId}`);\n\n  // Name\n  const isUrl: boolean = isEmpty(url);\n\n  // If no name, get it from url path\n  let formatName: string = parseString(name, 160);\n  let formatType: string = parseString(fileType, 16);\n\n  if(formatName === '' && isUrl) {\n    formatName = url.substring(url.lastIndexOf('/') + 1);\n  }\n\n  if(formatType === '') {\n    const nameArr: string[] = formatName.split('.');\n    const ext: string = nameArr[nameArr.length - 1];\n\n    switch(ext) {\n      case 'jpeg':\n      case 'jpg':\n        formatType = 'image/jpeg';\n        break;\n      case 'png':\n        formatType = 'image/png';\n        break;\n      case 'zip':\n        formatType = 'application/zip';\n        break;\n      default:\n        break;\n    }\n  }\n\n  let isImage: boolean;\n\n  switch(formatType) {\n    case 'image/jpeg':\n    case 'image/png':\n      isImage = true;\n      break;\n    default:\n      isImage = false;\n      break;\n  }\n\n  // Description\n  const formatDesc: string = parseString(description, 500);\n\n  // Only allow file uploads to premium users\n  if(!isImage && userAccess !== 2) {\n    throw new UserError('account_restriction');\n  }\n\n  const saveToDb = (insert: FileType) => {\n    const aqlQry: AqlQuery = aql`INSERT ${insert} IN files RETURN NEW`;\n\n    return database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((file = {}) => file)\n      .catch((error: Error) => {\n        throw error;\n      });\n  };\n\n  const uploadFile = (buf: Buffer, uploadType: string) => {\n    const now: number = Date.now();\n\n    // If image, resize and create a thumbnail\n    if(isImage) {\n      return resizeSaveImage(context, formatFileId, buf, uploadType)\n        .then((resizedImage: FileType) => {\n          const insert: FileType = {\n            ...resizedImage,\n            _key: formatFileId,\n            added: now,\n            description: formatDesc,\n            fileType: formatType,\n            modified: now,\n            name: formatName,\n            userId: sessionId\n          };\n\n          return saveToDb(insert);\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    }\n    const insert: FileType = {\n      _key: formatFileId,\n      added: now,\n      description: formatDesc,\n      fileType: formatType,\n      modified: now,\n      name: formatName,\n      userId: sessionId\n    };\n\n    return saveToDb(insert);\n  };\n\n  // If file is a url path, download the file and save\n  if(isUrl) {\n    return httpGet(url)\n      .then((body) => uploadFile(Buffer.from(body, 'binary'), formatType))\n      .catch(() => {\n        throw new UserError('file_request');\n      });\n  } else if(item.base64 !== '') {\n    const buffer: Buffer = Buffer.from(item.base64);\n    return uploadFile(buffer, formatType);\n  }\n  throw new Error('file_required');\n};\n\n// Giphy\nexport const getGiphyTrends = (context: ApiContext, limit: number = 30): Promise<any[]> => {\n  const gifUrl: string = `http://api.giphy.com/v1/gifs/trending?api_key=${Config.get('giphy.key')}&limit=${limit}`;\n\n  return httpGet(gifUrl)\n    .then((res: Response) => res.json())\n    .then((json) => json.data.map((gifImage = {id: null, images: null}) => {\n      const {\n        id,\n        images: {\n          original: {url = ''} = {},\n          fixed_height_small: {url: thumb = ''} = {}\n        } = {}\n      } = gifImage;\n\n      return {\n        id,\n        thumb,\n        type: 'giphy',\n        url\n      };\n    }));\n};\n\nexport const getGiphySearch = (context: ApiContext, query: string, limit: number = 30): Promise<any[]> => {\n  const formatQuery: string = encodeURI(query);\n  const gifUrl: string = `http://api.giphy.com/v1/gifs/search?q=${formatQuery}&api_key=${Config.get('giphy.key')}&limit=${limit}`;\n\n  return fetch(gifUrl)\n    .then((res: Response) => res.json())\n    .then((json) => json.data.map((gifImage = {id: null, images: null}) => {\n      const {\n        id,\n        images: {\n          original: {url = ''} = {},\n          fixed_height_small: {url: thumb = ''} = {}\n        } = {}\n      } = gifImage;\n\n      return {\n        id,\n        thumb,\n        type: 'giphy',\n        url\n      };\n    }));\n};\n\nexport const getYouTubeTrends = (context: ApiContext, limit: number = 30): Promise<any[]> =>\n  new Promise((resolve, reject) => {\n    youtube.videos.list({\n      chart: 'mostPopular',\n      maxResults: limit,\n      part: ['snippet'],\n      regionCode: 'US'\n    }, (error: Error, data: any) => {\n      if(error) {\n        console.error(error);\n        reject(new Error(error[0].message));\n      } else if(data) {\n        const list = data.items.map((item) => ({\n          id: item.id,\n          thumb: item.snippet.thumbnails.high.url,\n          type: 'youtube',\n          url: `http://www.youtube.com/embed/${item.id}`\n        }));\n\n        resolve(list);\n      }\n    });\n  });\n\n\nexport const getYouTubeSearch = (context: ApiContext, query: string, limit: number = 30): Promise<any[]> =>\n  new Promise((resolve, reject) => {\n    youtube.search.list({\n      maxResults: limit,\n      part: ['snippet'],\n      // eslint-disable-next-line\n      q: query,\n      regionCode: 'US'\n    }, (error: Error, data: any) => {\n      if(error) {\n        console.error(error);\n        reject(new Error(error[0].message));\n      } else if(data) {\n        const {items} = data;\n        const list = items.map((item) => ({\n          id: item.id,\n          thumb: item.snippet.thumbnails.high.url,\n          type: 'youtube',\n          url: `http://www.youtube.com/embed/${item.id}`\n        }));\n\n        resolve(list);\n      }\n    });\n  });\n\n// Files\nexport const getPathUserFiles = (userId: string, filename: string): string => `users/${userId}/files/${filename}`;\n\nexport const getUrlUserFiles = (userId: string, filename: string, dir: string = 'files', type: string = 'profile'): string => {\n  if(filename) {\n    return `https://box.${Config.get('app.url')}/users/${userId}/${dir}/${filename}`;\n  }\n\n  if(type === 'profile') {\n    return `https://box.${Config.get('app.url')}/defaults/user_bk.jpg`;\n  }\n\n  return `https://box.${Config.get('app.url')}/defaults/user_wh.jpg`;\n};\n\nexport const createFile = (db: Database, file: FileType): Promise<FileType> => {\n  const {fileId} = file;\n  const insert: any = {\n    _key: fileId,\n    added: Date.now()\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${fileId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN files RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedFile: FileType = {}) => updatedFile)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const linkFiles = (db: Database, files: FileType[], postId: string): Promise<any> =>\n  Promise.all(\n    files.map((file: FileType) => createFile(db, file)\n      .then((file: FileType) => createPostEdge(db, file, postId)))\n  );\n\nexport const updateFiles = (db: Database, postId: string, files: FileType[]): Promise<any> => {\n  const edgeCollection: EdgeCollection = db.collection('isPosted');\n\n  return edgeCollection.inEdges(postId, {})\n    .then((edges: any) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry: AqlQuery = aql`REMOVE {_key:${edgeKey}} IN isPosted`;\n\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(files.length) {\n              // Link files\n              return linkFiles(db, files, postId).then(() => files);\n            }\n            return files;\n          });\n      } else if(files.length) {\n        // Link files\n        return linkFiles(db, files, postId).then(() => files);\n      }\n      return files;\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const encodeBase64 = (buffer: Buffer): string => Buffer.from(buffer).toString('base64');\n\nexport const decodeBase64 = (dataString: string): object => {\n  const getData = (str: string) => str.match(/^data:([A-Za-z-+\\/]+);base64,(.+)$/) || [];\n  // const getData = (base64: string) => base64.substr(base64.indexOf(',') + 1);\n  let matches = getData(dataString);\n\n  if(matches.length !== 3) {\n    // If invalid make sure we don't need to decode\n    matches = getData(decodeURIComponent(dataString));\n\n    // Check it again.\n    if(matches.length !== 3) {\n      throw Error('Invalid input string');\n    }\n  }\n\n  return {\n    data: Buffer.from(matches[2], 'base64'),\n    type: matches[1]\n  };\n};\n"],
  "mappings": "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",
  "names": ["isEmpty", "insert", "httpGet", "file"]
}

|
|
301
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/files.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 {get as httpGet} from '@nlabs/rip-hunter';\nimport {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {google} from 'googleapis';\n\nimport {Config} from '../config';\nimport {ApiContext} from '../types/auth';\nimport {FileType} from '../types/files';\nimport {UserError} from '../utils/analytics';\nimport {resizeSaveImage} from './images';\nimport {createPostEdge} from './posts';\n\nconst youtube = google.youtube({auth: Config.get('google.key'), version: 'v3'});\n\n// const eventCategory: string = 'files';\n\n// Upload file\nexport const addFile = (context: ApiContext, item: FileType = {}): Promise<FileType> => {\n  const {database, session: {userId: sessionId, userAccess}} = context;\n  const {\n    description,\n    fileId,\n    fileType,\n    name,\n    url\n  } = item;\n\n  // Id\n  const formatFileId: string = fileId ? parseId(fileId) : createHash(`file-${sessionId}`);\n\n  // Name\n  const isUrl: boolean = !!url;\n\n  // If no name, get it from url path\n  let formatName: string = parseString(name, 160);\n  let formatType: string = parseString(fileType, 16);\n\n  if(formatName === '' && isUrl) {\n    formatName = url.substring(url.lastIndexOf('/') + 1);\n  }\n\n  if(formatType === '') {\n    const nameArr: string[] = formatName.split('.');\n    const ext: string = nameArr[nameArr.length - 1];\n\n    switch(ext) {\n      case 'jpeg':\n      case 'jpg':\n        formatType = 'image/jpeg';\n        break;\n      case 'png':\n        formatType = 'image/png';\n        break;\n      case 'zip':\n        formatType = 'application/zip';\n        break;\n      default:\n        break;\n    }\n  }\n\n  let isImage: boolean;\n\n  switch(formatType) {\n    case 'image/jpeg':\n    case 'image/png':\n      isImage = true;\n      break;\n    default:\n      isImage = false;\n      break;\n  }\n\n  // Description\n  const formatDesc: string = parseString(description, 500);\n\n  // Only allow file uploads to premium users\n  if(!isImage && userAccess !== 2) {\n    throw new UserError('account_restriction');\n  }\n\n  const saveToDb = (insert: FileType) => {\n    const aqlQry: AqlQuery = aql`INSERT ${insert} IN files RETURN NEW`;\n\n    return database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((file = {}) => file)\n      .catch((error: Error) => {\n        throw error;\n      });\n  };\n\n  const uploadFile = (buf: Buffer, uploadType: string) => {\n    const now: number = Date.now();\n\n    // If image, resize and create a thumbnail\n    if(isImage) {\n      return resizeSaveImage(context, formatFileId, buf, uploadType)\n        .then((resizedImage: FileType) => {\n          const insert: FileType = {\n            ...resizedImage,\n            _key: formatFileId,\n            added: now,\n            description: formatDesc,\n            fileType: formatType,\n            modified: now,\n            name: formatName,\n            userId: sessionId\n          };\n\n          return saveToDb(insert);\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    }\n    const insert: FileType = {\n      _key: formatFileId,\n      added: now,\n      description: formatDesc,\n      fileType: formatType,\n      modified: now,\n      name: formatName,\n      userId: sessionId\n    };\n\n    return saveToDb(insert);\n  };\n\n  // If file is a url path, download the file and save\n  if(isUrl) {\n    return httpGet(url)\n      .then((body) => uploadFile(Buffer.from(body, 'binary'), formatType))\n      .catch(() => {\n        throw new UserError('file_request');\n      });\n  } else if(item.base64 !== '') {\n    const buffer: Buffer = Buffer.from(item.base64);\n    return uploadFile(buffer, formatType);\n  }\n  throw new Error('file_required');\n};\n\n// Giphy\nexport const getGiphyTrends = (context: ApiContext, limit: number = 30): Promise<any[]> => {\n  const gifUrl = `http://api.giphy.com/v1/gifs/trending?api_key=${Config.get('giphy.key')}&limit=${limit}`;\n\n  return httpGet(gifUrl)\n    .then((res: Response) => res.json())\n    .then((json: any) => json?.data?.map((gifImage = {id: null, images: null}) => {\n      const {\n        id,\n        images: {\n          original: {url = ''} = {},\n          fixed_height_small: {url: thumb = ''} = {}\n        } = {}\n      } = gifImage;\n\n      return {\n        id,\n        thumb,\n        type: 'giphy',\n        url\n      };\n    }));\n};\n\nexport const getGiphySearch = (context: ApiContext, query: string, limit: number = 30): Promise<any[]> => {\n  const formatQuery = encodeURI(query);\n  const gifUrl = `http://api.giphy.com/v1/gifs/search?q=${formatQuery}&api_key=${Config.get('giphy.key')}&limit=${limit}`;\n\n  return fetch(gifUrl)\n    .then((res: Response) => res.json())\n    .then((json: any) => json?.data?.map((gifImage = {id: null, images: null}) => {\n      const {\n        id,\n        images: {\n          original: {url = ''} = {},\n          fixed_height_small: {url: thumb = ''} = {}\n        } = {}\n      } = gifImage;\n\n      return {\n        id,\n        thumb,\n        type: 'giphy',\n        url\n      };\n    }));\n};\n\nexport const getYouTubeTrends = (context: ApiContext, limit: number = 30): Promise<any[]> =>\n  new Promise((resolve, reject) => {\n    youtube.videos.list({\n      chart: 'mostPopular',\n      maxResults: limit,\n      part: ['snippet'],\n      regionCode: 'US'\n    }, (error: Error, data: any) => {\n      if(error) {\n        console.error(error);\n        reject(new Error(error[0].message));\n      } else if(data) {\n        const list = data.items.map((item) => ({\n          id: item.id,\n          thumb: item.snippet.thumbnails.high.url,\n          type: 'youtube',\n          url: `http://www.youtube.com/embed/${item.id}`\n        }));\n\n        resolve(list);\n      }\n    });\n  });\n\n\nexport const getYouTubeSearch = (context: ApiContext, query: string, limit: number = 30): Promise<any[]> =>\n  new Promise((resolve, reject) => {\n    youtube.search.list({\n      maxResults: limit,\n      part: ['snippet'],\n      // eslint-disable-next-line\n      q: query,\n      regionCode: 'US'\n    }, (error: Error, data: any) => {\n      if(error) {\n        console.error(error);\n        reject(new Error(error[0].message));\n      } else if(data) {\n        const {items} = data;\n        const list = items.map((item) => ({\n          id: item.id,\n          thumb: item.snippet.thumbnails.high.url,\n          type: 'youtube',\n          url: `http://www.youtube.com/embed/${item.id}`\n        }));\n\n        resolve(list);\n      }\n    });\n  });\n\n// Files\nexport const getPathUserFiles = (userId: string, filename: string): string => `users/${userId}/files/${filename}`;\n\nexport const getUrlUserFiles = (userId: string, filename: string, dir: string = 'files', type: string = 'profile'): string => {\n  if(filename) {\n    return `https://box.${Config.get('app.url')}/users/${userId}/${dir}/${filename}`;\n  }\n\n  if(type === 'profile') {\n    return `https://box.${Config.get('app.url')}/defaults/user_bk.jpg`;\n  }\n\n  return `https://box.${Config.get('app.url')}/defaults/user_wh.jpg`;\n};\n\nexport const createFile = (db: Database, file: FileType): Promise<FileType> => {\n  const {fileId} = file;\n  const insert: any = {\n    _key: fileId,\n    added: Date.now()\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${fileId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN files RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedFile: FileType = {}) => updatedFile)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const linkFiles = (db: Database, files: FileType[], postId: string): Promise<any> =>\n  Promise.all(\n    files.map((file: FileType) => createFile(db, file)\n      .then((file: FileType) => createPostEdge(db, file, postId)))\n  );\n\nexport const updateFiles = (db: Database, postId: string, files: FileType[]): Promise<any> => {\n  const edgeCollection: EdgeCollection = db.collection('isPosted');\n\n  return edgeCollection.inEdges(postId, {})\n    .then((edges: any) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry: AqlQuery = aql`REMOVE {_key:${edgeKey}} IN isPosted`;\n\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(files.length) {\n              // Link files\n              return linkFiles(db, files, postId).then(() => files);\n            }\n            return files;\n          });\n      } else if(files.length) {\n        // Link files\n        return linkFiles(db, files, postId).then(() => files);\n      }\n      return files;\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const encodeBase64 = (buffer: Buffer): string => Buffer.from(buffer).toString('base64');\n\nexport const decodeBase64 = (dataString: string): object => {\n  const getData = (str: string) => str.match(/^data:([A-Za-z-+\\/]+);base64,(.+)$/) || [];\n  // const getData = (base64: string) => base64.substr(base64.indexOf(',') + 1);\n  let matches = getData(dataString);\n\n  if(matches.length !== 3) {\n    // If invalid make sure we don't need to decode\n    matches = getData(decodeURIComponent(dataString));\n\n    // Check it again.\n    if(matches.length !== 3) {\n      throw Error('Invalid input string');\n    }\n  }\n\n  return {\n    data: Buffer.from(matches[2], 'base64'),\n    type: matches[1]\n  };\n};\n"],
  "mappings": "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",
  "names": ["insert", "httpGet", "file"]
}

|
package/lib/actions/images.d.ts
CHANGED
|
@@ -14,7 +14,7 @@ export declare const getImagesByReactions: (context: ApiContext, reactions?: str
|
|
|
14
14
|
export declare const getImage: (context: ApiContext, id: string) => Promise<ImageType>;
|
|
15
15
|
export declare const getPathUserImages: (userId: string, imageId: string, type: string, dir?: string) => string;
|
|
16
16
|
export declare const getAppImageUrl: (data: ImageUrlData) => string;
|
|
17
|
-
export declare const
|
|
17
|
+
export declare const getImageUrl: (data: ImageUrlData) => string;
|
|
18
18
|
export declare const resizeSaveImage: (context: ApiContext, imageId: string, buffer: Buffer, type?: string, s3Options?: PutObjectRequest) => Promise<ImageType>;
|
|
19
19
|
export declare const addImage: (context: ApiContext, image: ImageType, s3Options?: PutObjectRequest) => Promise<ImageType>;
|
|
20
20
|
export declare const addImageEdge: (context: ApiContext, imageEdge: ImageEdgeType) => Promise<object>;
|