@nlabs/reaktor 0.4.0 → 0.4.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/actions/conversations.d.ts +14 -0
- package/lib/actions/conversations.js +333 -0
- package/lib/actions/dynamodb.js +155 -0
- package/lib/actions/email.js +177 -0
- package/lib/actions/files.js +319 -0
- package/lib/{data → actions}/groups.d.ts +4 -3
- package/lib/actions/groups.js +282 -0
- package/lib/actions/images.d.ts +22 -0
- package/lib/actions/images.js +682 -0
- package/lib/actions/index.js +40 -0
- package/lib/{data → actions}/ios.d.ts +2 -1
- package/lib/actions/ios.js +179 -0
- package/lib/actions/locations.js +112 -0
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +216 -0
- package/lib/{data → actions}/notifications.d.ts +2 -2
- package/lib/actions/notifications.js +63 -0
- package/lib/{data → actions}/payments.d.ts +2 -2
- package/lib/actions/payments.js +491 -0
- package/lib/actions/posts.d.ts +19 -0
- package/lib/actions/posts.js +538 -0
- package/lib/actions/reactions.d.ts +30 -0
- package/lib/actions/reactions.js +340 -0
- package/lib/{data → actions}/s3.d.ts +1 -1
- package/lib/actions/s3.js +122 -0
- package/lib/{data → actions}/search.d.ts +2 -2
- package/lib/actions/search.js +99 -0
- package/lib/actions/sms.js +76 -0
- package/lib/actions/statistics.d.ts +2 -0
- package/lib/actions/statistics.js +63 -0
- package/lib/actions/subscription.js +209 -0
- package/lib/actions/tags.d.ts +26 -0
- package/lib/actions/tags.js +340 -0
- package/lib/actions/users.d.ts +44 -0
- package/lib/actions/users.js +571 -0
- package/lib/{data → actions}/websockets.d.ts +1 -1
- package/lib/actions/websockets.js +156 -0
- package/lib/config.d.ts +2 -3
- package/lib/config.js +116 -149
- package/lib/index.d.ts +1 -1
- package/lib/index.js +23 -45
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/layout.js +292 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordForgot.js +28 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.js +25 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/verifyEmail.js +28 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/email/welcome.js +28 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.js +14 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.js +14 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.js +14 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.js +14 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/templates/sms/welcome.js +14 -0
- package/lib/types/apps.d.ts +2 -2
- package/lib/types/apps.js +4 -2
- package/lib/types/arangodb.js +4 -2
- package/lib/types/auth.d.ts +4 -8
- package/lib/types/auth.js +4 -2
- package/lib/types/conversations.d.ts +3 -3
- package/lib/types/conversations.js +4 -2
- package/lib/types/email.d.ts +2 -2
- package/lib/types/email.js +4 -2
- package/lib/types/files.js +4 -2
- package/lib/types/google.js +4 -2
- package/lib/types/groups.d.ts +2 -1
- package/lib/types/groups.js +4 -2
- package/lib/types/images.d.ts +8 -5
- package/lib/types/images.js +4 -2
- package/lib/types/index.d.ts +1 -1
- package/lib/types/index.js +37 -227
- package/lib/types/locations.js +4 -2
- package/lib/types/messages.d.ts +12 -2
- package/lib/types/messages.js +4 -2
- package/lib/types/notifications.d.ts +2 -2
- package/lib/types/notifications.js +4 -2
- package/lib/types/payments.js +4 -2
- package/lib/types/posts.d.ts +18 -1
- package/lib/types/posts.js +4 -2
- package/lib/types/statistics.d.ts +3 -0
- package/lib/types/statistics.js +4 -0
- package/lib/types/tags.d.ts +6 -0
- package/lib/types/tags.js +4 -2
- package/lib/types/users.d.ts +15 -11
- package/lib/types/users.js +4 -2
- package/lib/utils/analytics.d.ts +7 -0
- package/lib/utils/analytics.js +101 -77
- package/lib/utils/arangodb.d.ts +1 -1
- package/lib/utils/arangodb.js +93 -114
- package/lib/utils/auth.js +58 -55
- package/lib/utils/graphql.js +38 -19
- package/lib/utils/index.d.ts +1 -1
- package/lib/utils/index.js +26 -84
- package/lib/utils/objects.js +44 -53
- package/lib/utils/session.d.ts +18 -0
- package/lib/utils/session.js +42 -0
- package/package.json +32 -30
- package/lib/data/conversations.d.ts +0 -8
- package/lib/data/conversations.js +0 -311
- package/lib/data/dynamodb.js +0 -206
- package/lib/data/email.js +0 -222
- package/lib/data/files.js +0 -525
- package/lib/data/groups.js +0 -435
- package/lib/data/images.d.ts +0 -22
- package/lib/data/images.js +0 -1051
- package/lib/data/index.js +0 -266
- package/lib/data/ios.js +0 -355
- package/lib/data/locations.js +0 -172
- package/lib/data/messages.d.ts +0 -9
- package/lib/data/messages.js +0 -299
- package/lib/data/notifications.js +0 -59
- package/lib/data/payments.js +0 -771
- package/lib/data/posts.d.ts +0 -23
- package/lib/data/posts.js +0 -766
- package/lib/data/reactions.d.ts +0 -14
- package/lib/data/reactions.js +0 -529
- package/lib/data/s3.js +0 -155
- package/lib/data/search.js +0 -155
- package/lib/data/sms.js +0 -83
- package/lib/data/subscription.js +0 -337
- package/lib/data/tags.d.ts +0 -14
- package/lib/data/tags.js +0 -397
- package/lib/data/users.d.ts +0 -20
- package/lib/data/users.js +0 -470
- package/lib/data/websockets.js +0 -250
- package/lib/types/reactions.d.ts +0 -17
- package/lib/types/reactions.js +0 -2
- package/lib/utils/redis.d.ts +0 -1
- package/lib/utils/redis.js +0 -36
- package/templates/email/layout.html +0 -279
- package/templates/email/passwordForgot.html +0 -15
- package/templates/email/passwordRecovery.html +0 -12
- package/templates/email/verifyEmail.html +0 -15
- package/templates/sms/passwordForgot.txt +0 -1
- package/templates/sms/passwordRecovery.txt +0 -1
- package/templates/sms/verifyEmail.txt +0 -1
- package/templates/sms/verifyPhone.txt +0 -1
- /package/lib/{data → actions}/dynamodb.d.ts +0 -0
- /package/lib/{data → actions}/email.d.ts +0 -0
- /package/lib/{data → actions}/files.d.ts +0 -0
- /package/lib/{data → actions}/index.d.ts +0 -0
- /package/lib/{data → actions}/locations.d.ts +0 -0
- /package/lib/{data → actions}/sms.d.ts +0 -0
- /package/lib/{data → actions}/subscription.d.ts +0 -0
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
__markAsModule(target);
|
|
10
|
+
for (var name in all)
|
|
11
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
12
|
+
};
|
|
13
|
+
var __reExport = (target, module2, desc) => {
|
|
14
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
15
|
+
for (let key of __getOwnPropNames(module2))
|
|
16
|
+
if (!__hasOwnProp.call(target, key) && key !== "default")
|
|
17
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
18
|
+
}
|
|
19
|
+
return target;
|
|
20
|
+
};
|
|
21
|
+
var __toModule = (module2) => {
|
|
22
|
+
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
|
|
23
|
+
};
|
|
24
|
+
__export(exports, {
|
|
25
|
+
appTemplate: () => appTemplate,
|
|
26
|
+
sendEmail: () => sendEmail,
|
|
27
|
+
sendTemplate: () => sendTemplate,
|
|
28
|
+
sesSend: () => sesSend
|
|
29
|
+
});
|
|
30
|
+
var import_aws_sdk = __toModule(require("aws-sdk"));
|
|
31
|
+
var import_isEmpty = __toModule(require("lodash/isEmpty"));
|
|
32
|
+
var import_config = __toModule(require("../config"));
|
|
33
|
+
var import_layout = __toModule(require("../templates/email/layout"));
|
|
34
|
+
var import_passwordForgot = __toModule(require("../templates/email/passwordForgot"));
|
|
35
|
+
var import_passwordRecovery = __toModule(require("../templates/email/passwordRecovery"));
|
|
36
|
+
var import_verifyEmail = __toModule(require("../templates/email/verifyEmail"));
|
|
37
|
+
var import_welcome = __toModule(require("../templates/email/welcome"));
|
|
38
|
+
var import_passwordForgot2 = __toModule(require("../templates/sms/passwordForgot"));
|
|
39
|
+
var import_passwordRecovery2 = __toModule(require("../templates/sms/passwordRecovery"));
|
|
40
|
+
var import_verifyEmail2 = __toModule(require("../templates/sms/verifyEmail"));
|
|
41
|
+
var import_welcome2 = __toModule(require("../templates/sms/welcome"));
|
|
42
|
+
var import_s32 = __toModule(require("./s3"));
|
|
43
|
+
const appTemplate = (app, message = "", vars = {}) => {
|
|
44
|
+
let updatedMessage = "";
|
|
45
|
+
if (!(0, import_isEmpty.default)(app)) {
|
|
46
|
+
updatedMessage = message.replace(/\[appName\]/g, app.name).replace(/\[appUrl\]/g, app.url).replace(/\[appEmail\]/g, app.email);
|
|
47
|
+
}
|
|
48
|
+
Object.keys(vars).forEach((key) => {
|
|
49
|
+
if (vars[key]) {
|
|
50
|
+
updatedMessage = message.replace(new RegExp(`\\[${key}\\]`, "g"), vars[key]);
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
return updatedMessage;
|
|
54
|
+
};
|
|
55
|
+
const sesSend = (params) => new Promise((resolve, reject) => {
|
|
56
|
+
import_aws_sdk.default.config.update(import_config.Config.get("aws"));
|
|
57
|
+
const ses = new import_aws_sdk.SES();
|
|
58
|
+
ses.sendEmail(params, (error, response) => {
|
|
59
|
+
if (error) {
|
|
60
|
+
return reject(error);
|
|
61
|
+
}
|
|
62
|
+
return resolve(response);
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
const sendEmail = (params) => {
|
|
66
|
+
const {
|
|
67
|
+
app = {},
|
|
68
|
+
html,
|
|
69
|
+
subject,
|
|
70
|
+
subTitle = "",
|
|
71
|
+
text,
|
|
72
|
+
title = "",
|
|
73
|
+
user = {}
|
|
74
|
+
} = params;
|
|
75
|
+
const to = [user.email];
|
|
76
|
+
let promise;
|
|
77
|
+
const formatSubject = appTemplate(app, subject);
|
|
78
|
+
const formatSubTitle = appTemplate(app, subTitle);
|
|
79
|
+
const formatTitle = appTemplate(app, title);
|
|
80
|
+
const formatText = appTemplate(app, text);
|
|
81
|
+
const formatHtml = appTemplate(app, html);
|
|
82
|
+
const { _key: hasCustomEmail, urlFacebook, urlTwitter } = app;
|
|
83
|
+
const parseTemplate = (body) => {
|
|
84
|
+
const templateBody = appTemplate(app, body || "");
|
|
85
|
+
let links = "";
|
|
86
|
+
const spacer = '<td width="5"><img width="1" height="1" border="0" title="" alt="" src="https://box.reaktor.io/images/email/spacer.gif"/></td>';
|
|
87
|
+
if (urlFacebook) {
|
|
88
|
+
links = `<td width="30"><a href="${urlFacebook}"><img width="30" height="30" border="0" title="Facebook" alt="Facebook" src="https://box.reaktor.io/images/email/icon-facebook.png"/></a></td>`;
|
|
89
|
+
}
|
|
90
|
+
if (urlTwitter) {
|
|
91
|
+
if (urlFacebook) {
|
|
92
|
+
links += spacer;
|
|
93
|
+
}
|
|
94
|
+
links += `<td width="30"><a href="${urlTwitter}"><img width="30" height="30" border="0" title="Twitter" alt="Twitter" src="https://box.reaktor.io/images/email/icon-twitter.png"/></a></td>`;
|
|
95
|
+
}
|
|
96
|
+
if (!links.length) {
|
|
97
|
+
links += spacer;
|
|
98
|
+
}
|
|
99
|
+
return templateBody.replace(/\[title\]/g, formatTitle).replace(/\[subTitle\]/g, formatSubTitle).replace(/\[subject\]/g, formatSubject).replace(/\[message\]/g, formatHtml).replace(/\[links\]/g, links);
|
|
100
|
+
};
|
|
101
|
+
if (hasCustomEmail) {
|
|
102
|
+
const s3Params = { Bucket: null, Key: "apps/templates/email.html" };
|
|
103
|
+
promise = (0, import_s32.s3Get)(s3Params).then((results) => parseTemplate(results.Body.toString()));
|
|
104
|
+
} else {
|
|
105
|
+
promise = Promise.resolve(parseTemplate(import_layout.default));
|
|
106
|
+
}
|
|
107
|
+
return promise.then((parsedHtml) => {
|
|
108
|
+
const emailParams = {
|
|
109
|
+
Destination: { ToAddresses: to },
|
|
110
|
+
Message: {
|
|
111
|
+
Body: {
|
|
112
|
+
Html: { Data: parsedHtml },
|
|
113
|
+
Text: { Data: formatText }
|
|
114
|
+
},
|
|
115
|
+
Subject: { Data: formatSubject }
|
|
116
|
+
},
|
|
117
|
+
Source: `"${app.supportName}" <noreply@${import_config.Config.get("app.url")}>`
|
|
118
|
+
};
|
|
119
|
+
return sesSend(emailParams);
|
|
120
|
+
});
|
|
121
|
+
};
|
|
122
|
+
const sendTemplate = (templateName, emailParams) => {
|
|
123
|
+
const { app, user, subject, subTitle, title, vars } = emailParams;
|
|
124
|
+
let html;
|
|
125
|
+
let text;
|
|
126
|
+
try {
|
|
127
|
+
switch (templateName) {
|
|
128
|
+
case "passwordForgot": {
|
|
129
|
+
html = import_passwordForgot.default;
|
|
130
|
+
text = import_passwordForgot2.default;
|
|
131
|
+
break;
|
|
132
|
+
}
|
|
133
|
+
case "passwordRecovery": {
|
|
134
|
+
html = import_passwordRecovery.default;
|
|
135
|
+
text = import_passwordRecovery2.default;
|
|
136
|
+
break;
|
|
137
|
+
}
|
|
138
|
+
case "verifyRecovery": {
|
|
139
|
+
html = import_verifyEmail.default;
|
|
140
|
+
text = import_verifyEmail2.default;
|
|
141
|
+
break;
|
|
142
|
+
}
|
|
143
|
+
case "verifyEmail": {
|
|
144
|
+
html = import_verifyEmail.default;
|
|
145
|
+
text = import_verifyEmail2.default;
|
|
146
|
+
break;
|
|
147
|
+
}
|
|
148
|
+
case "welcome": {
|
|
149
|
+
html = import_welcome.default;
|
|
150
|
+
text = import_welcome2.default;
|
|
151
|
+
break;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
const templateHtml = appTemplate(app, html, vars);
|
|
155
|
+
const templateText = appTemplate(app, text, vars);
|
|
156
|
+
const params = {
|
|
157
|
+
app,
|
|
158
|
+
html: templateHtml,
|
|
159
|
+
subTitle,
|
|
160
|
+
subject,
|
|
161
|
+
text: templateText,
|
|
162
|
+
title,
|
|
163
|
+
user
|
|
164
|
+
};
|
|
165
|
+
return sendEmail(params).then(() => true).catch(() => false);
|
|
166
|
+
} catch (error) {
|
|
167
|
+
return Promise.reject(error);
|
|
168
|
+
}
|
|
169
|
+
};
|
|
170
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
171
|
+
0 && (module.exports = {
|
|
172
|
+
appTemplate,
|
|
173
|
+
sendEmail,
|
|
174
|
+
sendTemplate,
|
|
175
|
+
sesSend
|
|
176
|
+
});
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/email.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport aws, {SES} from 'aws-sdk';\nimport {GetObjectRequest} from 'aws-sdk/clients/s3';\nimport {SendEmailRequest, SendEmailResponse} from 'aws-sdk/clients/ses';\nimport isEmpty from 'lodash/isEmpty';\n\nimport {Config} from '../config';\nimport layoutTemplate from '../templates/email/layout';\nimport forgotEmailTemplate from '../templates/email/passwordForgot';\nimport recoveryEmailTemplate from '../templates/email/passwordRecovery';\nimport verifyEmailTemplate from '../templates/email/verifyEmail';\nimport welcomeEmailTemplate from '../templates/email/welcome';\nimport forgotSmsTemplate from '../templates/sms/passwordForgot';\nimport recoverySmsTemplate from '../templates/sms/passwordRecovery';\nimport verifySmsTemplate from '../templates/sms/verifyEmail';\nimport welcomeSmsTemplate from '../templates/sms/welcome';\nimport {AppType} from '../types/apps';\nimport {EmailType} from '../types/email';\nimport {s3Get} from './s3';\n\n// const eventCategory: string = 'email';\n\nexport const appTemplate = (app: AppType, message: string = '', vars = {}): string => {\n  let updatedMessage: string = '';\n\n  if(!isEmpty(app)) {\n    updatedMessage = message.replace(/\\[appName\\]/g, app.name)\n      .replace(/\\[appUrl\\]/g, app.url)\n      .replace(/\\[appEmail\\]/g, app.email);\n  }\n\n  Object.keys(vars).forEach((key: string) => {\n    if(vars[key]) {\n      updatedMessage = message.replace(new RegExp(`\\\\[${key}\\\\]`, 'g'), vars[key]);\n    }\n  });\n\n  return updatedMessage;\n};\n\n// AWS::SES\nexport const sesSend = (params: SendEmailRequest): Promise<SendEmailResponse> => new Promise((resolve, reject) => {\n  aws.config.update(Config.get('aws'));\n  const ses: SES = new SES();\n\n  ses.sendEmail(params, (error: Error, response: SendEmailResponse) => {\n    if(error) {\n      return reject(error);\n    }\n\n    return resolve(response);\n  });\n});\n\nexport const sendEmail = (params: EmailType): Promise<boolean> => {\n  const {\n    app = {},\n    html,\n    subject,\n    subTitle = '',\n    text,\n    title = '',\n    user = {}\n  } = params;\n\n  const to = [user.email];\n  let promise;\n\n  const formatSubject: string = appTemplate(app, subject);\n  const formatSubTitle: string = appTemplate(app, subTitle);\n  const formatTitle: string = appTemplate(app, title);\n  const formatText: string = appTemplate(app, text);\n  const formatHtml: string = appTemplate(app, html);\n  const {_key: hasCustomEmail, urlFacebook, urlTwitter} = app;\n\n  const parseTemplate = (body: string) => {\n    const templateBody: string = appTemplate(app, body || '');\n\n    // Links\n    let links: string = '';\n    const spacer = '<td width=\"5\"><img width=\"1\" height=\"1\" border=\"0\" title=\"\" alt=\"\" ' +\n      'src=\"https://box.reaktor.io/images/email/spacer.gif\"/></td>';\n\n    if(urlFacebook) {\n      links = `<td width=\"30\"><a href=\"${urlFacebook}\"><img width=\"30\" height=\"30\" border=\"0\" ` +\n        'title=\"Facebook\" alt=\"Facebook\" src=\"https://box.reaktor.io/images/email/icon-facebook.png\"/></a></td>';\n    }\n\n    if(urlTwitter) {\n      if(urlFacebook) {\n        links += spacer;\n      }\n\n      links += `<td width=\"30\"><a href=\"${urlTwitter}\"><img width=\"30\" height=\"30\" border=\"0\" ` +\n        'title=\"Twitter\" alt=\"Twitter\" src=\"https://box.reaktor.io/images/email/icon-twitter.png\"/></a></td>';\n    }\n\n    if(!links.length) {\n      links += spacer;\n    }\n\n    return templateBody.replace(/\\[title\\]/g, formatTitle)\n      .replace(/\\[subTitle\\]/g, formatSubTitle)\n      .replace(/\\[subject\\]/g, formatSubject)\n      .replace(/\\[message\\]/g, formatHtml)\n      .replace(/\\[links\\]/g, links);\n  };\n\n  if(hasCustomEmail) {\n    const s3Params: GetObjectRequest = {Bucket: null, Key: 'apps/templates/email.html'};\n    promise = s3Get(s3Params).then((results) => parseTemplate(results.Body.toString()));\n  } else {\n    promise = Promise.resolve(parseTemplate(layoutTemplate));\n  }\n\n  return promise.then((parsedHtml: string) => {\n    const emailParams: SendEmailRequest = {\n      Destination: {ToAddresses: to},\n      Message: {\n        Body: {\n          Html: {Data: parsedHtml},\n          Text: {Data: formatText}\n        },\n        Subject: {Data: formatSubject}\n      },\n      Source: `\"${app.supportName}\" <noreply@${Config.get('app.url')}>`\n    };\n\n    return sesSend(emailParams);\n  });\n};\n\nexport const sendTemplate = (templateName: string, emailParams: EmailType): Promise<boolean> => {\n  const {app, user, subject, subTitle, title, vars}: EmailType = emailParams;\n  let html: string;\n  let text: string;\n\n  try {\n    switch(templateName) {\n      case 'passwordForgot': {\n        html = forgotEmailTemplate;\n        text = forgotSmsTemplate;\n        break;\n      }\n      case 'passwordRecovery': {\n        html = recoveryEmailTemplate;\n        text = recoverySmsTemplate;\n        break;\n      }\n      case 'verifyRecovery': {\n        html = verifyEmailTemplate;\n        text = verifySmsTemplate;\n        break;\n      }\n      case 'verifyEmail': {\n        html = verifyEmailTemplate;\n        text = verifySmsTemplate;\n        break;\n      }\n      case 'welcome': {\n        html = welcomeEmailTemplate;\n        text = welcomeSmsTemplate;\n        break;\n      }\n    }\n\n    const templateHtml: string = appTemplate(app, html, vars);\n    const templateText: string = appTemplate(app, text, vars);\n\n    const params = {\n      app,\n      html: templateHtml,\n      subTitle,\n      subject,\n      text: templateText,\n      title,\n      user\n    };\n\n    return sendEmail(params)\n      .then(() => true)\n      .catch(() => false);\n  } catch(error) {\n    return Promise.reject(error);\n  }\n};\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,qBAAuB;AAGvB,qBAAoB;AAEpB,oBAAqB;AACrB,oBAA2B;AAC3B,4BAAgC;AAChC,8BAAkC;AAClC,yBAAgC;AAChC,qBAAiC;AACjC,6BAA8B;AAC9B,+BAAgC;AAChC,0BAA8B;AAC9B,sBAA+B;AAG/B,iBAAoB;AAIb,MAAM,cAAc,CAAC,KAAc,UAAkB,IAAI,OAAO,OAAe;AACpF,MAAI,iBAAyB;AAE7B,MAAG,CAAC,4BAAQ,MAAM;AAChB,qBAAiB,QAAQ,QAAQ,gBAAgB,IAAI,MAClD,QAAQ,eAAe,IAAI,KAC3B,QAAQ,iBAAiB,IAAI;AAAA;AAGlC,SAAO,KAAK,MAAM,QAAQ,CAAC,QAAgB;AACzC,QAAG,KAAK,MAAM;AACZ,uBAAiB,QAAQ,QAAQ,IAAI,OAAO,MAAM,UAAU,MAAM,KAAK;AAAA;AAAA;AAI3E,SAAO;AAAA;AAIF,MAAM,UAAU,CAAC,WAAyD,IAAI,QAAQ,CAAC,SAAS,WAAW;AAChH,yBAAI,OAAO,OAAO,qBAAO,IAAI;AAC7B,QAAM,MAAW,IAAI;AAErB,MAAI,UAAU,QAAQ,CAAC,OAAc,aAAgC;AACnE,QAAG,OAAO;AACR,aAAO,OAAO;AAAA;AAGhB,WAAO,QAAQ;AAAA;AAAA;AAIZ,MAAM,YAAY,CAAC,WAAwC;AAChE,QAAM;AAAA,IACJ,MAAM;AAAA,IACN;AAAA,IACA;AAAA,IACA,WAAW;AAAA,IACX;AAAA,IACA,QAAQ;AAAA,IACR,OAAO;AAAA,MACL;AAEJ,QAAM,KAAK,CAAC,KAAK;AACjB,MAAI;AAEJ,QAAM,gBAAwB,YAAY,KAAK;AAC/C,QAAM,iBAAyB,YAAY,KAAK;AAChD,QAAM,cAAsB,YAAY,KAAK;AAC7C,QAAM,aAAqB,YAAY,KAAK;AAC5C,QAAM,aAAqB,YAAY,KAAK;AAC5C,QAAM,EAAC,MAAM,gBAAgB,aAAa,eAAc;AAExD,QAAM,gBAAgB,CAAC,SAAiB;AACtC,UAAM,eAAuB,YAAY,KAAK,QAAQ;AAGtD,QAAI,QAAgB;AACpB,UAAM,SAAS;AAGf,QAAG,aAAa;AACd,cAAQ,2BAA2B;AAAA;AAIrC,QAAG,YAAY;AACb,UAAG,aAAa;AACd,iBAAS;AAAA;AAGX,eAAS,2BAA2B;AAAA;AAItC,QAAG,CAAC,MAAM,QAAQ;AAChB,eAAS;AAAA;AAGX,WAAO,aAAa,QAAQ,cAAc,aACvC,QAAQ,iBAAiB,gBACzB,QAAQ,gBAAgB,eACxB,QAAQ,gBAAgB,YACxB,QAAQ,cAAc;AAAA;AAG3B,MAAG,gBAAgB;AACjB,UAAM,WAA6B,EAAC,QAAQ,MAAM,KAAK;AACvD,cAAU,sBAAM,UAAU,KAAK,CAAC,YAAY,cAAc,QAAQ,KAAK;AAAA,SAClE;AACL,cAAU,QAAQ,QAAQ,cAAc;AAAA;AAG1C,SAAO,QAAQ,KAAK,CAAC,eAAuB;AAC1C,UAAM,cAAgC;AAAA,MACpC,aAAa,EAAC,aAAa;AAAA,MAC3B,SAAS;AAAA,QACP,MAAM;AAAA,UACJ,MAAM,EAAC,MAAM;AAAA,UACb,MAAM,EAAC,MAAM;AAAA;AAAA,QAEf,SAAS,EAAC,MAAM;AAAA;AAAA,MAElB,QAAQ,IAAI,IAAI,yBAAyB,qBAAO,IAAI;AAAA;AAGtD,WAAO,QAAQ;AAAA;AAAA;AAIZ,MAAM,eAAe,CAAC,cAAsB,gBAA6C;AAC9F,QAAM,EAAC,KAAK,MAAM,SAAS,UAAU,OAAO,SAAmB;AAC/D,MAAI;AACJ,MAAI;AAEJ,MAAI;AACF,YAAO;AAAA,WACA,kBAAkB;AACrB,eAAO;AACP,eAAO;AACP;AAAA;AAAA,WAEG,oBAAoB;AACvB,eAAO;AACP,eAAO;AACP;AAAA;AAAA,WAEG,kBAAkB;AACrB,eAAO;AACP,eAAO;AACP;AAAA;AAAA,WAEG,eAAe;AAClB,eAAO;AACP,eAAO;AACP;AAAA;AAAA,WAEG,WAAW;AACd,eAAO;AACP,eAAO;AACP;AAAA;AAAA;AAIJ,UAAM,eAAuB,YAAY,KAAK,MAAM;AACpD,UAAM,eAAuB,YAAY,KAAK,MAAM;AAEpD,UAAM,SAAS;AAAA,MACb;AAAA,MACA,MAAM;AAAA,MACN;AAAA,MACA;AAAA,MACA,MAAM;AAAA,MACN;AAAA,MACA;AAAA;AAGF,WAAO,UAAU,QACd,KAAK,MAAM,MACX,MAAM,MAAM;AAAA,WACT,OAAN;AACA,WAAO,QAAQ,OAAO;AAAA;AAAA;",
  "names": []
}

|
|
@@ -0,0 +1,319 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __defProps = Object.defineProperties;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
9
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
10
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
11
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
+
var __spreadValues = (a, b) => {
|
|
13
|
+
for (var prop in b || (b = {}))
|
|
14
|
+
if (__hasOwnProp.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
if (__getOwnPropSymbols)
|
|
17
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
18
|
+
if (__propIsEnum.call(b, prop))
|
|
19
|
+
__defNormalProp(a, prop, b[prop]);
|
|
20
|
+
}
|
|
21
|
+
return a;
|
|
22
|
+
};
|
|
23
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
24
|
+
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
|
|
25
|
+
var __export = (target, all) => {
|
|
26
|
+
__markAsModule(target);
|
|
27
|
+
for (var name in all)
|
|
28
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
29
|
+
};
|
|
30
|
+
var __reExport = (target, module2, desc) => {
|
|
31
|
+
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
|
|
32
|
+
for (let key of __getOwnPropNames(module2))
|
|
33
|
+
if (!__hasOwnProp.call(target, key) && key !== "default")
|
|
34
|
+
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
|
|
35
|
+
}
|
|
36
|
+
return target;
|
|
37
|
+
};
|
|
38
|
+
var __toModule = (module2) => {
|
|
39
|
+
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
|
|
40
|
+
};
|
|
41
|
+
__export(exports, {
|
|
42
|
+
addFile: () => addFile,
|
|
43
|
+
createFile: () => createFile,
|
|
44
|
+
decodeBase64: () => decodeBase64,
|
|
45
|
+
encodeBase64: () => encodeBase64,
|
|
46
|
+
getGiphySearch: () => getGiphySearch,
|
|
47
|
+
getGiphyTrends: () => getGiphyTrends,
|
|
48
|
+
getPathUserFiles: () => getPathUserFiles,
|
|
49
|
+
getUrlUserFiles: () => getUrlUserFiles,
|
|
50
|
+
getYouTubeSearch: () => getYouTubeSearch,
|
|
51
|
+
getYouTubeTrends: () => getYouTubeTrends,
|
|
52
|
+
linkFiles: () => linkFiles,
|
|
53
|
+
updateFiles: () => updateFiles
|
|
54
|
+
});
|
|
55
|
+
var import_rip_hunter = __toModule(require("@nlabs/rip-hunter"));
|
|
56
|
+
var import_utils = __toModule(require("@nlabs/utils"));
|
|
57
|
+
var import_arangojs = __toModule(require("arangojs"));
|
|
58
|
+
var import_googleapis = __toModule(require("googleapis"));
|
|
59
|
+
var import_graphql_errors = __toModule(require("graphql-errors"));
|
|
60
|
+
var import_isEmpty = __toModule(require("lodash/isEmpty"));
|
|
61
|
+
var request = __toModule(require("request-promise"));
|
|
62
|
+
var import_config = __toModule(require("../config"));
|
|
63
|
+
var import_images = __toModule(require("./images"));
|
|
64
|
+
var import_posts = __toModule(require("./posts"));
|
|
65
|
+
const youtube = import_googleapis.google.youtube({ auth: import_config.Config.get("google.key"), version: "v3" });
|
|
66
|
+
request.defaults({ encoding: null });
|
|
67
|
+
const addFile = (context, item = {}) => {
|
|
68
|
+
const { database, session: { userId: sessionId, userAccess } } = context;
|
|
69
|
+
const {
|
|
70
|
+
description,
|
|
71
|
+
fileId,
|
|
72
|
+
fileType,
|
|
73
|
+
name,
|
|
74
|
+
url
|
|
75
|
+
} = item;
|
|
76
|
+
const formatFileId = fileId ? (0, import_utils.parseId)(fileId) : (0, import_utils.createHash)(`file-${sessionId}`);
|
|
77
|
+
const isUrl = (0, import_isEmpty.default)(url);
|
|
78
|
+
let formatName = (0, import_utils.parseString)(name, 160);
|
|
79
|
+
let formatType = (0, import_utils.parseString)(fileType, 16);
|
|
80
|
+
if (formatName === "" && isUrl) {
|
|
81
|
+
formatName = url.substring(url.lastIndexOf("/") + 1);
|
|
82
|
+
}
|
|
83
|
+
if (formatType === "") {
|
|
84
|
+
const nameArr = formatName.split(".");
|
|
85
|
+
const ext = nameArr[nameArr.length - 1];
|
|
86
|
+
switch (ext) {
|
|
87
|
+
case "jpeg":
|
|
88
|
+
case "jpg":
|
|
89
|
+
formatType = "image/jpeg";
|
|
90
|
+
break;
|
|
91
|
+
case "png":
|
|
92
|
+
formatType = "image/png";
|
|
93
|
+
break;
|
|
94
|
+
case "zip":
|
|
95
|
+
formatType = "application/zip";
|
|
96
|
+
break;
|
|
97
|
+
default:
|
|
98
|
+
break;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
let isImage;
|
|
102
|
+
switch (formatType) {
|
|
103
|
+
case "image/jpeg":
|
|
104
|
+
case "image/png":
|
|
105
|
+
isImage = true;
|
|
106
|
+
break;
|
|
107
|
+
default:
|
|
108
|
+
isImage = false;
|
|
109
|
+
break;
|
|
110
|
+
}
|
|
111
|
+
const formatDesc = (0, import_utils.parseString)(description, 500);
|
|
112
|
+
if (!isImage && userAccess !== 2) {
|
|
113
|
+
throw new import_graphql_errors.UserError("account_restriction");
|
|
114
|
+
}
|
|
115
|
+
const saveToDb = (insert) => {
|
|
116
|
+
const aqlQry = import_arangojs.aql`INSERT ${insert} IN files RETURN NEW`;
|
|
117
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).then((file = {}) => file).catch((error) => {
|
|
118
|
+
throw error;
|
|
119
|
+
});
|
|
120
|
+
};
|
|
121
|
+
const uploadFile = (buf, uploadType) => {
|
|
122
|
+
const now = Date.now();
|
|
123
|
+
if (isImage) {
|
|
124
|
+
return (0, import_images.resizeSaveImage)(context, formatFileId, buf, uploadType).then((resizedImage) => {
|
|
125
|
+
const insert2 = __spreadProps(__spreadValues({}, resizedImage), {
|
|
126
|
+
_key: formatFileId,
|
|
127
|
+
added: now,
|
|
128
|
+
description: formatDesc,
|
|
129
|
+
fileType: formatType,
|
|
130
|
+
modified: now,
|
|
131
|
+
name: formatName,
|
|
132
|
+
userId: sessionId
|
|
133
|
+
});
|
|
134
|
+
return saveToDb(insert2);
|
|
135
|
+
}).catch((error) => {
|
|
136
|
+
throw error;
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
const insert = {
|
|
140
|
+
_key: formatFileId,
|
|
141
|
+
added: now,
|
|
142
|
+
description: formatDesc,
|
|
143
|
+
fileType: formatType,
|
|
144
|
+
modified: now,
|
|
145
|
+
name: formatName,
|
|
146
|
+
userId: sessionId
|
|
147
|
+
};
|
|
148
|
+
return saveToDb(insert);
|
|
149
|
+
};
|
|
150
|
+
if (isUrl) {
|
|
151
|
+
return request.get({ encoding: null, uri: url }).then((body) => uploadFile(Buffer.from(body, "binary"), formatType)).catch(() => {
|
|
152
|
+
throw new import_graphql_errors.UserError("file_request");
|
|
153
|
+
});
|
|
154
|
+
} else if (item.base64 !== "") {
|
|
155
|
+
const buffer = Buffer.from(item.base64);
|
|
156
|
+
return uploadFile(buffer, formatType);
|
|
157
|
+
}
|
|
158
|
+
throw new Error("file_required");
|
|
159
|
+
};
|
|
160
|
+
const getGiphyTrends = (context, limit = 30) => {
|
|
161
|
+
const gifUrl = `http://api.giphy.com/v1/gifs/trending?api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
|
|
162
|
+
return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json.data.map((gifImage = { id: null, images: null }) => {
|
|
163
|
+
const {
|
|
164
|
+
id,
|
|
165
|
+
images: {
|
|
166
|
+
original: { url = "" } = {},
|
|
167
|
+
fixed_height_small: { url: thumb = "" } = {}
|
|
168
|
+
} = {}
|
|
169
|
+
} = gifImage;
|
|
170
|
+
return {
|
|
171
|
+
id,
|
|
172
|
+
thumb,
|
|
173
|
+
type: "giphy",
|
|
174
|
+
url
|
|
175
|
+
};
|
|
176
|
+
}));
|
|
177
|
+
};
|
|
178
|
+
const getGiphySearch = (context, query, limit = 30) => {
|
|
179
|
+
const formatQuery = encodeURI(query);
|
|
180
|
+
const gifUrl = `http://api.giphy.com/v1/gifs/search?q=${formatQuery}&api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
|
|
181
|
+
return fetch(gifUrl).then((res) => res.json()).then((json) => json.data.map((gifImage = { id: null, images: null }) => {
|
|
182
|
+
const {
|
|
183
|
+
id,
|
|
184
|
+
images: {
|
|
185
|
+
original: { url = "" } = {},
|
|
186
|
+
fixed_height_small: { url: thumb = "" } = {}
|
|
187
|
+
} = {}
|
|
188
|
+
} = gifImage;
|
|
189
|
+
return {
|
|
190
|
+
id,
|
|
191
|
+
thumb,
|
|
192
|
+
type: "giphy",
|
|
193
|
+
url
|
|
194
|
+
};
|
|
195
|
+
}));
|
|
196
|
+
};
|
|
197
|
+
const getYouTubeTrends = (context, limit = 30) => new Promise((resolve, reject) => {
|
|
198
|
+
youtube.videos.list({
|
|
199
|
+
chart: "mostPopular",
|
|
200
|
+
maxResults: limit,
|
|
201
|
+
part: ["snippet"],
|
|
202
|
+
regionCode: "US"
|
|
203
|
+
}, (error, data) => {
|
|
204
|
+
if (error) {
|
|
205
|
+
console.error(error);
|
|
206
|
+
reject(new Error(error[0].message));
|
|
207
|
+
} else if (data) {
|
|
208
|
+
const list = data.items.map((item) => ({
|
|
209
|
+
id: item.id,
|
|
210
|
+
thumb: item.snippet.thumbnails.high.url,
|
|
211
|
+
type: "youtube",
|
|
212
|
+
url: `http://www.youtube.com/embed/${item.id}`
|
|
213
|
+
}));
|
|
214
|
+
resolve(list);
|
|
215
|
+
}
|
|
216
|
+
});
|
|
217
|
+
});
|
|
218
|
+
const getYouTubeSearch = (context, query, limit = 30) => new Promise((resolve, reject) => {
|
|
219
|
+
youtube.search.list({
|
|
220
|
+
maxResults: limit,
|
|
221
|
+
part: ["snippet"],
|
|
222
|
+
q: query,
|
|
223
|
+
regionCode: "US"
|
|
224
|
+
}, (error, data) => {
|
|
225
|
+
if (error) {
|
|
226
|
+
console.error(error);
|
|
227
|
+
reject(new Error(error[0].message));
|
|
228
|
+
} else if (data) {
|
|
229
|
+
const { items } = data;
|
|
230
|
+
const list = items.map((item) => ({
|
|
231
|
+
id: item.id,
|
|
232
|
+
thumb: item.snippet.thumbnails.high.url,
|
|
233
|
+
type: "youtube",
|
|
234
|
+
url: `http://www.youtube.com/embed/${item.id}`
|
|
235
|
+
}));
|
|
236
|
+
resolve(list);
|
|
237
|
+
}
|
|
238
|
+
});
|
|
239
|
+
});
|
|
240
|
+
const getPathUserFiles = (userId, filename) => `users/${userId}/files/${filename}`;
|
|
241
|
+
const getUrlUserFiles = (userId, filename, dir = "files", type = "profile") => {
|
|
242
|
+
if (filename) {
|
|
243
|
+
return `https://box.${import_config.Config.get("app.url")}/users/${userId}/${dir}/${filename}`;
|
|
244
|
+
}
|
|
245
|
+
if (type === "profile") {
|
|
246
|
+
return `https://box.${import_config.Config.get("app.url")}/defaults/user_bk.jpg`;
|
|
247
|
+
}
|
|
248
|
+
return `https://box.${import_config.Config.get("app.url")}/defaults/user_wh.jpg`;
|
|
249
|
+
};
|
|
250
|
+
const createFile = (db, file) => {
|
|
251
|
+
const { fileId } = file;
|
|
252
|
+
const insert = {
|
|
253
|
+
_key: fileId,
|
|
254
|
+
added: Date.now()
|
|
255
|
+
};
|
|
256
|
+
const aqlQry = import_arangojs.aql`UPSERT {_key: ${fileId}}
|
|
257
|
+
INSERT ${insert}
|
|
258
|
+
UPDATE {}
|
|
259
|
+
IN files RETURN NEW`;
|
|
260
|
+
return db.query(aqlQry).then((cursor) => cursor.next()).then((updatedFile = {}) => updatedFile).catch((error) => {
|
|
261
|
+
throw error;
|
|
262
|
+
});
|
|
263
|
+
};
|
|
264
|
+
const linkFiles = (db, files, postId) => Promise.all(files.map((file) => createFile(db, file).then((file2) => (0, import_posts.createPostEdge)(db, file2, postId))));
|
|
265
|
+
const updateFiles = (db, postId, files) => {
|
|
266
|
+
const edgeCollection = db.collection("isPosted");
|
|
267
|
+
return edgeCollection.inEdges(postId).then((edges) => {
|
|
268
|
+
if (edges.length) {
|
|
269
|
+
return Promise.all(edges.map((edge) => {
|
|
270
|
+
const { _key: edgeKey } = edge;
|
|
271
|
+
const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isPosted`;
|
|
272
|
+
return db.query(aqlQry).catch((error) => {
|
|
273
|
+
throw error;
|
|
274
|
+
});
|
|
275
|
+
})).then(() => {
|
|
276
|
+
if (files.length) {
|
|
277
|
+
return linkFiles(db, files, postId).then(() => files);
|
|
278
|
+
}
|
|
279
|
+
return files;
|
|
280
|
+
});
|
|
281
|
+
} else if (files.length) {
|
|
282
|
+
return linkFiles(db, files, postId).then(() => files);
|
|
283
|
+
}
|
|
284
|
+
return files;
|
|
285
|
+
}).catch((error) => {
|
|
286
|
+
throw error;
|
|
287
|
+
});
|
|
288
|
+
};
|
|
289
|
+
const encodeBase64 = (buffer) => Buffer.from(buffer).toString("base64");
|
|
290
|
+
const decodeBase64 = (dataString) => {
|
|
291
|
+
const getData = (str) => str.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/) || [];
|
|
292
|
+
let matches = getData(dataString);
|
|
293
|
+
if (matches.length !== 3) {
|
|
294
|
+
matches = getData(decodeURIComponent(dataString));
|
|
295
|
+
if (matches.length !== 3) {
|
|
296
|
+
throw Error("Invalid input string");
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
return {
|
|
300
|
+
data: Buffer.from(matches[2], "base64"),
|
|
301
|
+
type: matches[1]
|
|
302
|
+
};
|
|
303
|
+
};
|
|
304
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
305
|
+
0 && (module.exports = {
|
|
306
|
+
addFile,
|
|
307
|
+
createFile,
|
|
308
|
+
decodeBase64,
|
|
309
|
+
encodeBase64,
|
|
310
|
+
getGiphySearch,
|
|
311
|
+
getGiphyTrends,
|
|
312
|
+
getPathUserFiles,
|
|
313
|
+
getUrlUserFiles,
|
|
314
|
+
getYouTubeSearch,
|
|
315
|
+
getYouTubeTrends,
|
|
316
|
+
linkFiles,
|
|
317
|
+
updateFiles
|
|
318
|
+
});
|
|
319
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/files.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {get as httpGet} from '@nlabs/rip-hunter';\nimport {createHash, parseId, parseString} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {google} from 'googleapis';\nimport {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 {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, session: {userId: sessionId, userAccess}} = context;\n  const {\n    description,\n    fileId,\n    fileType,\n    name,\n    url\n  } = item;\n\n  // Id\n  const formatFileId: string = fileId ? parseId(fileId) : createHash(`file-${sessionId}`);\n\n  // Name\n  const isUrl: boolean = isEmpty(url);\n\n  // If no name, get it from url path\n  let formatName: string = parseString(name, 160);\n  let formatType: string = parseString(fileType, 16);\n\n  if(formatName === '' && isUrl) {\n    formatName = url.substring(url.lastIndexOf('/') + 1);\n  }\n\n  if(formatType === '') {\n    const nameArr: string[] = formatName.split('.');\n    const ext: string = nameArr[nameArr.length - 1];\n\n    switch(ext) {\n      case 'jpeg':\n      case 'jpg':\n        formatType = 'image/jpeg';\n        break;\n      case 'png':\n        formatType = 'image/png';\n        break;\n      case 'zip':\n        formatType = 'application/zip';\n        break;\n      default:\n        break;\n    }\n  }\n\n  let isImage: boolean;\n\n  switch(formatType) {\n    case 'image/jpeg':\n    case 'image/png':\n      isImage = true;\n      break;\n    default:\n      isImage = false;\n      break;\n  }\n\n  // Description\n  const formatDesc: string = parseString(description, 500);\n\n  // Only allow file uploads to premium users\n  if(!isImage && userAccess !== 2) {\n    throw new UserError('account_restriction');\n  }\n\n  const saveToDb = (insert: FileType) => {\n    const aqlQry: AqlQuery = aql`INSERT ${insert} IN files RETURN NEW`;\n\n    return database.query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((file = {}) => file)\n      .catch((error: Error) => {\n        throw error;\n      });\n  };\n\n  const uploadFile = (buf: Buffer, uploadType: string) => {\n    const now: number = Date.now();\n\n    // If image, resize and create a thumbnail\n    if(isImage) {\n      return resizeSaveImage(context, formatFileId, buf, uploadType)\n        .then((resizedImage: FileType) => {\n          const insert: FileType = {\n            ...resizedImage,\n            _key: formatFileId,\n            added: now,\n            description: formatDesc,\n            fileType: formatType,\n            modified: now,\n            name: formatName,\n            userId: sessionId\n          };\n\n          return saveToDb(insert);\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    }\n    const insert: FileType = {\n      _key: formatFileId,\n      added: now,\n      description: formatDesc,\n      fileType: formatType,\n      modified: now,\n      name: formatName,\n      userId: sessionId\n    };\n\n    return saveToDb(insert);\n  };\n\n  // If file is a url path, download the file and save\n  if(isUrl) {\n    return 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"],
  "mappings": "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",
  "names": []
}

|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
+
import { Database } from 'arangojs';
|
|
1
2
|
import { ApiContext } from '../types/auth';
|
|
2
|
-
import { GroupEdgeType, GroupType,
|
|
3
|
+
import { GroupEdgeType, GroupType, GroupUser } from '../types/groups';
|
|
3
4
|
export declare const getGroupList: (context: ApiContext, from: number, to: number) => Promise<GroupType[]>;
|
|
4
5
|
export declare const getGroupListByUser: (context: ApiContext, from: number, to: number) => Promise<GroupType[]>;
|
|
5
6
|
export declare const getGroupListByTags: (context: ApiContext, tags: string[], from: number, to: number) => Promise<GroupType[]>;
|
|
6
7
|
export declare const getGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
|
|
7
8
|
export declare const getGroupDetails: (context: ApiContext, groupId: string) => Promise<GroupType>;
|
|
8
|
-
export declare const createGroupEdge: (database:
|
|
9
|
+
export declare const createGroupEdge: (database: Database, userId: string, groupId: string) => Promise<GroupEdgeType>;
|
|
9
10
|
export declare const addGroup: (context: ApiContext, item?: GroupType) => Promise<GroupType>;
|
|
10
11
|
export declare const updateGroup: (context: ApiContext, item?: GroupType) => Promise<GroupType>;
|
|
11
12
|
export declare const deleteGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
|
|
12
13
|
export declare const getGroupsByReaction: (context: ApiContext, reaction: string) => Promise<GroupType[]>;
|
|
13
|
-
export declare const isGrouped: (database:
|
|
14
|
+
export declare const isGrouped: (database: Database, userId: string, groupId: string) => Promise<GroupUser>;
|