@nlabs/reaktor 0.1.4 → 0.1.6
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/data/conversations.js +6 -5
- package/lib/data/files.d.ts +1 -1
- package/lib/data/files.js +40 -40
- package/lib/data/groups.d.ts +1 -1
- package/lib/data/groups.js +26 -26
- package/lib/data/images.d.ts +14 -7
- package/lib/data/images.js +438 -332
- package/lib/data/ios.js +1 -1
- package/lib/data/messages.js +27 -27
- package/lib/data/posts.js +5 -4
- package/lib/data/reactions.js +1 -1
- package/lib/data/s3.js +1 -1
- package/lib/data/subscription.js +1 -1
- package/lib/data/tags.d.ts +1 -1
- package/lib/data/tags.js +36 -36
- package/lib/data/users.d.ts +2 -0
- package/lib/data/users.js +63 -6
- package/lib/types/auth.d.ts +1 -0
- package/lib/types/files.d.ts +2 -2
- package/lib/types/images.d.ts +16 -2
- package/lib/utils/auth.js +11 -3
- package/package.json +5 -4
|
@@ -34,10 +34,6 @@ function _templateObject() {
|
|
|
34
34
|
|
|
35
35
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
36
36
|
|
|
37
|
-
/**
|
|
38
|
-
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
39
|
-
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
40
|
-
*/
|
|
41
37
|
import { createHash, parseId } from '@nlabs/utils';
|
|
42
38
|
import { aql } from 'arangojs';
|
|
43
39
|
import cloneDeep from 'lodash/cloneDeep';
|
|
@@ -48,6 +44,11 @@ import { getLimit, useDb } from '../utils';
|
|
|
48
44
|
import { logError } from '../utils/analytics';
|
|
49
45
|
import { getUrlImages } from './images';
|
|
50
46
|
import { getDisplayName } from './users';
|
|
47
|
+
/**
|
|
48
|
+
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
49
|
+
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
50
|
+
*/
|
|
51
|
+
|
|
51
52
|
var eventCategory = 'conversations';
|
|
52
53
|
export var getConversationList = function getConversationList(context, from, to) {
|
|
53
54
|
var action = 'getList';
|
|
@@ -194,4 +195,4 @@ export var updateConversation = function updateConversation(context, item) {
|
|
|
194
195
|
});
|
|
195
196
|
});
|
|
196
197
|
};
|
|
197
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/conversations.ts"],"names":["createHash","parseId","aql","cloneDeep","identity","isEmpty","pick","getLimit","useDb","logError","getUrlImages","getDisplayName","eventCategory","getConversationList","context","from","to","action","database","sessionId","userId","limit","aqlQry","query","then","cursor","all","catch","error","category","label","getDirectConversation","formatUserId","next","conversation","users","length","map","user","userKey","_key","imgId","thumbUrlData","directory","isThumb","type","typeId","name","thumb","getConversation","convoId","formatConvoId","updateConversation","item","direct","id","rcpt","formatId","join","now","Date","update","undefined","modified","insert","added"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport identity from 'lodash/identity';\nimport isEmpty from 'lodash/isEmpty';\nimport pick from 'lodash/pick';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUrlImages} from './images';\nimport {getDisplayName} from './users';\n\nconst eventCategory: string = 'conversations';\n\nexport const getConversationList = (context: ApiContext, from: number, to: number): Promise<ConversationType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR c IN conversations\n    FILTER POSITION(c.users, \"${sessionId}\", false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    ${limit.aql}\n    RETURN {_key:c._key, name: c.name, direct: c.direct, users: u}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirect';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER LENGTH(c.users) == 2 &&\n    POSITION(c.users, ${sessionId}, false) &&\n    POSITION(c.users, ${formatUserId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR user IN users\n      FILTER user._key == g\n      RETURN user\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      const {users = []} = conversation;\n\n      if(users.length) {\n        conversation.users = users.map((user: UserType) => {\n          const {_key: userKey, imgId} = user;\n          const thumbUrlData: ImageUrlData = {\n            directory: 'images',\n            imgId,\n            isThumb: true,\n            type: 'users',\n            typeId: userKey\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUrlImages(thumbUrlData)\n          };\n        });\n      }\n\n      return conversation;\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER ${formatConvoId} == c._key && IS_LIST(c.users) && POSITION(c.users, ${sessionId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {_key: userKey, imgId} = user;\n          const thumbUrlData: ImageUrlData = {\n            directory: 'images',\n            imgId,\n            isThumb: true,\n            type: 'users',\n            typeId: userKey\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUrlImages(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, item): Promise<ConversationType> => {\n  const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const {direct, id, name, users} = pick(item, identity);\n  const rcpt: UserType[] = users || [];\n  const formatId: string = item.id || createHash(`convo-${sessionId}-${rcpt.join('')}`);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct: !!direct ? direct : undefined,\n    modified: now,\n    name: !!name ? name : undefined,\n    // Users\n    users: !!users ? users : undefined\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${id}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
|
198
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/conversations.ts"],"names":["createHash","parseId","aql","cloneDeep","identity","isEmpty","pick","getLimit","useDb","logError","getUrlImages","getDisplayName","eventCategory","getConversationList","context","from","to","action","database","sessionId","userId","limit","aqlQry","query","then","cursor","all","catch","error","category","label","getDirectConversation","formatUserId","next","conversation","users","length","map","user","userKey","_key","imgId","thumbUrlData","directory","isThumb","type","typeId","name","thumb","getConversation","convoId","formatConvoId","updateConversation","item","direct","id","rcpt","formatId","join","now","Date","update","undefined","modified","insert","added"],"mappings":"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","sourcesContent":["import {createHash, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport identity from 'lodash/identity';\nimport isEmpty from 'lodash/isEmpty';\nimport pick from 'lodash/pick';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUrlImages} from './images';\nimport {getDisplayName} from './users';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nconst eventCategory: string = 'conversations';\n\nexport const getConversationList = (context: ApiContext, from: number, to: number): Promise<ConversationType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR c IN conversations\n    FILTER POSITION(c.users, \"${sessionId}\", false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    ${limit.aql}\n    RETURN {_key:c._key, name: c.name, direct: c.direct, users: u}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirect';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER LENGTH(c.users) == 2 &&\n    POSITION(c.users, ${sessionId}, false) &&\n    POSITION(c.users, ${formatUserId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR user IN users\n      FILTER user._key == g\n      RETURN user\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      const {users = []} = conversation;\n\n      if(users.length) {\n        conversation.users = users.map((user: UserType) => {\n          const {_key: userKey, imgId} = user;\n          const thumbUrlData: ImageUrlData = {\n            directory: 'images',\n            imgId,\n            isThumb: true,\n            type: 'users',\n            typeId: userKey\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUrlImages(thumbUrlData)\n          };\n        });\n      }\n\n      return conversation;\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER ${formatConvoId} == c._key && IS_LIST(c.users) && POSITION(c.users, ${sessionId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {_key: userKey, imgId} = user;\n          const thumbUrlData: ImageUrlData = {\n            directory: 'images',\n            imgId,\n            isThumb: true,\n            type: 'users',\n            typeId: userKey\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUrlImages(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, item): Promise<ConversationType> => {\n  const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const {direct, id, name, users} = pick(item, identity);\n  const rcpt: UserType[] = users || [];\n  const formatId: string = item.id || createHash(`convo-${sessionId}-${rcpt.join('')}`);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct: !!direct ? direct : undefined,\n    modified: now,\n    name: !!name ? name : undefined,\n    // Users\n    users: !!users ? users : undefined\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${id}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
package/lib/data/files.d.ts
CHANGED
|
@@ -9,8 +9,8 @@ export declare const getYouTubeTrends: (context: ApiContext, limit?: number) =>
|
|
|
9
9
|
export declare const getYouTubeSearch: (context: ApiContext, query: string, limit?: number) => Promise<any[]>;
|
|
10
10
|
export declare const getPathUserFiles: (userId: string, filename: string) => string;
|
|
11
11
|
export declare const getUrlUserFiles: (userId: string, filename: string, dir?: string, type?: string) => string;
|
|
12
|
+
export declare const createFile: (db: Database, file: FileType) => Promise<FileType>;
|
|
12
13
|
export declare const linkFiles: (db: Database, files: FileType[], postId: string) => Promise<any>;
|
|
13
14
|
export declare const updateFiles: (db: Database, postId: string, files: FileType[]) => Promise<any>;
|
|
14
|
-
export declare const createFile: (db: Database, file: FileType) => Promise<FileType>;
|
|
15
15
|
export declare const encodeBase64: (buffer: Buffer) => string;
|
|
16
16
|
export declare const decodeBase64: (dataString: string) => object;
|
package/lib/data/files.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
function _templateObject3() {
|
|
2
|
-
var data = _taggedTemplateLiteral(["
|
|
2
|
+
var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isPosted"]);
|
|
3
3
|
|
|
4
4
|
_templateObject3 = function _templateObject3() {
|
|
5
5
|
return data;
|
|
@@ -9,7 +9,7 @@ function _templateObject3() {
|
|
|
9
9
|
}
|
|
10
10
|
|
|
11
11
|
function _templateObject2() {
|
|
12
|
-
var data = _taggedTemplateLiteral(["
|
|
12
|
+
var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE {}\n IN files RETURN NEW"]);
|
|
13
13
|
|
|
14
14
|
_templateObject2 = function _templateObject2() {
|
|
15
15
|
return data;
|
|
@@ -34,20 +34,22 @@ function _templateObject() {
|
|
|
34
34
|
|
|
35
35
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
36
36
|
|
|
37
|
-
/**
|
|
38
|
-
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
39
|
-
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
40
|
-
*/
|
|
41
37
|
import { get as httpGet } from '@nlabs/rip-hunter';
|
|
42
38
|
import { createHash, parseId, parseString } from '@nlabs/utils';
|
|
43
39
|
import { aql } from 'arangojs';
|
|
44
40
|
import { google } from 'googleapis';
|
|
45
41
|
import { UserError } from 'graphql-errors';
|
|
42
|
+
import isEmpty from 'lodash/isEmpty';
|
|
46
43
|
import * as request from 'request-promise';
|
|
47
44
|
import { Config } from '../config';
|
|
48
45
|
import { useDb } from '../utils';
|
|
49
46
|
import { resizeSaveImage } from './images';
|
|
50
47
|
import { createPostEdge } from './posts';
|
|
48
|
+
/**
|
|
49
|
+
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
50
|
+
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
51
|
+
*/
|
|
52
|
+
|
|
51
53
|
var youtube = google.youtube({
|
|
52
54
|
auth: Config.get('google.key'),
|
|
53
55
|
version: 'v3'
|
|
@@ -62,19 +64,15 @@ export var addFile = function addFile(context) {
|
|
|
62
64
|
var database = context.database,
|
|
63
65
|
sessionId = context.userId,
|
|
64
66
|
userType = context.userType;
|
|
65
|
-
var
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
_item$name = item.name,
|
|
71
|
-
name = _item$name === void 0 ? '' : _item$name,
|
|
72
|
-
_item$url = item.url,
|
|
73
|
-
url = _item$url === void 0 ? '' : _item$url; // Id
|
|
67
|
+
var description = item.description,
|
|
68
|
+
fileId = item.fileId,
|
|
69
|
+
fileType = item.fileType,
|
|
70
|
+
name = item.name,
|
|
71
|
+
url = item.url; // Id
|
|
74
72
|
|
|
75
|
-
var
|
|
73
|
+
var formatFileId = fileId ? parseId(fileId) : createHash("file-".concat(sessionId)); // Name
|
|
76
74
|
|
|
77
|
-
var isUrl = url
|
|
75
|
+
var isUrl = isEmpty(url); // If no name, get it from url path
|
|
78
76
|
|
|
79
77
|
var formatName = parseString(name, 160);
|
|
80
78
|
var formatType = parseString(fileType, 16);
|
|
@@ -142,9 +140,9 @@ export var addFile = function addFile(context) {
|
|
|
142
140
|
var now = Date.now(); // If image, resize and create a thumbnail
|
|
143
141
|
|
|
144
142
|
if (isImage) {
|
|
145
|
-
return resizeSaveImage(
|
|
143
|
+
return resizeSaveImage(context, formatFileId, buf, uploadType).then(function (resizedImage) {
|
|
146
144
|
var insert = _objectSpread({}, resizedImage, {
|
|
147
|
-
_key:
|
|
145
|
+
_key: formatFileId,
|
|
148
146
|
added: now,
|
|
149
147
|
description: formatDesc,
|
|
150
148
|
fileType: formatType,
|
|
@@ -160,7 +158,7 @@ export var addFile = function addFile(context) {
|
|
|
160
158
|
}
|
|
161
159
|
|
|
162
160
|
var insert = {
|
|
163
|
-
_key:
|
|
161
|
+
_key: formatFileId,
|
|
164
162
|
added: now,
|
|
165
163
|
description: formatDesc,
|
|
166
164
|
fileType: formatType,
|
|
@@ -284,6 +282,7 @@ export var getYouTubeSearch = function getYouTubeSearch(context, query) {
|
|
|
284
282
|
youtube.search.list({
|
|
285
283
|
maxResults: limit,
|
|
286
284
|
part: 'snippet',
|
|
285
|
+
// eslint-disable-next-line
|
|
287
286
|
q: query,
|
|
288
287
|
regionCode: 'US'
|
|
289
288
|
}, function (error, data) {
|
|
@@ -323,6 +322,22 @@ export var getUrlUserFiles = function getUrlUserFiles(userId, filename) {
|
|
|
323
322
|
|
|
324
323
|
return "https://box.".concat(Config.get('app.url'), "/defaults/user_wh.jpg");
|
|
325
324
|
};
|
|
325
|
+
export var createFile = function createFile(db, file) {
|
|
326
|
+
var fileId = file.fileId;
|
|
327
|
+
var insert = {
|
|
328
|
+
_key: fileId,
|
|
329
|
+
added: Date.now()
|
|
330
|
+
};
|
|
331
|
+
var aqlQry = aql(_templateObject2(), fileId, insert);
|
|
332
|
+
return db.query(aqlQry).then(function (cursor) {
|
|
333
|
+
return cursor.next();
|
|
334
|
+
}).then(function () {
|
|
335
|
+
var updatedFile = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
336
|
+
return updatedFile;
|
|
337
|
+
}).catch(function (error) {
|
|
338
|
+
throw error;
|
|
339
|
+
});
|
|
340
|
+
};
|
|
326
341
|
export var linkFiles = function linkFiles(db, files, postId) {
|
|
327
342
|
return Promise.all(files.map(function (file) {
|
|
328
343
|
return createFile(db, file).then(function (file) {
|
|
@@ -337,7 +352,7 @@ export var updateFiles = function updateFiles(db, postId, files) {
|
|
|
337
352
|
// Remove linked edges
|
|
338
353
|
return Promise.all(edges.map(function (edge) {
|
|
339
354
|
var edgeKey = edge._key;
|
|
340
|
-
var aqlQry = aql(
|
|
355
|
+
var aqlQry = aql(_templateObject3(), edgeKey);
|
|
341
356
|
return db.query(aqlQry).catch(function (error) {
|
|
342
357
|
throw error;
|
|
343
358
|
});
|
|
@@ -363,29 +378,14 @@ export var updateFiles = function updateFiles(db, postId, files) {
|
|
|
363
378
|
throw error;
|
|
364
379
|
});
|
|
365
380
|
};
|
|
366
|
-
export var createFile = function createFile(db, file) {
|
|
367
|
-
var insert = {
|
|
368
|
-
_key: file.id,
|
|
369
|
-
added: Date.now()
|
|
370
|
-
};
|
|
371
|
-
var aqlQry = aql(_templateObject3(), file.id, insert);
|
|
372
|
-
return db.query(aqlQry).then(function (cursor) {
|
|
373
|
-
return cursor.next();
|
|
374
|
-
}).then(function () {
|
|
375
|
-
var updatedFile = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
376
|
-
return updatedFile;
|
|
377
|
-
}).catch(function (error) {
|
|
378
|
-
throw error;
|
|
379
|
-
});
|
|
380
|
-
};
|
|
381
381
|
export var encodeBase64 = function encodeBase64(buffer) {
|
|
382
382
|
return new Buffer(buffer).toString('base64');
|
|
383
383
|
};
|
|
384
384
|
export var decodeBase64 = function decodeBase64(dataString) {
|
|
385
|
-
// const getData = (str: string) => str.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/) || [];
|
|
386
385
|
var getData = function getData(str) {
|
|
387
|
-
return str.match(/^data:([A-Za-z
|
|
388
|
-
};
|
|
386
|
+
return str.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/) || [];
|
|
387
|
+
}; // const getData = (base64: string) => base64.substr(base64.indexOf(',') + 1);
|
|
388
|
+
|
|
389
389
|
|
|
390
390
|
var matches = getData(dataString);
|
|
391
391
|
|
|
@@ -403,4 +403,4 @@ export var decodeBase64 = function decodeBase64(dataString) {
|
|
|
403
403
|
type: matches[1]
|
|
404
404
|
};
|
|
405
405
|
};
|
|
406
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/files.ts"],"names":["get","httpGet","createHash","parseId","parseString","aql","google","UserError","request","Config","useDb","resizeSaveImage","createPostEdge","youtube","auth","version","defaults","encoding","addFile","context","item","database","sessionId","userId","userType","description","fileType","id","name","url","fileId","isUrl","formatName","formatType","substring","lastIndexOf","nameArr","split","ext","length","isImage","formatDesc","saveToDb","insert","aqlQry","query","then","cursor","next","file","catch","error","uploadFile","buf","uploadType","now","Date","resizedImage","_key","added","modified","uri","body","Buffer","base64","buffer","Error","getGiphyTrends","limit","gifUrl","res","json","data","map","gifImage","images","original","fixed_height_small","thumb","type","getGiphySearch","formatQuery","encodeURI","fetch","getYouTubeTrends","Promise","resolve","reject","videos","list","chart","maxResults","part","regionCode","console","message","items","snippet","thumbnails","high","getYouTubeSearch","search","q","getPathUserFiles","filename","getUrlUserFiles","dir","linkFiles","db","files","postId","all","createFile","updateFiles","edgeCollection","inEdges","edges","edge","edgeKey","updatedFile","encodeBase64","toString","decodeBase64","dataString","getData","str","match","matches","decodeURIComponent"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {get as httpGet} from '@nlabs/rip-hunter';\nimport {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport {google} from 'googleapis';\nimport {UserError} from 'graphql-errors';\nimport * as request from 'request-promise';\nimport {ApiContext} from 'types/auth';\n\nimport {Config} from '../config';\nimport {FileType} from '../types/files';\nimport {useDb} from '../utils';\nimport {resizeSaveImage} from './images';\nimport {createPostEdge} from './posts';\n\nconst youtube = google.youtube({auth: Config.get('google.key'), version: 'v3'});\nrequest.defaults({encoding: null});\n\n// const eventCategory: string = 'files';\n\n// Upload file\nexport const addFile = (context: ApiContext, item: FileType = {}): Promise<FileType> => {\n  const {database, userId: sessionId, userType} = context;\n  const {\n    description = '',\n    fileType = '',\n    id,\n    name = '',\n    url = ''\n  } = item;\n\n  // Id\n  const fileId: string = id ? parseId(id) : 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 && userType !== 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 useDb(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(sessionId, fileId, buf, uploadType)\n        .then((resizedImage: FileType) => {\n          const insert: FileType = {\n            ...resizedImage,\n            _key: fileId,\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: fileId,\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 request.get({encoding: null, uri: url})\n      .then((body) => uploadFile(new Buffer(body, 'binary'), formatType))\n      .catch(() => {\n        throw new UserError('file_request');\n      });\n  } else if(item.base64 !== '') {\n    const buffer: Buffer = new Buffer(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  return 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  return new Promise((resolve, reject) => {\n    youtube.search.list({\n      maxResults: limit,\n      part: 'snippet',\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\n// Files\nexport const getPathUserFiles = (userId: string, filename: string): string => {\n  return `users/${userId}/files/${filename}`;\n};\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 linkFiles = (db: Database, files: FileType[], postId: string): Promise<any> => {\n  return Promise.all(\n    files.map((file: FileType) => createFile(db, file)\n      .then((file: FileType) => createPostEdge(db, file, postId)))\n  );\n};\n\nexport const updateFiles = (db: Database, postId: string, files: FileType[]): Promise<any> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n\n  return edgeCollection.inEdges(postId)\n    .then((edges) => {\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 createFile = (db: Database, file: FileType): Promise<FileType> => {\n  const insert: any = {\n    _key: file.id,\n    added: Date.now()\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${file.id}}\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 encodeBase64 = (buffer: Buffer): string => {\n  return new Buffer(buffer).toString('base64');\n}\n\nexport const decodeBase64 = (dataString: string): object => {\n  // const getData = (str: string) => str.match(/^data:([A-Za-z-+\\/]+);base64,(.+)$/) || [];\n  const getData = (str: string) => str.match(/^data:([A-Za-z-+/]+);base64,(.+)$/) || [];\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: new Buffer(matches[2], 'base64'),\n    type: matches[1]\n  };\n};\n"]}
|
|
406
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/files.ts"],"names":["get","httpGet","createHash","parseId","parseString","aql","google","UserError","isEmpty","request","Config","useDb","resizeSaveImage","createPostEdge","youtube","auth","version","defaults","encoding","addFile","context","item","database","sessionId","userId","userType","description","fileId","fileType","name","url","formatFileId","isUrl","formatName","formatType","substring","lastIndexOf","nameArr","split","ext","length","isImage","formatDesc","saveToDb","insert","aqlQry","query","then","cursor","next","file","catch","error","uploadFile","buf","uploadType","now","Date","resizedImage","_key","added","modified","uri","body","Buffer","base64","buffer","Error","getGiphyTrends","limit","gifUrl","res","json","data","map","gifImage","id","images","original","fixed_height_small","thumb","type","getGiphySearch","formatQuery","encodeURI","fetch","getYouTubeTrends","Promise","resolve","reject","videos","list","chart","maxResults","part","regionCode","console","message","items","snippet","thumbnails","high","getYouTubeSearch","search","q","getPathUserFiles","filename","getUrlUserFiles","dir","createFile","db","updatedFile","linkFiles","files","postId","all","updateFiles","edgeCollection","inEdges","edges","edge","edgeKey","encodeBase64","toString","decodeBase64","dataString","getData","str","match","matches","decodeURIComponent"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAQA,GAAG,IAAIC,OAAf,QAA6B,mBAA7B;AACA,SAAQC,UAAR,EAAoBC,OAApB,EAA6BC,WAA7B,QAA+C,cAA/C;AACA,SAAQC,GAAR,QAA4B,UAA5B;AAGA,SAAQC,MAAR,QAAqB,YAArB;AACA,SAAQC,SAAR,QAAwB,gBAAxB;AACA,OAAOC,OAAP,MAAoB,gBAApB;AACA,OAAO,KAAKC,OAAZ,MAAyB,iBAAzB;AAGA,SAAQC,MAAR,QAAqB,WAArB;AAEA,SAAQC,KAAR,QAAoB,UAApB;AACA,SAAQC,eAAR,QAA8B,UAA9B;AACA,SAAQC,cAAR,QAA6B,SAA7B;AAEA;;;;;AAIA,IAAMC,OAAO,GAAGR,MAAM,CAACQ,OAAP,CAAe;AAACC,EAAAA,IAAI,EAAEL,MAAM,CAACV,GAAP,CAAW,YAAX,CAAP;AAAiCgB,EAAAA,OAAO,EAAE;AAA1C,CAAf,CAAhB;AACAP,OAAO,CAACQ,QAAR,CAAiB;AAACC,EAAAA,QAAQ,EAAE;AAAX,CAAjB,E,CAEA;AAEA;;AACA,OAAO,IAAMC,OAAO,GAAG,SAAVA,OAAU,CAACC,OAAD,EAAiE;AAAA,MAA3CC,IAA2C,uEAA1B,EAA0B;AAAA,MAC/EC,QAD+E,GACtCF,OADsC,CAC/EE,QAD+E;AAAA,MAC7DC,SAD6D,GACtCH,OADsC,CACrEI,MADqE;AAAA,MAClDC,QADkD,GACtCL,OADsC,CAClDK,QADkD;AAAA,MAGpFC,WAHoF,GAQlFL,IARkF,CAGpFK,WAHoF;AAAA,MAIpFC,MAJoF,GAQlFN,IARkF,CAIpFM,MAJoF;AAAA,MAKpFC,QALoF,GAQlFP,IARkF,CAKpFO,QALoF;AAAA,MAMpFC,IANoF,GAQlFR,IARkF,CAMpFQ,IANoF;AAAA,MAOpFC,GAPoF,GAQlFT,IARkF,CAOpFS,GAPoF,EAUtF;;AACA,MAAMC,YAAoB,GAAGJ,MAAM,GAAGxB,OAAO,CAACwB,MAAD,CAAV,GAAqBzB,UAAU,gBAASqB,SAAT,EAAlE,CAXsF,CAatF;;AACA,MAAMS,KAAc,GAAGxB,OAAO,CAACsB,GAAD,CAA9B,CAdsF,CAgBtF;;AACA,MAAIG,UAAkB,GAAG7B,WAAW,CAACyB,IAAD,EAAO,GAAP,CAApC;AACA,MAAIK,UAAkB,GAAG9B,WAAW,CAACwB,QAAD,EAAW,EAAX,CAApC;;AAEA,MAAGK,UAAU,KAAK,EAAf,IAAqBD,KAAxB,EAA+B;AAC7BC,IAAAA,UAAU,GAAGH,GAAG,CAACK,SAAJ,CAAcL,GAAG,CAACM,WAAJ,CAAgB,GAAhB,IAAuB,CAArC,CAAb;AACD;;AAED,MAAGF,UAAU,KAAK,EAAlB,EAAsB;AACpB,QAAMG,OAAiB,GAAGJ,UAAU,CAACK,KAAX,CAAiB,GAAjB,CAA1B;AACA,QAAMC,GAAW,GAAGF,OAAO,CAACA,OAAO,CAACG,MAAR,GAAiB,CAAlB,CAA3B;;AAEA,YAAOD,GAAP;AACE,WAAK,MAAL;AACA,WAAK,KAAL;AACEL,QAAAA,UAAU,GAAG,YAAb;AACA;;AACF,WAAK,KAAL;AACEA,QAAAA,UAAU,GAAG,WAAb;AACA;;AACF,WAAK,KAAL;AACEA,QAAAA,UAAU,GAAG,iBAAb;AACA;;AACF;AACE;AAZJ;AAcD;;AAED,MAAIO,OAAJ;;AAEA,UAAOP,UAAP;AACE,SAAK,YAAL;AACA,SAAK,WAAL;AACEO,MAAAA,OAAO,GAAG,IAAV;AACA;;AACF;AACEA,MAAAA,OAAO,GAAG,KAAV;AACA;AAPJ,GA9CsF,CAwDtF;;;AACA,MAAMC,UAAkB,GAAGtC,WAAW,CAACsB,WAAD,EAAc,GAAd,CAAtC,CAzDsF,CA2DtF;;AACA,MAAG,CAACe,OAAD,IAAYhB,QAAQ,KAAK,CAA5B,EAA+B;AAC7B,UAAM,IAAIlB,SAAJ,CAAc,qBAAd,CAAN;AACD;;AAED,MAAMoC,QAAQ,GAAG,SAAXA,QAAW,CAACC,MAAD,EAAsB;AACrC,QAAMC,MAAgB,GAAGxC,GAAH,oBAAgBuC,MAAhB,CAAtB;AAEA,WAAOjC,KAAK,CAACW,QAAD,CAAL,CAAgBwB,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,aAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,KADD,EAEJF,IAFI,CAEC;AAAA,UAACG,IAAD,uEAAQ,EAAR;AAAA,aAAeA,IAAf;AAAA,KAFD,EAGJC,KAHI,CAGE,UAACC,KAAD,EAAkB;AACvB,YAAMA,KAAN;AACD,KALI,CAAP;AAMD,GATD;;AAWA,MAAMC,UAAU,GAAG,SAAbA,UAAa,CAACC,GAAD,EAAcC,UAAd,EAAqC;AACtD,QAAMC,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB,CADsD,CAGtD;;AACA,QAAGf,OAAH,EAAY;AACV,aAAO7B,eAAe,CAACQ,OAAD,EAAUW,YAAV,EAAwBuB,GAAxB,EAA6BC,UAA7B,CAAf,CACJR,IADI,CACC,UAACW,YAAD,EAA4B;AAChC,YAAMd,MAAgB,qBACjBc,YADiB;AAEpBC,UAAAA,IAAI,EAAE5B,YAFc;AAGpB6B,UAAAA,KAAK,EAAEJ,GAHa;AAIpB9B,UAAAA,WAAW,EAAEgB,UAJO;AAKpBd,UAAAA,QAAQ,EAAEM,UALU;AAMpB2B,UAAAA,QAAQ,EAAEL,GANU;AAOpB3B,UAAAA,IAAI,EAAEI,UAPc;AAQpBT,UAAAA,MAAM,EAAED;AARY,UAAtB;;AAWA,eAAOoB,QAAQ,CAACC,MAAD,CAAf;AACD,OAdI,EAeJO,KAfI,CAeE,UAACC,KAAD,EAAkB;AACvB,cAAMA,KAAN;AACD,OAjBI,CAAP;AAkBD;;AACD,QAAMR,MAAgB,GAAG;AACvBe,MAAAA,IAAI,EAAE5B,YADiB;AAEvB6B,MAAAA,KAAK,EAAEJ,GAFgB;AAGvB9B,MAAAA,WAAW,EAAEgB,UAHU;AAIvBd,MAAAA,QAAQ,EAAEM,UAJa;AAKvB2B,MAAAA,QAAQ,EAAEL,GALa;AAMvB3B,MAAAA,IAAI,EAAEI,UANiB;AAOvBT,MAAAA,MAAM,EAAED;AAPe,KAAzB;AAUA,WAAOoB,QAAQ,CAACC,MAAD,CAAf;AACD,GAnCD,CA3EsF,CAgHtF;;;AACA,MAAGZ,KAAH,EAAU;AACR,WAAOvB,OAAO,CAACT,GAAR,CAAY;AAACkB,MAAAA,QAAQ,EAAE,IAAX;AAAiB4C,MAAAA,GAAG,EAAEhC;AAAtB,KAAZ,EACJiB,IADI,CACC,UAACgB,IAAD;AAAA,aAAUV,UAAU,CAAC,IAAIW,MAAJ,CAAWD,IAAX,EAAiB,QAAjB,CAAD,EAA6B7B,UAA7B,CAApB;AAAA,KADD,EAEJiB,KAFI,CAEE,YAAM;AACX,YAAM,IAAI5C,SAAJ,CAAc,cAAd,CAAN;AACD,KAJI,CAAP;AAKD,GAND,MAMO,IAAGc,IAAI,CAAC4C,MAAL,KAAgB,EAAnB,EAAuB;AAC5B,QAAMC,MAAc,GAAG,IAAIF,MAAJ,CAAW3C,IAAI,CAAC4C,MAAhB,CAAvB;AACA,WAAOZ,UAAU,CAACa,MAAD,EAAShC,UAAT,CAAjB;AACD;;AACD,QAAM,IAAIiC,KAAJ,CAAU,eAAV,CAAN;AACD,CA5HM,C,CA8HP;;AACA,OAAO,IAAMC,cAAc,GAAG,SAAjBA,cAAiB,CAAChD,OAAD,EAA6D;AAAA,MAAvCiD,KAAuC,uEAAvB,EAAuB;AACzF,MAAMC,MAAc,2DAAoD5D,MAAM,CAACV,GAAP,CAAW,WAAX,CAApD,oBAAqFqE,KAArF,CAApB;AAEA,SAAOpE,OAAO,CAACqE,MAAD,CAAP,CACJvB,IADI,CACC,UAACwB,GAAD;AAAA,WAAmBA,GAAG,CAACC,IAAJ,EAAnB;AAAA,GADD,EAEJzB,IAFI,CAEC,UAACyB,IAAD;AAAA,WAAUA,IAAI,CAACC,IAAL,CAAUC,GAAV,CAAc,YAAyC;AAAA,UAAxCC,QAAwC,uEAA7B;AAACC,QAAAA,EAAE,EAAE,IAAL;AAAWC,QAAAA,MAAM,EAAE;AAAnB,OAA6B;AAAA,UAEnED,EAFmE,GAOjED,QAPiE,CAEnEC,EAFmE;AAAA,6BAOjED,QAPiE,CAGnEE,MAHmE;AAAA,uDAM/D,EAN+D;AAAA,mDAIjEC,QAJiE;AAAA,iEAI1C,EAJ0C;AAAA,yDAItDhD,GAJsD;AAAA,UAItDA,GAJsD,uCAIhD,EAJgD;AAAA,mDAKjEiD,kBALiE;AAAA,iEAKzB,EALyB;AAAA,yDAK5CjD,GAL4C;AAAA,UAKvCkD,KALuC,uCAK/B,EAL+B;AASrE,aAAO;AACLJ,QAAAA,EAAE,EAAFA,EADK;AAELI,QAAAA,KAAK,EAALA,KAFK;AAGLC,QAAAA,IAAI,EAAE,OAHD;AAILnD,QAAAA,GAAG,EAAHA;AAJK,OAAP;AAMD,KAfe,CAAV;AAAA,GAFD,CAAP;AAkBD,CArBM;AAuBP,OAAO,IAAMoD,cAAc,GAAG,SAAjBA,cAAiB,CAAC9D,OAAD,EAAsB0B,KAAtB,EAA4E;AAAA,MAAvCuB,KAAuC,uEAAvB,EAAuB;AACxG,MAAMc,WAAmB,GAAGC,SAAS,CAACtC,KAAD,CAArC;AACA,MAAMwB,MAAc,mDAA4Ca,WAA5C,sBAAmEzE,MAAM,CAACV,GAAP,CAAW,WAAX,CAAnE,oBAAoGqE,KAApG,CAApB;AAEA,SAAOgB,KAAK,CAACf,MAAD,CAAL,CACJvB,IADI,CACC,UAACwB,GAAD;AAAA,WAAmBA,GAAG,CAACC,IAAJ,EAAnB;AAAA,GADD,EAEJzB,IAFI,CAEC,UAACyB,IAAD;AAAA,WAAUA,IAAI,CAACC,IAAL,CAAUC,GAAV,CAAc,YAAyC;AAAA,UAAxCC,QAAwC,uEAA7B;AAACC,QAAAA,EAAE,EAAE,IAAL;AAAWC,QAAAA,MAAM,EAAE;AAAnB,OAA6B;AAAA,UAEnED,EAFmE,GAOjED,QAPiE,CAEnEC,EAFmE;AAAA,8BAOjED,QAPiE,CAGnEE,MAHmE;AAAA,yDAM/D,EAN+D;AAAA,oDAIjEC,QAJiE;AAAA,iEAI1C,EAJ0C;AAAA,yDAItDhD,GAJsD;AAAA,UAItDA,GAJsD,uCAIhD,EAJgD;AAAA,oDAKjEiD,kBALiE;AAAA,iEAKzB,EALyB;AAAA,yDAK5CjD,GAL4C;AAAA,UAKvCkD,KALuC,uCAK/B,EAL+B;AASrE,aAAO;AACLJ,QAAAA,EAAE,EAAFA,EADK;AAELI,QAAAA,KAAK,EAALA,KAFK;AAGLC,QAAAA,IAAI,EAAE,OAHD;AAILnD,QAAAA,GAAG,EAAHA;AAJK,OAAP;AAMD,KAfe,CAAV;AAAA,GAFD,CAAP;AAkBD,CAtBM;AAwBP,OAAO,IAAMwD,gBAAgB,GAAG,SAAnBA,gBAAmB,CAAClE,OAAD;AAAA,MAAsBiD,KAAtB,uEAAsC,EAAtC;AAAA,SAC9B,IAAIkB,OAAJ,CAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;AAC/B3E,IAAAA,OAAO,CAAC4E,MAAR,CAAeC,IAAf,CAAoB;AAClBC,MAAAA,KAAK,EAAE,aADW;AAElBC,MAAAA,UAAU,EAAExB,KAFM;AAGlByB,MAAAA,IAAI,EAAE,SAHY;AAIlBC,MAAAA,UAAU,EAAE;AAJM,KAApB,EAKG,UAAC3C,KAAD,EAAeqB,IAAf,EAA6B;AAC9B,UAAGrB,KAAH,EAAU;AACR4C,QAAAA,OAAO,CAAC5C,KAAR,CAAcA,KAAd;AACAqC,QAAAA,MAAM,CAAC,IAAItB,KAAJ,CAAUf,KAAK,CAAC,CAAD,CAAL,CAAS6C,OAAnB,CAAD,CAAN;AACD,OAHD,MAGO,IAAGxB,IAAH,EAAS;AACd,YAAMkB,IAAI,GAAGlB,IAAI,CAACyB,KAAL,CAAWxB,GAAX,CAAe,UAACrD,IAAD;AAAA,iBAAW;AACrCuD,YAAAA,EAAE,EAAEvD,IAAI,CAACuD,EAD4B;AAErCI,YAAAA,KAAK,EAAE3D,IAAI,CAAC8E,OAAL,CAAaC,UAAb,CAAwBC,IAAxB,CAA6BvE,GAFC;AAGrCmD,YAAAA,IAAI,EAAE,SAH+B;AAIrCnD,YAAAA,GAAG,yCAAkCT,IAAI,CAACuD,EAAvC;AAJkC,WAAX;AAAA,SAAf,CAAb;AAOAY,QAAAA,OAAO,CAACG,IAAD,CAAP;AACD;AACF,KAnBD;AAoBD,GArBD,CAD8B;AAAA,CAAzB;AAyBP,OAAO,IAAMW,gBAAgB,GAAG,SAAnBA,gBAAmB,CAAClF,OAAD,EAAsB0B,KAAtB;AAAA,MAAqCuB,KAArC,uEAAqD,EAArD;AAAA,SAC9B,IAAIkB,OAAJ,CAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;AAC/B3E,IAAAA,OAAO,CAACyF,MAAR,CAAeZ,IAAf,CAAoB;AAClBE,MAAAA,UAAU,EAAExB,KADM;AAElByB,MAAAA,IAAI,EAAE,SAFY;AAGlB;AACAU,MAAAA,CAAC,EAAE1D,KAJe;AAKlBiD,MAAAA,UAAU,EAAE;AALM,KAApB,EAMG,UAAC3C,KAAD,EAAeqB,IAAf,EAA6B;AAC9B,UAAGrB,KAAH,EAAU;AACR4C,QAAAA,OAAO,CAAC5C,KAAR,CAAcA,KAAd;AACAqC,QAAAA,MAAM,CAAC,IAAItB,KAAJ,CAAUf,KAAK,CAAC,CAAD,CAAL,CAAS6C,OAAnB,CAAD,CAAN;AACD,OAHD,MAGO,IAAGxB,IAAH,EAAS;AAAA,YACPyB,KADO,GACEzB,IADF,CACPyB,KADO;AAEd,YAAMP,IAAI,GAAGO,KAAK,CAACxB,GAAN,CAAU,UAACrD,IAAD;AAAA,iBAAW;AAChCuD,YAAAA,EAAE,EAAEvD,IAAI,CAACuD,EADuB;AAEhCI,YAAAA,KAAK,EAAE3D,IAAI,CAAC8E,OAAL,CAAaC,UAAb,CAAwBC,IAAxB,CAA6BvE,GAFJ;AAGhCmD,YAAAA,IAAI,EAAE,SAH0B;AAIhCnD,YAAAA,GAAG,yCAAkCT,IAAI,CAACuD,EAAvC;AAJ6B,WAAX;AAAA,SAAV,CAAb;AAOAY,QAAAA,OAAO,CAACG,IAAD,CAAP;AACD;AACF,KArBD;AAsBD,GAvBD,CAD8B;AAAA,CAAzB,C,CA0BP;;AACA,OAAO,IAAMc,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACjF,MAAD,EAAiBkF,QAAjB;AAAA,yBAAuDlF,MAAvD,oBAAuEkF,QAAvE;AAAA,CAAzB;AAEP,OAAO,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAACnF,MAAD,EAAiBkF,QAAjB,EAA+F;AAAA,MAA5DE,GAA4D,uEAA9C,OAA8C;AAAA,MAArC3B,IAAqC,uEAAtB,SAAsB;;AAC5H,MAAGyB,QAAH,EAAa;AACX,iCAAsBhG,MAAM,CAACV,GAAP,CAAW,SAAX,CAAtB,oBAAqDwB,MAArD,cAA+DoF,GAA/D,cAAsEF,QAAtE;AACD;;AAED,MAAGzB,IAAI,KAAK,SAAZ,EAAuB;AACrB,iCAAsBvE,MAAM,CAACV,GAAP,CAAW,SAAX,CAAtB;AACD;;AAED,+BAAsBU,MAAM,CAACV,GAAP,CAAW,SAAX,CAAtB;AACD,CAVM;AAYP,OAAO,IAAM6G,UAAU,GAAG,SAAbA,UAAa,CAACC,EAAD,EAAe5D,IAAf,EAAqD;AAAA,MACtEvB,MADsE,GAC5DuB,IAD4D,CACtEvB,MADsE;AAE7E,MAAMiB,MAAW,GAAG;AAClBe,IAAAA,IAAI,EAAEhC,MADY;AAElBiC,IAAAA,KAAK,EAAEH,IAAI,CAACD,GAAL;AAFW,GAApB;AAKA,MAAMX,MAAgB,GAAGxC,GAAH,qBAAuBsB,MAAvB,EACXiB,MADW,CAAtB;AAKA,SAAOkE,EAAE,CAAChE,KAAH,CAASD,MAAT,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,IAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAACgE,WAAD,uEAAyB,EAAzB;AAAA,WAAgCA,WAAhC;AAAA,GAFD,EAGJ5D,KAHI,CAGE,UAACC,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GALI,CAAP;AAMD,CAlBM;AAoBP,OAAO,IAAM4D,SAAS,GAAG,SAAZA,SAAY,CAACF,EAAD,EAAeG,KAAf,EAAkCC,MAAlC;AAAA,SACvB3B,OAAO,CAAC4B,GAAR,CACEF,KAAK,CAACvC,GAAN,CAAU,UAACxB,IAAD;AAAA,WAAoB2D,UAAU,CAACC,EAAD,EAAK5D,IAAL,CAAV,CAC3BH,IAD2B,CACtB,UAACG,IAAD;AAAA,aAAoBrC,cAAc,CAACiG,EAAD,EAAK5D,IAAL,EAAWgE,MAAX,CAAlC;AAAA,KADsB,CAApB;AAAA,GAAV,CADF,CADuB;AAAA,CAAlB;AAMP,OAAO,IAAME,WAAW,GAAG,SAAdA,WAAc,CAACN,EAAD,EAAeI,MAAf,EAA+BD,KAA/B,EAAmE;AAC5F,MAAMI,cAAc,GAAGP,EAAE,CAACO,cAAH,CAAkB,UAAlB,CAAvB;AAEA,SAAOA,cAAc,CAACC,OAAf,CAAuBJ,MAAvB,EACJnE,IADI,CACC,UAACwE,KAAD,EAAW;AACf,QAAGA,KAAK,CAAC/E,MAAT,EAAiB;AACf;AACA,aAAO+C,OAAO,CAAC4B,GAAR,CACLI,KAAK,CAAC7C,GAAN,CAAU,UAAC8C,IAAD,EAAU;AAAA,YACLC,OADK,GACMD,IADN,CACX7D,IADW;AAElB,YAAMd,MAAgB,GAAGxC,GAAH,qBAAsBoH,OAAtB,CAAtB;AAEA,eAAOX,EAAE,CAAChE,KAAH,CAASD,MAAT,EAAiBM,KAAjB,CAAuB,UAACC,KAAD,EAAkB;AAC9C,gBAAMA,KAAN;AACD,SAFM,CAAP;AAGD,OAPD,CADK,EASJL,IATI,CASC,YAAM;AACV,YAAGkE,KAAK,CAACzE,MAAT,EAAiB;AACf;AACA,iBAAOwE,SAAS,CAACF,EAAD,EAAKG,KAAL,EAAYC,MAAZ,CAAT,CAA6BnE,IAA7B,CAAkC;AAAA,mBAAMkE,KAAN;AAAA,WAAlC,CAAP;AACD;;AACD,eAAOA,KAAP;AACD,OAfI,CAAP;AAgBD,KAlBD,MAkBO,IAAGA,KAAK,CAACzE,MAAT,EAAiB;AACtB;AACA,aAAOwE,SAAS,CAACF,EAAD,EAAKG,KAAL,EAAYC,MAAZ,CAAT,CAA6BnE,IAA7B,CAAkC;AAAA,eAAMkE,KAAN;AAAA,OAAlC,CAAP;AACD;;AACD,WAAOA,KAAP;AACD,GAzBI,EA0BJ9D,KA1BI,CA0BE,UAACC,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GA5BI,CAAP;AA6BD,CAhCM;AAkCP,OAAO,IAAMsE,YAAY,GAAG,SAAfA,YAAe,CAACxD,MAAD;AAAA,SAA4B,IAAIF,MAAJ,CAAWE,MAAX,EAAmByD,QAAnB,CAA4B,QAA5B,CAA5B;AAAA,CAArB;AAEP,OAAO,IAAMC,YAAY,GAAG,SAAfA,YAAe,CAACC,UAAD,EAAgC;AAC1D,MAAMC,OAAO,GAAG,SAAVA,OAAU,CAACC,GAAD;AAAA,WAAiBA,GAAG,CAACC,KAAJ,CAAU,oCAAV,KAAmD,EAApE;AAAA,GAAhB,CAD0D,CAE1D;;;AACA,MAAIC,OAAO,GAAGH,OAAO,CAACD,UAAD,CAArB;;AAEA,MAAGI,OAAO,CAACzF,MAAR,KAAmB,CAAtB,EAAyB;AACvB;AACAyF,IAAAA,OAAO,GAAGH,OAAO,CAACI,kBAAkB,CAACL,UAAD,CAAnB,CAAjB,CAFuB,CAIvB;;AACA,QAAGI,OAAO,CAACzF,MAAR,KAAmB,CAAtB,EAAyB;AACvB,YAAM2B,KAAK,CAAC,sBAAD,CAAX;AACD;AACF;;AAED,SAAO;AACLM,IAAAA,IAAI,EAAE,IAAIT,MAAJ,CAAWiE,OAAO,CAAC,CAAD,CAAlB,EAAuB,QAAvB,CADD;AAELhD,IAAAA,IAAI,EAAEgD,OAAO,CAAC,CAAD;AAFR,GAAP;AAID,CAnBM","sourcesContent":["import {get as httpGet} from '@nlabs/rip-hunter';\nimport {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport {google} from 'googleapis';\nimport {UserError} from 'graphql-errors';\nimport isEmpty from 'lodash/isEmpty';\nimport * as request from 'request-promise';\nimport {ApiContext} from 'types/auth';\n\nimport {Config} from '../config';\nimport {FileType} from '../types/files';\nimport {useDb} from '../utils';\nimport {resizeSaveImage} from './images';\nimport {createPostEdge} from './posts';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nconst youtube = google.youtube({auth: Config.get('google.key'), version: 'v3'});\nrequest.defaults({encoding: null});\n\n// const eventCategory: string = 'files';\n\n// Upload file\nexport const addFile = (context: ApiContext, item: FileType = {}): Promise<FileType> => {\n  const {database, userId: sessionId, userType} = 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 && userType !== 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 useDb(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 request.get({encoding: null, uri: url})\n      .then((body) => uploadFile(new Buffer(body, 'binary'), formatType))\n      .catch(() => {\n        throw new UserError('file_request');\n      });\n  } else if(item.base64 !== '') {\n    const buffer: Buffer = new Buffer(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 = db.edgeCollection('isPosted');\n\n  return edgeCollection.inEdges(postId)\n    .then((edges) => {\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 => new Buffer(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: new Buffer(matches[2], 'base64'),\n    type: matches[1]\n  };\n};\n"]}
|
package/lib/data/groups.d.ts
CHANGED
|
@@ -5,9 +5,9 @@ export declare const getGroupListByUser: (context: ApiContext, from: number, to:
|
|
|
5
5
|
export declare const getGroupListByTags: (context: ApiContext, tags: string[], from: number, to: number) => Promise<GroupType[]>;
|
|
6
6
|
export declare const getGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
|
|
7
7
|
export declare const getGroupDetails: (context: ApiContext, groupId: string) => Promise<GroupType>;
|
|
8
|
+
export declare const createGroupEdge: (database: string, userId: string, groupId: string, type: string) => Promise<GroupEdgeType>;
|
|
8
9
|
export declare const addGroup: (context: ApiContext, item?: GroupType) => Promise<GroupType>;
|
|
9
10
|
export declare const updateGroup: (context: ApiContext, item?: GroupType) => Promise<GroupType>;
|
|
10
11
|
export declare const deleteGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
|
|
11
12
|
export declare const getGroupsByReaction: (context: ApiContext, reaction: string) => Promise<GroupType[]>;
|
|
12
13
|
export declare const isGrouped: (database: string, userId: string, groupId: string) => Promise<GroupUserType>;
|
|
13
|
-
export declare const createGroupEdge: (database: string, userId: string, groupId: string, type: string) => Promise<GroupEdgeType>;
|
package/lib/data/groups.js
CHANGED
|
@@ -174,6 +174,31 @@ export var getGroupDetails = function getGroupDetails(context, groupId) {
|
|
|
174
174
|
});
|
|
175
175
|
});
|
|
176
176
|
};
|
|
177
|
+
export var createGroupEdge = function createGroupEdge(database, userId, groupId, type) {
|
|
178
|
+
var action = 'createGroupEdge';
|
|
179
|
+
var formatUserId = parseId(userId);
|
|
180
|
+
var formatGroupId = parseId(groupId);
|
|
181
|
+
var formatType = parseChar(type, 16);
|
|
182
|
+
var now = Date.now();
|
|
183
|
+
var edgeCollection = useDb(database).edgeCollection('isGrouped');
|
|
184
|
+
var edgeId = createHash("group-".concat(formatUserId, "-").concat(formatGroupId));
|
|
185
|
+
var edge = {
|
|
186
|
+
_key: edgeId,
|
|
187
|
+
added: now,
|
|
188
|
+
type: formatType
|
|
189
|
+
};
|
|
190
|
+
return edgeCollection.save(edge, "users/".concat(formatUserId), "groups/".concat(formatGroupId)).catch(function (error) {
|
|
191
|
+
return logError({
|
|
192
|
+
action: action,
|
|
193
|
+
category: eventCategory,
|
|
194
|
+
label: 'db_error'
|
|
195
|
+
}, error, {
|
|
196
|
+
id: formatUserId
|
|
197
|
+
}).then(function () {
|
|
198
|
+
return null;
|
|
199
|
+
});
|
|
200
|
+
});
|
|
201
|
+
};
|
|
177
202
|
export var addGroup = function addGroup(context) {
|
|
178
203
|
var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
179
204
|
var action = 'add';
|
|
@@ -326,29 +351,4 @@ export var isGrouped = function isGrouped(database, userId, groupId) {
|
|
|
326
351
|
});
|
|
327
352
|
});
|
|
328
353
|
};
|
|
329
|
-
export var createGroupEdge = function createGroupEdge(database, userId, groupId, type) {
|
|
330
|
-
var action = 'createGroupEdge';
|
|
331
|
-
var formatUserId = parseId(userId);
|
|
332
|
-
var formatGroupId = parseId(groupId);
|
|
333
|
-
var formatType = parseChar(type, 16);
|
|
334
|
-
var now = Date.now();
|
|
335
|
-
var edgeCollection = useDb(database).edgeCollection('isGrouped');
|
|
336
|
-
var edgeId = createHash("group-".concat(formatUserId, "-").concat(formatGroupId));
|
|
337
|
-
var edge = {
|
|
338
|
-
_key: edgeId,
|
|
339
|
-
added: now,
|
|
340
|
-
type: formatType
|
|
341
|
-
};
|
|
342
|
-
return edgeCollection.save(edge, "users/".concat(formatUserId), "groups/".concat(formatGroupId)).catch(function (error) {
|
|
343
|
-
return logError({
|
|
344
|
-
action: action,
|
|
345
|
-
category: eventCategory,
|
|
346
|
-
label: 'db_error'
|
|
347
|
-
}, error, {
|
|
348
|
-
id: formatUserId
|
|
349
|
-
}).then(function () {
|
|
350
|
-
return null;
|
|
351
|
-
});
|
|
352
|
-
});
|
|
353
|
-
};
|
|
354
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/groups.ts"],"names":["createHash","parseChar","parseId","aql","flatten","uniqBy","getLimit","logError","useDb","extractTags","eventCategory","getGroupList","context","from","to","action","database","limit","aqlQry","query","then","cursor","all","catch","error","category","label","getGroupListByUser","sessionId","userId","getGroupListByTags","tags","Promise","map","tagName","formatTagName","results","getGroup","itemId","formatItemId","next","group","getGroupDetails","groupId","formatGroupId","addGroup","item","now","Date","description","name","type","id","formatDesc","substr","formatType","insert","_key","added","modified","db","itemType","createGroupEdge","updateGroup","update","groupKey","deleteGroup","getGroupsByReaction","reaction","formatReaction","userDocId","isGrouped","formatUserId","isValid","length","edgeCollection","edgeId","edge","save"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAQA,UAAR,EAAoBC,SAApB,EAA+BC,OAA/B,QAA6C,cAA7C;AACA,SAAQC,GAAR,QAA4B,UAA5B;AAGA,OAAOC,OAAP,MAAoB,gBAApB;AACA,OAAOC,MAAP,MAAmB,eAAnB;AAKA,SAAQC,QAAR,EAAkBC,QAAlB,EAA4BC,KAA5B,QAAwC,UAAxC;AACA,SAAQC,WAAR,QAA0B,QAA1B;AAEA;;;;;AAKA,IAAMC,aAAqB,GAAG,QAA9B;AAEA,OAAO,IAAMC,YAAY,GAAG,SAAfA,YAAe,CAACC,OAAD,EAAsBC,IAAtB,EAAoCC,EAApC,EAAyE;AACnG,MAAMC,MAAc,GAAG,cAAvB;AADmG,MAE5FC,QAF4F,GAEhFJ,OAFgF,CAE5FI,QAF4F;AAGnG,MAAMC,KAAoB,GAAGX,QAAQ,CAACO,IAAD,EAAOC,EAAP,CAArC;AACA,MAAMI,MAAc,yJAKdD,KAAK,CAACd,GALQ,wEAApB;AASA,SAAOK,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJC,KAFI,CAEE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CApBM;AAsBP,OAAO,IAAMO,kBAAkB,GAAG,SAArBA,kBAAqB,CAACf,OAAD,EAAsBC,IAAtB,EAAoCC,EAApC,EAAyE;AACzG;AADyG,MAElGE,QAFkG,GAEnEJ,OAFmE,CAElGI,QAFkG;AAAA,MAEhFY,SAFgF,GAEnEhB,OAFmE,CAExFiB,MAFwF;AAGzG,MAAMZ,KAAoB,GAAGX,QAAQ,CAACO,IAAD,EAAOC,EAAP,CAArC;AACA,MAAMI,MAAc,mDAAoCU,SAApC,gJAKdX,KAAK,CAACd,GALQ,wEAApB;AASA,SAAOK,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJC,KAFI,CAEE,UAACC,KAAD,EAAkB;AACvB,UAAMA,KAAN;AACD,GAJI,CAAP;AAKD,CAlBM;AAoBP,OAAO,IAAMM,kBAAkB,GAAG,SAArBA,kBAAqB,CAAClB,OAAD,EAAsBmB,IAAtB,EAAsClB,IAAtC,EAAoDC,EAApD,EAAyF;AACzH,MAAMC,MAAc,GAAG,eAAvB;AADyH,MAElHC,QAFkH,GAEtGJ,OAFsG,CAElHI,QAFkH;AAIzH,SAAOgB,OAAO,CAACV,GAAR,CACL,CAACS,IAAI,IAAI,EAAT,EAAaE,GAAb,CAAiB,UAACC,OAAD,EAAqB;AACpC,QAAMC,aAAqB,GAAGjC,OAAO,CAACgC,OAAD,CAArC;AACA,QAAMjB,KAAoB,GAAGX,QAAQ,CAACO,IAAD,EAAOC,EAAP,CAArC;AACA,QAAMI,MAAc,mDAAoCiB,aAApC,6aAadlB,KAAK,CAACd,GAbQ,2HAApB;AAiBA,WAAOK,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EAA8BE,IAA9B,CAAmC,UAACC,MAAD;AAAA,aAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,KAAnC,CAAP;AACD,GArBD,CADK,EAwBJF,IAxBI,CAwBC,UAACgB,OAAD;AAAA,WAAa/B,MAAM,CAACD,OAAO,CAACgC,OAAD,CAAR,EAAmB,MAAnB,CAAnB;AAAA,GAxBD,EAyBJb,KAzBI,CAyBE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAzBF,CAAP;AA8BD,CAlCM;AAoCP,OAAO,IAAMiB,QAAQ,GAAG,SAAXA,QAAW,CAACzB,OAAD,EAAsB0B,MAAtB,EAA6D;AACnF,MAAMvB,MAAc,GAAG,SAAvB;AADmF,MAE5EC,QAF4E,GAE7CJ,OAF6C,CAE5EI,QAF4E;AAAA,MAE1DY,SAF0D,GAE7ChB,OAF6C,CAElEiB,MAFkE;AAGnF,MAAMU,YAAoB,GAAGrC,OAAO,CAACoC,MAAD,CAApC;AAEA,MAAMpB,MAAgB,GAAGf,GAAH,oCAAsCyB,SAAtC,GACCW,YADD,CAAtB;AASA,SAAO/B,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC;AAAA,QAACqB,KAAD,uEAAoB,EAApB;AAAA,WAA2BA,KAA3B;AAAA,GAFD,EAGJlB,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAHF,CAAP;AAQD,CAtBM;AAwBP,OAAO,IAAMsB,eAAe,GAAG,SAAlBA,eAAkB,CAAC9B,OAAD,EAAsB+B,OAAtB,EAA8D;AAC3F,MAAM5B,MAAc,GAAG,YAAvB;AAD2F,MAEpFC,QAFoF,GAExEJ,OAFwE,CAEpFI,QAFoF;AAG3F,MAAM4B,aAAqB,GAAG1C,OAAO,CAACyC,OAAD,CAArC;AACA,MAAMzB,MAAgB,GAAGf,GAAH,qBACCyC,aADD,CAAtB;AAKA,SAAOpC,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC;AAAA,QAACqB,KAAD,uEAAoB,EAApB;AAAA,WAA2BA,KAA3B;AAAA,GAFD,EAGJlB,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;AAmBP,OAAO,IAAMyB,QAAQ,GAAG,SAAXA,QAAW,CAACjC,OAAD,EAAmE;AAAA,MAA7CkC,IAA6C,uEAA3B,EAA2B;AACzF,MAAM/B,MAAc,GAAG,KAAvB;AADyF,MAElFC,QAFkF,GAEnDJ,OAFmD,CAElFI,QAFkF;AAAA,MAEhEY,SAFgE,GAEnDhB,OAFmD,CAExEiB,MAFwE;AAGzF,MAAMkB,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AAHyF,0BAQ1ED,IAR0E,CAKvFG,WALuF;AAAA,MAKvFA,WALuF,kCAKzE,EALyE;AAAA,mBAQ1EH,IAR0E,CAMvFI,IANuF;AAAA,MAMvFA,IANuF,2BAMhF,UANgF;AAAA,MAOvFC,IAPuF,GAQ1EL,IAR0E,CAOvFK,IAPuF;AASzF,MAAMC,EAAU,GAAGpD,UAAU,iBAAU4B,SAAV,EAA7B;AACA,MAAMyB,UAAkB,GAAGJ,WAAW,CAACK,MAAZ,CAAmB,CAAnB,EAAsB,GAAtB,CAA3B;AACA,MAAMC,UAAkB,GAAGtD,SAAS,CAACkD,IAAD,EAAO,EAAP,CAAT,IAAuB,SAAlD;AACA,MAAMK,MAAiB,GAAG;AACxBC,IAAAA,IAAI,EAAEL,EADkB;AAExBM,IAAAA,KAAK,EAAEX,GAFiB;AAGxBE,IAAAA,WAAW,EAAEI,UAHW;AAIxBM,IAAAA,QAAQ,EAAEZ,GAJc;AAKxBG,IAAAA,IAAI,EAAJA,IALwB;AAMxBC,IAAAA,IAAI,EAAEI;AANkB,GAA1B;AAQA,MAAMK,EAAY,GAAGpD,KAAK,CAACQ,QAAD,CAA1B;AACA,MAAME,MAAgB,GAAGf,GAAH,qBAAgBqD,MAAhB,CAAtB;AAEA,SAAOI,EAAE,CAACzC,KAAH,CAASD,MAAT,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC,YAA2B;AAAA,QAA1BqB,KAA0B,uEAAP,EAAO;AAC/B,QAAMoB,QAAgB,GAAG,QAAzB,CAD+B,CAG/B;;AAH+B,QAIlBlB,OAJkB,GAIIF,KAJJ,CAIxBgB,IAJwB;AAK/B,WAAOhD,WAAW,CAACmD,EAAD,EAAKC,QAAL,EAAelB,OAAf,EAAwBU,UAAxB,CAAX,CACJjC,IADI,CACC;AAAA,aAAM0C,eAAe,CAAC9C,QAAD,EAAWY,SAAX,EAAsBe,OAAtB,EAA+B,OAA/B,CAAf,CAAuDvB,IAAvD,CAA4D;AAAA,eAAMqB,KAAN;AAAA,OAA5D,CAAN;AAAA,KADD,CAAP;AAED,GATI,EAUJlB,KAVI,CAUE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAVF,CAAP;AAeD,CAtCM;AAwCP,OAAO,IAAM2C,WAAW,GAAG,SAAdA,WAAc,CAACnD,OAAD,EAAmE;AAAA,MAA7CkC,IAA6C,uEAA3B,EAA2B;AAC5F,MAAM/B,MAAc,GAAG,QAAvB;AAD4F,MAErFC,QAFqF,GAEzEJ,OAFyE,CAErFI,QAFqF;AAAA,2BAO7E8B,IAP6E,CAI1FG,WAJ0F;AAAA,MAI1FA,WAJ0F,mCAI5E,EAJ4E;AAAA,MAK1FG,EAL0F,GAO7EN,IAP6E,CAK1FM,EAL0F;AAAA,oBAO7EN,IAP6E,CAM1FI,IAN0F;AAAA,MAM1FA,IAN0F,4BAMnF,UANmF;AAQ5F,MAAMZ,MAAc,GAAGpC,OAAO,CAACkD,EAAD,CAA9B;AACA,MAAML,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,MAAMM,UAAkB,GAAGJ,WAAW,CAACK,MAAZ,CAAmB,CAAnB,EAAsB,GAAtB,CAA3B;AACA,MAAMU,MAAW,GAAG;AAClBf,IAAAA,WAAW,EAAEI,UADK;AAElBM,IAAAA,QAAQ,EAAEZ,GAFQ;AAGlBG,IAAAA,IAAI,EAAJA;AAHkB,GAApB;AAKA,MAAMU,EAAY,GAAGpD,KAAK,CAACQ,QAAD,CAA1B;AACA,MAAME,MAAgB,GAAGf,GAAH,qBAAgBmC,MAAhB,EAA+B0B,MAA/B,CAAtB;AAEA,SAAOJ,EAAE,CAACzC,KAAH,CAASD,MAAT,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC,YAA2B;AAAA,QAA1BqB,KAA0B,uEAAP,EAAO;AAAA,QAClBwB,QADkB,GACNxB,KADM,CACxBgB,IADwB;AAE/B,QAAMI,QAAgB,GAAG,QAAzB,CAF+B,CAI/B;;AACA,WAAOpD,WAAW,CAACmD,EAAD,EAAKC,QAAL,EAAeI,QAAf,EAAyBhB,WAAzB,CAAX,CAAiD7B,IAAjD,CAAsD;AAAA,aAAMqB,KAAN;AAAA,KAAtD,CAAP;AACD,GARI,EASJlB,KATI,CASE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GATF,CAAP;AAcD,CAjCM;AAmCP,OAAO,IAAM8C,WAAW,GAAG,SAAdA,WAAc,CAACtD,OAAD,EAAsB0B,MAAtB,EAA6D;AACtF,MAAMvB,MAAc,GAAG,QAAvB;AADsF,MAE/EC,QAF+E,GAEnEJ,OAFmE,CAE/EI,QAF+E;AAGtF,MAAMuB,YAAoB,GAAGrC,OAAO,CAACoC,MAAD,CAApC;AACA,MAAMpB,MAAgB,GAAGf,GAAH,qBACCoC,YADD,CAAtB;AAKA,SAAO/B,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACmB,IAAP,EAAzB;AAAA,GADD,EAEJpB,IAFI,CAEC;AAAA,QAACqB,KAAD,uEAAoB,EAApB;AAAA,WAA2BA,KAA3B;AAAA,GAFD,EAGJlB,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;AAmBP,OAAO,IAAM+C,mBAAmB,GAAG,SAAtBA,mBAAsB,CAACvD,OAAD,EAAsBwD,QAAtB,EAAiE;AAClG,MAAMrD,MAAc,GAAG,qBAAvB;AADkG,MAE3FC,QAF2F,GAE5DJ,OAF4D,CAE3FI,QAF2F;AAAA,MAEzEY,SAFyE,GAE5DhB,OAF4D,CAEjFiB,MAFiF;AAGlG,MAAMwC,cAAsB,GAAGpE,SAAS,CAACmE,QAAD,EAAW,EAAX,CAAxC;AACA,MAAME,SAAiB,mBAAY1C,SAAZ,CAAvB,CAJkG,CAMlG;;AACA,MAAMV,MAAgB,GAAGf,GAAH,qBAA8BmE,SAA9B,EACED,cADF,CAAtB;AAKA,SAAO7D,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJC,KAFI,CAEE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvBZ,OAJuB,CAAR,CAINQ,IAJM,CAID;AAAA,aAAM,IAAN;AAAA,KAJC,CAAlB;AAAA,GAFF,CAAP;AAOD,CAnBM;AAqBP,OAAO,IAAMmD,SAAS,GAAG,SAAZA,SAAY,CAACvD,QAAD,EAAmBa,MAAnB,EAAmCc,OAAnC,EAA+E;AACtG,MAAM5B,MAAc,GAAG,WAAvB;AACA,MAAMyD,YAAoB,GAAGtE,OAAO,CAAC2B,MAAD,CAApC;AACA,MAAMe,aAAqB,GAAG1C,OAAO,CAACyC,OAAD,CAArC;AACA,MAAMzB,MAAgB,GAAGf,GAAH,qBACDyC,aADC,EAGD4B,YAHC,CAAtB;AAOA,SAAOhE,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC,YAAkB;AAAA,QAAjBgB,OAAiB,uEAAP,EAAO;AACtB,QAAMqC,OAAO,GAAG,CAAC,CAACrC,OAAO,CAACsC,MAA1B;AAEA,WAAO;AACL/B,MAAAA,OAAO,EAAPA,OADK;AAEL8B,MAAAA,OAAO,EAAPA,OAFK;AAGL5C,MAAAA,MAAM,EAANA;AAHK,KAAP;AAKD,GAVI,EAWJN,KAXI,CAWE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB;AAAC4B,MAAAA,EAAE,EAAEvB;AAAL,KAJuB,CAAR,CAIDT,IAJC,CAII;AAAA,aAAM,IAAN;AAAA,KAJJ,CAAlB;AAAA,GAXF,CAAP;AAgBD,CA3BM;AA6BP,OAAO,IAAM0C,eAAe,GAAG,SAAlBA,eAAkB,CAAC9C,QAAD,EAAmBa,MAAnB,EAAmCc,OAAnC,EAAoDQ,IAApD,EAA6F;AAC1H,MAAMpC,MAAc,GAAG,iBAAvB;AACA,MAAMyD,YAAoB,GAAGtE,OAAO,CAAC2B,MAAD,CAApC;AACA,MAAMe,aAAqB,GAAG1C,OAAO,CAACyC,OAAD,CAArC;AACA,MAAMY,UAAkB,GAAGtD,SAAS,CAACkD,IAAD,EAAO,EAAP,CAApC;AAEA,MAAMJ,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,MAAM4B,cAAc,GAAGnE,KAAK,CAACQ,QAAD,CAAL,CAAgB2D,cAAhB,CAA+B,WAA/B,CAAvB;AACA,MAAMC,MAAc,GAAG5E,UAAU,iBAAUwE,YAAV,cAA0B5B,aAA1B,EAAjC;AAEA,MAAMiC,IAAS,GAAG;AAChBpB,IAAAA,IAAI,EAAEmB,MADU;AAEhBlB,IAAAA,KAAK,EAAEX,GAFS;AAGhBI,IAAAA,IAAI,EAAEI;AAHU,GAAlB;AAMA,SAAOoB,cAAc,CAACG,IAAf,CAAoBD,IAApB,kBAAmCL,YAAnC,oBAA6D5B,aAA7D,GACJrB,KADI,CACE,UAACC,KAAD;AAAA,WAAkBjB,QAAQ,CAAC;AAChCQ,MAAAA,MAAM,EAANA,MADgC;AAEhCU,MAAAA,QAAQ,EAAEf,aAFsB;AAGhCgB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB;AAAC4B,MAAAA,EAAE,EAAEoB;AAAL,KAJuB,CAAR,CAIKpD,IAJL,CAIU;AAAA,aAAM,IAAN;AAAA,KAJV,CAAlB;AAAA,GADF,CAAP;AAMD,CAtBM","sourcesContent":["import {createHash, parseChar, parseId} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {GroupEdgeType, GroupType, GroupUserType} from '../types/groups';\nimport {getLimit, logError, useDb} from '../utils';\nimport {extractTags} from './tags';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\n\nconst eventCategory: string = 'groups';\n\nexport const getGroupList = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  const action: string = 'getListByApp';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g in groups\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupListByUser = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g, e IN INBOUND \"${`users/${sessionId}`}\" isGrouped\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getGroupListByTags = (context: ApiContext, tags: string[], from: number, to: number): Promise<GroupType[]> => {\n  const action: string = 'getListByTags';\n  const {database} = context;\n\n  return Promise.all(\n    (tags || []).map((tagName: string) => {\n      const formatTagName: string = parseId(tagName);\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR p, e IN OUTBOUND \"${`tags/${formatTagName}`}\" isTagged\n          FOR u IN users\n          LET likes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'like'\n            RETURN like\n          )\n          LET dislikes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'dislike'\n            RETURN like\n          )\n          FILTER e.type == 'post' && p.userId == u._key\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {user:u, likes:LENGTH(likes), dislikes:LENGTH(dislikes)})`;\n\n      return useDb(database).query(aqlQry).then((cursor: ArrayCursor) => cursor.all());\n    })\n  )\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n\n  const aqlQry: AqlQuery = aql`FOR g, e IN INBOUND ${`users/${sessionId}`} isGrouped\n      FILTER g._key == ${formatItemId}\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      LIMIT 1\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupDetails = (context: ApiContext, groupId: string): Promise<GroupType> => {\n  const action: string = 'getDetails';\n  const {database} = context;\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatGroupId}\n      LIMIT 1\n      RETURN g`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const addGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'add';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    description = '',\n    name = 'Untitled',\n    type\n  }: GroupType = item;\n  const id: string = createHash(`group-${sessionId}`);\n  const formatDesc: string = description.substr(0, 640);\n  const formatType: string = parseChar(type, 16) || 'private';\n  const insert: GroupType = {\n    _key: id,\n    added: now,\n    description: formatDesc,\n    modified: now,\n    name,\n    type: formatType\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN groups RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => {\n      const itemType: string = 'groups';\n\n      // Update linked tags\n      const {_key: groupId}: GroupType = group;\n      return extractTags(db, itemType, groupId, formatDesc)\n        .then(() => createGroupEdge(database, sessionId, groupId, 'admin').then(() => group));\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const {\n    description = '',\n    id,\n    name = 'Untitled'\n  }: GroupType = item;\n  const itemId: string = parseId(id);\n  const now: number = Date.now();\n  const formatDesc: string = description.substr(0, 640);\n  const update: any = {\n    description: formatDesc,\n    modified: now,\n    name\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => {\n      const {_key: groupKey} = group;\n      const itemType: string = 'groups';\n\n      // Update linked tags\n      return extractTags(db, itemType, groupKey, description).then(() => group);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatItemId}\n      REMOVE g IN groups\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupsByReaction = (context: ApiContext, reaction: string): Promise<GroupType[]> => {\n  const action: string = 'getGroupsByReaction';\n  const {database, userId: sessionId} = context;\n  const formatReaction: string = parseChar(reaction, 32);\n  const userDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR u, r IN OUTBOUND ${userDocId} hasReaction\n      FILTER r.value == ${formatReaction}\n      COLLECT reactionName = r.value INTO reactionItems\n      RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const isGrouped = (database: string, userId: string, groupId: string): Promise<GroupUserType> => {\n  const action: string = 'isGrouped';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n    FILTER g._key == ${formatGroupId}\n    FOR u IN INBOUND g._id isGrouped\n    FILTER u._key == ${formatUserId}\n    LIMIT 1\n    RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results = []) => {\n      const isValid = !!results.length;\n\n      return {\n        groupId,\n        isValid,\n        userId\n      };\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: userId}).then(() => null));\n};\n\nexport const createGroupEdge = (database: string, userId: string, groupId: string, type: string): Promise<GroupEdgeType> => {\n  const action: string = 'createGroupEdge';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const formatType: string = parseChar(type, 16);\n\n  const now: number = Date.now();\n  const edgeCollection = useDb(database).edgeCollection('isGrouped');\n  const edgeId: string = createHash(`group-${formatUserId}-${formatGroupId}`);\n\n  const edge: any = {\n    _key: edgeId,\n    added: now,\n    type: formatType\n  };\n\n  return edgeCollection.save(edge, `users/${formatUserId}`, `groups/${formatGroupId}`)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: formatUserId}).then(() => null));\n};\n"]}
|
|
354
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/groups.ts"],"names":["createHash","parseChar","parseId","aql","flatten","uniqBy","getLimit","logError","useDb","extractTags","eventCategory","getGroupList","context","from","to","action","database","limit","aqlQry","query","then","cursor","all","catch","error","category","label","getGroupListByUser","sessionId","userId","getGroupListByTags","tags","Promise","map","tagName","formatTagName","results","getGroup","itemId","formatItemId","next","group","getGroupDetails","groupId","formatGroupId","createGroupEdge","type","formatUserId","formatType","now","Date","edgeCollection","edgeId","edge","_key","added","save","id","addGroup","item","description","name","formatDesc","substr","insert","modified","db","itemType","updateGroup","update","groupKey","deleteGroup","getGroupsByReaction","reaction","formatReaction","userDocId","isGrouped","isValid","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {GroupEdgeType, GroupType, GroupUserType} from '../types/groups';\nimport {getLimit, logError, useDb} from '../utils';\nimport {extractTags} from './tags';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\n\nconst eventCategory: string = 'groups';\n\nexport const getGroupList = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  const action: string = 'getListByApp';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g in groups\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupListByUser = (context: ApiContext, from: number, to: number): Promise<GroupType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR g, e IN INBOUND \"${`users/${sessionId}`}\" isGrouped\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      ${limit.aql}\n      SORT g.added\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getGroupListByTags = (\n  context: ApiContext,\n  tags: string[],\n  from: number,\n  to: number\n): Promise<GroupType[]> => {\n  const action: string = 'getListByTags';\n  const {database} = context;\n\n  return Promise.all(\n    (tags || []).map((tagName: string) => {\n      const formatTagName: string = parseId(tagName);\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR p, e IN OUTBOUND \"${`tags/${formatTagName}`}\" isTagged\n          FOR u IN users\n          LET likes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'like'\n            RETURN like\n          )\n          LET dislikes = (\n            FOR post, like IN INBOUND p._id likes\n            FILTER like.value == 'dislike'\n            RETURN like\n          )\n          FILTER e.type == 'post' && p.userId == u._key\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {user:u, likes:LENGTH(likes), dislikes:LENGTH(dislikes)})`;\n\n      return useDb(database).query(aqlQry).then((cursor: ArrayCursor) => cursor.all());\n    })\n  )\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n\n  const aqlQry: AqlQuery = aql`FOR g, e IN INBOUND ${`users/${sessionId}`} isGrouped\n      FILTER g._key == ${formatItemId}\n      LET users = (\n        FOR u, l IN OUTBOUND g._id isGrouped\n        RETURN MERGE (u, {type:l.type})\n      )\n      LIMIT 1\n      RETURN DISTINCT MERGE(g, {users:users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupDetails = (context: ApiContext, groupId: string): Promise<GroupType> => {\n  const action: string = 'getDetails';\n  const {database} = context;\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatGroupId}\n      LIMIT 1\n      RETURN g`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const createGroupEdge = (\n  database: string,\n  userId: string,\n  groupId: string,\n  type: string\n): Promise<GroupEdgeType> => {\n  const action: string = 'createGroupEdge';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const formatType: string = parseChar(type, 16);\n\n  const now: number = Date.now();\n  const edgeCollection = useDb(database).edgeCollection('isGrouped');\n  const edgeId: string = createHash(`group-${formatUserId}-${formatGroupId}`);\n\n  const edge: any = {\n    _key: edgeId,\n    added: now,\n    type: formatType\n  };\n\n  return edgeCollection.save(edge, `users/${formatUserId}`, `groups/${formatGroupId}`)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: formatUserId}).then(() => null));\n};\n\nexport const addGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'add';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    description = '',\n    name = 'Untitled',\n    type\n  }: GroupType = item;\n  const id: string = createHash(`group-${sessionId}`);\n  const formatDesc: string = description.substr(0, 640);\n  const formatType: string = parseChar(type, 16) || 'private';\n  const insert: GroupType = {\n    _key: id,\n    added: now,\n    description: formatDesc,\n    modified: now,\n    name,\n    type: formatType\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN groups RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => {\n      const itemType: string = 'groups';\n\n      // Update linked tags\n      const {_key: groupId}: GroupType = group;\n      return extractTags(db, itemType, groupId, formatDesc)\n        .then(() => createGroupEdge(database, sessionId, groupId, 'admin').then(() => group));\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateGroup = (context: ApiContext, item: GroupType = {}): Promise<GroupType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const {\n    description = '',\n    id,\n    name = 'Untitled'\n  }: GroupType = item;\n  const itemId: string = parseId(id);\n  const now: number = Date.now();\n  const formatDesc: string = description.substr(0, 640);\n  const update: any = {\n    description: formatDesc,\n    modified: now,\n    name\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPDATE ${itemId} WITH ${update} IN groups RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => {\n      const {_key: groupKey} = group;\n      const itemType: string = 'groups';\n\n      // Update linked tags\n      return extractTags(db, itemType, groupKey, description).then(() => group);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteGroup = (context: ApiContext, itemId: string): Promise<GroupType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n      FILTER g._key == ${formatItemId}\n      REMOVE g IN groups\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((group: GroupType = {}) => group)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getGroupsByReaction = (context: ApiContext, reaction: string): Promise<GroupType[]> => {\n  const action: string = 'getGroupsByReaction';\n  const {database, userId: sessionId} = context;\n  const formatReaction: string = parseChar(reaction, 32);\n  const userDocId: string = `users/${sessionId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR u, r IN OUTBOUND ${userDocId} hasReaction\n      FILTER r.value == ${formatReaction}\n      COLLECT reactionName = r.value INTO reactionItems\n      RETURN {value: reactionName, count: LENGTH(reactionItems[*].r.value)}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const isGrouped = (database: string, userId: string, groupId: string): Promise<GroupUserType> => {\n  const action: string = 'isGrouped';\n  const formatUserId: string = parseId(userId);\n  const formatGroupId: string = parseId(groupId);\n  const aqlQry: AqlQuery = aql`FOR g IN groups\n    FILTER g._key == ${formatGroupId}\n    FOR u IN INBOUND g._id isGrouped\n    FILTER u._key == ${formatUserId}\n    LIMIT 1\n    RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results = []) => {\n      const isValid = !!results.length;\n\n      return {\n        groupId,\n        isValid,\n        userId\n      };\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {id: userId}).then(() => null));\n};\n"]}
|