@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
package/lib/actions/tags.js
CHANGED
|
@@ -29,101 +29,100 @@ var tags_exports = {};
|
|
|
29
29
|
__export(tags_exports, {
|
|
30
30
|
addTag: () => addTag,
|
|
31
31
|
addTagToItem: () => addTagToItem,
|
|
32
|
-
createTag: () => createTag,
|
|
33
|
-
createTagEdge: () => createTagEdge,
|
|
34
32
|
deleteTag: () => deleteTag,
|
|
35
33
|
deleteTagFromItem: () => deleteTagFromItem,
|
|
36
34
|
extractTags: () => extractTags,
|
|
37
35
|
getTag: () => getTag,
|
|
38
36
|
getTags: () => getTags,
|
|
39
37
|
getTagsByItem: () => getTagsByItem,
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
38
|
+
getTagsByName: () => getTagsByName,
|
|
39
|
+
updateTag: () => updateTag,
|
|
40
|
+
updateTagsInItem: () => updateTagsInItem
|
|
43
41
|
});
|
|
44
42
|
module.exports = __toCommonJS(tags_exports);
|
|
45
43
|
var import_utils = require("@nlabs/utils");
|
|
46
44
|
var import_arangojs = require("arangojs");
|
|
47
45
|
var import_words = __toESM(require("lodash/words"));
|
|
48
|
-
var
|
|
46
|
+
var import_tagAdapter = require("../adapters/tagAdapter");
|
|
47
|
+
var import_error = require("../types/error");
|
|
48
|
+
var import_analyticsUtils = require("../utils/analyticsUtils");
|
|
49
|
+
var import_arangodbUtils = require("../utils/arangodbUtils");
|
|
49
50
|
const eventCategory = "tags";
|
|
50
|
-
const getTags = (context, options) => {
|
|
51
|
+
const getTags = (context, options = {}) => {
|
|
51
52
|
const action = "getList";
|
|
52
53
|
const { database } = context;
|
|
53
|
-
const { search = "", from = 0, to = 30 } = options;
|
|
54
|
-
const limit = (0,
|
|
55
|
-
const
|
|
54
|
+
const { search = "", from = 0, to = 30, userId } = options;
|
|
55
|
+
const limit = (0, import_arangodbUtils.getLimit)(from, to);
|
|
56
|
+
const filters = [];
|
|
57
|
+
if (search) {
|
|
58
|
+
filters.push(`LIKE(t.name, "%${search}%")`);
|
|
59
|
+
}
|
|
60
|
+
if (userId) {
|
|
61
|
+
filters.push(`t.userId == "${userId}"`);
|
|
62
|
+
}
|
|
56
63
|
const aqlQry = `FOR t IN tags
|
|
57
|
-
${
|
|
64
|
+
FILTER ${filters.join(" || ")}
|
|
58
65
|
${limit.aql}
|
|
59
66
|
SORT t.name
|
|
60
67
|
RETURN t`;
|
|
61
|
-
return database.query(aqlQry).then((cursor) => cursor.all()).
|
|
68
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
62
69
|
action,
|
|
63
70
|
category: eventCategory,
|
|
64
|
-
|
|
65
|
-
}, error, {})
|
|
71
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
72
|
+
}, error, {}));
|
|
66
73
|
};
|
|
67
|
-
const getTagsByItem = (context,
|
|
68
|
-
const action = "
|
|
69
|
-
const { from = 0, to = 30 } =
|
|
74
|
+
const getTagsByItem = (context, itemDocId, options = {}) => {
|
|
75
|
+
const action = "getTagsByItem";
|
|
76
|
+
const { from = 0, to = 30 } = options;
|
|
70
77
|
const { database } = context;
|
|
71
|
-
const limit = (0,
|
|
72
|
-
const formatItemId = (0, import_utils.parseArangoId)(
|
|
78
|
+
const limit = (0, import_arangodbUtils.getLimit)(from, to);
|
|
79
|
+
const formatItemId = (0, import_utils.parseArangoId)(itemDocId);
|
|
73
80
|
const tagQuery = `FOR t, it IN INBOUND "${formatItemId}" isTagged
|
|
74
81
|
${limit.aql}
|
|
75
82
|
SORT it.added
|
|
76
83
|
RETURN t`;
|
|
77
|
-
return database.query(tagQuery).then((cursor) => cursor.all()
|
|
84
|
+
return database.query(tagQuery).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
78
85
|
action,
|
|
79
86
|
category: eventCategory,
|
|
80
|
-
|
|
81
|
-
}, error, {})
|
|
87
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
88
|
+
}, error, {}));
|
|
82
89
|
};
|
|
83
|
-
const
|
|
84
|
-
const action = "
|
|
85
|
-
const { from = 0, id, to = 30 } = args;
|
|
90
|
+
const getTag = (context, tagId) => {
|
|
91
|
+
const action = "getTag";
|
|
86
92
|
const { database } = context;
|
|
87
|
-
const
|
|
93
|
+
const formatId = (0, import_utils.parseId)(tagId);
|
|
88
94
|
const aqlQry = `FOR t IN tags
|
|
89
|
-
FILTER t.
|
|
90
|
-
|
|
91
|
-
SORT t.added
|
|
95
|
+
FILTER t._key == "${formatId}"
|
|
96
|
+
LIMIT 1
|
|
92
97
|
RETURN t`;
|
|
93
|
-
return database.query(aqlQry).then((cursor) => cursor.
|
|
98
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
94
99
|
action,
|
|
95
100
|
category: eventCategory,
|
|
96
|
-
|
|
97
|
-
}, error, {})
|
|
101
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
102
|
+
}, error, {}));
|
|
98
103
|
};
|
|
99
|
-
const
|
|
100
|
-
const action = "
|
|
104
|
+
const getTagsByName = (context, tagNames) => {
|
|
105
|
+
const action = "getTagsByName";
|
|
101
106
|
const { database } = context;
|
|
102
|
-
const
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
107
|
+
const formatTagNames = tagNames.map((tagName) => (0, import_utils.parseVarChar)(tagName, 32)).filter((tagName) => !!tagName);
|
|
108
|
+
if (!formatTagNames.length) {
|
|
109
|
+
return Promise.resolve([]);
|
|
110
|
+
}
|
|
111
|
+
const aqlQry = import_arangojs.aql`FOR t IN tags
|
|
112
|
+
FILTER POSITION(${JSON.stringify(formatTagNames)}, t.name)
|
|
106
113
|
RETURN t`;
|
|
107
|
-
return database.query(aqlQry).then((cursor) => cursor.
|
|
114
|
+
return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
108
115
|
action,
|
|
109
116
|
category: eventCategory,
|
|
110
|
-
|
|
111
|
-
}, error, {})
|
|
117
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
118
|
+
}, error, {}));
|
|
112
119
|
};
|
|
113
|
-
const addTag = (context,
|
|
120
|
+
const addTag = (context, tag) => {
|
|
114
121
|
const action = "addTag";
|
|
115
|
-
const { database
|
|
116
|
-
const { userAccess } = session;
|
|
117
|
-
if (userAccess < 3) {
|
|
118
|
-
return (0, import_utils2.logException)({
|
|
119
|
-
action,
|
|
120
|
-
category: eventCategory,
|
|
121
|
-
label: "db_error"
|
|
122
|
-
}, session);
|
|
123
|
-
}
|
|
122
|
+
const { database } = context;
|
|
124
123
|
const now = Date.now();
|
|
125
|
-
const { description, name } = tag;
|
|
126
|
-
const formatId = (0, import_utils.createHash)(`tag-${name.
|
|
124
|
+
const { description, name } = (0, import_tagAdapter.parseTag)(tag);
|
|
125
|
+
const formatId = (0, import_utils.createHash)(`tag-${name.toLowerCase()}`, null);
|
|
127
126
|
const insert = {
|
|
128
127
|
_key: formatId,
|
|
129
128
|
added: now,
|
|
@@ -132,205 +131,137 @@ const addTag = (context, { tag }) => {
|
|
|
132
131
|
name: (0, import_utils.parseVarChar)(name, 32)
|
|
133
132
|
};
|
|
134
133
|
const aqlQry = import_arangojs.aql`INSERT ${insert} IN tags RETURN NEW`;
|
|
135
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).
|
|
134
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
136
135
|
action,
|
|
137
136
|
category: eventCategory,
|
|
138
|
-
|
|
139
|
-
}, error, {})
|
|
137
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
138
|
+
}, error, {}));
|
|
140
139
|
};
|
|
141
|
-
const addTagToItem = async (context, {
|
|
140
|
+
const addTagToItem = async (context, { itemDocId, tagBy, tagDocId }) => {
|
|
142
141
|
const action = "addTagToItem";
|
|
143
|
-
const { database } = context;
|
|
142
|
+
const { database, session: { userId: sessionId } } = context;
|
|
144
143
|
const added = Date.now();
|
|
145
|
-
const
|
|
146
|
-
const
|
|
147
|
-
const edgeId = (0, import_utils.createHash)(`isTagged-${
|
|
144
|
+
const formatTagDocId = (0, import_utils.parseArangoId)(tagDocId);
|
|
145
|
+
const formatItemDocId = (0, import_utils.parseArangoId)(itemDocId);
|
|
146
|
+
const edgeId = (0, import_utils.createHash)(`isTagged-${formatTagDocId}-${formatItemDocId}`, null);
|
|
148
147
|
const edgeCollection = database.collection("isTagged");
|
|
149
|
-
const
|
|
150
|
-
|
|
151
|
-
|
|
148
|
+
const type = formatItemDocId.split("/")[0];
|
|
149
|
+
const formatTagBy = (0, import_utils.parseId)(tagBy) || sessionId;
|
|
150
|
+
const edge = { _from: formatTagDocId, _key: edgeId, _to: formatItemDocId, added, tagBy: formatTagBy, type };
|
|
151
|
+
await edgeCollection.save(edge, { overwriteMode: "ignore", returnNew: true, silent: true }).catch((error) => (0, import_analyticsUtils.logError)({
|
|
152
152
|
action,
|
|
153
153
|
category: eventCategory,
|
|
154
|
-
label: "db_error",
|
|
155
154
|
params: {
|
|
156
155
|
edge
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
156
|
+
},
|
|
157
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
158
|
+
}, error, {}));
|
|
159
|
+
const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${formatTagDocId}) RETURN t`;
|
|
160
|
+
return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
161
161
|
action,
|
|
162
162
|
category: eventCategory,
|
|
163
|
-
label: "db_error",
|
|
164
163
|
params: {
|
|
165
164
|
edge
|
|
166
|
-
}
|
|
167
|
-
|
|
165
|
+
},
|
|
166
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
167
|
+
}, error, {}));
|
|
168
168
|
};
|
|
169
|
-
const updateTag = (context,
|
|
170
|
-
const action = "
|
|
171
|
-
const { database, session } = context;
|
|
172
|
-
const { userAccess } = session;
|
|
173
|
-
if (userAccess < 3) {
|
|
174
|
-
return (0, import_utils2.logException)({
|
|
175
|
-
action,
|
|
176
|
-
category: eventCategory,
|
|
177
|
-
label: "db_error"
|
|
178
|
-
}, session);
|
|
179
|
-
}
|
|
169
|
+
const updateTag = (context, tag) => {
|
|
170
|
+
const action = "updateTag";
|
|
171
|
+
const { database, session: { userId: sessionId } } = context;
|
|
180
172
|
const now = Date.now();
|
|
181
|
-
const { description,
|
|
173
|
+
const { description, name, tagId } = (0, import_tagAdapter.parseTag)(tag);
|
|
182
174
|
const formatName = (0, import_utils.parseVarChar)(name, 32);
|
|
183
175
|
const update = {
|
|
184
176
|
description: (0, import_utils.parseVarChar)(description, 64),
|
|
185
177
|
modified: now,
|
|
186
178
|
name: formatName
|
|
187
179
|
};
|
|
188
|
-
const
|
|
189
|
-
const tagId = !formatId ? (0, import_utils.createHash)(`tag-${formatName.toLowerCase()}`, null) : formatId;
|
|
180
|
+
const newTagKey = tagId || (0, import_utils.createHash)(`tag-${formatName.toLowerCase()}`, null);
|
|
190
181
|
const insert = {
|
|
191
182
|
...update,
|
|
192
|
-
|
|
193
|
-
|
|
183
|
+
_id: `tags/${newTagKey}`,
|
|
184
|
+
_key: newTagKey,
|
|
185
|
+
added: now,
|
|
186
|
+
tagBy: sessionId
|
|
194
187
|
};
|
|
195
|
-
const aqlQry = import_arangojs.aql`UPSERT {
|
|
188
|
+
const aqlQry = import_arangojs.aql`UPSERT {name: ${formatName}}
|
|
196
189
|
INSERT ${insert}
|
|
197
190
|
UPDATE ${update}
|
|
198
191
|
IN tags RETURN NEW`;
|
|
199
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).
|
|
192
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
200
193
|
action,
|
|
201
194
|
category: eventCategory,
|
|
202
|
-
|
|
203
|
-
}, error, {})
|
|
195
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
196
|
+
}, error, {}));
|
|
204
197
|
};
|
|
205
|
-
const deleteTag = (context,
|
|
198
|
+
const deleteTag = async (context, tag) => {
|
|
206
199
|
const action = "deleteTag";
|
|
207
|
-
const { database
|
|
208
|
-
const
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
200
|
+
const { database } = context;
|
|
201
|
+
const formatItemId = (0, import_arangodbUtils.getDocId)("tags", tag);
|
|
202
|
+
const tagQuery = `FOR it FROM isTagged
|
|
203
|
+
FILTER it._from == "${formatItemId}" || it._to == "${formatItemId}"
|
|
204
|
+
REMOVE it IN isTagged
|
|
205
|
+
RETURN OLD`;
|
|
206
|
+
await database.query(tagQuery).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
207
|
+
action,
|
|
208
|
+
category: eventCategory,
|
|
209
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
210
|
+
}, error, {}));
|
|
211
|
+
const aqlQry = `LET t = DOCUMENT(${formatItemId})
|
|
219
212
|
REMOVE t IN tags
|
|
220
213
|
RETURN OLD`;
|
|
221
|
-
return database.query(aqlQry).then((cursor) => cursor.next()).
|
|
214
|
+
return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
222
215
|
action,
|
|
223
216
|
category: eventCategory,
|
|
224
|
-
|
|
225
|
-
}, error, {})
|
|
217
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
218
|
+
}, error, {}));
|
|
226
219
|
};
|
|
227
|
-
const deleteTagFromItem = async (context, {
|
|
220
|
+
const deleteTagFromItem = async (context, { tagDocId, edgeDocId }) => {
|
|
228
221
|
const action = "deleteTagFromItem";
|
|
229
222
|
const { database } = context;
|
|
230
|
-
const
|
|
231
|
-
const
|
|
232
|
-
const edgeId = (0, import_utils.createHash)(`isTagged-${formatTagId}-${formatItemId}`, null);
|
|
223
|
+
const formatTagDocId = (0, import_utils.parseArangoId)(tagDocId);
|
|
224
|
+
const formatEdgeDocId = (0, import_utils.parseArangoId)(edgeDocId);
|
|
233
225
|
const edgeCollection = database.collection("isTagged");
|
|
234
|
-
const edge = {
|
|
235
|
-
await edgeCollection.remove(edge, { silent: true }).catch((error) => (0,
|
|
226
|
+
const edge = { _id: formatEdgeDocId };
|
|
227
|
+
await edgeCollection.remove(edge, { silent: true }).catch((error) => (0, import_analyticsUtils.logError)({
|
|
236
228
|
action,
|
|
237
229
|
category: eventCategory,
|
|
238
|
-
|
|
239
|
-
}, error, {})
|
|
240
|
-
const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${
|
|
241
|
-
return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0,
|
|
230
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
231
|
+
}, error, {}));
|
|
232
|
+
const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${formatTagDocId}) RETURN t`;
|
|
233
|
+
return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
|
|
242
234
|
action,
|
|
243
235
|
category: eventCategory,
|
|
244
|
-
|
|
245
|
-
}, error, {})
|
|
246
|
-
};
|
|
247
|
-
const createTag = (db, tagName) => {
|
|
248
|
-
const tagId = (0, import_utils.createHash)(`tag-${tagName.toLowerCase()}`, null);
|
|
249
|
-
const insert = {
|
|
250
|
-
_key: tagId,
|
|
251
|
-
added: Date.now(),
|
|
252
|
-
name: tagName
|
|
253
|
-
};
|
|
254
|
-
const aqlQry = import_arangojs.aql`UPSERT {_key: ${tagId}}
|
|
255
|
-
INSERT ${insert}
|
|
256
|
-
UPDATE {}
|
|
257
|
-
IN tags RETURN NEW`;
|
|
258
|
-
return db.query(aqlQry).then((cursor) => cursor.next()).then((tag = {}) => tag).catch((error) => {
|
|
259
|
-
throw error;
|
|
260
|
-
});
|
|
261
|
-
};
|
|
262
|
-
const createTagEdge = (db, tag, itemId) => {
|
|
263
|
-
const edgeCollection = db.collection("isTagged");
|
|
264
|
-
const { _id: tagId } = tag;
|
|
265
|
-
const edgeId = (0, import_utils.createHash)(`isTagged-${tagId}-${itemId}`);
|
|
266
|
-
const type = itemId.split("/")[0];
|
|
267
|
-
const edge = {
|
|
268
|
-
_from: tagId,
|
|
269
|
-
_key: edgeId,
|
|
270
|
-
_to: itemId,
|
|
271
|
-
added: Date.now(),
|
|
272
|
-
type
|
|
273
|
-
};
|
|
274
|
-
return edgeCollection.save(edge, { returnNew: true }).then(() => tag);
|
|
275
|
-
};
|
|
276
|
-
const linkTags = async (db, tagNames, itemId) => {
|
|
277
|
-
const edgeCollection = db.collection("isTagged");
|
|
278
|
-
const edges = await edgeCollection.inEdges(itemId, {});
|
|
279
|
-
console.log({ edges });
|
|
280
|
-
if (edges.length) {
|
|
281
|
-
await Promise.all(
|
|
282
|
-
edges.map((edge) => {
|
|
283
|
-
const { _key: edgeKey } = edge;
|
|
284
|
-
const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isTagged`;
|
|
285
|
-
return db.query(aqlQry);
|
|
286
|
-
})
|
|
287
|
-
);
|
|
288
|
-
}
|
|
289
|
-
return Promise.all(
|
|
290
|
-
tagNames.map((tagName) => createTag(db, tagName).then((tag) => createTagEdge(db, tag, itemId)))
|
|
291
|
-
);
|
|
236
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
237
|
+
}, error, {}));
|
|
292
238
|
};
|
|
293
|
-
const extractTags = (
|
|
294
|
-
|
|
295
|
-
const
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
).then(() => {
|
|
307
|
-
if (tags.length) {
|
|
308
|
-
return linkTags(db, tags, itemId);
|
|
309
|
-
}
|
|
310
|
-
return [];
|
|
311
|
-
});
|
|
312
|
-
} else if (tags.length) {
|
|
313
|
-
return linkTags(db, tags, itemId);
|
|
314
|
-
}
|
|
315
|
-
return [];
|
|
316
|
-
}).catch((error) => {
|
|
317
|
-
throw error;
|
|
318
|
-
});
|
|
239
|
+
const extractTags = (content) => (0, import_words.default)(content, /#[a-zA-Z\d-]+/g).map((tag) => (0, import_utils.parseId)(tag));
|
|
240
|
+
const updateTagsInItem = (context, { itemDocId, tags }) => {
|
|
241
|
+
const action = "updateTagsInItem";
|
|
242
|
+
const { database } = context;
|
|
243
|
+
const edgeCollection = database.collection("isTagged");
|
|
244
|
+
return edgeCollection.inEdges(itemDocId, {}).then((edges) => Promise.all([
|
|
245
|
+
...edges.filter(({ name: existingTagName }) => !tags.find(({ name: tagName }) => existingTagName === tagName)).map(({ _id: edgeDocId, _from: tagDocId }) => deleteTagFromItem(context, { tagDocId, edgeDocId })),
|
|
246
|
+
...tags.filter(({ name: tagName }) => !edges.find(({ name: existingTagName }) => existingTagName === tagName)).map(({ _id: tagDocId, tagBy }) => addTagToItem(context, { itemDocId, tagBy, tagDocId }))
|
|
247
|
+
]).then(() => tags)).catch((error) => (0, import_analyticsUtils.logError)({
|
|
248
|
+
action,
|
|
249
|
+
category: eventCategory,
|
|
250
|
+
value: import_error.ErrorTypes.DATABASE_ERROR
|
|
251
|
+
}, error, {}));
|
|
319
252
|
};
|
|
320
253
|
// Annotate the CommonJS export names for ESM import in node:
|
|
321
254
|
0 && (module.exports = {
|
|
322
255
|
addTag,
|
|
323
256
|
addTagToItem,
|
|
324
|
-
createTag,
|
|
325
|
-
createTagEdge,
|
|
326
257
|
deleteTag,
|
|
327
258
|
deleteTagFromItem,
|
|
328
259
|
extractTags,
|
|
329
260
|
getTag,
|
|
330
261
|
getTags,
|
|
331
262
|
getTagsByItem,
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
263
|
+
getTagsByName,
|
|
264
|
+
updateTag,
|
|
265
|
+
updateTagsInItem
|
|
335
266
|
});
|
|
336
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/tags.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 {createHash, parseArangoId, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport words from 'lodash/words';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {TagType} from '../types/tags';\nimport {getLimit, logError, logException} from '../utils';\n\nconst eventCategory: string = 'tags';\nexport interface TagOptions {\n  readonly search?: string;\n  readonly from?: number;\n  readonly to?: number;\n}\n\nexport const getTags = (\n  context: ApiContext,\n  options?: TagOptions\n): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const {search = '', from = 0, to = 30} = options;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const filter: string = search.length ? `FILTER LIKE(t.name, \"%${search}%\")` : '';\n  const aqlQry: string = `FOR t IN tags\n    ${filter}\n    ${limit.aql}\n    SORT t.name\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTagsByItem = (context: ApiContext, itemId: string,  args): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {from = 0, to = 30} = args;\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const formatItemId: string = parseArangoId(itemId);\n\n  const tagQuery: string = `FOR t, it IN INBOUND \"${formatItemId}\" isTagged\n    ${limit.aql}\n    SORT it.added\n    RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.all() || [])\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTagsByOwner = (context: ApiContext, args): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {from = 0, id, to = 30} = args;\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR t IN tags\n    FILTER t.userId == \"${id}\"\n    ${limit.aql}\n    SORT t.added\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const formatId: string = JSON.stringify(parseId(tagId));\n  const aqlQry: string = `FOR t IN tags\n    FILTER t._key == ${formatId}\n    LIMIT 1\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addTag = (context: ApiContext, {tag}): Promise<TagType> => {\n  const action: string = 'addTag';\n  const {database, session} = context;\n  const {userAccess} = session;\n\n  if(userAccess < 3) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, session);\n  }\n\n  const now: number = Date.now();\n  const {description, name} = tag;\n  const formatId: string = createHash(`tag-${name.toLowercase()}`, null);\n\n  const insert: any = {\n    _key: formatId,\n    added: now,\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: parseVarChar(name, 32)\n  };\n\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN tags RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addTagToItem = async (context: ApiContext, {itemId, tagId}): Promise<TagType> => {\n  const action: string = 'addTagToItem';\n  const {database} = context;\n  const added: number = Date.now();\n  const formatTagId: string = parseArangoId(tagId);\n  const formatItemId: string = parseArangoId(itemId);\n  const edgeId: string = createHash(`isTagged-${formatTagId}-${formatItemId}`, null);\n  const edgeCollection: EdgeCollection = database.collection('isTagged');\n  const edge: any = {_from: formatTagId, _key: edgeId, _to: formatItemId, added};\n  console.log({edge});\n  await edgeCollection.save(edge, {overwriteMode: 'ignore', silent: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error',\n      params: {\n        edge\n      }\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n\n\n  const tagQuery: AqlQuery = aql`LET t = DOCUMENT(${formatTagId}) RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error',\n      params: {\n        edge\n      }\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const updateTag = (context: ApiContext, item: TagType = {}): Promise<TagType> => {\n  const action: string = 'update';\n  const {database, session} = context;\n  const {userAccess} = session;\n\n  if(userAccess < 3) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, session);\n  }\n\n  const now: number = Date.now();\n  const {description, id, name} = item;\n  const formatName: string = parseVarChar(name, 32);\n\n  const update: TagType = {\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: formatName\n  };\n\n  const formatId: string = parseId(id);\n  const tagId: string = !formatId ? createHash(`tag-${formatName.toLowerCase()}`, null) : formatId;\n\n  const insert: TagType = {\n    ...update,\n    _key: tagId,\n    added: now\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${tagId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN tags RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const deleteTag = (context: ApiContext, {tagId}): Promise<TagType> => {\n  const action: string = 'deleteTag';\n  const {database, session} = context;\n  const {userAccess} = session;\n\n  if(userAccess < 3) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, session);\n  }\n\n  const formatTagId: string = parseId(tagId);\n  const aqlQry: AqlQuery = aql`FOR t IN tags\n    FILTER t._key == ${formatTagId}\n    REMOVE t IN tags\n    RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const deleteTagFromItem = async (context: ApiContext, {itemId, tagId}): Promise<TagType> => {\n  const action: string = 'deleteTagFromItem';\n  const {database} = context;\n  const formatTagId: string = parseArangoId(tagId);\n  const formatItemId: string = parseArangoId(itemId);\n  const edgeId: string = createHash(`isTagged-${formatTagId}-${formatItemId}`, null);\n  const edgeCollection: EdgeCollection = database.collection('isTagged');\n  const edge: any = {_key: edgeId};\n\n  await edgeCollection.remove(edge, {silent: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n\n  const tagQuery: AqlQuery = aql`LET t = DOCUMENT(${tagId}) RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const createTag = (db: Database, tagName: string): Promise<TagType> => {\n  const tagId: string = createHash(`tag-${tagName.toLowerCase()}`, null);\n  const insert: TagType = {\n    _key: tagId,\n    added: Date.now(),\n    name: tagName\n  };\n\n  const aqlQry = aql`UPSERT {_key: ${tagId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN tags RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createTagEdge = (db: Database, tag: TagType, itemId: string): Promise<TagType> => {\n  const edgeCollection = db.collection('isTagged');\n  const {_id: tagId} = tag;\n  const edgeId = createHash(`isTagged-${tagId}-${itemId}`);\n  const type: string = itemId.split('/')[0];\n  const edge: any = {\n    _from: tagId,\n    _key: edgeId,\n    _to: itemId,\n    added: Date.now(),\n    type\n  };\n\n  return edgeCollection.save(edge, {returnNew: true}).then(() => tag);\n};\n\nexport const linkTags = async (db: Database, tagNames: string[], itemId: string): Promise<TagType[]> => {\n  const edgeCollection = db.collection('isTagged');\n  const edges: any = await edgeCollection.inEdges(itemId, {});\n\n  console.log({edges});\n  if(edges.length) {\n    await Promise.all(\n      edges.map((edge) => {\n        const {_key: edgeKey} = edge;\n        const aqlQry = aql`REMOVE {_key:${edgeKey}} IN isTagged`;\n        return db.query(aqlQry);\n      })\n    );\n  }\n\n  return Promise.all(tagNames.map((tagName: string) => createTag(db, tagName)\n    .then((tag: TagType) => createTagEdge(db, tag, itemId)))\n  );\n};\n\nexport const extractTags = (db: Database, itemId, content): Promise<TagType[]> => {\n  const tags: string[] = words(content, /#[a-zA-Z\\d-]+/g).map((tag: string) => parseId(tag));\n  const edgeCollection = db.collection('isTagged');\n\n  return edgeCollection.inEdges(itemId, {})\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 = aql`REMOVE {_key:${edgeKey}} IN isTagged`;\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(tags.length) {\n              // Create tags\n              return linkTags(db, tags, itemId);\n            }\n            return [];\n          });\n      } else if(tags.length) {\n        // Create tags\n        return linkTags(db, tags, itemId);\n      }\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"],
  "mappings": "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",
  "names": ["import_utils", "error", "tag", "words"]
}

