@nlabs/reaktor 0.1.2 → 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.
Files changed (144) hide show
  1. package/.DS_Store +0 -0
  2. package/lib/config.d.ts +21 -0
  3. package/lib/config.js +130 -0
  4. package/lib/data/conversations.d.ts +6 -0
  5. package/lib/data/conversations.js +197 -0
  6. package/lib/data/dynamodb.d.ts +8 -0
  7. package/lib/data/dynamodb.js +139 -0
  8. package/lib/data/email.d.ts +7 -0
  9. package/lib/data/email.js +163 -0
  10. package/lib/data/files.d.ts +16 -0
  11. package/lib/data/files.js +406 -0
  12. package/lib/data/groups.d.ts +13 -0
  13. package/lib/data/groups.js +354 -0
  14. package/lib/data/images.d.ts +12 -0
  15. package/lib/data/images.js +667 -0
  16. package/{src/data/index.ts → lib/data/index.d.ts} +1 -5
  17. package/lib/data/index.js +24 -0
  18. package/lib/data/ios.d.ts +6 -0
  19. package/lib/data/ios.js +302 -0
  20. package/lib/data/locations.d.ts +3 -0
  21. package/lib/data/locations.js +132 -0
  22. package/lib/data/messages.d.ts +9 -0
  23. package/lib/data/messages.js +248 -0
  24. package/lib/data/notifications.d.ts +5 -0
  25. package/lib/data/notifications.js +42 -0
  26. package/lib/data/payments.d.ts +11 -0
  27. package/lib/data/payments.js +748 -0
  28. package/lib/data/posts.d.ts +22 -0
  29. package/lib/data/posts.js +578 -0
  30. package/lib/data/reactions.d.ts +6 -0
  31. package/lib/data/reactions.js +218 -0
  32. package/lib/data/s3.d.ts +6 -0
  33. package/lib/data/s3.js +103 -0
  34. package/lib/data/search.d.ts +3 -0
  35. package/lib/data/search.js +98 -0
  36. package/lib/data/sms.d.ts +3 -0
  37. package/lib/data/sms.js +59 -0
  38. package/lib/data/subscription.d.ts +7 -0
  39. package/lib/data/subscription.js +284 -0
  40. package/lib/data/tags.d.ts +14 -0
  41. package/lib/data/tags.js +304 -0
  42. package/lib/data/users.d.ts +12 -0
  43. package/lib/data/users.js +310 -0
  44. package/lib/index.d.ts +3 -0
  45. package/lib/index.js +8 -0
  46. package/lib/types/apps.d.ts +43 -0
  47. package/lib/types/apps.js +2 -0
  48. package/lib/types/arangodb.d.ts +17 -0
  49. package/lib/types/arangodb.js +2 -0
  50. package/lib/types/auth.d.ts +10 -0
  51. package/lib/types/auth.js +2 -0
  52. package/lib/types/conversations.d.ts +6 -0
  53. package/lib/types/conversations.js +2 -0
  54. package/lib/types/email.d.ts +12 -0
  55. package/lib/types/email.js +2 -0
  56. package/lib/types/files.d.ts +26 -0
  57. package/lib/types/files.js +2 -0
  58. package/lib/types/google.d.ts +27 -0
  59. package/lib/types/google.js +2 -0
  60. package/lib/types/groups.d.ts +21 -0
  61. package/lib/types/groups.js +2 -0
  62. package/lib/types/images.d.ts +24 -0
  63. package/lib/types/images.js +2 -0
  64. package/{src/types/index.ts → lib/types/index.d.ts} +0 -4
  65. package/lib/types/index.js +22 -0
  66. package/lib/types/locations.d.ts +20 -0
  67. package/lib/types/locations.js +2 -0
  68. package/lib/types/messages.d.ts +12 -0
  69. package/lib/types/messages.js +2 -0
  70. package/lib/types/notifications.d.ts +19 -0
  71. package/lib/types/notifications.js +2 -0
  72. package/lib/types/payments.d.ts +114 -0
  73. package/lib/types/payments.js +2 -0
  74. package/lib/types/posts.d.ts +28 -0
  75. package/lib/types/posts.js +2 -0
  76. package/lib/types/reactions.d.ts +4 -0
  77. package/lib/types/reactions.js +2 -0
  78. package/lib/types/tags.d.ts +9 -0
  79. package/lib/types/tags.js +2 -0
  80. package/lib/types/users.d.ts +78 -0
  81. package/lib/types/users.js +2 -0
  82. package/lib/utils/analytics.d.ts +3 -0
  83. package/lib/utils/analytics.js +47 -0
  84. package/lib/utils/arangodb.d.ts +9 -0
  85. package/lib/utils/arangodb.js +98 -0
  86. package/lib/utils/auth.d.ts +7 -0
  87. package/lib/utils/auth.js +80 -0
  88. package/lib/utils/graphql.d.ts +1 -0
  89. package/lib/utils/graphql.js +7 -0
  90. package/{src/utils/index.ts → lib/utils/index.d.ts} +0 -4
  91. package/lib/utils/index.js +11 -0
  92. package/lib/utils/objects.d.ts +3 -0
  93. package/lib/utils/objects.js +34 -0
  94. package/lib/utils/redis.d.ts +1 -0
  95. package/lib/utils/redis.js +15 -0
  96. package/package.json +5 -5
  97. package/.vscode/extensions.json +0 -15
  98. package/.vscode/settings.json +0 -82
  99. package/lex.config.js +0 -4
  100. package/src/config.ts +0 -127
  101. package/src/data/conversations.ts +0 -181
  102. package/src/data/dynamodb.ts +0 -157
  103. package/src/data/email.ts +0 -163
  104. package/src/data/files.ts +0 -352
  105. package/src/data/groups.ts +0 -308
  106. package/src/data/images.ts +0 -606
  107. package/src/data/ios.ts +0 -249
  108. package/src/data/locations.ts +0 -114
  109. package/src/data/messages.ts +0 -237
  110. package/src/data/notifications.ts +0 -48
  111. package/src/data/payments.ts +0 -675
  112. package/src/data/posts.ts +0 -580
  113. package/src/data/reactions.ts +0 -186
  114. package/src/data/s3.ts +0 -117
  115. package/src/data/search.ts +0 -74
  116. package/src/data/sms.ts +0 -60
  117. package/src/data/subscription.ts +0 -228
  118. package/src/data/tags.ts +0 -230
  119. package/src/data/users.ts +0 -254
  120. package/src/index.ts +0 -7
  121. package/src/types/apps.ts +0 -56
  122. package/src/types/arangodb.ts +0 -23
  123. package/src/types/auth.ts +0 -20
  124. package/src/types/conversations.ts +0 -11
  125. package/src/types/email.ts +0 -17
  126. package/src/types/files.ts +0 -31
  127. package/src/types/google.ts +0 -37
  128. package/src/types/groups.ts +0 -27
  129. package/src/types/images.ts +0 -32
  130. package/src/types/locations.ts +0 -24
  131. package/src/types/messages.ts +0 -16
  132. package/src/types/notifications.ts +0 -26
  133. package/src/types/payments.ts +0 -129
  134. package/src/types/posts.ts +0 -34
  135. package/src/types/reactions.ts +0 -8
  136. package/src/types/tags.ts +0 -13
  137. package/src/types/users.ts +0 -89
  138. package/src/utils/analytics.ts +0 -41
  139. package/src/utils/arangodb.ts +0 -100
  140. package/src/utils/auth.ts +0 -61
  141. package/src/utils/graphql.ts +0 -7
  142. package/src/utils/objects.ts +0 -34
  143. package/src/utils/redis.ts +0 -17
  144. package/tsconfig.json +0 -45
