@nlabs/reaktor 0.3.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/lib/config.js +153 -0
  2. package/lib/data/conversations.js +311 -0
  3. package/lib/data/dynamodb.js +206 -0
  4. package/lib/data/email.js +222 -0
  5. package/lib/data/files.js +525 -0
  6. package/lib/data/groups.js +435 -0
  7. package/lib/data/images.d.ts +3 -2
  8. package/lib/data/images.js +1051 -0
  9. package/lib/data/index.js +266 -0
  10. package/lib/data/ios.js +355 -0
  11. package/lib/data/locations.js +172 -0
  12. package/lib/data/messages.js +299 -0
  13. package/lib/data/notifications.d.ts +2 -2
  14. package/lib/data/notifications.js +59 -0
  15. package/lib/data/payments.js +771 -0
  16. package/lib/data/posts.d.ts +1 -1
  17. package/lib/data/posts.js +766 -0
  18. package/lib/data/reactions.js +529 -0
  19. package/lib/data/s3.js +155 -0
  20. package/lib/data/search.js +155 -0
  21. package/lib/data/sms.js +83 -0
  22. package/lib/data/subscription.js +337 -0
  23. package/lib/data/tags.js +397 -0
  24. package/lib/data/users.d.ts +7 -4
  25. package/lib/data/users.js +470 -0
  26. package/lib/data/websockets.js +250 -0
  27. package/lib/index.js +45 -0
  28. package/lib/types/apps.js +2 -0
  29. package/lib/types/arangodb.js +2 -0
  30. package/lib/types/auth.js +2 -0
  31. package/lib/types/conversations.d.ts +2 -0
  32. package/lib/types/conversations.js +2 -0
  33. package/lib/types/email.js +2 -0
  34. package/lib/types/files.js +2 -0
  35. package/lib/types/google.js +2 -0
  36. package/lib/types/groups.js +2 -0
  37. package/lib/types/images.js +2 -0
  38. package/lib/types/index.js +227 -0
  39. package/lib/types/locations.js +2 -0
  40. package/lib/types/messages.js +2 -0
  41. package/lib/types/notifications.js +2 -0
  42. package/lib/types/payments.js +2 -0
  43. package/lib/types/posts.js +2 -0
  44. package/lib/types/reactions.d.ts +2 -0
  45. package/lib/types/reactions.js +2 -0
  46. package/lib/types/tags.js +2 -0
  47. package/lib/types/users.d.ts +1 -0
  48. package/lib/types/users.js +2 -0
  49. package/lib/utils/analytics.js +83 -0
  50. package/lib/utils/arangodb.js +143 -0
  51. package/lib/utils/auth.js +75 -0
  52. package/lib/utils/graphql.js +21 -0
  53. package/lib/utils/index.js +84 -0
  54. package/lib/utils/objects.js +62 -0
  55. package/lib/utils/redis.js +36 -0
  56. package/package.json +30 -30