|
|
267
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/actions/tags.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 {createHash, parseArangoId, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport {Edge} from 'arangojs/documents';\nimport words from 'lodash/words';\n\nimport {parseTag} from '../adapters/tagAdapter';\nimport type {ArangoDbLimit} from '../types/arangodb';\nimport type {ApiContext} from '../types/auth';\nimport {ErrorTypes} from '../types/error';\nimport type {TagType} from '../types/tags';\nimport {logError} from '../utils/analyticsUtils';\nimport {getDocId, getLimit} from '../utils/arangodbUtils';\n\nconst eventCategory: string = 'tags';\nexport interface TagOptions {\n  readonly from?: number;\n  readonly search?: string;\n  readonly to?: number;\n  readonly userId?: string;\n}\n\nexport const getTags = (\n  context: ApiContext,\n  options: TagOptions = {}\n): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const {search = '', from = 0, to = 30, userId} = options;\n  const limit: ArangoDbLimit = getLimit(from, to);\n\n  const filters: string[] = [];\n\n  if(search) {\n    filters.push(`LIKE(t.name, \"%${search}%\")`);\n  }\n\n  if(userId) {\n    filters.push(`t.userId == \"${userId}\"`);\n  }\n\n  const aqlQry: string = `FOR t IN tags\n    FILTER ${filters.join(' || ')}\n    ${limit.aql}\n    SORT t.name\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const getTagsByItem = (\n  context: ApiContext,\n  itemDocId: string,\n  options: TagOptions = {}\n): Promise<TagType[]> => {\n  const action: string = 'getTagsByItem';\n  const {from = 0, to = 30} = options;\n  const {database} = context;\n  const limit: ArangoDbLimit = getLimit(from, to);\n  const formatItemId: string = parseArangoId(itemDocId);\n  const tagQuery: string = `FOR t, it IN INBOUND \"${formatItemId}\" isTagged\n    ${limit.aql}\n    SORT it.added\n    RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const getTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'getTag';\n  const {database} = context;\n  const formatId: string = parseId(tagId);\n  const aqlQry: string = `FOR t IN tags\n    FILTER t._key == \"${formatId}\"\n    LIMIT 1\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const getTagsByName = (context: ApiContext, tagNames: string[]): Promise<TagType[]> => {\n  const action: string = 'getTagsByName';\n  const {database} = context;\n  const formatTagNames = tagNames\n    .map((tagName) => parseVarChar(tagName, 32))\n    .filter((tagName) => !!tagName);\n\n  if(!formatTagNames.length) {\n    return Promise.resolve([]);\n  }\n\n  const aqlQry: AqlQuery = aql`FOR t IN tags\n    FILTER POSITION(${JSON.stringify(formatTagNames)}, t.name)\n    RETURN t`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const addTag = (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'addTag';\n  const {database} = context;\n  const now: number = Date.now();\n  const {description, name} = parseTag(tag);\n  const formatId: string = createHash(`tag-${name.toLowerCase()}`, null);\n  const insert: any = {\n    _key: formatId,\n    added: now,\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: parseVarChar(name, 32)\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN tags RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const addTagToItem = async (\n  context: ApiContext,\n  {itemDocId, tagBy, tagDocId}: {itemDocId: string, tagBy?: string, tagDocId: string}\n): Promise<TagType> => {\n  const action: string = 'addTagToItem';\n  const {database, session: {userId: sessionId}} = context;\n  const added: number = Date.now();\n  const formatTagDocId: string = parseArangoId(tagDocId);\n  const formatItemDocId: string = parseArangoId(itemDocId);\n  const edgeId: string = createHash(`isTagged-${formatTagDocId}-${formatItemDocId}`, null);\n  const edgeCollection: EdgeCollection = database.collection('isTagged');\n  const type: string = formatItemDocId.split('/')[0];\n  const formatTagBy: string = parseId(tagBy) || sessionId;\n  const edge: Edge = {_from: formatTagDocId, _key: edgeId, _to: formatItemDocId, added, tagBy: formatTagBy, type};\n\n  await edgeCollection.save(edge, {overwriteMode: 'ignore', returnNew: true, silent: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      params: {\n        edge\n      },\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n\n  const tagQuery: AqlQuery = aql`LET t = DOCUMENT(${formatTagDocId}) RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      params: {\n        edge\n      },\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const updateTag = (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'updateTag';\n  const {database, session: {userId: sessionId}} = context;\n  const now: number = Date.now();\n  const {description, name, tagId} = parseTag(tag);\n  const formatName: string = parseVarChar(name, 32);\n  const update: TagType = {\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: formatName\n  };\n  const newTagKey: string = tagId || createHash(`tag-${formatName.toLowerCase()}`, null);\n  const insert: TagType = {\n    ...update,\n    _id: `tags/${newTagKey}`,\n    _key: newTagKey,\n    added: now,\n    tagBy: sessionId\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {name: ${formatName}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN tags RETURN NEW`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const deleteTag = async (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'deleteTag';\n  const {database} = context;\n  const formatItemId = getDocId('tags', tag);\n  const tagQuery: string = `FOR it FROM isTagged\n    FILTER it._from == \"${formatItemId}\" || it._to == \"${formatItemId}\"\n    REMOVE it IN isTagged\n    RETURN OLD`;\n\n  await database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n\n  const aqlQry = `LET t = DOCUMENT(${formatItemId})\n    REMOVE t IN tags\n    RETURN OLD`;\n\n  return database.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const deleteTagFromItem = async (context: ApiContext, {tagDocId, edgeDocId}): Promise<TagType> => {\n  const action = 'deleteTagFromItem';\n  const {database} = context;\n  const formatTagDocId = parseArangoId(tagDocId);\n  const formatEdgeDocId = parseArangoId(edgeDocId);\n  const edgeCollection: EdgeCollection = database.collection('isTagged');\n  const edge = {_id: formatEdgeDocId};\n\n  await edgeCollection.remove(edge, {silent: true})\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n\n  const tagQuery: AqlQuery = aql`LET t = DOCUMENT(${formatTagDocId}) RETURN t`;\n\n  return database.query(tagQuery)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n\nexport const extractTags = (content: string): string[] =>\n  words(content, /#[a-zA-Z\\d-]+/g).map((tag: string) => parseId(tag));\n\nexport const updateTagsInItem = (context: ApiContext, {itemDocId, tags}): Promise<TagType[]> => {\n  const action = 'updateTagsInItem';\n  const {database} = context;\n  const edgeCollection = database.collection('isTagged');\n\n  return edgeCollection.inEdges(itemDocId, {})\n    .then((edges: any) => Promise.all([\n      ...edges\n        .filter(({name: existingTagName}) => !tags.find(({name: tagName}) => existingTagName === tagName))\n        .map(({_id: edgeDocId, _from: tagDocId}) =>\n          deleteTagFromItem(context, {tagDocId, edgeDocId})),\n      ...tags\n        .filter(({name: tagName}) => !edges.find(({name: existingTagName}) => existingTagName === tagName))\n        .map(({_id: tagDocId, tagBy}) =>\n          addTagToItem(context, {itemDocId, tagBy, tagDocId}))\n    ]).then(() => tags))\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.DATABASE_ERROR\n    }, error, {}));\n};\n"],
  "mappings": "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",
  "names": ["words"]
}

