@nlabs/reaktor 0.8.0 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc +10 -0
- package/.prettierrc.js +4 -0
- package/README.md +1 -1
- package/coverage/actions/groups.ts.html +1039 -0
- package/coverage/actions/images.ts.html +2500 -0
- package/coverage/actions/index.html +131 -0
- package/coverage/actions/tags.ts.html +1000 -0
- package/coverage/adapters/arangoAdapter.ts.html +151 -0
- package/coverage/adapters/index.html +146 -0
- package/coverage/adapters/reaktorAdapter.ts.html +127 -0
- package/coverage/adapters/tagAdapter.ts.html +160 -0
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/clover.xml +6 -0
- package/coverage/coverage-final.json +1 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +176 -0
- package/coverage/lcov-report/base.css +224 -0
- package/coverage/lcov-report/block-navigation.js +87 -0
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +101 -0
- package/coverage/lcov-report/prettify.css +1 -0
- package/coverage/lcov-report/prettify.js +2 -0
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +196 -0
- package/coverage/lcov.info +0 -0
- package/coverage/mocks/file.ts.html +118 -0
- package/coverage/mocks/group.ts.html +145 -0
- package/coverage/mocks/image.ts.html +136 -0
- package/coverage/mocks/index.html +146 -0
- package/coverage/mocks/post.ts.html +169 -0
- package/coverage/mocks/tag.ts.html +121 -0
- package/coverage/mocks/user.ts.html +268 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +196 -0
- package/coverage/types/error.ts.html +145 -0
- package/coverage/types/index.html +116 -0
- package/coverage/utils/adapterUtils.ts.html +151 -0
- package/coverage/utils/analyticsUtils.ts.html +292 -0
- package/coverage/utils/arangodbUtils.ts.html +463 -0
- package/coverage/utils/index.html +146 -0
- package/jest.setup.js +0 -0
- package/jpg:- +0 -0
- package/lib/actions/apps.d.ts +25 -0
- package/lib/actions/apps.js +252 -0
- package/lib/actions/conversations.d.ts +14 -0
- package/lib/actions/conversations.js +131 -126
- package/lib/actions/dynamodb.d.ts +8 -0
- package/lib/actions/dynamodb.js +35 -32
- package/lib/actions/email.d.ts +5 -0
- package/lib/actions/email.js +23 -53
- package/lib/actions/files.d.ts +19 -0
- package/lib/actions/files.js +188 -202
- package/lib/actions/groups.d.ts +14 -0
- package/lib/actions/groups.js +38 -36
- package/lib/actions/images.d.ts +26 -0
- package/lib/actions/images.js +236 -229
- package/lib/actions/index.d.ts +21 -0
- package/lib/actions/index.js +3 -1
- package/lib/actions/ios.d.ts +7 -0
- package/lib/actions/ios.js +11 -10
- package/lib/actions/locations.d.ts +5 -0
- package/lib/actions/locations.js +29 -37
- package/lib/actions/messages.d.ts +13 -0
- package/lib/actions/messages.js +10 -10
- package/lib/actions/notifications.d.ts +5 -0
- package/lib/actions/notifications.js +1 -1
- package/lib/actions/payments.d.ts +10 -0
- package/lib/actions/payments.js +27 -26
- package/lib/actions/posts.d.ts +19 -0
- package/lib/actions/posts.js +176 -156
- package/lib/actions/reactions.d.ts +30 -0
- package/lib/actions/reactions.js +30 -28
- package/lib/actions/s3.d.ts +7 -0
- package/lib/actions/s3.js +37 -32
- package/lib/actions/search.d.ts +3 -0
- package/lib/actions/search.js +11 -9
- package/lib/actions/sms.d.ts +3 -0
- package/lib/actions/sms.js +58 -34
- package/lib/actions/statistics.d.ts +3 -0
- package/lib/actions/statistics.js +21 -18
- package/lib/actions/subscription.d.ts +7 -0
- package/lib/actions/subscription.js +24 -21
- package/lib/actions/tags.d.ts +29 -0
- package/lib/actions/tags.js +129 -198
- package/lib/actions/users.d.ts +47 -0
- package/lib/actions/users.js +188 -194
- package/lib/actions/websockets.d.ts +19 -0
- package/lib/actions/websockets.js +60 -34
- package/lib/adapters/arangoAdapter.d.ts +2 -0
- package/lib/adapters/arangoAdapter.js +46 -0
- package/lib/adapters/fileAdapter.d.ts +3 -0
- package/lib/adapters/fileAdapter.js +76 -0
- package/lib/adapters/postAdapter.d.ts +2 -0
- package/lib/adapters/postAdapter.js +70 -0
- package/lib/adapters/reaktorAdapter.d.ts +6 -0
- package/lib/adapters/reaktorAdapter.js +44 -0
- package/lib/adapters/tagAdapter.d.ts +2 -0
- package/lib/adapters/tagAdapter.js +50 -0
- package/lib/adapters/userAdapter.d.ts +2 -0
- package/lib/adapters/userAdapter.js +110 -0
- package/lib/config.d.ts +20 -0
- package/lib/config.js +14 -15
- package/lib/index.d.ts +5 -0
- package/lib/lambdas/actions/websockets.d.ts +6 -0
- package/lib/lambdas/actions/websockets.js +7 -7
- package/lib/lambdas/authorizer.d.ts +20 -0
- package/lib/lambdas/authorizer.js +1 -1
- package/lib/lambdas/connection.d.ts +12 -0
- package/lib/lambdas/connection.js +5 -4
- package/lib/lambdas/utils/message.d.ts +1 -0
- package/lib/lambdas/utils/websocket.d.ts +7 -0
- package/lib/lambdas/utils/websocket.js +8 -6
- package/lib/mocks/conversation.d.ts +8 -0
- package/lib/mocks/conversation.js +35 -0
- package/lib/mocks/file.d.ts +11 -0
- package/lib/mocks/file.js +38 -0
- package/lib/mocks/group.d.ts +17 -0
- package/lib/mocks/group.js +47 -0
- package/lib/mocks/image.d.ts +3 -0
- package/lib/mocks/image.js +43 -0
- package/lib/mocks/nlabs.png +0 -0
- package/lib/mocks/post.d.ts +38 -0
- package/lib/mocks/post.js +55 -0
- package/lib/mocks/tag.d.ts +2 -0
- package/lib/mocks/tag.js +37 -0
- package/lib/mocks/user.d.ts +4 -0
- package/lib/mocks/user.js +88 -0
- package/lib/templates/email/layout.d.ts +2 -0
- package/lib/templates/email/passwordForgot.d.ts +2 -0
- package/lib/templates/email/passwordRecovery.d.ts +2 -0
- package/lib/templates/email/verifyEmail.d.ts +2 -0
- package/lib/templates/email/welcome.d.ts +2 -0
- package/lib/templates/sms/passwordForgot.d.ts +2 -0
- package/lib/templates/sms/passwordRecovery.d.ts +2 -0
- package/lib/templates/sms/verifyEmail.d.ts +2 -0
- package/lib/templates/sms/verifyPhone.d.ts +2 -0
- package/lib/templates/sms/welcome.d.ts +2 -0
- package/lib/types/apps.d.ts +46 -0
- package/lib/types/apps.js +17 -1
- package/lib/types/arangodb.d.ts +30 -0
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.d.ts +7 -0
- package/lib/types/auth.js +1 -1
- package/lib/types/connections.d.ts +7 -0
- package/lib/types/connections.js +1 -1
- package/lib/types/conversations.d.ts +29 -0
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.d.ts +13 -0
- package/lib/types/email.js +1 -1
- package/lib/types/error.d.ts +20 -0
- package/lib/types/error.js +44 -0
- package/lib/types/files.d.ts +26 -0
- package/lib/types/files.js +1 -1
- package/lib/types/google.d.ts +29 -0
- package/lib/types/google.js +1 -1
- package/lib/types/groups.d.ts +21 -0
- package/lib/types/groups.js +1 -1
- package/lib/types/images.d.ts +51 -0
- package/lib/types/images.js +1 -1
- package/lib/types/index.d.ts +18 -0
- package/lib/types/locations.d.ts +20 -0
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +16 -0
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.d.ts +17 -0
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.d.ts +112 -0
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.d.ts +31 -0
- package/lib/types/posts.js +1 -1
- package/lib/types/statistics.d.ts +3 -0
- package/lib/types/statistics.js +1 -1
- package/lib/types/tags.d.ts +10 -0
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +76 -0
- package/lib/types/users.js +1 -1
- package/lib/types/websocket.d.ts +13 -0
- package/lib/types/websocket.js +1 -1
- package/lib/utils/adapterUtils.d.ts +1 -0
- package/lib/utils/adapterUtils.js +45 -0
- package/lib/utils/analyticsUtils.d.ts +21 -0
- package/lib/utils/analyticsUtils.js +72 -0
- package/lib/utils/arangodbUtils.d.ts +65 -0
- package/lib/utils/arangodbUtils.js +144 -0
- package/lib/utils/auth.d.ts +20 -0
- package/lib/utils/auth.js +13 -30
- package/lib/utils/index.d.ts +5 -0
- package/lib/utils/index.js +7 -9
- package/lib/utils/session.d.ts +16 -0
- package/lib/utils/session.js +11 -2
- package/package.json +12 -5
- package/lib/utils/analytics.js +0 -88
- package/lib/utils/arangodb.js +0 -118
- package/lib/utils/graphql.js +0 -46
- package/lib/utils/objects.js +0 -59
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
var apps_exports = {};
|
|
19
|
+
__export(apps_exports, {
|
|
20
|
+
addApp: () => addApp,
|
|
21
|
+
deactivateApp: () => deactivateApp,
|
|
22
|
+
deleteApp: () => deleteApp,
|
|
23
|
+
getApp: () => getApp,
|
|
24
|
+
getAppOptional: () => getAppOptional,
|
|
25
|
+
getApps: () => getApps,
|
|
26
|
+
parseAppOptions: () => parseAppOptions,
|
|
27
|
+
updateApp: () => updateApp
|
|
28
|
+
});
|
|
29
|
+
module.exports = __toCommonJS(apps_exports);
|
|
30
|
+
var import_arangojs = require("arangojs");
|
|
31
|
+
var import_utils = require("@nlabs/utils");
|
|
32
|
+
var import_error = require("../types/error");
|
|
33
|
+
var import_analyticsUtils = require("../utils/analyticsUtils");
|
|
34
|
+
var import_arangodbUtils = require("../utils/arangodbUtils");
|
|
35
|
+
var import_session = require("../utils/session");
|
|
36
|
+
const eventCategory = "apps";
|
|
37
|
+
const getAppOptional = (fields = []) => fields.reduce((selects, field) => {
|
|
38
|
+
if (field.includes("Count")) {
|
|
39
|
+
return (0, import_arangodbUtils.selectReactionCountByType)("apps", "a", field, selects);
|
|
40
|
+
}
|
|
41
|
+
return selects;
|
|
42
|
+
}, { objects: [], queries: [] });
|
|
43
|
+
const parseAppOptions = (options = {}) => {
|
|
44
|
+
const {
|
|
45
|
+
from = 0,
|
|
46
|
+
to = 30
|
|
47
|
+
} = options;
|
|
48
|
+
const limit = (0, import_arangodbUtils.getLimit)(from, to);
|
|
49
|
+
return {
|
|
50
|
+
...options,
|
|
51
|
+
limit
|
|
52
|
+
};
|
|
53
|
+
};
|
|
54
|
+
const addApp = async (context, app) => {
|
|
55
|
+
const action = "addUser";
|
|
56
|
+
const { database } = context;
|
|
57
|
+
const { email, name, phone } = app;
|
|
58
|
+
const formatName = (0, import_utils.parseString)(name);
|
|
59
|
+
const formatEmail = (0, import_utils.parseEmail)(email);
|
|
60
|
+
const formatPhone = (0, import_utils.parsePhone)(phone);
|
|
61
|
+
if (!formatName) {
|
|
62
|
+
return (0, import_analyticsUtils.logException)({
|
|
63
|
+
action,
|
|
64
|
+
category: eventCategory,
|
|
65
|
+
params: { name },
|
|
66
|
+
value: import_error.ErrorTypes.INVALID_ARGUMENTS
|
|
67
|
+
}, context);
|
|
68
|
+
}
|
|
69
|
+
const filters = [`a.name == "${formatName}"`];
|
|
70
|
+
if (formatEmail) {
|
|
71
|
+
filters.push(`a.email == "${formatEmail}"`);
|
|
72
|
+
}
|
|
73
|
+
const checkQuery = `FOR u IN users
|
|
74
|
+
FILTER ${filters.join(" || ")}
|
|
75
|
+
RETURN u`;
|
|
76
|
+
try {
|
|
77
|
+
const existingApps = await database.query(checkQuery).then((cursor) => cursor.all());
|
|
78
|
+
if (existingApps.length) {
|
|
79
|
+
return (0, import_analyticsUtils.logException)({
|
|
80
|
+
action,
|
|
81
|
+
category: eventCategory,
|
|
82
|
+
value: import_error.ErrorTypes.EXISTING_ITEM,
|
|
83
|
+
params: { name }
|
|
84
|
+
}, context);
|
|
85
|
+
}
|
|
86
|
+
} catch (error) {
|
|
87
|
+
return (0, import_analyticsUtils.logError)({
|
|
88
|
+
action,
|
|
89
|
+
category: eventCategory,
|
|
90
|
+
label: import_error.ErrorTypes.DATABASE_ERROR,
|
|
91
|
+
params: { name }
|
|
92
|
+
}, error, context);
|
|
93
|
+
}
|
|
94
|
+
const insert = {
|
|
95
|
+
_key: (0, import_utils.createHash)(name, null),
|
|
96
|
+
active: true,
|
|
97
|
+
added: Date.now(),
|
|
98
|
+
email: formatEmail,
|
|
99
|
+
modified: Date.now(),
|
|
100
|
+
phone: formatPhone,
|
|
101
|
+
name: formatName
|
|
102
|
+
};
|
|
103
|
+
const insertQuery = import_arangojs.aql`INSERT ${insert} IN apps RETURN NEW`;
|
|
104
|
+
return await database.query(insertQuery).then((cursor) => cursor.next() || {}).catch((error) => (0, import_analyticsUtils.logError)({
|
|
105
|
+
action,
|
|
106
|
+
category: eventCategory,
|
|
107
|
+
label: import_error.ErrorTypes.DATABASE_ERROR,
|
|
108
|
+
params: { name }
|
|
109
|
+
}, error, context));
|
|
110
|
+
};
|
|
111
|
+
const updateApp = async (context, app) => {
|
|
112
|
+
const action = "updateApp";
|
|
113
|
+
const { database } = context;
|
|
114
|
+
const { _key, _id, id, appId, ...updated } = app;
|
|
115
|
+
const appDocId = (0, import_arangodbUtils.getDocId)("apps", app);
|
|
116
|
+
const appQuery = import_arangojs.aql`LET a = DOCUMENT(${appDocId})
|
|
117
|
+
UPDATE a WITH ${updated} IN apps
|
|
118
|
+
RETURN NEW`;
|
|
119
|
+
return await database.query(appQuery).then((cursor) => cursor.next()).catch(
|
|
120
|
+
(error) => (0, import_analyticsUtils.logError)({
|
|
121
|
+
action,
|
|
122
|
+
category: eventCategory,
|
|
123
|
+
label: import_error.ErrorTypes.DATABASE_ERROR,
|
|
124
|
+
params: { app }
|
|
125
|
+
}, error, context)
|
|
126
|
+
);
|
|
127
|
+
};
|
|
128
|
+
const deleteApp = async (context, app) => {
|
|
129
|
+
const action = "deleteApp";
|
|
130
|
+
const { database, session } = context;
|
|
131
|
+
const isAdmin = (0, import_session.isAdminUser)(session);
|
|
132
|
+
const appDocId = (0, import_arangodbUtils.getDocId)("apps", app);
|
|
133
|
+
if (!isAdmin) {
|
|
134
|
+
return (0, import_analyticsUtils.logException)({
|
|
135
|
+
action,
|
|
136
|
+
category: eventCategory,
|
|
137
|
+
label: "unauthorized",
|
|
138
|
+
params: app,
|
|
139
|
+
value: import_error.ErrorTypes.INVALID_SESSION
|
|
140
|
+
}, context);
|
|
141
|
+
}
|
|
142
|
+
const aqlQuery = import_arangojs.aql`FOR a IN apps
|
|
143
|
+
FILTER a._id == \"${appDocId}\"
|
|
144
|
+
LIMIT 1
|
|
145
|
+
REMOVE a IN apps
|
|
146
|
+
RETURN OLD`;
|
|
147
|
+
return database.query(aqlQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
148
|
+
action,
|
|
149
|
+
category: eventCategory,
|
|
150
|
+
label: import_error.ErrorTypes.DATABASE_ERROR,
|
|
151
|
+
params: app
|
|
152
|
+
}, error, context));
|
|
153
|
+
};
|
|
154
|
+
const deactivateApp = (context, app) => {
|
|
155
|
+
const action = "deactivateApp";
|
|
156
|
+
const { database, session } = context;
|
|
157
|
+
const isAdmin = (0, import_session.isAdminUser)(session);
|
|
158
|
+
const appDocId = (0, import_arangodbUtils.getDocId)("apps", app);
|
|
159
|
+
if (!isAdmin) {
|
|
160
|
+
return (0, import_analyticsUtils.logException)({
|
|
161
|
+
action,
|
|
162
|
+
category: eventCategory,
|
|
163
|
+
label: "unauthorized",
|
|
164
|
+
value: import_error.ErrorTypes.INVALID_SESSION
|
|
165
|
+
}, context);
|
|
166
|
+
}
|
|
167
|
+
const updated = {
|
|
168
|
+
active: false
|
|
169
|
+
};
|
|
170
|
+
const aqlQuery = import_arangojs.aql`UPDATE ${appDocId} WITH ${updated} IN apps LIMIT 1 RETURN NEW`;
|
|
171
|
+
return database.query(aqlQuery).then((cursor) => cursor.next()).catch((error) => {
|
|
172
|
+
throw error;
|
|
173
|
+
});
|
|
174
|
+
};
|
|
175
|
+
const getApp = (context, options) => {
|
|
176
|
+
const action = "getApp";
|
|
177
|
+
const { database, fields, session } = context;
|
|
178
|
+
const { id, key, name } = parseAppOptions(options);
|
|
179
|
+
const { objects: selectObjects, queries: selectQueries } = getAppOptional(fields);
|
|
180
|
+
const filterBy = ["a.active == true"];
|
|
181
|
+
const isAdmin = (0, import_session.isAdminUser)(session);
|
|
182
|
+
if (!isAdmin) {
|
|
183
|
+
return (0, import_analyticsUtils.logException)({
|
|
184
|
+
action,
|
|
185
|
+
category: eventCategory,
|
|
186
|
+
label: "unauthorized",
|
|
187
|
+
value: import_error.ErrorTypes.INVALID_SESSION
|
|
188
|
+
}, context);
|
|
189
|
+
}
|
|
190
|
+
if (id) {
|
|
191
|
+
filterBy.push(`a._id == "${(0, import_utils.parseArangoId)(id)}"`);
|
|
192
|
+
}
|
|
193
|
+
if (key) {
|
|
194
|
+
filterBy.push(`a._key == "apps/${(0, import_utils.parseId)(key)}"`);
|
|
195
|
+
}
|
|
196
|
+
if (name) {
|
|
197
|
+
filterBy.push(`CONTAINS(a.name, "${(0, import_utils.parseString)(name)}")`);
|
|
198
|
+
}
|
|
199
|
+
const aqlQuery = `FOR a IN apps
|
|
200
|
+
FILTER ${filterBy.join(" && ")}
|
|
201
|
+
${selectQueries.join("\n")}
|
|
202
|
+
RETURN MERGE(a, {${selectObjects.join(", ")}})`;
|
|
203
|
+
return database.query(aqlQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
204
|
+
action,
|
|
205
|
+
category: eventCategory,
|
|
206
|
+
label: import_error.ErrorTypes.DATABASE_ERROR,
|
|
207
|
+
params: options
|
|
208
|
+
}, error, context));
|
|
209
|
+
};
|
|
210
|
+
const getApps = (context, options) => {
|
|
211
|
+
const action = "getApps";
|
|
212
|
+
const { database, fields, session } = context;
|
|
213
|
+
const { limit, name } = parseAppOptions(options);
|
|
214
|
+
const { objects: selectObjects, queries: selectQueries } = getAppOptional(fields);
|
|
215
|
+
const filterBy = ["a.active == true"];
|
|
216
|
+
const isAdmin = (0, import_session.isAdminUser)(session);
|
|
217
|
+
if (!isAdmin) {
|
|
218
|
+
return (0, import_analyticsUtils.logException)({
|
|
219
|
+
action,
|
|
220
|
+
category: eventCategory,
|
|
221
|
+
label: "unauthorized",
|
|
222
|
+
value: import_error.ErrorTypes.INVALID_SESSION
|
|
223
|
+
}, context);
|
|
224
|
+
}
|
|
225
|
+
if (name) {
|
|
226
|
+
filterBy.push(`CONTAINS(a.name, "${(0, import_utils.parseString)(name)}")`);
|
|
227
|
+
}
|
|
228
|
+
const aqlQuery = `FOR a IN apps
|
|
229
|
+
FILTER ${filterBy.join(" && ")}
|
|
230
|
+
${selectQueries.join("\n")}
|
|
231
|
+
${limit.aql}
|
|
232
|
+
SORT a.name
|
|
233
|
+
RETURN MERGE(a, {${selectObjects.join(", ")}})`;
|
|
234
|
+
return database.query(aqlQuery).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
235
|
+
action,
|
|
236
|
+
category: eventCategory,
|
|
237
|
+
label: import_error.ErrorTypes.DATABASE_ERROR,
|
|
238
|
+
params: options
|
|
239
|
+
}, error, context));
|
|
240
|
+
};
|
|
241
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
242
|
+
0 && (module.exports = {
|
|
243
|
+
addApp,
|
|
244
|
+
deactivateApp,
|
|
245
|
+
deleteApp,
|
|
246
|
+
getApp,
|
|
247
|
+
getAppOptional,
|
|
248
|
+
getApps,
|
|
249
|
+
parseAppOptions,
|
|
250
|
+
updateApp
|
|
251
|
+
});
|
|
252
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/apps.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 {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {createHash, parseArangoId, parseEmail, parseId, parsePhone, parseString} from '@nlabs/utils';\n\nimport {AppType} from '../types/apps';\nimport {ErrorTypes} from '../types/error';\nimport {logError, logException} from '../utils/analyticsUtils';\nimport {getDocId, getLimit, selectReactionCountByType} from '../utils/arangodbUtils';\nimport {isAdminUser} from '../utils/session';\nimport type {ApiContext} from '../types/auth';\nimport type {UserType} from '../types/users';\n\nconst eventCategory: string = 'apps';\n\nexport interface AppOptions {\n  readonly id?: string;\n  readonly key?: string;\n  readonly from?: number;\n  readonly name?: string;\n  readonly to?: number;\n}\n\nexport const getAppOptional = (fields: string[] = []) =>\n  fields.reduce((selects: any, field: string) => {\n    if(field.includes('Count')) {\n      return selectReactionCountByType('apps', 'a', field, selects);\n    }\n\n    return selects;\n  }, {objects: [], queries: []});\n\nexport const parseAppOptions = (options: AppOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n  const limit = getLimit(from, to);\n\n  return {\n    ...options,\n    limit\n  };\n};\n\nexport const addApp = async (context: ApiContext, app: AppType): Promise<UserType> => {\n  const action = 'addUser';\n  const {database} = context;\n  const {email, name, phone} = app;\n  const formatName = parseString(name);\n  const formatEmail = parseEmail(email);\n  const formatPhone = parsePhone(phone);\n\n  if(!formatName) {\n    return logException({\n      action,\n      category: eventCategory,\n      params: {name},\n      value: ErrorTypes.INVALID_ARGUMENTS\n    }, context);\n  }\n\n  const filters: string[] = [`a.name == \"${formatName}\"`];\n\n  if(formatEmail) {\n    filters.push(`a.email == \"${formatEmail}\"`);\n  }\n\n  const checkQuery: string = `FOR u IN users\n    FILTER ${filters.join(' || ')}\n    RETURN u`;\n\n  try {\n    const existingApps = await database.query(checkQuery).then((cursor: ArrayCursor) => cursor.all());\n\n    if(existingApps.length) {\n      return logException({\n        action,\n        category: eventCategory,\n        value: ErrorTypes.EXISTING_ITEM,\n        params: {name}\n      }, context);\n    }\n  } catch(error) {\n    return logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR,\n      params: {name}\n    }, error, context);\n  }\n\n  const insert: AppType = {\n    _key: createHash(name, null),\n    active: true,\n    added: Date.now(),\n    email: formatEmail,\n    modified: Date.now(),\n    phone: formatPhone,\n    name: formatName\n  };\n\n  const insertQuery: AqlQuery = aql`INSERT ${insert} IN apps RETURN NEW`;\n\n  return await database.query(insertQuery)\n    .then((cursor: ArrayCursor) => cursor.next() || {})\n    .catch((error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR,\n      params: {name}\n    }, error, context));\n};\n\nexport const updateApp = async (context: ApiContext, app: AppType): Promise<AppType> => {\n  const action: string = 'updateApp';\n  const {database} = context;\n  const {_key, _id, id, appId, ...updated} = app;\n  const appDocId = getDocId('apps', app);\n  const appQuery: AqlQuery = aql`LET a = DOCUMENT(${appDocId})\n    UPDATE a WITH ${updated} IN apps\n    RETURN NEW`;\n\n  return await database.query(appQuery)\n    .then((cursor) => cursor.next())\n    .catch((error) =>\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR,\n        params: {app}\n      }, error, context)\n    );\n};\n\nexport const deleteApp = async (context: ApiContext, app: AppType): Promise<AppType> => {\n  const action: string = 'deleteApp';\n  const {database, session} = context;\n  const isAdmin = isAdminUser(session);\n  const appDocId = getDocId('apps', app);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      params: app,\n      value: ErrorTypes.INVALID_SESSION\n    }, context);\n  }\n\n  const aqlQuery: AqlQuery = aql`FOR a IN apps\n    FILTER a._id == \\\"${appDocId}\\\"\n    LIMIT 1\n    REMOVE a IN apps\n    RETURN OLD`;\n\n  return database.query(aqlQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error) =>\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR,\n        params: app\n      }, error, context));\n};\n\nexport const deactivateApp = (context: ApiContext, app: AppType): Promise<UserType> => {\n  const action: string = 'deactivateApp';\n  const {database, session} = context;\n  const isAdmin = isAdminUser(session);\n  const appDocId = getDocId('apps', app);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: ErrorTypes.INVALID_SESSION\n    }, context);\n  }\n\n  const updated: AppType = {\n    active: false\n  };\n  const aqlQuery: AqlQuery = aql`UPDATE ${appDocId} WITH ${updated} IN apps LIMIT 1 RETURN NEW`;\n\n  return database.query(aqlQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getApp = (context: ApiContext, options?: AppOptions): Promise<AppType> => {\n  const action: string = 'getApp';\n  const {database, fields, session} = context;\n  const {id, key, name} = parseAppOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getAppOptional(fields);\n  const filterBy: string[] = ['a.active == true'];\n  const isAdmin = isAdminUser(session);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: ErrorTypes.INVALID_SESSION\n    }, context);\n  }\n\n  if(id) {\n    filterBy.push(`a._id == \"${parseArangoId(id)}\"`);\n  }\n\n  if(key) {\n    filterBy.push(`a._key == \"apps/${parseId(key)}\"`);\n  }\n\n  if(name) {\n    filterBy.push(`CONTAINS(a.name, \"${parseString(name)}\")`);\n  }\n\n  // Get data from database\n  const aqlQuery: string = `FOR a IN apps\n    FILTER ${filterBy.join(' && ')}\n    ${selectQueries.join('\\n')}\n    RETURN MERGE(a, {${selectObjects.join(', ')}})`;\n\n  return database.query(aqlQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR,\n      params: options\n    }, error, context));\n};\n\nexport const getApps = (context: ApiContext, options?: AppOptions): Promise<AppType[]> => {\n  const action: string = 'getApps';\n  const {database, fields, session} = context;\n  const {limit, name} = parseAppOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getAppOptional(fields);\n  const filterBy: string[] = ['a.active == true'];\n  const isAdmin = isAdminUser(session);\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: ErrorTypes.INVALID_SESSION\n    }, context);\n  }\n\n  if(name) {\n    filterBy.push(`CONTAINS(a.name, \"${parseString(name)}\")`);\n  }\n\n  // Get data from database\n  const aqlQuery: string = `FOR a IN apps\n    FILTER ${filterBy.join(' && ')}\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT a.name\n    RETURN MERGE(a, {${selectObjects.join(', ')}})`;\n\n  return database.query(aqlQuery)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR,\n      params: options\n    }, error, context));\n};\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { ArangoDbLimit, ConnectionType, ConversationOptions, ConversationType, ConversationUsersParams, DirectConversationParams, UpdateConversationUserParams } from '../types';
|
|
2
|
+
import type { ApiContext } from '../types/auth';
|
|
3
|
+
export declare const parseConversationOptions: (options?: ConversationOptions) => {
|
|
4
|
+
limit: ArangoDbLimit;
|
|
5
|
+
};
|
|
6
|
+
export declare const getConversations: (context: ApiContext, userId: string, options?: any) => Promise<ConversationType[]>;
|
|
7
|
+
export declare const getDirectConversation: (context: ApiContext, { fromId, toId, toUser }: DirectConversationParams) => Promise<ConversationType>;
|
|
8
|
+
export declare const addDirectConversation: (context: ApiContext, { fromId, toId, toUser }: DirectConversationParams) => Promise<ConversationType>;
|
|
9
|
+
export declare const getConnectionUsers: (context: ApiContext, { conversationId, includeAll, isDirect }: ConversationUsersParams) => Promise<ConnectionType[]>;
|
|
10
|
+
export declare const getConversationUsers: (context: ApiContext, { conversationId, includeAll, isDirect }: ConversationUsersParams) => Promise<ConversationType[]>;
|
|
11
|
+
export declare const getConversation: (context: ApiContext, conversationId: string) => Promise<ConversationType>;
|
|
12
|
+
export declare const updateConversation: (context: ApiContext, conversation: ConversationType) => Promise<ConversationType>;
|
|
13
|
+
export declare const addUserToConversation: (context: ApiContext, { conversationId, userId }: UpdateConversationUserParams) => Promise<ConversationType>;
|
|
14
|
+
export declare const deleteUserFromConversation: (context: ApiContext, { conversationId, userId }: UpdateConversationUserParams) => Promise<ConversationType>;
|