@@ -0,0 +1,163 @@
1
+ /**
2
+ * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */
5
+ import aws, { SES } from 'aws-sdk';
6
+ import fs from 'fs';
7
+ import isEmpty from 'lodash/isEmpty';
8
+ import { Config } from '../config';
9
+ import { s3Get } from './s3'; // const eventCategory: string = 'email';
10
+
11
+ export var appTemplate = function appTemplate(app) {
12
+ var message = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
13
+ var vars = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
14
+ var updatedMessage = '';
15
+
16
+ if (!isEmpty(app)) {
17
+ updatedMessage = message.replace(/\[appName\]/g, app.name).replace(/\[appUrl\]/g, app.url).replace(/\[appEmail\]/g, app.email);
18
+ }
19
+
20
+ Object.keys(vars).forEach(function (key) {
21
+ if (vars[key]) {
22
+ updatedMessage = message.replace(new RegExp("\\[".concat(key, "\\]"), 'g'), vars[key]);
23
+ }
24
+ });
25
+ return updatedMessage;
26
+ };
27
+ export var sendEmail = function sendEmail(params) {
28
+ var _params$app = params.app,
29
+ app = _params$app === void 0 ? {} : _params$app,
30
+ html = params.html,
31
+ subject = params.subject,
32
+ _params$subTitle = params.subTitle,
33
+ subTitle = _params$subTitle === void 0 ? '' : _params$subTitle,
34
+ text = params.text,
35
+ _params$title = params.title,
36
+ title = _params$title === void 0 ? '' : _params$title,
37
+ _params$user = params.user,
38
+ user = _params$user === void 0 ? {} : _params$user;
39
+ var to = [user.email];
40
+ var promise;
41
+ var formatSubject = appTemplate(app, subject);
42
+ var formatSubTitle = appTemplate(app, subTitle);
43
+ var formatTitle = appTemplate(app, title);
44
+ var formatText = appTemplate(app, text);
45
+ var formatHtml = appTemplate(app, html);
46
+ var hasCustomEmail = app._key,
47
+ urlFacebook = app.urlFacebook,
48
+ urlTwitter = app.urlTwitter;
49
+
50
+ var parseTemplate = function parseTemplate(body) {
51
+ var templateBody = appTemplate(app, body || ''); // Links
52
+
53
+ var links = '';
54
+ var spacer = '<td width="5"><img width="1" height="1" border="0" title="" alt="" ' + 'src="https://box.reaktor.io/images/email/spacer.gif"/></td>';
55
+
56
+ if (urlFacebook) {
57
+ links = "<td width=\"30\"><a href=\"".concat(urlFacebook, "\"><img width=\"30\" height=\"30\" border=\"0\" ") + 'title="Facebook" alt="Facebook" src="https://box.reaktor.io/images/email/icon-facebook.png"/></a></td>';
58
+ }
59
+
60
+ if (urlTwitter) {
61
+ if (urlFacebook) {
62
+ links += spacer;
63
+ }
64
+
65
+ links += "<td width=\"30\"><a href=\"".concat(urlTwitter, "\"><img width=\"30\" height=\"30\" border=\"0\" ") + 'title="Twitter" alt="Twitter" src="https://box.reaktor.io/images/email/icon-twitter.png"/></a></td>';
66
+ }
67
+
68
+ if (!links.length) {
69
+ links += spacer;
70
+ }
71
+
72
+ return templateBody.replace(/\[title\]/g, formatTitle).replace(/\[subTitle\]/g, formatSubTitle).replace(/\[subject\]/g, formatSubject).replace(/\[message\]/g, formatHtml).replace(/\[links\]/g, links);
73
+ };
74
+
75
+ if (hasCustomEmail) {
76
+ var s3Params = {
77
+ Bucket: null,
78
+ Key: "apps/templates/email.html"
79
+ };
80
+ promise = s3Get(s3Params).then(function (results) {
81
+ return parseTemplate(results.Body.toString());
82
+ });
83
+ } else {
84
+ promise = new Promise(function (resolve, reject) {
85
+ fs.readFile('./templates/email/layout.html', 'utf8', function (err, data) {
86
+ if (err) {
87
+ return reject(err);
88
+ }
89
+
90
+ return resolve(parseTemplate(data));
91
+ });
92
+ });
93
+ }
94
+
95
+ return promise.then(function (parsedHtml) {
96
+ var emailParams = {
97
+ Destination: {
98
+ ToAddresses: to
99
+ },
100
+ Message: {
101
+ Body: {
102
+ Html: {
103
+ Data: parsedHtml
104
+ },
105
+ Text: {
106
+ Data: formatText
107
+ }
108
+ },
109
+ Subject: {
110
+ Data: formatSubject
111
+ }
112
+ },
113
+ Source: "\"".concat(app.supportName, "\" <noreply@").concat(Config.get('app.url'), ">")
114
+ };
115
+ return sesSend(emailParams);
116
+ });
117
+ };
118
+ export var sendTemplate = function sendTemplate(templateName, emailParams) {
119
+ var app = emailParams.app,
120
+ user = emailParams.user,
121
+ subject = emailParams.subject,
122
+ subTitle = emailParams.subTitle,
123
+ title = emailParams.title,
124
+ vars = emailParams.vars;
125
+
126
+ try {
127
+ var html = fs.readFileSync("./templates/email/".concat(templateName, ".html"), 'utf8');
128
+ var templateHtml = appTemplate(app, html, vars);
129
+ var text = fs.readFileSync("./templates/sms/".concat(templateName, ".txt"), 'utf8');
130
+ var templateText = appTemplate(app, text, vars);
131
+ var params = {
132
+ app: app,
133
+ html: templateHtml,
134
+ subTitle: subTitle,
135
+ subject: subject,
136
+ text: templateText,
137
+ title: title,
138
+ user: user
139
+ };
140
+ return sendEmail(params).then(function () {
141
+ return true;
142
+ }).catch(function () {
143
+ return false;
144
+ });
145
+ } catch (error) {
146
+ return Promise.reject(error);
147
+ }
148
+ }; // AWS::SES
149
+
150
+ export var sesSend = function sesSend(params) {
151
+ return new Promise(function (resolve, reject) {
152
+ aws.config.update(Config.get('aws'));
153
+ var ses = new SES();
154
+ ses.sendEmail(params, function (error, response) {
155
+ if (error) {
156
+ return reject(error);
157
+ }
158
+
159
+ return resolve(response);
160
+ });
161
+ });
162
+ };
163
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/email.ts"],"names":["aws","SES","fs","isEmpty","Config","s3Get","appTemplate","app","message","vars","updatedMessage","replace","name","url","email","Object","keys","forEach","key","RegExp","sendEmail","params","html","subject","subTitle","text","title","user","to","promise","formatSubject","formatSubTitle","formatTitle","formatText","formatHtml","hasCustomEmail","_key","urlFacebook","urlTwitter","parseTemplate","body","templateBody","links","spacer","length","s3Params","Bucket","Key","then","results","Body","toString","Promise","resolve","reject","readFile","err","data","parsedHtml","emailParams","Destination","ToAddresses","Message","Html","Data","Text","Subject","Source","supportName","get","sesSend","sendTemplate","templateName","readFileSync","templateHtml","templateText","catch","error","config","update","ses","response"],"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 aws, {SES} from 'aws-sdk';\nimport {GetObjectRequest} from 'aws-sdk/clients/s3';\nimport {SendEmailRequest, SendEmailResponse} from 'aws-sdk/clients/ses';\nimport fs from 'fs';\nimport isEmpty from 'lodash/isEmpty';\n\nimport {Config} from '../config';\nimport {AppType} from '../types/apps';\nimport {EmailType} from '../types/email';\nimport {s3Get} from './s3';\n\n// const eventCategory: string = 'email';\n\nexport const appTemplate = (app: AppType, message: string = '', vars = {}): string => {\n  let updatedMessage: string = '';\n\n  if(!isEmpty(app)) {\n    updatedMessage = message.replace(/\\[appName\\]/g, app.name)\n      .replace(/\\[appUrl\\]/g, app.url)\n      .replace(/\\[appEmail\\]/g, app.email);\n  }\n\n  Object.keys(vars).forEach((key: string) => {\n    if(vars[key]) {\n      updatedMessage = message.replace(new RegExp(`\\\\[${key}\\\\]`, 'g'), vars[key]);\n    }\n  });\n\n  return updatedMessage;\n};\n\nexport const sendEmail = (params: EmailType): Promise<boolean> => {\n  const {\n    app = {},\n    html,\n    subject,\n    subTitle = '',\n    text,\n    title = '',\n    user = {}\n  } = params;\n\n  const to = [user.email];\n  let promise;\n\n  const formatSubject: string = appTemplate(app, subject);\n  const formatSubTitle: string = appTemplate(app, subTitle);\n  const formatTitle: string = appTemplate(app, title);\n  const formatText: string = appTemplate(app, text);\n  const formatHtml: string = appTemplate(app, html);\n  const {_key: hasCustomEmail, urlFacebook, urlTwitter} = app;\n\n  const parseTemplate = (body: string) => {\n    const templateBody: string = appTemplate(app, body || '');\n\n    // Links\n    let links: string = '';\n    const spacer = '<td width=\"5\"><img width=\"1\" height=\"1\" border=\"0\" title=\"\" alt=\"\" ' +\n      'src=\"https://box.reaktor.io/images/email/spacer.gif\"/></td>';\n\n    if(urlFacebook) {\n      links = `<td width=\"30\"><a href=\"${urlFacebook}\"><img width=\"30\" height=\"30\" border=\"0\" ` +\n        'title=\"Facebook\" alt=\"Facebook\" src=\"https://box.reaktor.io/images/email/icon-facebook.png\"/></a></td>';\n    }\n\n    if(urlTwitter) {\n      if(urlFacebook) {\n        links += spacer;\n      }\n\n      links += `<td width=\"30\"><a href=\"${urlTwitter}\"><img width=\"30\" height=\"30\" border=\"0\" ` +\n        'title=\"Twitter\" alt=\"Twitter\" src=\"https://box.reaktor.io/images/email/icon-twitter.png\"/></a></td>';\n    }\n\n    if(!links.length) {\n      links += spacer;\n    }\n\n    return templateBody.replace(/\\[title\\]/g, formatTitle)\n      .replace(/\\[subTitle\\]/g, formatSubTitle)\n      .replace(/\\[subject\\]/g, formatSubject)\n      .replace(/\\[message\\]/g, formatHtml)\n      .replace(/\\[links\\]/g, links);\n  };\n\n  if(hasCustomEmail) {\n    const s3Params: GetObjectRequest = {Bucket: null, Key: `apps/templates/email.html`};\n    promise = s3Get(s3Params).then((results) => parseTemplate(results.Body.toString()));\n  } else {\n    promise = new Promise((resolve, reject) => {\n      fs.readFile('./templates/email/layout.html', 'utf8', (err, data) => {\n        if(err) {\n          return reject(err);\n        }\n\n        return resolve(parseTemplate(data));\n      });\n    });\n  }\n\n  return promise.then((parsedHtml: string) => {\n    const emailParams: SendEmailRequest = {\n      Destination: {ToAddresses: to},\n      Message: {\n        Body: {\n          Html: {Data: parsedHtml},\n          Text: {Data: formatText}\n        },\n        Subject: {Data: formatSubject}\n      },\n      Source: `\"${app.supportName}\" <noreply@${Config.get('app.url')}>`\n    };\n\n    return sesSend(emailParams);\n  });\n};\n\nexport const sendTemplate = (templateName: string, emailParams: EmailType): Promise<boolean> => {\n  const {app, user, subject, subTitle, title, vars}: EmailType = emailParams;\n\n  try {\n    const html: string = fs.readFileSync(`./templates/email/${templateName}.html`, 'utf8');\n    const templateHtml: string = appTemplate(app, html, vars);\n    const text: string = fs.readFileSync(`./templates/sms/${templateName}.txt`, 'utf8');\n    const templateText: string = appTemplate(app, text, vars);\n\n    const params = {\n      app,\n      html: templateHtml,\n      subTitle,\n      subject,\n      text: templateText,\n      title,\n      user\n    };\n\n    return sendEmail(params)\n      .then(() => true)\n      .catch(() => false);\n  } catch(error) {\n    return Promise.reject(error);\n  }\n};\n\n// AWS::SES\nexport const sesSend = (params: SendEmailRequest): Promise<SendEmailResponse> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const ses: SES = new SES();\n\n    ses.sendEmail(params, (error: Error, response: SendEmailResponse) => {\n      if(error) {\n        return reject(error);\n      }\n\n      return resolve(response);\n    });\n  });\n};\n"]}
@@ -0,0 +1,16 @@
1
+ /// <reference types="node" />
2
+ import { Database } from 'arangojs';
3
+ import { ApiContext } from 'types/auth';
4
+ import { FileType } from '../types/files';
5
+ export declare const addFile: (context: ApiContext, item?: FileType) => Promise<FileType>;
6
+ export declare const getGiphyTrends: (context: ApiContext, limit?: number) => Promise<any[]>;
7
+ export declare const getGiphySearch: (context: ApiContext, query: string, limit?: number) => Promise<any[]>;
8
+ export declare const getYouTubeTrends: (context: ApiContext, limit?: number) => Promise<any[]>;
9
+ export declare const getYouTubeSearch: (context: ApiContext, query: string, limit?: number) => Promise<any[]>;
10
+ export declare const getPathUserFiles: (userId: string, filename: string) => string;
11
+ export declare const getUrlUserFiles: (userId: string, filename: string, dir?: string, type?: string) => string;
12
+ export declare const linkFiles: (db: Database, files: FileType[], postId: string) => Promise<any>;
13
+ export declare const updateFiles: (db: Database, postId: string, files: FileType[]) => Promise<any>;
14
+ export declare const createFile: (db: Database, file: FileType) => Promise<FileType>;
15
+ export declare const encodeBase64: (buffer: Buffer) => string;
16
+ export declare const decodeBase64: (dataString: string) => object;
@@ -0,0 +1,406 @@
1
+ function _templateObject3() {
2
+ var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE {}\n IN files RETURN NEW"]);
3
+
4
+ _templateObject3 = function _templateObject3() {
5
+ return data;
6
+ };
7
+
8
+ return data;
9
+ }
10
+
11
+ function _templateObject2() {
12
+ var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isPosted"]);
13
+
14
+ _templateObject2 = function _templateObject2() {
15
+ return data;
16
+ };
17
+
18
+ return data;
19
+ }
20
+
21
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
22
+
23
+ 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; }
24
+
25
+ function _templateObject() {
26
+ var data = _taggedTemplateLiteral(["INSERT ", " IN files RETURN NEW"]);
27
+
28
+ _templateObject = function _templateObject() {
29
+ return data;
30
+ };
31
+
32
+ return data;
33
+ }
34
+
35
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
36
+
37
+ /**
38
+ * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
39
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
40
+ */
41
+ import { get as httpGet } from '@nlabs/rip-hunter';
42
+ import { createHash, parseId, parseString } from '@nlabs/utils';
43
+ import { aql } from 'arangojs';
44
+ import { google } from 'googleapis';
45
+ import { UserError } from 'graphql-errors';
46
+ import * as request from 'request-promise';
47
+ import { Config } from '../config';
48
+ import { useDb } from '../utils';
49
+ import { resizeSaveImage } from './images';
50
+ import { createPostEdge } from './posts';
51
+ var youtube = google.youtube({
52
+ auth: Config.get('google.key'),
53
+ version: 'v3'
54
+ });
55
+ request.defaults({
56
+ encoding: null
57
+ }); // const eventCategory: string = 'files';
58
+ // Upload file
59
+
60
+ export var addFile = function addFile(context) {
61
+ var item = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
62
+ var database = context.database,
63
+ sessionId = context.userId,
64
+ userType = context.userType;
65
+ var _item$description = item.description,
66
+ description = _item$description === void 0 ? '' : _item$description,
67
+ _item$fileType = item.fileType,
68
+ fileType = _item$fileType === void 0 ? '' : _item$fileType,
69
+ id = item.id,
70
+ _item$name = item.name,
71
+ name = _item$name === void 0 ? '' : _item$name,
72
+ _item$url = item.url,
73
+ url = _item$url === void 0 ? '' : _item$url; // Id
74
+
75
+ var fileId = id ? parseId(id) : createHash("file-".concat(sessionId)); // Name
76
+
77
+ var isUrl = url !== ''; // If no name, get it from url path
78
+
79
+ var formatName = parseString(name, 160);
80
+ var formatType = parseString(fileType, 16);
81
+
82
+ if (formatName === '' && isUrl) {
83
+ formatName = url.substring(url.lastIndexOf('/') + 1);
84
+ }
85
+
86
+ if (formatType === '') {
87
+ var nameArr = formatName.split('.');
88
+ var ext = nameArr[nameArr.length - 1];
89
+
90
+ switch (ext) {
91
+ case 'jpeg':
92
+ case 'jpg':
93
+ formatType = 'image/jpeg';
94
+ break;
95
+
96
+ case 'png':
97
+ formatType = 'image/png';
98
+ break;
99
+
100
+ case 'zip':
101
+ formatType = 'application/zip';
102
+ break;
103
+
104
+ default:
105
+ break;
106
+ }
107
+ }
108
+
109
+ var isImage;
110
+
111
+ switch (formatType) {
112
+ case 'image/jpeg':
113
+ case 'image/png':
114
+ isImage = true;
115
+ break;
116
+
117
+ default:
118
+ isImage = false;
119
+ break;
120
+ } // Description
121
+
122
+
123
+ var formatDesc = parseString(description, 500); // Only allow file uploads to premium users
124
+
125
+ if (!isImage && userType !== 2) {
126
+ throw new UserError('account_restriction');
127
+ }
128
+
129
+ var saveToDb = function saveToDb(insert) {
130
+ var aqlQry = aql(_templateObject(), insert);
131
+ return useDb(database).query(aqlQry).then(function (cursor) {
132
+ return cursor.next();
133
+ }).then(function () {
134
+ var file = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
135
+ return file;
136
+ }).catch(function (error) {
137
+ throw error;
138
+ });
139
+ };
140
+
141
+ var uploadFile = function uploadFile(buf, uploadType) {
142
+ var now = Date.now(); // If image, resize and create a thumbnail
143
+
144
+ if (isImage) {
145
+ return resizeSaveImage(sessionId, fileId, buf, uploadType).then(function (resizedImage) {
146
+ var insert = _objectSpread({}, resizedImage, {
147
+ _key: fileId,
148
+ added: now,
149
+ description: formatDesc,
150
+ fileType: formatType,
151
+ modified: now,
152
+ name: formatName,
153
+ userId: sessionId
154
+ });
155
+
156
+ return saveToDb(insert);
157
+ }).catch(function (error) {
158
+ throw error;
159
+ });
160
+ }
161
+
162
+ var insert = {
163
+ _key: fileId,
164
+ added: now,
165
+ description: formatDesc,
166
+ fileType: formatType,
167
+ modified: now,
168
+ name: formatName,
169
+ userId: sessionId
170
+ };
171
+ return saveToDb(insert);
172
+ }; // If file is a url path, download the file and save
173
+
174
+
175
+ if (isUrl) {
176
+ return request.get({
177
+ encoding: null,
178
+ uri: url
179
+ }).then(function (body) {
180
+ return uploadFile(new Buffer(body, 'binary'), formatType);
181
+ }).catch(function () {
182
+ throw new UserError('file_request');
183
+ });
184
+ } else if (item.base64 !== '') {
185
+ var buffer = new Buffer(item.base64);
186
+ return uploadFile(buffer, formatType);
187
+ }
188
+
189
+ throw new Error('file_required');
190
+ }; // Giphy
191
+
192
+ export var getGiphyTrends = function getGiphyTrends(context) {
193
+ var limit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 30;
194
+ var gifUrl = "http://api.giphy.com/v1/gifs/trending?api_key=".concat(Config.get('giphy.key'), "&limit=").concat(limit);
195
+ return httpGet(gifUrl).then(function (res) {
196
+ return res.json();
197
+ }).then(function (json) {
198
+ return json.data.map(function () {
199
+ var gifImage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
200
+ id: null,
201
+ images: null
202
+ };
203
+ var id = gifImage.id,
204
+ _gifImage$images = gifImage.images;
205
+ _gifImage$images = _gifImage$images === void 0 ? {} : _gifImage$images;
206
+ var _gifImage$images$orig = _gifImage$images.original;
207
+ _gifImage$images$orig = _gifImage$images$orig === void 0 ? {} : _gifImage$images$orig;
208
+ var _gifImage$images$orig2 = _gifImage$images$orig.url,
209
+ url = _gifImage$images$orig2 === void 0 ? '' : _gifImage$images$orig2,
210
+ _gifImage$images$fixe = _gifImage$images.fixed_height_small;
211
+ _gifImage$images$fixe = _gifImage$images$fixe === void 0 ? {} : _gifImage$images$fixe;
212
+ var _gifImage$images$fixe2 = _gifImage$images$fixe.url,
213
+ thumb = _gifImage$images$fixe2 === void 0 ? '' : _gifImage$images$fixe2;
214
+ return {
215
+ id: id,
216
+ thumb: thumb,
217
+ type: 'giphy',
218
+ url: url
219
+ };
220
+ });
221
+ });
222
+ };
223
+ export var getGiphySearch = function getGiphySearch(context, query) {
224
+ var limit = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
225
+ var formatQuery = encodeURI(query);
226
+ var gifUrl = "http://api.giphy.com/v1/gifs/search?q=".concat(formatQuery, "&api_key=").concat(Config.get('giphy.key'), "&limit=").concat(limit);
227
+ return fetch(gifUrl).then(function (res) {
228
+ return res.json();
229
+ }).then(function (json) {
230
+ return json.data.map(function () {
231
+ var gifImage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
232
+ id: null,
233
+ images: null
234
+ };
235
+ var id = gifImage.id,
236
+ _gifImage$images2 = gifImage.images;
237
+ _gifImage$images2 = _gifImage$images2 === void 0 ? {} : _gifImage$images2;
238
+ var _gifImage$images2$ori = _gifImage$images2.original;
239
+ _gifImage$images2$ori = _gifImage$images2$ori === void 0 ? {} : _gifImage$images2$ori;
240
+ var _gifImage$images2$ori2 = _gifImage$images2$ori.url,
241
+ url = _gifImage$images2$ori2 === void 0 ? '' : _gifImage$images2$ori2,
242
+ _gifImage$images2$fix = _gifImage$images2.fixed_height_small;
243
+ _gifImage$images2$fix = _gifImage$images2$fix === void 0 ? {} : _gifImage$images2$fix;
244
+ var _gifImage$images2$fix2 = _gifImage$images2$fix.url,
245
+ thumb = _gifImage$images2$fix2 === void 0 ? '' : _gifImage$images2$fix2;
246
+ return {
247
+ id: id,
248
+ thumb: thumb,
249
+ type: 'giphy',
250
+ url: url
251
+ };
252
+ });
253
+ });
254
+ };
255
+ export var getYouTubeTrends = function getYouTubeTrends(context) {
256
+ var limit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 30;
257
+ return new Promise(function (resolve, reject) {
258
+ youtube.videos.list({
259
+ chart: 'mostPopular',
260
+ maxResults: limit,
261
+ part: 'snippet',
262
+ regionCode: 'US'
263
+ }, function (error, data) {
264
+ if (error) {
265
+ console.error(error);
266
+ reject(new Error(error[0].message));
267
+ } else if (data) {
268
+ var list = data.items.map(function (item) {
269
+ return {
270
+ id: item.id,
271
+ thumb: item.snippet.thumbnails.high.url,
272
+ type: 'youtube',
273
+ url: "http://www.youtube.com/embed/".concat(item.id)
274
+ };
275
+ });
276
+ resolve(list);
277
+ }
278
+ });
279
+ });
280
+ };
281
+ export var getYouTubeSearch = function getYouTubeSearch(context, query) {
282
+ var limit = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 30;
283
+ return new Promise(function (resolve, reject) {
284
+ youtube.search.list({
285
+ maxResults: limit,
286
+ part: 'snippet',
287
+ q: query,
288
+ regionCode: 'US'
289
+ }, function (error, data) {
290
+ if (error) {
291
+ console.error(error);
292
+ reject(new Error(error[0].message));
293
+ } else if (data) {
294
+ var items = data.items;
295
+ var list = items.map(function (item) {
296
+ return {
297
+ id: item.id,
298
+ thumb: item.snippet.thumbnails.high.url,
299
+ type: 'youtube',
300
+ url: "http://www.youtube.com/embed/".concat(item.id)
301
+ };
302
+ });
303
+ resolve(list);
304
+ }
305
+ });
306
+ });
307
+ }; // Files
308
+
309
+ export var getPathUserFiles = function getPathUserFiles(userId, filename) {
310
+ return "users/".concat(userId, "/files/").concat(filename);
311
+ };
312
+ export var getUrlUserFiles = function getUrlUserFiles(userId, filename) {
313
+ var dir = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'files';
314
+ var type = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'profile';
315
+
316
+ if (filename) {
317
+ return "https://box.".concat(Config.get('app.url'), "/users/").concat(userId, "/").concat(dir, "/").concat(filename);
318
+ }
319
+
320
+ if (type === 'profile') {
321
+ return "https://box.".concat(Config.get('app.url'), "/defaults/user_bk.jpg");
322
+ }
323
+
324
+ return "https://box.".concat(Config.get('app.url'), "/defaults/user_wh.jpg");
325
+ };
326
+ export var linkFiles = function linkFiles(db, files, postId) {
327
+ return Promise.all(files.map(function (file) {
328
+ return createFile(db, file).then(function (file) {
329
+ return createPostEdge(db, file, postId);
330
+ });
331
+ }));
332
+ };
333
+ export var updateFiles = function updateFiles(db, postId, files) {
334
+ var edgeCollection = db.edgeCollection('isPosted');
335
+ return edgeCollection.inEdges(postId).then(function (edges) {
336
+ if (edges.length) {
337
+ // Remove linked edges
338
+ return Promise.all(edges.map(function (edge) {
339
+ var edgeKey = edge._key;
340
+ var aqlQry = aql(_templateObject2(), edgeKey);
341
+ return db.query(aqlQry).catch(function (error) {
342
+ throw error;
343
+ });
344
+ })).then(function () {
345
+ if (files.length) {
346
+ // Link files
347
+ return linkFiles(db, files, postId).then(function () {
348
+ return files;
349
+ });
350
+ }
351
+
352
+ return files;
353
+ });
354
+ } else if (files.length) {
355
+ // Link files
356
+ return linkFiles(db, files, postId).then(function () {
357
+ return files;
358
+ });
359
+ }
360
+
361
+ return files;
362
+ }).catch(function (error) {
363
+ throw error;
364
+ });
365
+ };
366
+ export var createFile = function createFile(db, file) {
367
+ var insert = {
368
+ _key: file.id,
369
+ added: Date.now()
370
+ };
371
+ var aqlQry = aql(_templateObject3(), file.id, insert);
372
+ return db.query(aqlQry).then(function (cursor) {
373
+ return cursor.next();
374
+ }).then(function () {
375
+ var updatedFile = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
376
+ return updatedFile;
377
+ }).catch(function (error) {
378
+ throw error;
379
+ });
380
+ };
381
+ export var encodeBase64 = function encodeBase64(buffer) {
382
+ return new Buffer(buffer).toString('base64');
383
+ };
384
+ export var decodeBase64 = function decodeBase64(dataString) {
385
+ // const getData = (str: string) => str.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/) || [];
386
+ var getData = function getData(str) {
387
+ return str.match(/^data:([A-Za-z-+/]+);base64,(.+)$/) || [];
388
+ };
389
+
390
+ var matches = getData(dataString);
391
+
392
+ if (matches.length !== 3) {
393
+ // If invalid make sure we don't need to decode
394
+ matches = getData(decodeURIComponent(dataString)); // Check it again.
395
+
396
+ if (matches.length !== 3) {
397
+ throw Error('Invalid input string');
398
+ }
399
+ }
400
+
401
+ return {
402
+ data: new Buffer(matches[2], 'base64'),
403
+ type: matches[1]
404
+ };
405
+ };
406
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/files.ts"],"names":["get","httpGet","createHash","parseId","parseString","aql","google","UserError","request","Config","useDb","resizeSaveImage","createPostEdge","youtube","auth","version","defaults","encoding","addFile","context","item","database","sessionId","userId","userType","description","fileType","id","name","url","fileId","isUrl","formatName","formatType","substring","lastIndexOf","nameArr","split","ext","length","isImage","formatDesc","saveToDb","insert","aqlQry","query","then","cursor","next","file","catch","error","uploadFile","buf","uploadType","now","Date","resizedImage","_key","added","modified","uri","body","Buffer","base64","buffer","Error","getGiphyTrends","limit","gifUrl","res","json","data","map","gifImage","images","original","fixed_height_small","thumb","type","getGiphySearch","formatQuery","encodeURI","fetch","getYouTubeTrends","Promise","resolve","reject","videos","list","chart","maxResults","part","regionCode","console","message","items","snippet","thumbnails","high","getYouTubeSearch","search","q","getPathUserFiles","filename","getUrlUserFiles","dir","linkFiles","db","files","postId","all","createFile","updateFiles","edgeCollection","inEdges","edges","edge","edgeKey","updatedFile","encodeBase64","toString","decodeBase64","dataString","getData","str","match","matches","decodeURIComponent"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {get as httpGet} from '@nlabs/rip-hunter';\nimport {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport {google} from 'googleapis';\nimport {UserError} from 'graphql-errors';\nimport * as request from 'request-promise';\nimport {ApiContext} from 'types/auth';\n\nimport {Config} from '../config';\nimport {FileType} from '../types/files';\nimport {useDb} from '../utils';\nimport {resizeSaveImage} from './images';\nimport {createPostEdge} from './posts';\n\nconst youtube = google.youtube({auth: Config.get('google.key'), version: 'v3'});\nrequest.defaults({encoding: null});\n\n// const eventCategory: string = 'files';\n\n// Upload file\nexport const addFile = (context: ApiContext, item: FileType = {}): Promise<FileType> => {\n  const {database, userId: sessionId, userType} = context;\n  const {\n    description = '',\n    fileType = '',\n    id,\n    name = '',\n    url = ''\n  } = item;\n\n  // Id\n  const fileId: string = id ? parseId(id) : createHash(`file-${sessionId}`);\n\n  // Name\n  const isUrl: boolean = url !== '';\n\n  // If no name, get it from url path\n  let formatName: string = parseString(name, 160);\n  let formatType: string = parseString(fileType, 16);\n\n  if(formatName === '' && isUrl) {\n    formatName = url.substring(url.lastIndexOf('/') + 1);\n  }\n\n  if(formatType === '') {\n    const nameArr: string[] = formatName.split('.');\n    const ext: string = nameArr[nameArr.length - 1];\n\n    switch(ext) {\n      case 'jpeg':\n      case 'jpg':\n        formatType = 'image/jpeg';\n        break;\n      case 'png':\n        formatType = 'image/png';\n        break;\n      case 'zip':\n        formatType = 'application/zip';\n        break;\n      default:\n        break;\n    }\n  }\n\n  let isImage: boolean;\n\n  switch(formatType) {\n    case 'image/jpeg':\n    case 'image/png':\n      isImage = true;\n      break;\n    default:\n      isImage = false;\n      break;\n  }\n\n  // Description\n  const formatDesc: string = parseString(description, 500);\n\n  // Only allow file uploads to premium users\n  if(!isImage && userType !== 2) {\n    throw new UserError('account_restriction');\n  }\n\n  const saveToDb = (insert: FileType) => {\n    const aqlQry: AqlQuery = aql`INSERT ${insert} IN files RETURN NEW`;\n\n    return useDb(database).query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((file = {}) => file)\n      .catch((error: Error) => {\n        throw error;\n      });\n  };\n\n  const uploadFile = (buf: Buffer, uploadType: string) => {\n    const now: number = Date.now();\n\n    // If image, resize and create a thumbnail\n    if(isImage) {\n      return resizeSaveImage(sessionId, fileId, buf, uploadType)\n        .then((resizedImage: FileType) => {\n          const insert: FileType = {\n            ...resizedImage,\n            _key: fileId,\n            added: now,\n            description: formatDesc,\n            fileType: formatType,\n            modified: now,\n            name: formatName,\n            userId: sessionId\n          };\n\n          return saveToDb(insert);\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    }\n    const insert: FileType = {\n      _key: fileId,\n      added: now,\n      description: formatDesc,\n      fileType: formatType,\n      modified: now,\n      name: formatName,\n      userId: sessionId\n    };\n\n    return saveToDb(insert);\n  };\n\n  // If file is a url path, download the file and save\n  if(isUrl) {\n    return request.get({encoding: null, uri: url})\n      .then((body) => uploadFile(new Buffer(body, 'binary'), formatType))\n      .catch(() => {\n        throw new UserError('file_request');\n      });\n  } else if(item.base64 !== '') {\n    const buffer: Buffer = new Buffer(item.base64);\n    return uploadFile(buffer, formatType);\n  }\n  throw new Error('file_required');\n};\n\n// Giphy\nexport const getGiphyTrends = (context: ApiContext, limit: number = 30): Promise<any[]> => {\n  const gifUrl: string = `http://api.giphy.com/v1/gifs/trending?api_key=${Config.get('giphy.key')}&limit=${limit}`;\n\n  return httpGet(gifUrl)\n    .then((res: Response) => res.json())\n    .then((json) => json.data.map((gifImage = {id: null, images: null}) => {\n      const {\n        id,\n        images: {\n          original: {url = ''} = {},\n          fixed_height_small: {url: thumb = ''} = {}\n        } = {}\n      } = gifImage;\n\n      return {\n        id,\n        thumb,\n        type: 'giphy',\n        url\n      };\n    }));\n};\n\nexport const getGiphySearch = (context: ApiContext, query: string, limit: number = 30): Promise<any[]> => {\n  const formatQuery: string = encodeURI(query);\n  const gifUrl: string = `http://api.giphy.com/v1/gifs/search?q=${formatQuery}&api_key=${Config.get('giphy.key')}&limit=${limit}`;\n\n  return fetch(gifUrl)\n    .then((res: Response) => res.json())\n    .then((json) => json.data.map((gifImage = {id: null, images: null}) => {\n      const {\n        id,\n        images: {\n          original: {url = ''} = {},\n          fixed_height_small: {url: thumb = ''} = {}\n        } = {}\n      } = gifImage;\n\n      return {\n        id,\n        thumb,\n        type: 'giphy',\n        url\n      };\n    }));\n};\n\nexport const getYouTubeTrends = (context: ApiContext, limit: number = 30): Promise<any[]> => {\n  return new Promise((resolve, reject) => {\n    youtube.videos.list({\n      chart: 'mostPopular',\n      maxResults: limit,\n      part: 'snippet',\n      regionCode: 'US'\n    }, (error: Error, data: any) => {\n      if(error) {\n        console.error(error);\n        reject(new Error(error[0].message));\n      } else if(data) {\n        const list = data.items.map((item) => ({\n          id: item.id,\n          thumb: item.snippet.thumbnails.high.url,\n          type: 'youtube',\n          url: `http://www.youtube.com/embed/${item.id}`\n        }));\n\n        resolve(list);\n      }\n    });\n  });\n};\n\nexport const getYouTubeSearch = (context: ApiContext, query: string, limit: number = 30): Promise<any[]> => {\n  return new Promise((resolve, reject) => {\n    youtube.search.list({\n      maxResults: limit,\n      part: 'snippet',\n      q: query,\n      regionCode: 'US'\n    }, (error: Error, data: any) => {\n      if(error) {\n        console.error(error);\n        reject(new Error(error[0].message));\n      } else if(data) {\n        const {items} = data;\n        const list = items.map((item) => ({\n          id: item.id,\n          thumb: item.snippet.thumbnails.high.url,\n          type: 'youtube',\n          url: `http://www.youtube.com/embed/${item.id}`\n        }));\n\n        resolve(list);\n      }\n    });\n  });\n};\n\n// Files\nexport const getPathUserFiles = (userId: string, filename: string): string => {\n  return `users/${userId}/files/${filename}`;\n};\n\nexport const getUrlUserFiles = (userId: string, filename: string, dir: string = 'files', type: string = 'profile'): string => {\n  if(filename) {\n    return `https://box.${Config.get('app.url')}/users/${userId}/${dir}/${filename}`;\n  }\n\n  if(type === 'profile') {\n    return `https://box.${Config.get('app.url')}/defaults/user_bk.jpg`;\n  }\n\n  return `https://box.${Config.get('app.url')}/defaults/user_wh.jpg`;\n};\n\nexport const linkFiles = (db: Database, files: FileType[], postId: string): Promise<any> => {\n  return Promise.all(\n    files.map((file: FileType) => createFile(db, file)\n      .then((file: FileType) => createPostEdge(db, file, postId)))\n  );\n};\n\nexport const updateFiles = (db: Database, postId: string, files: FileType[]): Promise<any> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n\n  return edgeCollection.inEdges(postId)\n    .then((edges) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry: AqlQuery = aql`REMOVE {_key:${edgeKey}} IN isPosted`;\n\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(files.length) {\n              // Link files\n              return linkFiles(db, files, postId).then(() => files);\n            }\n            return files;\n          });\n      } else if(files.length) {\n        // Link files\n        return linkFiles(db, files, postId).then(() => files);\n      }\n      return files;\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createFile = (db: Database, file: FileType): Promise<FileType> => {\n  const insert: any = {\n    _key: file.id,\n    added: Date.now()\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${file.id}}\n    INSERT ${insert}\n    UPDATE {}\n    IN files RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedFile: FileType = {}) => updatedFile)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const encodeBase64 = (buffer: Buffer): string => {\n  return new Buffer(buffer).toString('base64');\n}\n\nexport const decodeBase64 = (dataString: string): object => {\n  // const getData = (str: string) => str.match(/^data:([A-Za-z-+\\/]+);base64,(.+)$/) || [];\n  const getData = (str: string) => str.match(/^data:([A-Za-z-+/]+);base64,(.+)$/) || [];\n  let matches = getData(dataString);\n\n  if(matches.length !== 3) {\n    // If invalid make sure we don't need to decode\n    matches = getData(decodeURIComponent(dataString));\n\n    // Check it again.\n    if(matches.length !== 3) {\n      throw Error('Invalid input string');\n    }\n  }\n\n  return {\n    data: new Buffer(matches[2], 'base64'),\n    type: matches[1]\n  };\n};\n"]}