|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { ApiContext } from '../types/auth';
|
|
2
|
+
import type { UserType } from '../types/users';
|
|
3
|
+
import { SessionToken } from '../utils/session';
|
|
4
|
+
import { SessionError } from '../types/error';
|
|
5
|
+
export interface UserOptions {
|
|
6
|
+
readonly from?: number;
|
|
7
|
+
readonly to?: number;
|
|
8
|
+
readonly username?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare enum UserAccess {
|
|
11
|
+
DEACTIVATED = 0,
|
|
12
|
+
ACTIVE = 1,
|
|
13
|
+
PREMIUM = 2,
|
|
14
|
+
CONTENT_ADMIN = 3,
|
|
15
|
+
ADMIN = 4
|
|
16
|
+
}
|
|
17
|
+
export declare const createToken: (userId: string, username: string, userAccess: number, expiresInMinutes?: number) => SessionToken;
|
|
18
|
+
export declare const getUserOptional: (fields?: string[]) => any;
|
|
19
|
+
export declare const parseUserOptions: (options?: UserOptions) => {
|
|
20
|
+
limit: import("..").ArangoDbLimit;
|
|
21
|
+
from?: number;
|
|
22
|
+
to?: number;
|
|
23
|
+
username?: string;
|
|
24
|
+
};
|
|
25
|
+
export declare const addUser: (context: ApiContext, user: UserType) => Promise<UserType>;
|
|
26
|
+
export declare const updateUser: (context: ApiContext, user: UserType) => Promise<UserType>;
|
|
27
|
+
export declare const confirmCode: (context: ApiContext, { code, type }: {
|
|
28
|
+
code: any;
|
|
29
|
+
type: any;
|
|
30
|
+
}) => Promise<boolean>;
|
|
31
|
+
export declare const deleteUser: (context: ApiContext, user: UserType) => Promise<any>;
|
|
32
|
+
export declare const deactivateUser: (context: ApiContext, user: UserType) => Promise<UserType>;
|
|
33
|
+
export declare const getDisplayName: (user: UserType) => string;
|
|
34
|
+
export declare const getSessionUser: (context: ApiContext) => Promise<UserType>;
|
|
35
|
+
export declare const getUser: (context: ApiContext, user: UserType) => Promise<UserType>;
|
|
36
|
+
export declare const getUsers: (context: ApiContext, options?: UserOptions) => Promise<UserType[]>;
|
|
37
|
+
export declare const getUsersByReactions: (context: ApiContext, { reactions, username }: any, options?: UserOptions) => Promise<UserType[]>;
|
|
38
|
+
export declare const getUsersByTags: (context: ApiContext, { tags, username }: any, options?: UserOptions) => Promise<UserType[]>;
|
|
39
|
+
export declare const getUsersByLatest: (context: ApiContext, { username }: any, options?: UserOptions) => Promise<UserType[]>;
|
|
40
|
+
export declare const refreshSession: (context: ApiContext, { expires, token }: {
|
|
41
|
+
expires: any;
|
|
42
|
+
token: any;
|
|
43
|
+
}) => Promise<SessionToken | SessionError>;
|
|
44
|
+
export declare const signIn: (context: ApiContext, args: any) => Promise<SessionToken>;
|
|
45
|
+
export declare const signOut: (context: ApiContext) => Promise<boolean>;
|
|
46
|
+
export declare const getActiveUserCount: (context: ApiContext) => Promise<any>;
|
|
47
|
+
export declare const getUserByToken: (context: ApiContext, token: string) => Promise<UserType>;
|