@nlabs/reaktor 0.1.1 → 0.1.3
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/.DS_Store +0 -0
- package/lib/config.js +10 -7
- package/lib/data/posts.d.ts +13 -7
- package/lib/data/posts.js +77 -39
- package/lib/types/posts.d.ts +1 -0
- package/package.json +8 -8
- package/.vscode/extensions.json +0 -15
- package/.vscode/settings.json +0 -82
- package/lex.config.js +0 -4
- package/src/config.ts +0 -121
- package/src/data/conversations.ts +0 -181
- package/src/data/dynamodb.ts +0 -157
- package/src/data/email.ts +0 -163
- package/src/data/files.ts +0 -352
- package/src/data/groups.ts +0 -308
- package/src/data/images.ts +0 -606
- package/src/data/index.ts +0 -23
- package/src/data/ios.ts +0 -249
- package/src/data/locations.ts +0 -114
- package/src/data/messages.ts +0 -237
- package/src/data/notifications.ts +0 -48
- package/src/data/payments.ts +0 -675
- package/src/data/posts.ts +0 -561
- package/src/data/reactions.ts +0 -186
- package/src/data/s3.ts +0 -117
- package/src/data/search.ts +0 -74
- package/src/data/sms.ts +0 -60
- package/src/data/subscription.ts +0 -228
- package/src/data/tags.ts +0 -230
- package/src/data/users.ts +0 -254
- package/src/index.ts +0 -7
- package/src/types/apps.ts +0 -56
- package/src/types/arangodb.ts +0 -23
- package/src/types/auth.ts +0 -20
- package/src/types/conversations.ts +0 -11
- package/src/types/email.ts +0 -17
- package/src/types/files.ts +0 -31
- package/src/types/google.ts +0 -37
- package/src/types/groups.ts +0 -27
- package/src/types/images.ts +0 -32
- package/src/types/index.ts +0 -21
- package/src/types/locations.ts +0 -24
- package/src/types/messages.ts +0 -16
- package/src/types/notifications.ts +0 -26
- package/src/types/payments.ts +0 -129
- package/src/types/posts.ts +0 -33
- package/src/types/reactions.ts +0 -8
- package/src/types/tags.ts +0 -13
- package/src/types/users.ts +0 -89
- package/src/utils/analytics.ts +0 -41
- package/src/utils/arangodb.ts +0 -100
- package/src/utils/auth.ts +0 -61
- package/src/utils/graphql.ts +0 -7
- package/src/utils/index.ts +0 -10
- package/src/utils/objects.ts +0 -34
- package/src/utils/redis.ts +0 -17
- package/tsconfig.json +0 -45
package/.DS_Store
ADDED
|
Binary file
|
package/lib/config.js
CHANGED
|
@@ -16,12 +16,15 @@ import merge from 'lodash/merge';
|
|
|
16
16
|
var appPackage = require('../package.json');
|
|
17
17
|
|
|
18
18
|
var _process$env = process.env,
|
|
19
|
-
|
|
19
|
+
_process$env$arangodb = _process$env.arangodbDatabase,
|
|
20
|
+
arangodbDatabase = _process$env$arangodb === void 0 ? 'reaktor' : _process$env$arangodb,
|
|
20
21
|
arangodbPassword = _process$env.arangodbPassword,
|
|
21
|
-
_process$env$
|
|
22
|
-
arangodbPort = _process$env$
|
|
23
|
-
|
|
24
|
-
|
|
22
|
+
_process$env$arangodb2 = _process$env.arangodbPort,
|
|
23
|
+
arangodbPort = _process$env$arangodb2 === void 0 ? '8529' : _process$env$arangodb2,
|
|
24
|
+
_process$env$arangodb3 = _process$env.arangodbUrl,
|
|
25
|
+
arangodbUrl = _process$env$arangodb3 === void 0 ? 'db.reaktor.io' : _process$env$arangodb3,
|
|
26
|
+
_process$env$arangodb4 = _process$env.arangodbUsername,
|
|
27
|
+
arangodbUsername = _process$env$arangodb4 === void 0 ? 'reaktor' : _process$env$arangodb4;
|
|
25
28
|
export var Config =
|
|
26
29
|
/*#__PURE__*/
|
|
27
30
|
function () {
|
|
@@ -51,7 +54,7 @@ _defineProperty(Config, "values", {
|
|
|
51
54
|
version: appPackage.version
|
|
52
55
|
},
|
|
53
56
|
arangodb: {
|
|
54
|
-
apiUrl: "http://".concat(
|
|
57
|
+
apiUrl: "http://".concat(arangodbUrl, ":").concat(arangodbPort),
|
|
55
58
|
database: arangodbDatabase,
|
|
56
59
|
dump: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangodump',
|
|
57
60
|
password: arangodbPassword,
|
|
@@ -124,4 +127,4 @@ _defineProperty(Config, "values", {
|
|
|
124
127
|
},
|
|
125
128
|
test: {}
|
|
126
129
|
});
|
|
127
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
130
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/config.ts"],"names":["get","merge","appPackage","require","process","env","arangodbDatabase","arangodbPassword","arangodbPort","arangodbUrl","arangodbUsername","Config","path","environment","stage","configValues","values","default","app","name","url","version","arangodb","apiUrl","database","dump","password","port","restore","username","aws","Bucket","accessKeyId","maxRetries","region","secretAccessKey","signatureVersion","giphy","key","google","analytics","accountId","trackingId","geocode","image","imgQuality","imgSize","thmQuality","thmSize","redis","host","stripe","token","twilio","number","sid","development","production","test"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport get from 'lodash/get';\nimport merge from 'lodash/merge';\n\nexport interface AppConfig {\n  readonly app?: object;\n  readonly arangodb?: object;\n  readonly aws?: object;\n  readonly giphy?: object;\n  readonly google?: object;\n  readonly image?: object;\n  readonly redis?: object;\n  readonly stripe?: object;\n  readonly twilio?: object;\n}\n\nexport interface EnvConfig {\n  readonly default: AppConfig;\n  readonly development: AppConfig;\n  readonly production: AppConfig;\n  readonly test: AppConfig;\n}\n\nconst appPackage: any = require('../package.json');\n\nconst {\n  arangodbDatabase = 'reaktor',\n  arangodbPassword,\n  arangodbPort = '8529',\n  arangodbUrl = 'db.reaktor.io',\n  arangodbUsername = 'reaktor'\n} = process.env;\n\nexport class Config {\n  static values: EnvConfig = {\n    default: {\n      app: {\n        name: 'reaktor',\n        url: 'reaktor.io',\n        version: appPackage.version\n      },\n      arangodb: {\n        apiUrl: `http://${arangodbUrl}:${arangodbPort}`,\n        database: arangodbDatabase,\n        dump: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangodump',\n        password: arangodbPassword,\n        port: arangodbPort,\n        restore: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangorestore',\n        url: arangodbUrl,\n        username: arangodbUsername\n      },\n      aws: {\n        Bucket: 'dev.reaktor.io',\n        accessKeyId: 'AKIAJIYDT3EA2ZFMTJNA',\n        maxRetries: 3,\n        region: 'us-east-1',\n        secretAccessKey: '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',\n        signatureVersion: 'v4'\n      },\n      giphy: {\n        key: 'dc6zaTOxFJmzC'\n      },\n      google: {\n        analytics: {\n          accountId: '78158717',\n          trackingId: 'UA-78158717-1'\n        },\n        geocode: {\n          key: 'AIzaSyBwjmpBjWhiJoBCZiYzRurM9m4WnCxslv0',\n          url: 'https://maps.googleapis.com/maps/api/geocode/json'\n        },\n        key: 'AIzaSyC3_f2Us3y0qjbyMJ-4t5ObtCzfq_FHIgQ'\n      },\n      image: {\n        imgQuality: 90,\n        imgSize: 1500,\n        thmQuality: 80,\n        thmSize: 150\n      },\n      redis: {\n        host: '127.0.0.1',\n        port: 6379\n      },\n      stripe: {\n        token: 'sk_test_LS956be57YUXTB5a4sLGb5BQ'\n      },\n      twilio: {\n        number: '+15005550006',\n        sid: 'AC6bd7f513cbed2e5134c650be06cc732e',\n        token: '520ae739e761bab759b147f1ad28278f'\n      }\n    },\n    development: {\n    },\n    production: {\n      arangodb: {\n        dump: '/usr/bin/arangodump',\n        restore: '/usr/bin/arangorestore',\n      },\n      aws: {\n        Bucket: 'box.reaktor.io'\n      },\n      redis: {\n        host: 'reaktor-redis.ehcvnt.0001.use1.cache.amazonaws.com'\n      },\n      stripe: {\n        token: 'sk_live_bElZl8RLhMCJy33KG4lyLD4o'\n      },\n      twilio: {\n        number: '+18554165227',\n        sid: 'AC90b0528a911e652d643329a4d7b4d2c7',\n        token: 'a7941d173bd4846d0966a186e9865b72'\n      }\n    },\n    test: {\n    }\n  };\n\n  static get(path: string | string[]): any {\n    const environment: string = process.env.stage || 'development';\n    const configValues: object = merge(this.values.default, this.values[environment], {environment});\n    return get(configValues, path);\n  }\n}\n"]}
|
package/lib/data/posts.d.ts
CHANGED
|
@@ -1,14 +1,20 @@
|
|
|
1
1
|
import { Database } from 'arangojs';
|
|
2
2
|
import { ApiContext, FileType, PostOptions, PostType } from '../types';
|
|
3
|
+
export declare const parsePostOptions: (options?: PostOptions) => {
|
|
4
|
+
latitude: number;
|
|
5
|
+
longitude: number;
|
|
6
|
+
limit: import("../types").ArangoDBLimit;
|
|
7
|
+
type: string;
|
|
8
|
+
};
|
|
3
9
|
export declare const getPostOptional: (fields: string[]) => any;
|
|
4
|
-
export declare const getPostList: (context: ApiContext,
|
|
5
|
-
export declare const getPostListByGroup: (context: ApiContext, groupId: string,
|
|
6
|
-
export declare const getPostListByLatest: (context: ApiContext,
|
|
7
|
-
export declare const getPostListByTags: (context: ApiContext, tagNames: string[], options
|
|
8
|
-
export declare const getPostListByUser: (context: ApiContext, userId: string, options
|
|
9
|
-
export declare const getPostListByArea: (context: ApiContext, latitude: number, longitude: number,
|
|
10
|
+
export declare const getPostList: (context: ApiContext, options?: PostOptions) => Promise<PostType[]>;
|
|
11
|
+
export declare const getPostListByGroup: (context: ApiContext, groupId: string, options?: PostOptions) => Promise<PostType[]>;
|
|
12
|
+
export declare const getPostListByLatest: (context: ApiContext, options?: PostOptions) => Promise<PostType[]>;
|
|
13
|
+
export declare const getPostListByTags: (context: ApiContext, tagNames: string[], options?: PostOptions) => Promise<PostType[]>;
|
|
14
|
+
export declare const getPostListByUser: (context: ApiContext, userId: string, options?: PostOptions) => Promise<PostType[]>;
|
|
15
|
+
export declare const getPostListByArea: (context: ApiContext, latitude: number, longitude: number, options?: PostOptions) => Promise<PostType[]>;
|
|
10
16
|
export declare const getPost: (context: ApiContext, itemId: string) => Promise<PostType>;
|
|
11
|
-
export declare const getPostComments: (context: ApiContext, itemId: string,
|
|
17
|
+
export declare const getPostComments: (context: ApiContext, itemId: string, options?: PostOptions) => Promise<PostType[]>;
|
|
12
18
|
export declare const addPost: (context: ApiContext, item: PostType) => Promise<PostType>;
|
|
13
19
|
export declare const updatePost: (context: ApiContext, item: PostType) => Promise<PostType>;
|
|
14
20
|
export declare const deletePost: (context: ApiContext, itemId: string) => Promise<PostType>;
|
package/lib/data/posts.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
function _templateObject8() {
|
|
2
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type ==
|
|
2
|
+
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n REMOVE p IN posts\n RETURN OLD"]);
|
|
3
3
|
|
|
4
4
|
_templateObject8 = function _templateObject8() {
|
|
5
5
|
return data;
|
|
@@ -39,7 +39,7 @@ function _templateObject5() {
|
|
|
39
39
|
}
|
|
40
40
|
|
|
41
41
|
function _templateObject4() {
|
|
42
|
-
var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", userId: ", "}\n
|
|
42
|
+
var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", userId: ", "}\n INSERT ", "\n UPDATE ", "\n IN posts RETURN NEW"]);
|
|
43
43
|
|
|
44
44
|
_templateObject4 = function _templateObject4() {
|
|
45
45
|
return data;
|
|
@@ -63,7 +63,7 @@ function _templateObject3() {
|
|
|
63
63
|
}
|
|
64
64
|
|
|
65
65
|
function _templateObject2() {
|
|
66
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n
|
|
66
|
+
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p.type == ", " && p._key == ", "\n LIMIT 1\n RETURN p"]);
|
|
67
67
|
|
|
68
68
|
_templateObject2 = function _templateObject2() {
|
|
69
69
|
return data;
|
|
@@ -73,7 +73,7 @@ function _templateObject2() {
|
|
|
73
73
|
}
|
|
74
74
|
|
|
75
75
|
function _templateObject() {
|
|
76
|
-
var data = _taggedTemplateLiteral(["FOR p IN posts\n
|
|
76
|
+
var data = _taggedTemplateLiteral(["FOR p IN posts\n FILTER p._key == ", "\n LIMIT 1\n RETURN p"]);
|
|
77
77
|
|
|
78
78
|
_templateObject = function _templateObject() {
|
|
79
79
|
return data;
|
|
@@ -97,6 +97,23 @@ import { updateFiles } from './files';
|
|
|
97
97
|
import { extractTags } from './tags'; // const eventCategory: string = 'posts';
|
|
98
98
|
|
|
99
99
|
var MAX_CONTENT_LENGTH = 100000;
|
|
100
|
+
export var parsePostOptions = function parsePostOptions() {
|
|
101
|
+
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
102
|
+
var _options$from = options.from,
|
|
103
|
+
from = _options$from === void 0 ? 0 : _options$from,
|
|
104
|
+
latitude = options.latitude,
|
|
105
|
+
longitude = options.longitude,
|
|
106
|
+
_options$to = options.to,
|
|
107
|
+
to = _options$to === void 0 ? 30 : _options$to,
|
|
108
|
+
_options$type = options.type,
|
|
109
|
+
type = _options$type === void 0 ? 'default' : _options$type;
|
|
110
|
+
return {
|
|
111
|
+
latitude: parseNum(latitude, 32),
|
|
112
|
+
longitude: parseNum(longitude, 32),
|
|
113
|
+
limit: getLimit(from, to),
|
|
114
|
+
type: parseChar(type, 32)
|
|
115
|
+
};
|
|
116
|
+
};
|
|
100
117
|
export var getPostOptional = function getPostOptional(fields) {
|
|
101
118
|
return fields.reduce(function (selects, field) {
|
|
102
119
|
switch (field) {
|
|
@@ -131,24 +148,27 @@ export var getPostOptional = function getPostOptional(fields) {
|
|
|
131
148
|
queries: []
|
|
132
149
|
});
|
|
133
150
|
};
|
|
134
|
-
export var getPostList = function getPostList(context,
|
|
151
|
+
export var getPostList = function getPostList(context, options) {
|
|
135
152
|
// const action: string = 'getListByApp';
|
|
136
153
|
var database = context.database,
|
|
137
154
|
fields = context.fields;
|
|
138
|
-
|
|
155
|
+
|
|
156
|
+
var _parsePostOptions = parsePostOptions(options),
|
|
157
|
+
limit = _parsePostOptions.limit,
|
|
158
|
+
type = _parsePostOptions.type;
|
|
139
159
|
|
|
140
160
|
var _getPostOptional = getPostOptional(fields),
|
|
141
161
|
selectObjects = _getPostOptional.objects,
|
|
142
162
|
selectQueries = _getPostOptional.queries;
|
|
143
163
|
|
|
144
|
-
var aqlQry = "FOR p IN posts\n FILTER p.privacy == \"public\" && p.parent == null\n ".concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
164
|
+
var aqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
145
165
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
146
166
|
return cursor.all();
|
|
147
167
|
}).catch(function (error) {
|
|
148
168
|
throw error;
|
|
149
169
|
});
|
|
150
170
|
};
|
|
151
|
-
export var getPostListByGroup = function getPostListByGroup(context, groupId,
|
|
171
|
+
export var getPostListByGroup = function getPostListByGroup(context, groupId, options) {
|
|
152
172
|
// const action: string = 'getListByGroup';
|
|
153
173
|
var database = context.database,
|
|
154
174
|
fields = context.fields,
|
|
@@ -168,8 +188,11 @@ export var getPostListByGroup = function getPostListByGroup(context, groupId, fr
|
|
|
168
188
|
var groups = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
|
169
189
|
|
|
170
190
|
if (groups.length) {
|
|
171
|
-
var
|
|
172
|
-
|
|
191
|
+
var _parsePostOptions2 = parsePostOptions(options),
|
|
192
|
+
limit = _parsePostOptions2.limit,
|
|
193
|
+
type = _parsePostOptions2.type;
|
|
194
|
+
|
|
195
|
+
var postAqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.groupId == \"").concat(formatGroupId, "\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
173
196
|
return db.query(postAqlQry).then(function (cursor) {
|
|
174
197
|
return cursor.all();
|
|
175
198
|
}).catch(function (error) {
|
|
@@ -182,17 +205,20 @@ export var getPostListByGroup = function getPostListByGroup(context, groupId, fr
|
|
|
182
205
|
throw error;
|
|
183
206
|
});
|
|
184
207
|
};
|
|
185
|
-
export var getPostListByLatest = function getPostListByLatest(context,
|
|
208
|
+
export var getPostListByLatest = function getPostListByLatest(context, options) {
|
|
186
209
|
// const action: string = 'getListByLatest';
|
|
187
210
|
var database = context.database,
|
|
188
211
|
fields = context.fields;
|
|
189
|
-
|
|
212
|
+
|
|
213
|
+
var _parsePostOptions3 = parsePostOptions(options),
|
|
214
|
+
limit = _parsePostOptions3.limit,
|
|
215
|
+
type = _parsePostOptions3.type;
|
|
190
216
|
|
|
191
217
|
var _getPostOptional3 = getPostOptional(fields),
|
|
192
218
|
selectObjects = _getPostOptional3.objects,
|
|
193
219
|
selectQueries = _getPostOptional3.queries;
|
|
194
220
|
|
|
195
|
-
var aqlQry = "FOR p IN posts\n FILTER p.privacy == \"public\" && p.parent == null\n ".concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
221
|
+
var aqlQry = "FOR p IN posts\n FILTER p.type == \"".concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
196
222
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
197
223
|
return cursor.all();
|
|
198
224
|
}).catch(function (error) {
|
|
@@ -203,12 +229,12 @@ export var getPostListByTags = function getPostListByTags(context, tagNames, opt
|
|
|
203
229
|
// const action: string = 'getListByTags';
|
|
204
230
|
var database = context.database,
|
|
205
231
|
fields = context.fields;
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
232
|
+
|
|
233
|
+
var _parsePostOptions4 = parsePostOptions(options),
|
|
234
|
+
latitude = _parsePostOptions4.latitude,
|
|
235
|
+
longitude = _parsePostOptions4.longitude,
|
|
236
|
+
limit = _parsePostOptions4.limit,
|
|
237
|
+
type = _parsePostOptions4.type;
|
|
212
238
|
|
|
213
239
|
var _getPostOptional4 = getPostOptional(fields),
|
|
214
240
|
selectObjects = _getPostOptional4.objects,
|
|
@@ -226,8 +252,7 @@ export var getPostListByTags = function getPostListByTags(context, tagNames, opt
|
|
|
226
252
|
|
|
227
253
|
sortBy.push('p.added');
|
|
228
254
|
return Promise.all(tagNames.map(function (tagName) {
|
|
229
|
-
var
|
|
230
|
-
var aqlQry = "FOR targetTag IN tags\n FILTER targetTag.name == \"".concat(tagName, "\"\n FOR p, e IN OUTBOUND targetTag._id isTagged\n ").concat(selectQueries.join('\n'), "\n FILTER p.privacy == \"public\" && e.type == 'posts'\n ").concat(limit.aql, "\n SORT ").concat(sortBy.join(', '), "\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
255
|
+
var aqlQry = "FOR targetTag IN tags\n FILTER targetTag.name == \"".concat(tagName, "\"\n FOR p, e IN OUTBOUND targetTag._id isTagged\n ").concat(selectQueries.join('\n'), "\n FILTER p.type = \"").concat(type, "\" && p.privacy == \"public\" && e.type == 'posts'\n ").concat(limit.aql, "\n SORT ").concat(sortBy.join(', '), "\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
231
256
|
console.log(aqlQry);
|
|
232
257
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
233
258
|
return cursor.all();
|
|
@@ -244,31 +269,35 @@ export var getPostListByUser = function getPostListByUser(context, userId, optio
|
|
|
244
269
|
// const action: string = 'getListByUser';
|
|
245
270
|
var database = context.database,
|
|
246
271
|
fields = context.fields;
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
272
|
+
|
|
273
|
+
var _parsePostOptions5 = parsePostOptions(options),
|
|
274
|
+
limit = _parsePostOptions5.limit,
|
|
275
|
+
type = _parsePostOptions5.type;
|
|
276
|
+
|
|
251
277
|
var formatUserId = parseId(userId);
|
|
252
|
-
var limit = getLimit(from, to);
|
|
253
278
|
|
|
254
279
|
var _getPostOptional5 = getPostOptional(fields),
|
|
255
280
|
selectObjects = _getPostOptional5.objects,
|
|
256
281
|
selectQueries = _getPostOptional5.queries;
|
|
257
282
|
|
|
258
|
-
var aqlQry = "FOR p IN posts\n FILTER p.userId == \"".concat(formatUserId, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
283
|
+
var aqlQry = "FOR p IN posts\n FILTER p.userId == \"".concat(formatUserId, "\" && p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parent == null\n ").concat(selectQueries.join('\n'), "\n ").concat(limit.aql, "\n SORT p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
259
284
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
260
285
|
return cursor.all();
|
|
261
286
|
}).catch(function (error) {
|
|
262
287
|
throw error;
|
|
263
288
|
});
|
|
264
289
|
};
|
|
265
|
-
export var getPostListByArea = function getPostListByArea(context, latitude, longitude,
|
|
290
|
+
export var getPostListByArea = function getPostListByArea(context, latitude, longitude, options) {
|
|
266
291
|
// const action: string = 'getListByUser';
|
|
267
292
|
var database = context.database,
|
|
268
293
|
fields = context.fields;
|
|
294
|
+
|
|
295
|
+
var _parsePostOptions6 = parsePostOptions(options),
|
|
296
|
+
limit = _parsePostOptions6.limit,
|
|
297
|
+
type = _parsePostOptions6.type;
|
|
298
|
+
|
|
269
299
|
var formatLatitude = parseNum(latitude);
|
|
270
300
|
var formatLongitude = parseNum(longitude);
|
|
271
|
-
var limit = getLimit(from, to);
|
|
272
301
|
|
|
273
302
|
var _getPostOptional6 = getPostOptional(fields),
|
|
274
303
|
selectObjects = _getPostOptional6.objects,
|
|
@@ -276,7 +305,7 @@ export var getPostListByArea = function getPostListByArea(context, latitude, lon
|
|
|
276
305
|
|
|
277
306
|
selectQueries.push("LET distance = DISTANCE(\n ".concat(formatLatitude, ",\n ").concat(formatLongitude, ",\n NOT_NULL(p.latitude, 0),\n NOT_NULL(p.longitude, 0))\n "));
|
|
278
307
|
selectObjects.push('distance:distance');
|
|
279
|
-
var aqlQry = "FOR p IN posts\n ".concat(selectQueries.join('\n'), "\n FILTER p.privacy == \"public\" && p.parentId == null\n ").concat(limit.aql, "\n SORT distance, p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
308
|
+
var aqlQry = "FOR p IN posts\n ".concat(selectQueries.join('\n'), "\n FILTER p.type == \"").concat(type, "\" && p.privacy == \"public\" && p.parentId == null\n ").concat(limit.aql, "\n SORT distance, p.added\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
|
|
280
309
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
281
310
|
return cursor.all();
|
|
282
311
|
}).catch(function (error) {
|
|
@@ -329,14 +358,19 @@ export var getPost = function getPost(context, itemId) {
|
|
|
329
358
|
throw error;
|
|
330
359
|
});
|
|
331
360
|
};
|
|
332
|
-
export var getPostComments = function getPostComments(context, itemId,
|
|
361
|
+
export var getPostComments = function getPostComments(context, itemId, options) {
|
|
333
362
|
// const action: string = 'getComments';
|
|
334
363
|
var database = context.database,
|
|
335
364
|
sessionId = context.userId;
|
|
365
|
+
|
|
366
|
+
var _parsePostOptions7 = parsePostOptions(options),
|
|
367
|
+
limit = _parsePostOptions7.limit,
|
|
368
|
+
type = _parsePostOptions7.type;
|
|
369
|
+
|
|
336
370
|
var formatItemId = parseId(itemId); // Get the parent post to get restrictions
|
|
337
371
|
|
|
338
372
|
var db = useDb(database);
|
|
339
|
-
var aqlQry = aql(_templateObject2(), formatItemId);
|
|
373
|
+
var aqlQry = aql(_templateObject2(), type, formatItemId);
|
|
340
374
|
return db.query(aqlQry).then(function (cursor) {
|
|
341
375
|
return cursor.next();
|
|
342
376
|
}).then(function () {
|
|
@@ -347,12 +381,11 @@ export var getPostComments = function getPostComments(context, itemId, from, to)
|
|
|
347
381
|
privacy = _post$privacy2 === void 0 ? 'public' : _post$privacy2; // Query based on privacy level
|
|
348
382
|
|
|
349
383
|
var privacyAqlQry;
|
|
350
|
-
var limit = getLimit(from, to);
|
|
351
384
|
|
|
352
385
|
if (groupId && privacy === 'group') {
|
|
353
|
-
privacyAqlQry = "FOR p IN posts\n
|
|
386
|
+
privacyAqlQry = "FOR p IN posts\n FOR user IN users\n FILTER p.parent == \"".concat(_key, "\" && user._key == p.userId\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n FOR group IN groups\n FILTER group._key == p.groupId\n FOR u, e IN OUTBOUND group._id isGrouped\n FILTER u._key == \"").concat(sessionId, "\"\n SORT p.added\n ").concat(limit.aql, "\n RETURN MERGE(p, {user: user, reactions: reactions})");
|
|
354
387
|
} else if (privacy === 'public') {
|
|
355
|
-
privacyAqlQry = "FOR p IN posts\n
|
|
388
|
+
privacyAqlQry = "FOR p IN posts\n FOR user IN users\n FILTER p.parent == \"".concat(_key, "\" && user._key == p.userId\n LET reactions = (\n FOR post, r IN INBOUND p._id reactions\n COLLECT reactionName = r.value INTO reactionItems\n RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n )\n SORT p.added\n ").concat(limit.aql, "\n RETURN MERGE(p, {user: user, reactions: reactions})");
|
|
356
389
|
}
|
|
357
390
|
|
|
358
391
|
if (privacyAqlQry) {
|
|
@@ -384,7 +417,9 @@ export var addPost = function addPost(context, item) {
|
|
|
384
417
|
_item$parentId = item.parentId,
|
|
385
418
|
parentId = _item$parentId === void 0 ? null : _item$parentId,
|
|
386
419
|
_item$privacy = item.privacy,
|
|
387
|
-
privacy = _item$privacy === void 0 ? 'public' : _item$privacy
|
|
420
|
+
privacy = _item$privacy === void 0 ? 'public' : _item$privacy,
|
|
421
|
+
_item$type = item.type,
|
|
422
|
+
type = _item$type === void 0 ? 'default' : _item$type;
|
|
388
423
|
var now = Date.now();
|
|
389
424
|
var insert = {
|
|
390
425
|
_key: createHash("post-".concat(sessionId)),
|
|
@@ -398,6 +433,7 @@ export var addPost = function addPost(context, item) {
|
|
|
398
433
|
name: parseString(name, 160),
|
|
399
434
|
parentId: parentId ? parseId(parentId) : undefined,
|
|
400
435
|
privacy: privacy ? parseVarChar(privacy, 16) : undefined,
|
|
436
|
+
type: parseChar(type, 32),
|
|
401
437
|
userId: sessionId
|
|
402
438
|
};
|
|
403
439
|
var db = useDb(database);
|
|
@@ -426,13 +462,15 @@ export var updatePost = function updatePost(context, item) {
|
|
|
426
462
|
name = item.name,
|
|
427
463
|
parentId = item.parentId,
|
|
428
464
|
postId = item.postId,
|
|
429
|
-
privacy = item.privacy
|
|
465
|
+
privacy = item.privacy,
|
|
466
|
+
type = item.type;
|
|
430
467
|
var update = {
|
|
431
468
|
content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,
|
|
432
469
|
modified: now,
|
|
433
470
|
name: name ? parseString(name, 160) : undefined,
|
|
434
471
|
parentId: parentId ? parseString(parentId, 160) : undefined,
|
|
435
|
-
privacy: privacy ? parseVarChar(privacy, 16) : undefined
|
|
472
|
+
privacy: privacy ? parseVarChar(privacy, 16) : undefined,
|
|
473
|
+
type: type !== undefined ? parseChar(type, 16) : undefined
|
|
436
474
|
};
|
|
437
475
|
var formatId = parseId(postId);
|
|
438
476
|
formatId = formatId === '' ? createHash("post-".concat(sessionId)) : formatId;
|
|
@@ -537,4 +575,4 @@ export var createPostEdge = function createPostEdge(db, file, postId) {
|
|
|
537
575
|
throw error;
|
|
538
576
|
});
|
|
539
577
|
};
|
|
540
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["createHash","parseChar","parseId","parseNum","parseString","parseVarChar","aql","flatten","uniqBy","getLimit","useDb","updateFiles","extractTags","MAX_CONTENT_LENGTH","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPostList","context","from","to","database","limit","selectObjects","selectQueries","aqlQry","join","query","then","cursor","all","catch","error","getPostListByGroup","groupId","sessionId","userId","formatGroupId","db","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","options","latitude","longitude","sortBy","undefined","formatLatitude","formatLongitude","Promise","map","tagName","console","log","results","getPostListByUser","formatUserId","getPostListByArea","getPost","itemId","formatItemId","next","post","_key","privacy","privacyAqlQry","filteredPost","getPostComments","addPost","item","content","location","name","parentId","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","fileId","id","edgeId","formatPostId","fileType","edge","type","save"],"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, parseChar, parseId, parseNum, parseString, parseVarChar} 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 {ApiContext, ArangoDBLimit, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\nconst MAX_CONTENT_LENGTH: number = 100000;\n\nexport const getPostOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND p._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER p.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPostList = (context: ApiContext, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostListByGroup = (context: ApiContext, groupId: string, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const limit: ArangoDBLimit = getLimit(from, to);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER p.groupId == \"${formatGroupId}\" && p.parent == null\n          ${selectQueries.join('\\n')}\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostListByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields} = context;\n  const {latitude, longitude, from = 0, to = 30} = options;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const sortBy: string[] = [];\n\n  if(latitude !== undefined && longitude !== undefined) {\n    const formatLatitude: number = parseNum(latitude);\n    const formatLongitude: number = parseNum(longitude);\n    selectQueries.push(`LET distance = DISTANCE(\n      ${formatLatitude},\n      ${formatLongitude},\n      NOT_NULL(p.latitude, 0),\n      NOT_NULL(p.longitude, 0))\n    `);\n    selectObjects.push('distance:distance');\n    sortBy.push('distance');\n  }\n\n  sortBy.push('p.added');\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR targetTag IN tags\n        FILTER targetTag.name == \"${tagName}\"\n        FOR p, e IN OUTBOUND targetTag._id isTagged\n        ${selectQueries.join('\\n')}\n        FILTER p.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      console.log(aqlQry);\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch(() => []);\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, options): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {from = 0, to = 30} = options;\n  const formatUserId: string = parseId(userId);\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostListByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  from: number,\n  to: number\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  selectQueries.push(`LET distance = DISTANCE(\n    ${formatLatitude},\n    ${formatLongitude},\n    NOT_NULL(p.latitude, 0),\n    NOT_NULL(p.longitude, 0))\n  `);\n  selectObjects.push('distance:distance');\n\n  const aqlQry: string = `FOR p IN posts\n    ${selectQueries.join('\\n')}\n    FILTER p.privacy == \"public\" && p.parentId == null\n    ${limit.aql}\n    SORT distance, p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, fields, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId}\n      LIMIT 1\n      RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostComments = (context: ApiContext, itemId: string, from: number, to: number): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId}\n      LIMIT 1\n      RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n      const limit = getLimit(from, to);\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n            FOR user IN users\n            FILTER p.parent == \"${_key}\" && user._key == p.userId\n            LET reactions = (\n              FOR post, r IN INBOUND p._id reactions\n              COLLECT reactionName = r.value INTO reactionItems\n              RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n            )\n            FOR group IN groups\n            FILTER group._key == p.groupId\n            FOR u, e IN OUTBOUND group._id isGrouped\n            FILTER u._key == \"${sessionId}\"\n            SORT p.added\n            ${limit.aql}\n            RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n            FOR user IN users\n            FILTER p.parent == \"${_key}\" && user._key == p.userId\n            LET reactions = (\n              FOR post, r IN INBOUND p._id reactions\n              COLLECT reactionName = r.value INTO reactionItems\n              RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n            )\n            SORT p.added\n            ${limit.aql}\n            RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    content = '',\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public'\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH),\n    groupId: groupId ? parseId(groupId) : undefined,\n    latitude: latitude !== undefined ? parseNum(latitude) : undefined,\n    location: location ? parseString(location, 160) : undefined,\n    longitude: longitude !== undefined ? parseNum(longitude) : undefined,\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parentId ? parseId(parentId) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    userId: sessionId\n  };\n\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.content)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    content,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    modified: now,\n    name: name ? parseString(name, 160) : undefined,\n    parentId: parentId ? parseString(parentId, 160) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n  };\n\n  let formatId: string = parseId(postId);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatId}, userId: ${sessionId}}\n      INSERT ${insert}\n      UPDATE ${update}\n      IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.content || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, formatId, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n}\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const fileId: string = parseId(file.id);\n  const edgeId: string = createHash(`file-${postId}-${fileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${fileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|
|
578
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["createHash","parseChar","parseId","parseNum","parseString","parseVarChar","aql","flatten","uniqBy","getLimit","useDb","updateFiles","extractTags","MAX_CONTENT_LENGTH","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPostList","context","database","selectObjects","selectQueries","aqlQry","join","query","then","cursor","all","catch","error","getPostListByGroup","groupId","sessionId","userId","formatGroupId","db","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","sortBy","undefined","formatLatitude","formatLongitude","Promise","map","tagName","console","log","results","getPostListByUser","formatUserId","getPostListByArea","getPost","itemId","formatItemId","next","post","_key","privacy","privacyAqlQry","filteredPost","getPostComments","addPost","item","content","location","name","parentId","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","fileId","id","edgeId","formatPostId","fileType","edge","save"],"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, parseChar, parseId, parseNum, parseString, parseVarChar} 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 {ApiContext, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\nconst MAX_CONTENT_LENGTH: number = 100000;\n\nexport const parsePostOptions = (options: PostOptions = {}) => {\n  const {\n    from = 0,\n    latitude,\n    longitude,\n    to = 30,\n    type = 'default'\n  } = options;\n\n\n  return {\n    latitude: parseNum(latitude, 32),\n    longitude: parseNum(longitude, 32),\n    limit: getLimit(from, to),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getPostOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND p._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER p.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostListByGroup = (context: ApiContext, groupId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const {limit, type} = parsePostOptions(options);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER p.type == \"${type}\" && p.groupId == \"${formatGroupId}\" && p.parent == null\n          ${selectQueries.join('\\n')}\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostListByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const sortBy: string[] = [];\n\n  if(latitude !== undefined && longitude !== undefined) {\n    const formatLatitude: number = parseNum(latitude);\n    const formatLongitude: number = parseNum(longitude);\n    selectQueries.push(`LET distance = DISTANCE(\n      ${formatLatitude},\n      ${formatLongitude},\n      NOT_NULL(p.latitude, 0),\n      NOT_NULL(p.longitude, 0))\n    `);\n    selectObjects.push('distance:distance');\n    sortBy.push('distance');\n  }\n\n  sortBy.push('p.added');\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const aqlQry: string = `FOR targetTag IN tags\n        FILTER targetTag.name == \"${tagName}\"\n        FOR p, e IN OUTBOUND targetTag._id isTagged\n        ${selectQueries.join('\\n')}\n        FILTER p.type = \"${type}\" && p.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      console.log(aqlQry);\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch(() => []);\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPostListByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  selectQueries.push(`LET distance = DISTANCE(\n    ${formatLatitude},\n    ${formatLongitude},\n    NOT_NULL(p.latitude, 0),\n    NOT_NULL(p.longitude, 0))\n  `);\n  selectObjects.push('distance:distance');\n\n  const aqlQry: string = `FOR p IN posts\n    ${selectQueries.join('\\n')}\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parentId == null\n    ${limit.aql}\n    SORT distance, p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\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 getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, fields, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostComments = (context: ApiContext, itemId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p.type == ${type} && p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == \"${sessionId}\"\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    content = '',\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public',\n    type = 'default'\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH),\n    groupId: groupId ? parseId(groupId) : undefined,\n    latitude: latitude !== undefined ? parseNum(latitude) : undefined,\n    location: location ? parseString(location, 160) : undefined,\n    longitude: longitude !== undefined ? parseNum(longitude) : undefined,\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parentId ? parseId(parentId) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: parseChar(type, 32),\n    userId: sessionId\n  };\n\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.content)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    content,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy,\n    type\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    modified: now,\n    name: name ? parseString(name, 160) : undefined,\n    parentId: parentId ? parseString(parentId, 160) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: type !== undefined ? parseChar(type, 16) : undefined\n  };\n\n  let formatId: string = parseId(postId);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.content || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, formatId, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n}\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const fileId: string = parseId(file.id);\n  const edgeId: string = createHash(`file-${postId}-${fileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${fileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|