@@ -0,0 +1,525 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
4
+
5
+ require("core-js/modules/es.symbol");
6
+
7
+ require("core-js/modules/es.symbol.description");
8
+
9
+ require("core-js/modules/es.array.concat");
10
+
11
+ require("core-js/modules/es.array.filter");
12
+
13
+ require("core-js/modules/es.array.for-each");
14
+
15
+ require("core-js/modules/es.array.iterator");
16
+
17
+ require("core-js/modules/es.array.last-index-of");
18
+
19
+ require("core-js/modules/es.array.map");
20
+
21
+ require("core-js/modules/es.array.slice");
22
+
23
+ require("core-js/modules/es.date.now");
24
+
25
+ require("core-js/modules/es.date.to-string");
26
+
27
+ require("core-js/modules/es.function.name");
28
+
29
+ require("core-js/modules/es.object.define-properties");
30
+
31
+ require("core-js/modules/es.object.define-property");
32
+
33
+ require("core-js/modules/es.object.freeze");
34
+
35
+ require("core-js/modules/es.object.get-own-property-descriptor");
36
+
37
+ require("core-js/modules/es.object.get-own-property-descriptors");
38
+
39
+ require("core-js/modules/es.object.keys");
40
+
41
+ require("core-js/modules/es.object.to-string");
42
+
43
+ require("core-js/modules/es.promise");
44
+
45
+ require("core-js/modules/es.regexp.exec");
46
+
47
+ require("core-js/modules/es.regexp.to-string");
48
+
49
+ require("core-js/modules/es.string.iterator");
50
+
51
+ require("core-js/modules/es.string.match");
52
+
53
+ require("core-js/modules/es.string.search");
54
+
55
+ require("core-js/modules/es.string.split");
56
+
57
+ require("core-js/modules/web.dom-collections.for-each");
58
+
59
+ require("core-js/modules/web.dom-collections.iterator");
60
+
61
+ Object.defineProperty(exports, "__esModule", {
62
+ value: true
63
+ });
64
+ exports.decodeBase64 = exports.encodeBase64 = exports.updateFiles = exports.linkFiles = exports.createFile = exports.getUrlUserFiles = exports.getPathUserFiles = exports.getYouTubeSearch = exports.getYouTubeTrends = exports.getGiphySearch = exports.getGiphyTrends = exports.addFile = void 0;
65
+
66
+ var _ripHunter = require("@nlabs/rip-hunter");
67
+
68
+ var _utils = require("@nlabs/utils");
69
+
70
+ var _arangojs = require("arangojs");
71
+
72
+ var _googleapis = require("googleapis");
73
+
74
+ var _graphqlErrors = require("graphql-errors");
75
+
76
+ var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
77
+
78
+ var request = _interopRequireWildcard(require("request-promise"));
79
+
80
+ var _config = require("../config");
81
+
82
+ var _utils2 = require("../utils");
83
+
84
+ var _images = require("./images");
85
+
86
+ var _posts = require("./posts");
87
+
88
+ function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
89
+
90
+ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
91
+
92
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
93
+
94
+ function _templateObject3() {
95
+ var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isPosted"]);
96
+
97
+ _templateObject3 = function _templateObject3() {
98
+ return data;
99
+ };
100
+
101
+ return data;
102
+ }
103
+
104
+ function _templateObject2() {
105
+ var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE {}\n IN files RETURN NEW"]);
106
+
107
+ _templateObject2 = function _templateObject2() {
108
+ return data;
109
+ };
110
+
111
+ return data;
112
+ }
113
+
114
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
115
+
116
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
117
+
118
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
119
+
120
+ function _templateObject() {
121
+ var data = _taggedTemplateLiteral(["INSERT ", " IN files RETURN NEW"]);
122
+
123
+ _templateObject = function _templateObject() {
124
+ return data;
125
+ };
126
+
127
+ return data;
128
+ }
129
+
130
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
131
+
132
+ /**
133
+ * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
134
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
135
+ */
136
+ var youtube = _googleapis.google.youtube({
137
+ auth: _config.Config.get('google.key'),
138
+ version: 'v3'
139
+ });
140
+
141
+ request.defaults({
142
+ encoding: null
143
+ }); // const eventCategory: string = 'files';
144
+ // Upload file
145
+
146
+ var addFile = function addFile(context) {
147
+ var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
148
+ var database = context.database,
149
+ sessionId = context.userId,
150
+ userAccess = context.userAccess;
151
+ var description = item.description,
152
+ fileId = item.fileId,
153
+ fileType = item.fileType,
154
+ name = item.name,
155
+ url = item.url; // Id
156
+
157
+ var formatFileId = fileId ? (0, _utils.parseId)(fileId) : (0, _utils.createHash)("file-".concat(sessionId)); // Name
158
+
159
+ var isUrl = (0, _isEmpty["default"])(url); // If no name, get it from url path
160
+
161
+ var formatName = (0, _utils.parseString)(name, 160);
162
+ var formatType = (0, _utils.parseString)(fileType, 16);
163
+
164
+ if (formatName === '' && isUrl) {
165
+ formatName = url.substring(url.lastIndexOf('/') + 1);
166
+ }
167
+
168
+ if (formatType === '') {
169
+ var nameArr = formatName.split('.');
170
+ var ext = nameArr[nameArr.length - 1];
171
+
172
+ switch (ext) {
173
+ case 'jpeg':
174
+ case 'jpg':
175
+ formatType = 'image/jpeg';
176
+ break;
177
+
178
+ case 'png':
179
+ formatType = 'image/png';
180
+ break;
181
+
182
+ case 'zip':
183
+ formatType = 'application/zip';
184
+ break;
185
+
186
+ default:
187
+ break;
188
+ }
189
+ }
190
+
191
+ var isImage;
192
+
193
+ switch (formatType) {
194
+ case 'image/jpeg':
195
+ case 'image/png':
196
+ isImage = true;
197
+ break;
198
+
199
+ default:
200
+ isImage = false;
201
+ break;
202
+ } // Description
203
+
204
+
205
+ var formatDesc = (0, _utils.parseString)(description, 500); // Only allow file uploads to premium users
206
+
207
+ if (!isImage && userAccess !== 2) {
208
+ throw new _graphqlErrors.UserError('account_restriction');
209
+ }
210
+
211
+ var saveToDb = function saveToDb(insert) {
212
+ var aqlQry = (0, _arangojs.aql)(_templateObject(), insert);
213
+ return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
214
+ return cursor.next();
215
+ }).then(function () {
216
+ var file = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
217
+ return file;
218
+ })["catch"](function (error) {
219
+ throw error;
220
+ });
221
+ };
222
+
223
+ var uploadFile = function uploadFile(buf, uploadType) {
224
+ var now = Date.now(); // If image, resize and create a thumbnail
225
+
226
+ if (isImage) {
227
+ return (0, _images.resizeSaveImage)(context, formatFileId, buf, uploadType).then(function (resizedImage) {
228
+ var insert = _objectSpread(_objectSpread({}, resizedImage), {}, {
229
+ _key: formatFileId,
230
+ added: now,
231
+ description: formatDesc,
232
+ fileType: formatType,
233
+ modified: now,
234
+ name: formatName,
235
+ userId: sessionId
236
+ });
237
+
238
+ return saveToDb(insert);
239
+ })["catch"](function (error) {
240
+ throw error;
241
+ });
242
+ }
243
+
244
+ var insert = {
245
+ _key: formatFileId,
246
+ added: now,
247
+ description: formatDesc,
248
+ fileType: formatType,
249
+ modified: now,
250
+ name: formatName,
251
+ userId: sessionId
252
+ };
253
+ return saveToDb(insert);
254
+ }; // If file is a url path, download the file and save
255
+
256
+
257
+ if (isUrl) {
258
+ return request.get({
259
+ encoding: null,
260
+ uri: url
261
+ }).then(function (body) {
262
+ return uploadFile(Buffer.from(body, 'binary'), formatType);
263
+ })["catch"](function () {
264
+ throw new _graphqlErrors.UserError('file_request');
265
+ });
266
+ } else if (item.base64 !== '') {
267
+ var buffer = Buffer.from(item.base64);
268
+ return uploadFile(buffer, formatType);
269
+ }
270
+
271
+ throw new Error('file_required');
272
+ }; // Giphy
273
+
274
+
275
+ exports.addFile = addFile;
276
+
277
+ var getGiphyTrends = function getGiphyTrends(context) {
278
+ var limit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 30;
279
+ var gifUrl = "http://api.giphy.com/v1/gifs/trending?api_key=".concat(_config.Config.get('giphy.key'), "&limit=").concat(limit);
280
+ return (0, _ripHunter.get)(gifUrl).then(function (res) {
281
+ return res.json();
282
+ }).then(function (json) {
283
+ return json.data.map(function () {
284
+ var gifImage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
285
+ id: null,
286
+ images: null
287
+ };
288
+ var id = gifImage.id,
289
+ _gifImage$images = gifImage.images;
290
+ _gifImage$images = _gifImage$images === void 0 ? {} : _gifImage$images;
291
+ var _gifImage$images$orig = _gifImage$images.original;
292
+ _gifImage$images$orig = _gifImage$images$orig === void 0 ? {} : _gifImage$images$orig;
293
+ var _gifImage$images$orig2 = _gifImage$images$orig.url,
294
+ url = _gifImage$images$orig2 === void 0 ? '' : _gifImage$images$orig2,
295
+ _gifImage$images$fixe = _gifImage$images.fixed_height_small;
296
+ _gifImage$images$fixe = _gifImage$images$fixe === void 0 ? {} : _gifImage$images$fixe;
297
+ var _gifImage$images$fixe2 = _gifImage$images$fixe.url,
298
+ thumb = _gifImage$images$fixe2 === void 0 ? '' : _gifImage$images$fixe2;
299
+ return {
300
+ id: id,
301
+ thumb: thumb,
302
+ type: 'giphy',
303
+ url: url
304
+ };
305
+ });
306
+ });
307
+ };
308
+
309
+ exports.getGiphyTrends = getGiphyTrends;
310
+
311
+ var getGiphySearch = function getGiphySearch(context, query) {
312
+ var limit = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
313
+ var formatQuery = encodeURI(query);
314
+ var gifUrl = "http://api.giphy.com/v1/gifs/search?q=".concat(formatQuery, "&api_key=").concat(_config.Config.get('giphy.key'), "&limit=").concat(limit);
315
+ return fetch(gifUrl).then(function (res) {
316
+ return res.json();
317
+ }).then(function (json) {
318
+ return json.data.map(function () {
319
+ var gifImage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
320
+ id: null,
321
+ images: null
322
+ };
323
+ var id = gifImage.id,
324
+ _gifImage$images2 = gifImage.images;
325
+ _gifImage$images2 = _gifImage$images2 === void 0 ? {} : _gifImage$images2;
326
+ var _gifImage$images2$ori = _gifImage$images2.original;
327
+ _gifImage$images2$ori = _gifImage$images2$ori === void 0 ? {} : _gifImage$images2$ori;
328
+ var _gifImage$images2$ori2 = _gifImage$images2$ori.url,
329
+ url = _gifImage$images2$ori2 === void 0 ? '' : _gifImage$images2$ori2,
330
+ _gifImage$images2$fix = _gifImage$images2.fixed_height_small;
331
+ _gifImage$images2$fix = _gifImage$images2$fix === void 0 ? {} : _gifImage$images2$fix;
332
+ var _gifImage$images2$fix2 = _gifImage$images2$fix.url,
333
+ thumb = _gifImage$images2$fix2 === void 0 ? '' : _gifImage$images2$fix2;
334
+ return {
335
+ id: id,
336
+ thumb: thumb,
337
+ type: 'giphy',
338
+ url: url
339
+ };
340
+ });
341
+ });
342
+ };
343
+
344
+ exports.getGiphySearch = getGiphySearch;
345
+
346
+ var getYouTubeTrends = function getYouTubeTrends(context) {
347
+ var limit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 30;
348
+ return new Promise(function (resolve, reject) {
349
+ youtube.videos.list({
350
+ chart: 'mostPopular',
351
+ maxResults: limit,
352
+ part: ['snippet'],
353
+ regionCode: 'US'
354
+ }, function (error, data) {
355
+ if (error) {
356
+ console.error(error);
357
+ reject(new Error(error[0].message));
358
+ } else if (data) {
359
+ var list = data.items.map(function (item) {
360
+ return {
361
+ id: item.id,
362
+ thumb: item.snippet.thumbnails.high.url,
363
+ type: 'youtube',
364
+ url: "http://www.youtube.com/embed/".concat(item.id)
365
+ };
366
+ });
367
+ resolve(list);
368
+ }
369
+ });
370
+ });
371
+ };
372
+
373
+ exports.getYouTubeTrends = getYouTubeTrends;
374
+
375
+ var getYouTubeSearch = function getYouTubeSearch(context, query) {
376
+ var limit = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
377
+ return new Promise(function (resolve, reject) {
378
+ youtube.search.list({
379
+ maxResults: limit,
380
+ part: ['snippet'],
381
+ // eslint-disable-next-line
382
+ q: query,
383
+ regionCode: 'US'
384
+ }, function (error, data) {
385
+ if (error) {
386
+ console.error(error);
387
+ reject(new Error(error[0].message));
388
+ } else if (data) {
389
+ var items = data.items;
390
+ var list = items.map(function (item) {
391
+ return {
392
+ id: item.id,
393
+ thumb: item.snippet.thumbnails.high.url,
394
+ type: 'youtube',
395
+ url: "http://www.youtube.com/embed/".concat(item.id)
396
+ };
397
+ });
398
+ resolve(list);
399
+ }
400
+ });
401
+ });
402
+ }; // Files
403
+
404
+
405
+ exports.getYouTubeSearch = getYouTubeSearch;
406
+
407
+ var getPathUserFiles = function getPathUserFiles(userId, filename) {
408
+ return "users/".concat(userId, "/files/").concat(filename);
409
+ };
410
+
411
+ exports.getPathUserFiles = getPathUserFiles;
412
+
413
+ var getUrlUserFiles = function getUrlUserFiles(userId, filename) {
414
+ var dir = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'files';
415
+ var type = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'profile';
416
+
417
+ if (filename) {
418
+ return "https://box.".concat(_config.Config.get('app.url'), "/users/").concat(userId, "/").concat(dir, "/").concat(filename);
419
+ }
420
+
421
+ if (type === 'profile') {
422
+ return "https://box.".concat(_config.Config.get('app.url'), "/defaults/user_bk.jpg");
423
+ }
424
+
425
+ return "https://box.".concat(_config.Config.get('app.url'), "/defaults/user_wh.jpg");
426
+ };
427
+
428
+ exports.getUrlUserFiles = getUrlUserFiles;
429
+
430
+ var createFile = function createFile(db, file) {
431
+ var fileId = file.fileId;
432
+ var insert = {
433
+ _key: fileId,
434
+ added: Date.now()
435
+ };
436
+ var aqlQry = (0, _arangojs.aql)(_templateObject2(), fileId, insert);
437
+ return db.query(aqlQry).then(function (cursor) {
438
+ return cursor.next();
439
+ }).then(function () {
440
+ var updatedFile = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
441
+ return updatedFile;
442
+ })["catch"](function (error) {
443
+ throw error;
444
+ });
445
+ };
446
+
447
+ exports.createFile = createFile;
448
+
449
+ var linkFiles = function linkFiles(db, files, postId) {
450
+ return Promise.all(files.map(function (file) {
451
+ return createFile(db, file).then(function (file) {
452
+ return (0, _posts.createPostEdge)(db, file, postId);
453
+ });
454
+ }));
455
+ };
456
+
457
+ exports.linkFiles = linkFiles;
458
+
459
+ var updateFiles = function updateFiles(db, postId, files) {
460
+ var edgeCollection = db.collection('isPosted');
461
+ return edgeCollection.inEdges(postId).then(function (edges) {
462
+ if (edges.length) {
463
+ // Remove linked edges
464
+ return Promise.all(edges.map(function (edge) {
465
+ var edgeKey = edge._key;
466
+ var aqlQry = (0, _arangojs.aql)(_templateObject3(), edgeKey);
467
+ return db.query(aqlQry)["catch"](function (error) {
468
+ throw error;
469
+ });
470
+ })).then(function () {
471
+ if (files.length) {
472
+ // Link files
473
+ return linkFiles(db, files, postId).then(function () {
474
+ return files;
475
+ });
476
+ }
477
+
478
+ return files;
479
+ });
480
+ } else if (files.length) {
481
+ // Link files
482
+ return linkFiles(db, files, postId).then(function () {
483
+ return files;
484
+ });
485
+ }
486
+
487
+ return files;
488
+ })["catch"](function (error) {
489
+ throw error;
490
+ });
491
+ };
492
+
493
+ exports.updateFiles = updateFiles;
494
+
495
+ var encodeBase64 = function encodeBase64(buffer) {
496
+ return Buffer.from(buffer).toString('base64');
497
+ };
498
+
499
+ exports.encodeBase64 = encodeBase64;
500
+
501
+ var decodeBase64 = function decodeBase64(dataString) {
502
+ var getData = function getData(str) {
503
+ return str.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/) || [];
504
+ }; // const getData = (base64: string) => base64.substr(base64.indexOf(',') + 1);
505
+
506
+
507
+ var matches = getData(dataString);
508
+
509
+ if (matches.length !== 3) {
510
+ // If invalid make sure we don't need to decode
511
+ matches = getData(decodeURIComponent(dataString)); // Check it again.
512
+
513
+ if (matches.length !== 3) {
514
+ throw Error('Invalid input string');
515
+ }
516
+ }
517
+
518
+ return {
519
+ data: Buffer.from(matches[2], 'base64'),
520
+ type: matches[1]
521
+ };
522
+ };
523
+
524
+ exports.decodeBase64 = decodeBase64;
525
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/files.ts"],"names":["youtube","google","auth","Config","get","version","request","defaults","encoding","addFile","context","item","database","sessionId","userId","userAccess","description","fileId","fileType","name","url","formatFileId","isUrl","formatName","formatType","substring","lastIndexOf","nameArr","split","ext","length","isImage","formatDesc","UserError","saveToDb","insert","aqlQry","aql","query","then","cursor","next","file","error","uploadFile","buf","uploadType","now","Date","resizedImage","_key","added","modified","uri","body","Buffer","from","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","collection","inEdges","edges","edge","edgeKey","encodeBase64","toString","decodeBase64","dataString","getData","str","match","matches","decodeURIComponent"],"mappings":"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","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/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/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, userAccess} = context;\n  const {\n    description,\n    fileId,\n    fileType,\n    name,\n    url\n  } = item;\n\n  // Id\n  const formatFileId: string = fileId ? parseId(fileId) : createHash(`file-${sessionId}`);\n\n  // Name\n  const isUrl: boolean = isEmpty(url);\n\n  // If no name, get it from url path\n  let formatName: string = parseString(name, 160);\n  let formatType: string = parseString(fileType, 16);\n\n  if(formatName === '' && isUrl) {\n    formatName = url.substring(url.lastIndexOf('/') + 1);\n  }\n\n  if(formatType === '') {\n    const nameArr: string[] = formatName.split('.');\n    const ext: string = nameArr[nameArr.length - 1];\n\n    switch(ext) {\n      case 'jpeg':\n      case 'jpg':\n        formatType = 'image/jpeg';\n        break;\n      case 'png':\n        formatType = 'image/png';\n        break;\n      case 'zip':\n        formatType = 'application/zip';\n        break;\n      default:\n        break;\n    }\n  }\n\n  let isImage: boolean;\n\n  switch(formatType) {\n    case 'image/jpeg':\n    case 'image/png':\n      isImage = true;\n      break;\n    default:\n      isImage = false;\n      break;\n  }\n\n  // Description\n  const formatDesc: string = parseString(description, 500);\n\n  // Only allow file uploads to premium users\n  if(!isImage && userAccess !== 2) {\n    throw new UserError('account_restriction');\n  }\n\n  const saveToDb = (insert: FileType) => {\n    const aqlQry: AqlQuery = aql`INSERT ${insert} IN files RETURN NEW`;\n\n    return 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(Buffer.from(body, 'binary'), formatType))\n      .catch(() => {\n        throw new UserError('file_request');\n      });\n  } else if(item.base64 !== '') {\n    const buffer: Buffer = Buffer.from(item.base64);\n    return uploadFile(buffer, formatType);\n  }\n  throw new Error('file_required');\n};\n\n// Giphy\nexport const getGiphyTrends = (context: ApiContext, limit: number = 30): Promise<any[]> => {\n  const gifUrl: string = `http://api.giphy.com/v1/gifs/trending?api_key=${Config.get('giphy.key')}&limit=${limit}`;\n\n  return httpGet(gifUrl)\n    .then((res: Response) => res.json())\n    .then((json) => json.data.map((gifImage = {id: null, images: null}) => {\n      const {\n        id,\n        images: {\n          original: {url = ''} = {},\n          fixed_height_small: {url: thumb = ''} = {}\n        } = {}\n      } = gifImage;\n\n      return {\n        id,\n        thumb,\n        type: 'giphy',\n        url\n      };\n    }));\n};\n\nexport const getGiphySearch = (context: ApiContext, query: string, limit: number = 30): Promise<any[]> => {\n  const formatQuery: string = encodeURI(query);\n  const gifUrl: string = `http://api.giphy.com/v1/gifs/search?q=${formatQuery}&api_key=${Config.get('giphy.key')}&limit=${limit}`;\n\n  return fetch(gifUrl)\n    .then((res: Response) => res.json())\n    .then((json) => json.data.map((gifImage = {id: null, images: null}) => {\n      const {\n        id,\n        images: {\n          original: {url = ''} = {},\n          fixed_height_small: {url: thumb = ''} = {}\n        } = {}\n      } = gifImage;\n\n      return {\n        id,\n        thumb,\n        type: 'giphy',\n        url\n      };\n    }));\n};\n\nexport const getYouTubeTrends = (context: ApiContext, limit: number = 30): Promise<any[]> =>\n  new Promise((resolve, reject) => {\n    youtube.videos.list({\n      chart: 'mostPopular',\n      maxResults: limit,\n      part: ['snippet'],\n      regionCode: 'US'\n    }, (error: Error, data: any) => {\n      if(error) {\n        console.error(error);\n        reject(new Error(error[0].message));\n      } else if(data) {\n        const list = data.items.map((item) => ({\n          id: item.id,\n          thumb: item.snippet.thumbnails.high.url,\n          type: 'youtube',\n          url: `http://www.youtube.com/embed/${item.id}`\n        }));\n\n        resolve(list);\n      }\n    });\n  });\n\n\nexport const getYouTubeSearch = (context: ApiContext, query: string, limit: number = 30): Promise<any[]> =>\n  new Promise((resolve, reject) => {\n    youtube.search.list({\n      maxResults: limit,\n      part: ['snippet'],\n      // eslint-disable-next-line\n      q: query,\n      regionCode: 'US'\n    }, (error: Error, data: any) => {\n      if(error) {\n        console.error(error);\n        reject(new Error(error[0].message));\n      } else if(data) {\n        const {items} = data;\n        const list = items.map((item) => ({\n          id: item.id,\n          thumb: item.snippet.thumbnails.high.url,\n          type: 'youtube',\n          url: `http://www.youtube.com/embed/${item.id}`\n        }));\n\n        resolve(list);\n      }\n    });\n  });\n\n// Files\nexport const getPathUserFiles = (userId: string, filename: string): string => `users/${userId}/files/${filename}`;\n\nexport const getUrlUserFiles = (userId: string, filename: string, dir: string = 'files', type: string = 'profile'): string => {\n  if(filename) {\n    return `https://box.${Config.get('app.url')}/users/${userId}/${dir}/${filename}`;\n  }\n\n  if(type === 'profile') {\n    return `https://box.${Config.get('app.url')}/defaults/user_bk.jpg`;\n  }\n\n  return `https://box.${Config.get('app.url')}/defaults/user_wh.jpg`;\n};\n\nexport const createFile = (db: Database, file: FileType): Promise<FileType> => {\n  const {fileId} = file;\n  const insert: any = {\n    _key: fileId,\n    added: Date.now()\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${fileId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN files RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedFile: FileType = {}) => updatedFile)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const linkFiles = (db: Database, files: FileType[], postId: string): Promise<any> =>\n  Promise.all(\n    files.map((file: FileType) => createFile(db, file)\n      .then((file: FileType) => createPostEdge(db, file, postId)))\n  );\n\nexport const updateFiles = (db: Database, postId: string, files: FileType[]): Promise<any> => {\n  const edgeCollection: EdgeCollection = db.collection('isPosted');\n\n  return edgeCollection.inEdges(postId)\n    .then((edges: any) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry: AqlQuery = aql`REMOVE {_key:${edgeKey}} IN isPosted`;\n\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(files.length) {\n              // Link files\n              return linkFiles(db, files, postId).then(() => files);\n            }\n            return files;\n          });\n      } else if(files.length) {\n        // Link files\n        return linkFiles(db, files, postId).then(() => files);\n      }\n      return files;\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const encodeBase64 = (buffer: Buffer): string => Buffer.from(buffer).toString('base64');\n\nexport const decodeBase64 = (dataString: string): object => {\n  const getData = (str: string) => str.match(/^data:([A-Za-z-+\\/]+);base64,(.+)$/) || [];\n  // const getData = (base64: string) => base64.substr(base64.indexOf(',') + 1);\n  let matches = getData(dataString);\n\n  if(matches.length !== 3) {\n    // If invalid make sure we don't need to decode\n    matches = getData(decodeURIComponent(dataString));\n\n    // Check it again.\n    if(matches.length !== 3) {\n      throw Error('Invalid input string');\n    }\n  }\n\n  return {\n    data: Buffer.from(matches[2], 'base64'),\n    type: matches[1]\n  };\n};\n"]}