@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.
Files changed (198) hide show
  1. package/.eslintrc +10 -0
  2. package/.prettierrc.js +4 -0
  3. package/README.md +1 -1
  4. package/coverage/actions/groups.ts.html +1039 -0
  5. package/coverage/actions/images.ts.html +2500 -0
  6. package/coverage/actions/index.html +131 -0
  7. package/coverage/actions/tags.ts.html +1000 -0
  8. package/coverage/adapters/arangoAdapter.ts.html +151 -0
  9. package/coverage/adapters/index.html +146 -0
  10. package/coverage/adapters/reaktorAdapter.ts.html +127 -0
  11. package/coverage/adapters/tagAdapter.ts.html +160 -0
  12. package/coverage/base.css +224 -0
  13. package/coverage/block-navigation.js +87 -0
  14. package/coverage/clover.xml +6 -0
  15. package/coverage/coverage-final.json +1 -0
  16. package/coverage/favicon.png +0 -0
  17. package/coverage/index.html +176 -0
  18. package/coverage/lcov-report/base.css +224 -0
  19. package/coverage/lcov-report/block-navigation.js +87 -0
  20. package/coverage/lcov-report/favicon.png +0 -0
  21. package/coverage/lcov-report/index.html +101 -0
  22. package/coverage/lcov-report/prettify.css +1 -0
  23. package/coverage/lcov-report/prettify.js +2 -0
  24. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  25. package/coverage/lcov-report/sorter.js +196 -0
  26. package/coverage/lcov.info +0 -0
  27. package/coverage/mocks/file.ts.html +118 -0
  28. package/coverage/mocks/group.ts.html +145 -0
  29. package/coverage/mocks/image.ts.html +136 -0
  30. package/coverage/mocks/index.html +146 -0
  31. package/coverage/mocks/post.ts.html +169 -0
  32. package/coverage/mocks/tag.ts.html +121 -0
  33. package/coverage/mocks/user.ts.html +268 -0
  34. package/coverage/prettify.css +1 -0
  35. package/coverage/prettify.js +2 -0
  36. package/coverage/sort-arrow-sprite.png +0 -0
  37. package/coverage/sorter.js +196 -0
  38. package/coverage/types/error.ts.html +145 -0
  39. package/coverage/types/index.html +116 -0
  40. package/coverage/utils/adapterUtils.ts.html +151 -0
  41. package/coverage/utils/analyticsUtils.ts.html +292 -0
  42. package/coverage/utils/arangodbUtils.ts.html +463 -0
  43. package/coverage/utils/index.html +146 -0
  44. package/jest.setup.js +0 -0
  45. package/jpg:- +0 -0
  46. package/lib/actions/apps.d.ts +25 -0
  47. package/lib/actions/apps.js +252 -0
  48. package/lib/actions/conversations.d.ts +14 -0
  49. package/lib/actions/conversations.js +131 -126
  50. package/lib/actions/dynamodb.d.ts +8 -0
  51. package/lib/actions/dynamodb.js +35 -32
  52. package/lib/actions/email.d.ts +5 -0
  53. package/lib/actions/email.js +23 -53
  54. package/lib/actions/files.d.ts +19 -0
  55. package/lib/actions/files.js +188 -202
  56. package/lib/actions/groups.d.ts +14 -0
  57. package/lib/actions/groups.js +38 -36
  58. package/lib/actions/images.d.ts +26 -0
  59. package/lib/actions/images.js +236 -229
  60. package/lib/actions/index.d.ts +21 -0
  61. package/lib/actions/index.js +3 -1
  62. package/lib/actions/ios.d.ts +7 -0
  63. package/lib/actions/ios.js +11 -10
  64. package/lib/actions/locations.d.ts +5 -0
  65. package/lib/actions/locations.js +29 -37
  66. package/lib/actions/messages.d.ts +13 -0
  67. package/lib/actions/messages.js +10 -10
  68. package/lib/actions/notifications.d.ts +5 -0
  69. package/lib/actions/notifications.js +1 -1
  70. package/lib/actions/payments.d.ts +10 -0
  71. package/lib/actions/payments.js +27 -26
  72. package/lib/actions/posts.d.ts +19 -0
  73. package/lib/actions/posts.js +176 -156
  74. package/lib/actions/reactions.d.ts +30 -0
  75. package/lib/actions/reactions.js +30 -28
  76. package/lib/actions/s3.d.ts +7 -0
  77. package/lib/actions/s3.js +37 -32
  78. package/lib/actions/search.d.ts +3 -0
  79. package/lib/actions/search.js +11 -9
  80. package/lib/actions/sms.d.ts +3 -0
  81. package/lib/actions/sms.js +58 -34
  82. package/lib/actions/statistics.d.ts +3 -0
  83. package/lib/actions/statistics.js +21 -18
  84. package/lib/actions/subscription.d.ts +7 -0
  85. package/lib/actions/subscription.js +24 -21
  86. package/lib/actions/tags.d.ts +29 -0
  87. package/lib/actions/tags.js +129 -198
  88. package/lib/actions/users.d.ts +47 -0
  89. package/lib/actions/users.js +188 -194
  90. package/lib/actions/websockets.d.ts +19 -0
  91. package/lib/actions/websockets.js +60 -34
  92. package/lib/adapters/arangoAdapter.d.ts +2 -0
  93. package/lib/adapters/arangoAdapter.js +46 -0
  94. package/lib/adapters/fileAdapter.d.ts +3 -0
  95. package/lib/adapters/fileAdapter.js +76 -0
  96. package/lib/adapters/postAdapter.d.ts +2 -0
  97. package/lib/adapters/postAdapter.js +70 -0
  98. package/lib/adapters/reaktorAdapter.d.ts +6 -0
  99. package/lib/adapters/reaktorAdapter.js +44 -0
  100. package/lib/adapters/tagAdapter.d.ts +2 -0
  101. package/lib/adapters/tagAdapter.js +50 -0
  102. package/lib/adapters/userAdapter.d.ts +2 -0
  103. package/lib/adapters/userAdapter.js +110 -0
  104. package/lib/config.d.ts +20 -0
  105. package/lib/config.js +14 -15
  106. package/lib/index.d.ts +5 -0
  107. package/lib/lambdas/actions/websockets.d.ts +6 -0
  108. package/lib/lambdas/actions/websockets.js +7 -7
  109. package/lib/lambdas/authorizer.d.ts +20 -0
  110. package/lib/lambdas/authorizer.js +1 -1
  111. package/lib/lambdas/connection.d.ts +12 -0
  112. package/lib/lambdas/connection.js +5 -4
  113. package/lib/lambdas/utils/message.d.ts +1 -0
  114. package/lib/lambdas/utils/websocket.d.ts +7 -0
  115. package/lib/lambdas/utils/websocket.js +8 -6
  116. package/lib/mocks/conversation.d.ts +8 -0
  117. package/lib/mocks/conversation.js +35 -0
  118. package/lib/mocks/file.d.ts +11 -0
  119. package/lib/mocks/file.js +38 -0
  120. package/lib/mocks/group.d.ts +17 -0
  121. package/lib/mocks/group.js +47 -0
  122. package/lib/mocks/image.d.ts +3 -0
  123. package/lib/mocks/image.js +43 -0
  124. package/lib/mocks/nlabs.png +0 -0
  125. package/lib/mocks/post.d.ts +38 -0
  126. package/lib/mocks/post.js +55 -0
  127. package/lib/mocks/tag.d.ts +2 -0
  128. package/lib/mocks/tag.js +37 -0
  129. package/lib/mocks/user.d.ts +4 -0
  130. package/lib/mocks/user.js +88 -0
  131. package/lib/templates/email/layout.d.ts +2 -0
  132. package/lib/templates/email/passwordForgot.d.ts +2 -0
  133. package/lib/templates/email/passwordRecovery.d.ts +2 -0
  134. package/lib/templates/email/verifyEmail.d.ts +2 -0
  135. package/lib/templates/email/welcome.d.ts +2 -0
  136. package/lib/templates/sms/passwordForgot.d.ts +2 -0
  137. package/lib/templates/sms/passwordRecovery.d.ts +2 -0
  138. package/lib/templates/sms/verifyEmail.d.ts +2 -0
  139. package/lib/templates/sms/verifyPhone.d.ts +2 -0
  140. package/lib/templates/sms/welcome.d.ts +2 -0
  141. package/lib/types/apps.d.ts +46 -0
  142. package/lib/types/apps.js +17 -1
  143. package/lib/types/arangodb.d.ts +30 -0
  144. package/lib/types/arangodb.js +1 -1
  145. package/lib/types/auth.d.ts +7 -0
  146. package/lib/types/auth.js +1 -1
  147. package/lib/types/connections.d.ts +7 -0
  148. package/lib/types/connections.js +1 -1
  149. package/lib/types/conversations.d.ts +29 -0
  150. package/lib/types/conversations.js +1 -1
  151. package/lib/types/email.d.ts +13 -0
  152. package/lib/types/email.js +1 -1
  153. package/lib/types/error.d.ts +20 -0
  154. package/lib/types/error.js +44 -0
  155. package/lib/types/files.d.ts +26 -0
  156. package/lib/types/files.js +1 -1
  157. package/lib/types/google.d.ts +29 -0
  158. package/lib/types/google.js +1 -1
  159. package/lib/types/groups.d.ts +21 -0
  160. package/lib/types/groups.js +1 -1
  161. package/lib/types/images.d.ts +51 -0
  162. package/lib/types/images.js +1 -1
  163. package/lib/types/index.d.ts +18 -0
  164. package/lib/types/locations.d.ts +20 -0
  165. package/lib/types/locations.js +1 -1
  166. package/lib/types/messages.d.ts +16 -0
  167. package/lib/types/messages.js +1 -1
  168. package/lib/types/notifications.d.ts +17 -0
  169. package/lib/types/notifications.js +1 -1
  170. package/lib/types/payments.d.ts +112 -0
  171. package/lib/types/payments.js +1 -1
  172. package/lib/types/posts.d.ts +31 -0
  173. package/lib/types/posts.js +1 -1
  174. package/lib/types/statistics.d.ts +3 -0
  175. package/lib/types/statistics.js +1 -1
  176. package/lib/types/tags.d.ts +10 -0
  177. package/lib/types/tags.js +1 -1
  178. package/lib/types/users.d.ts +76 -0
  179. package/lib/types/users.js +1 -1
  180. package/lib/types/websocket.d.ts +13 -0
  181. package/lib/types/websocket.js +1 -1
  182. package/lib/utils/adapterUtils.d.ts +1 -0
  183. package/lib/utils/adapterUtils.js +45 -0
  184. package/lib/utils/analyticsUtils.d.ts +21 -0
  185. package/lib/utils/analyticsUtils.js +72 -0
  186. package/lib/utils/arangodbUtils.d.ts +65 -0
  187. package/lib/utils/arangodbUtils.js +144 -0
  188. package/lib/utils/auth.d.ts +20 -0
  189. package/lib/utils/auth.js +13 -30
  190. package/lib/utils/index.d.ts +5 -0
  191. package/lib/utils/index.js +7 -9
  192. package/lib/utils/session.d.ts +16 -0
  193. package/lib/utils/session.js +11 -2
  194. package/package.json +12 -5
  195. package/lib/utils/analytics.js +0 -88
  196. package/lib/utils/arangodb.js +0 -118
  197. package/lib/utils/graphql.js +0 -46
  198. package/lib/utils/objects.js +0 -59
@@ -17,18 +17,22 @@ var __copyProps = (to, from, except, desc) => {
17
17
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
18
  var files_exports = {};
19
19
  __export(files_exports, {
20
+ GIPHY_URL: () => GIPHY_URL,
20
21
  addFile: () => addFile,
21
- createFile: () => createFile,
22
22
  decodeBase64: () => decodeBase64,
23
23
  encodeBase64: () => encodeBase64,
24
24
  getGiphySearch: () => getGiphySearch,
25
25
  getGiphyTrends: () => getGiphyTrends,
26
26
  getPathUserFiles: () => getPathUserFiles,
27
- getUrlUserFiles: () => getUrlUserFiles,
27
+ getYouTube: () => getYouTube,
28
28
  getYouTubeSearch: () => getYouTubeSearch,
29
29
  getYouTubeTrends: () => getYouTubeTrends,
30
+ insertFile: () => insertFile,
30
31
  linkFiles: () => linkFiles,
31
- updateFiles: () => updateFiles
32
+ parseGiphyItem: () => parseGiphyItem,
33
+ updateFiles: () => updateFiles,
34
+ uploadFile: () => uploadFile,
35
+ upsertFile: () => upsertFile
32
36
  });
33
37
  module.exports = __toCommonJS(files_exports);
34
38
  var import_rip_hunter = require("@nlabs/rip-hunter");
@@ -36,246 +40,224 @@ var import_utils = require("@nlabs/utils");
36
40
  var import_arangojs = require("arangojs");
37
41
  var import_googleapis = require("googleapis");
38
42
  var import_config = require("../config");
39
- var import_analytics = require("../utils/analytics");
43
+ var import_analyticsUtils = require("../utils/analyticsUtils");
40
44
  var import_images = require("./images");
41
45
  var import_posts = require("./posts");
42
- const youtube = import_googleapis.google.youtube({ auth: import_config.Config.get("google.key"), version: "v3" });
43
- const addFile = (context, item = {}) => {
44
- const { database, session: { userId: sessionId, userAccess } } = context;
46
+ var import_error = require("../types/error");
47
+ var import_fileAdapter = require("../adapters/fileAdapter");
48
+ const eventCategory = "files";
49
+ const GIPHY_URL = "http://api.giphy.com/v1/gifs";
50
+ const getYouTube = () => import_googleapis.google.youtube({ auth: import_config.Config.get("google.key"), version: "v3" });
51
+ const insertFile = (context, file) => {
52
+ const action = "insertFile";
53
+ const { database } = context;
54
+ const formattedFile = (0, import_fileAdapter.parseFile)(file);
55
+ const aqlQry = import_arangojs.aql`INSERT ${formattedFile} IN files RETURN NEW`;
56
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
57
+ action,
58
+ category: eventCategory,
59
+ label: import_error.ErrorTypes.DATABASE_ERROR
60
+ }, error, context));
61
+ };
62
+ const upsertFile = (context, file) => {
63
+ const action = "upsertFile";
64
+ const { database } = context;
65
+ const formattedFile = (0, import_fileAdapter.parseFile)(file);
66
+ const { fileId } = formattedFile;
67
+ const insert = {
68
+ ...formattedFile,
69
+ _key: fileId,
70
+ added: Date.now(),
71
+ modified: Date.now()
72
+ };
73
+ const update = {
74
+ ...formattedFile,
75
+ _key: fileId,
76
+ modified: Date.now()
77
+ };
78
+ const aqlQry = import_arangojs.aql`UPSERT {_key: ${fileId}}
79
+ INSERT ${insert}
80
+ UPDATE ${update}
81
+ IN files RETURN NEW`;
82
+ return database.query(aqlQry).then((cursor) => cursor.next()).then((updatedFile) => updatedFile).catch((error) => (0, import_analyticsUtils.logError)({
83
+ action,
84
+ category: eventCategory,
85
+ label: import_error.ErrorTypes.DATABASE_ERROR
86
+ }, error, context));
87
+ };
88
+ const uploadFile = (context, file, buffer) => {
89
+ const { session: { userId: sessionId } } = context;
90
+ const formattedFile = (0, import_fileAdapter.parseFile)(file);
45
91
  const {
46
92
  description,
47
93
  fileId,
48
94
  fileType,
49
95
  name,
50
96
  url
51
- } = item;
52
- const formatFileId = fileId ? (0, import_utils.parseId)(fileId) : (0, import_utils.createHash)(`file-${sessionId}`);
53
- const isUrl = !!url;
54
- let formatName = (0, import_utils.parseString)(name, 160);
55
- let formatType = (0, import_utils.parseString)(fileType, 16);
56
- if (formatName === "" && isUrl) {
57
- formatName = url.substring(url.lastIndexOf("/") + 1);
58
- }
59
- if (formatType === "") {
60
- const nameArr = formatName.split(".");
61
- const ext = nameArr[nameArr.length - 1];
62
- switch (ext) {
63
- case "jpeg":
64
- case "jpg":
65
- formatType = "image/jpeg";
66
- break;
67
- case "png":
68
- formatType = "image/png";
69
- break;
70
- case "zip":
71
- formatType = "application/zip";
72
- break;
73
- default:
74
- break;
75
- }
97
+ } = formattedFile;
98
+ const now = Date.now();
99
+ const formatFileId = fileId || (0, import_utils.createHash)(`file-${sessionId}`);
100
+ let updatedName = name;
101
+ if (!updatedName && !!url) {
102
+ updatedName = url.substring(url.lastIndexOf("/") + 1);
76
103
  }
77
- let isImage;
78
- switch (formatType) {
79
- case "image/jpeg":
80
- case "image/png":
81
- isImage = true;
82
- break;
83
- default:
84
- isImage = false;
85
- break;
86
- }
87
- const formatDesc = (0, import_utils.parseString)(description, 500);
88
- if (!isImage && userAccess !== 2) {
89
- throw new import_analytics.UserError("account_restriction");
90
- }
91
- const saveToDb = (insert) => {
92
- const aqlQry = import_arangojs.aql`INSERT ${insert} IN files RETURN NEW`;
93
- return database.query(aqlQry).then((cursor) => cursor.next()).then((file = {}) => file).catch((error) => {
94
- throw error;
95
- });
96
- };
97
- const uploadFile = (buf, uploadType) => {
98
- const now = Date.now();
99
- if (isImage) {
100
- return (0, import_images.resizeSaveImage)(context, formatFileId, buf, uploadType).then((resizedImage) => {
101
- const insert2 = {
102
- ...resizedImage,
103
- _key: formatFileId,
104
- added: now,
105
- description: formatDesc,
106
- fileType: formatType,
107
- modified: now,
108
- name: formatName,
109
- userId: sessionId
110
- };
111
- return saveToDb(insert2);
112
- }).catch((error) => {
113
- throw error;
114
- });
115
- }
116
- const insert = {
104
+ if (fileType === "image/jpeg" || fileType === "image/png") {
105
+ return (0, import_images.resizeSaveImage)(context, formatFileId, buffer, fileType).then((resizedImage) => insertFile(context, {
106
+ ...resizedImage,
117
107
  _key: formatFileId,
118
108
  added: now,
119
- description: formatDesc,
120
- fileType: formatType,
121
109
  modified: now,
122
- name: formatName,
110
+ name: updatedName,
123
111
  userId: sessionId
124
- };
125
- return saveToDb(insert);
126
- };
127
- if (isUrl) {
128
- return (0, import_rip_hunter.get)(url).then((body) => uploadFile(Buffer.from(body, "binary"), formatType)).catch(() => {
129
- throw new import_analytics.UserError("file_request");
130
- });
131
- } else if (item.base64 !== "") {
132
- const buffer = Buffer.from(item.base64);
133
- return uploadFile(buffer, formatType);
112
+ }));
134
113
  }
135
- throw new Error("file_required");
114
+ return insertFile(context, {
115
+ ...formattedFile,
116
+ added: now,
117
+ modified: now,
118
+ userId: sessionId
119
+ });
136
120
  };
137
- const getGiphyTrends = (context, limit = 30) => {
138
- const gifUrl = `http://api.giphy.com/v1/gifs/trending?api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
139
- return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json?.data?.map((gifImage = { id: null, images: null }) => {
140
- const {
141
- id,
142
- images: {
143
- original: { url = "" } = {},
144
- fixed_height_small: { url: thumb = "" } = {}
145
- } = {}
146
- } = gifImage;
147
- return {
148
- id,
149
- thumb,
150
- type: "giphy",
151
- url
152
- };
153
- }));
121
+ const addFile = (context, file) => {
122
+ const action = "addFile";
123
+ const { base64, url } = file;
124
+ if (!!url) {
125
+ return (0, import_rip_hunter.get)(url).then((body) => uploadFile(context, file, Buffer.from(body, "binary"))).catch((error) => (0, import_analyticsUtils.logError)({
126
+ action,
127
+ category: eventCategory,
128
+ label: import_error.ErrorTypes.FILE_REQUEST
129
+ }, error, context));
130
+ } else if (!!base64) {
131
+ const buffer = Buffer.from(base64);
132
+ return uploadFile(context, file, buffer);
133
+ }
134
+ return (0, import_analyticsUtils.logException)({
135
+ action,
136
+ category: eventCategory,
137
+ value: import_error.ErrorTypes.FILE_REQUIRED
138
+ }, {});
154
139
  };
155
- const getGiphySearch = (context, query, limit = 30) => {
140
+ const parseGiphyItem = (gifImage) => {
141
+ const {
142
+ id,
143
+ images: {
144
+ original: { url = "" } = {},
145
+ fixed_height_small: { url: thumb = "" } = {}
146
+ } = {}
147
+ } = gifImage;
148
+ if (!id || !url) {
149
+ return null;
150
+ }
151
+ return {
152
+ id,
153
+ thumb,
154
+ type: "giphy",
155
+ url
156
+ };
157
+ };
158
+ const getGiphyTrends = (limit = 30) => {
159
+ const gifUrl = `${GIPHY_URL}/trending?api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
160
+ return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json?.data?.map(parseGiphyItem).filter((item) => !!item));
161
+ };
162
+ const getGiphySearch = (query, limit = 30) => {
156
163
  const formatQuery = encodeURI(query);
157
- const gifUrl = `http://api.giphy.com/v1/gifs/search?q=${formatQuery}&api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
158
- return fetch(gifUrl).then((res) => res.json()).then((json) => json?.data?.map((gifImage = { id: null, images: null }) => {
159
- const {
160
- id,
161
- images: {
162
- original: { url = "" } = {},
163
- fixed_height_small: { url: thumb = "" } = {}
164
- } = {}
165
- } = gifImage;
166
- return {
167
- id,
168
- thumb,
169
- type: "giphy",
170
- url
171
- };
172
- }));
164
+ const gifUrl = `${GIPHY_URL}/search?q=${formatQuery}&api_key=${import_config.Config.get("giphy.key")}&limit=${limit}`;
165
+ return (0, import_rip_hunter.get)(gifUrl).then((res) => res.json()).then((json) => json?.data?.map(parseGiphyItem).filter((item) => !!item));
173
166
  };
174
- const getYouTubeTrends = (context, limit = 30) => new Promise((resolve, reject) => {
175
- youtube.videos.list({
176
- chart: "mostPopular",
177
- maxResults: limit,
178
- part: ["snippet"],
179
- regionCode: "US"
180
- }, (error, data) => {
181
- if (error) {
182
- console.error(error);
183
- reject(new Error(error[0].message));
184
- } else if (data) {
185
- const list = data.items.map((item) => ({
186
- id: item.id,
187
- thumb: item.snippet.thumbnails.high.url,
188
- type: "youtube",
189
- url: `http://www.youtube.com/embed/${item.id}`
190
- }));
191
- resolve(list);
192
- }
193
- });
194
- });
195
- const getYouTubeSearch = (context, query, limit = 30) => new Promise((resolve, reject) => {
196
- youtube.search.list({
197
- maxResults: limit,
198
- part: ["snippet"],
199
- // eslint-disable-next-line
200
- q: query,
201
- regionCode: "US"
202
- }, (error, data) => {
203
- if (error) {
204
- console.error(error);
205
- reject(new Error(error[0].message));
206
- } else if (data) {
207
- const { items } = data;
208
- const list = 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
- }
167
+ const getYouTubeTrends = (limit = 30) => {
168
+ const action = "getYouTubeTrends";
169
+ const youtube = getYouTube();
170
+ return new Promise((resolve, reject) => {
171
+ youtube.videos.list({
172
+ chart: "mostPopular",
173
+ maxResults: limit,
174
+ part: ["snippet"],
175
+ regionCode: "US"
176
+ }, (error, data) => {
177
+ if (error) {
178
+ console.error(error);
179
+ reject(new Error(import_error.ErrorTypes.YOUTUBE_ERROR));
180
+ } else if (data) {
181
+ const list = data.items.map((item) => ({
182
+ id: item.id,
183
+ thumb: item.snippet.thumbnails.high.url,
184
+ type: "youtube",
185
+ url: `http://www.youtube.com/embed/${item.id}`
186
+ }));
187
+ resolve(list);
188
+ }
189
+ });
216
190
  });
217
- });
218
- const getPathUserFiles = (userId, filename) => `users/${userId}/files/${filename}`;
219
- const getUrlUserFiles = (userId, filename, dir = "files", type = "profile") => {
220
- if (filename) {
221
- return `https://box.${import_config.Config.get("app.url")}/users/${userId}/${dir}/${filename}`;
222
- }
223
- if (type === "profile") {
224
- return `https://box.${import_config.Config.get("app.url")}/defaults/user_bk.jpg`;
225
- }
226
- return `https://box.${import_config.Config.get("app.url")}/defaults/user_wh.jpg`;
227
191
  };
228
- const createFile = (db, file) => {
229
- const { fileId } = file;
230
- const insert = {
231
- _key: fileId,
232
- added: Date.now()
233
- };
234
- const aqlQry = import_arangojs.aql`UPSERT {_key: ${fileId}}
235
- INSERT ${insert}
236
- UPDATE {}
237
- IN files RETURN NEW`;
238
- return db.query(aqlQry).then((cursor) => cursor.next()).then((updatedFile = {}) => updatedFile).catch((error) => {
239
- throw error;
192
+ const getYouTubeSearch = (query, limit = 30) => {
193
+ const action = "getYouTubeSearch";
194
+ const youtube = getYouTube();
195
+ return new Promise((resolve, reject) => {
196
+ youtube.search.list({
197
+ maxResults: limit,
198
+ part: ["snippet"],
199
+ q: query,
200
+ regionCode: "US"
201
+ }, (error, data) => {
202
+ if (error) {
203
+ console.error(error);
204
+ reject(new Error(import_error.ErrorTypes.YOUTUBE_ERROR));
205
+ } else if (data) {
206
+ const { items } = data;
207
+ const list = items.map((item) => ({
208
+ id: item.id,
209
+ thumb: item.snippet.thumbnails.high.url,
210
+ type: "youtube",
211
+ url: `http://www.youtube.com/embed/${item.id}`
212
+ }));
213
+ resolve(list);
214
+ }
215
+ });
240
216
  });
241
217
  };
242
- const linkFiles = (db, files, postId) => Promise.all(
243
- files.map((file) => createFile(db, file).then((file2) => (0, import_posts.createPostEdge)(db, file2, postId)))
218
+ const getPathUserFiles = (userId, filename) => `users/${userId}/files/${filename}`;
219
+ const linkFiles = (context, postDocId, files) => Promise.all(
220
+ files.map((file) => upsertFile(context, file).then((file2) => (0, import_posts.createPostEdge)(context, postDocId, file2.id, "isPosted", { type: file2.fileType })))
244
221
  );
245
- const updateFiles = (db, postId, files) => {
246
- const edgeCollection = db.collection("isPosted");
247
- return edgeCollection.inEdges(postId, {}).then((edges) => {
222
+ const updateFiles = (context, postDocId, files) => {
223
+ const action = "updateFiles";
224
+ const { database } = context;
225
+ const edgeCollection = database.collection("isPosted");
226
+ return edgeCollection.inEdges(postDocId, {}).then((edges) => {
248
227
  if (edges.length) {
249
228
  return Promise.all(
250
229
  edges.map((edge) => {
251
230
  const { _key: edgeKey } = edge;
252
231
  const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isPosted`;
253
- return db.query(aqlQry).catch((error) => {
232
+ return database.query(aqlQry).catch((error) => {
254
233
  throw error;
255
234
  });
256
235
  })
257
236
  ).then(() => {
258
237
  if (files.length) {
259
- return linkFiles(db, files, postId).then(() => files);
238
+ return linkFiles(context, postDocId, files).then(() => files);
260
239
  }
261
- return files;
240
+ return [];
262
241
  });
263
242
  } else if (files.length) {
264
- return linkFiles(db, files, postId).then(() => files);
243
+ return linkFiles(context, postDocId, files).then(() => files);
265
244
  }
266
245
  return files;
267
- }).catch((error) => {
268
- throw error;
269
- });
246
+ }).catch((error) => (0, import_analyticsUtils.logError)({
247
+ action,
248
+ category: eventCategory,
249
+ label: import_error.ErrorTypes.DATABASE_ERROR
250
+ }, error, context));
270
251
  };
271
252
  const encodeBase64 = (buffer) => Buffer.from(buffer).toString("base64");
272
253
  const decodeBase64 = (dataString) => {
273
- const getData = (str) => str.match(/^data:([A-Za-z-+\/]+);base64,(.+)$/) || [];
254
+ const action = "decodeBase64";
255
+ const getData = (str) => str.match(/^data:([A-Za-z-+/]+);base64,(.+)$/) || [];
274
256
  let matches = getData(dataString);
275
257
  if (matches.length !== 3) {
276
258
  matches = getData(decodeURIComponent(dataString));
277
259
  if (matches.length !== 3) {
278
- throw Error("Invalid input string");
260
+ throw Error(import_error.ErrorTypes.INVALID_INPUT);
279
261
  }
280
262
  }
281
263
  return {
@@ -285,17 +267,21 @@ const decodeBase64 = (dataString) => {
285
267
  };
286
268
  // Annotate the CommonJS export names for ESM import in node:
287
269
  0 && (module.exports = {
270
+ GIPHY_URL,
288
271
  addFile,
289
- createFile,
290
272
  decodeBase64,
291
273
  encodeBase64,
292
274
  getGiphySearch,
293
275
  getGiphyTrends,
294
276
  getPathUserFiles,
295
- getUrlUserFiles,
277
+ getYouTube,
296
278
  getYouTubeSearch,
297
279
  getYouTubeTrends,
280
+ insertFile,
298
281
  linkFiles,
299
- updateFiles
282
+ parseGiphyItem,
283
+ updateFiles,
284
+ uploadFile,
285
+ upsertFile
300
286
  });
301
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvZmlsZXMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2dldCBhcyBodHRwR2V0fSBmcm9tICdAbmxhYnMvcmlwLWh1bnRlcic7XG5pbXBvcnQge2NyZWF0ZUhhc2gsIHBhcnNlSWQsIHBhcnNlU3RyaW5nfSBmcm9tICdAbmxhYnMvdXRpbHMnO1xuaW1wb3J0IHthcWwsIERhdGFiYXNlfSBmcm9tICdhcmFuZ29qcyc7XG5pbXBvcnQge0FxbFF1ZXJ5fSBmcm9tICdhcmFuZ29qcy9hcWwnO1xuaW1wb3J0IHtFZGdlQ29sbGVjdGlvbn0gZnJvbSAnYXJhbmdvanMvY29sbGVjdGlvbic7XG5pbXBvcnQge0FycmF5Q3Vyc29yfSBmcm9tICdhcmFuZ29qcy9jdXJzb3InO1xuaW1wb3J0IHtnb29nbGV9IGZyb20gJ2dvb2dsZWFwaXMnO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7QXBpQ29udGV4dH0gZnJvbSAnLi4vdHlwZXMvYXV0aCc7XG5pbXBvcnQge0ZpbGVUeXBlfSBmcm9tICcuLi90eXBlcy9maWxlcyc7XG5pbXBvcnQge1VzZXJFcnJvcn0gZnJvbSAnLi4vdXRpbHMvYW5hbHl0aWNzJztcbmltcG9ydCB7cmVzaXplU2F2ZUltYWdlfSBmcm9tICcuL2ltYWdlcyc7XG5pbXBvcnQge2NyZWF0ZVBvc3RFZGdlfSBmcm9tICcuL3Bvc3RzJztcblxuY29uc3QgeW91dHViZSA9IGdvb2dsZS55b3V0dWJlKHthdXRoOiBDb25maWcuZ2V0KCdnb29nbGUua2V5JyksIHZlcnNpb246ICd2Myd9KTtcblxuLy8gY29uc3QgZXZlbnRDYXRlZ29yeTogc3RyaW5nID0gJ2ZpbGVzJztcblxuLy8gVXBsb2FkIGZpbGVcbmV4cG9ydCBjb25zdCBhZGRGaWxlID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGl0ZW06IEZpbGVUeXBlID0ge30pOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IHtkYXRhYmFzZSwgc2Vzc2lvbjoge3VzZXJJZDogc2Vzc2lvbklkLCB1c2VyQWNjZXNzfX0gPSBjb250ZXh0O1xuICBjb25zdCB7XG4gICAgZGVzY3JpcHRpb24sXG4gICAgZmlsZUlkLFxuICAgIGZpbGVUeXBlLFxuICAgIG5hbWUsXG4gICAgdXJsXG4gIH0gPSBpdGVtO1xuXG4gIC8vIElkXG4gIGNvbnN0IGZvcm1hdEZpbGVJZDogc3RyaW5nID0gZmlsZUlkID8gcGFyc2VJZChmaWxlSWQpIDogY3JlYXRlSGFzaChgZmlsZS0ke3Nlc3Npb25JZH1gKTtcblxuICAvLyBOYW1lXG4gIGNvbnN0IGlzVXJsOiBib29sZWFuID0gISF1cmw7XG5cbiAgLy8gSWYgbm8gbmFtZSwgZ2V0IGl0IGZyb20gdXJsIHBhdGhcbiAgbGV0IGZvcm1hdE5hbWU6IHN0cmluZyA9IHBhcnNlU3RyaW5nKG5hbWUsIDE2MCk7XG4gIGxldCBmb3JtYXRUeXBlOiBzdHJpbmcgPSBwYXJzZVN0cmluZyhmaWxlVHlwZSwgMTYpO1xuXG4gIGlmKGZvcm1hdE5hbWUgPT09ICcnICYmIGlzVXJsKSB7XG4gICAgZm9ybWF0TmFtZSA9IHVybC5zdWJzdHJpbmcodXJsLmxhc3RJbmRleE9mKCcvJykgKyAxKTtcbiAgfVxuXG4gIGlmKGZvcm1hdFR5cGUgPT09ICcnKSB7XG4gICAgY29uc3QgbmFtZUFycjogc3RyaW5nW10gPSBmb3JtYXROYW1lLnNwbGl0KCcuJyk7XG4gICAgY29uc3QgZXh0OiBzdHJpbmcgPSBuYW1lQXJyW25hbWVBcnIubGVuZ3RoIC0gMV07XG5cbiAgICBzd2l0Y2goZXh0KSB7XG4gICAgICBjYXNlICdqcGVnJzpcbiAgICAgIGNhc2UgJ2pwZyc6XG4gICAgICAgIGZvcm1hdFR5cGUgPSAnaW1hZ2UvanBlZyc7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAncG5nJzpcbiAgICAgICAgZm9ybWF0VHlwZSA9ICdpbWFnZS9wbmcnO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ3ppcCc6XG4gICAgICAgIGZvcm1hdFR5cGUgPSAnYXBwbGljYXRpb24vemlwJztcbiAgICAgICAgYnJlYWs7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBsZXQgaXNJbWFnZTogYm9vbGVhbjtcblxuICBzd2l0Y2goZm9ybWF0VHlwZSkge1xuICAgIGNhc2UgJ2ltYWdlL2pwZWcnOlxuICAgIGNhc2UgJ2ltYWdlL3BuZyc6XG4gICAgICBpc0ltYWdlID0gdHJ1ZTtcbiAgICAgIGJyZWFrO1xuICAgIGRlZmF1bHQ6XG4gICAgICBpc0ltYWdlID0gZmFsc2U7XG4gICAgICBicmVhaztcbiAgfVxuXG4gIC8vIERlc2NyaXB0aW9uXG4gIGNvbnN0IGZvcm1hdERlc2M6IHN0cmluZyA9IHBhcnNlU3RyaW5nKGRlc2NyaXB0aW9uLCA1MDApO1xuXG4gIC8vIE9ubHkgYWxsb3cgZmlsZSB1cGxvYWRzIHRvIHByZW1pdW0gdXNlcnNcbiAgaWYoIWlzSW1hZ2UgJiYgdXNlckFjY2VzcyAhPT0gMikge1xuICAgIHRocm93IG5ldyBVc2VyRXJyb3IoJ2FjY291bnRfcmVzdHJpY3Rpb24nKTtcbiAgfVxuXG4gIGNvbnN0IHNhdmVUb0RiID0gKGluc2VydDogRmlsZVR5cGUpID0+IHtcbiAgICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYElOU0VSVCAke2luc2VydH0gSU4gZmlsZXMgUkVUVVJOIE5FV2A7XG5cbiAgICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgICAudGhlbigoZmlsZSA9IHt9KSA9PiBmaWxlKVxuICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICB9KTtcbiAgfTtcblxuICBjb25zdCB1cGxvYWRGaWxlID0gKGJ1ZjogQnVmZmVyLCB1cGxvYWRUeXBlOiBzdHJpbmcpID0+IHtcbiAgICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG5cbiAgICAvLyBJZiBpbWFnZSwgcmVzaXplIGFuZCBjcmVhdGUgYSB0aHVtYm5haWxcbiAgICBpZihpc0ltYWdlKSB7XG4gICAgICByZXR1cm4gcmVzaXplU2F2ZUltYWdlKGNvbnRleHQsIGZvcm1hdEZpbGVJZCwgYnVmLCB1cGxvYWRUeXBlKVxuICAgICAgICAudGhlbigocmVzaXplZEltYWdlOiBGaWxlVHlwZSkgPT4ge1xuICAgICAgICAgIGNvbnN0IGluc2VydDogRmlsZVR5cGUgPSB7XG4gICAgICAgICAgICAuLi5yZXNpemVkSW1hZ2UsXG4gICAgICAgICAgICBfa2V5OiBmb3JtYXRGaWxlSWQsXG4gICAgICAgICAgICBhZGRlZDogbm93LFxuICAgICAgICAgICAgZGVzY3JpcHRpb246IGZvcm1hdERlc2MsXG4gICAgICAgICAgICBmaWxlVHlwZTogZm9ybWF0VHlwZSxcbiAgICAgICAgICAgIG1vZGlmaWVkOiBub3csXG4gICAgICAgICAgICBuYW1lOiBmb3JtYXROYW1lLFxuICAgICAgICAgICAgdXNlcklkOiBzZXNzaW9uSWRcbiAgICAgICAgICB9O1xuXG4gICAgICAgICAgcmV0dXJuIHNhdmVUb0RiKGluc2VydCk7XG4gICAgICAgIH0pXG4gICAgICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICBjb25zdCBpbnNlcnQ6IEZpbGVUeXBlID0ge1xuICAgICAgX2tleTogZm9ybWF0RmlsZUlkLFxuICAgICAgYWRkZWQ6IG5vdyxcbiAgICAgIGRlc2NyaXB0aW9uOiBmb3JtYXREZXNjLFxuICAgICAgZmlsZVR5cGU6IGZvcm1hdFR5cGUsXG4gICAgICBtb2RpZmllZDogbm93LFxuICAgICAgbmFtZTogZm9ybWF0TmFtZSxcbiAgICAgIHVzZXJJZDogc2Vzc2lvbklkXG4gICAgfTtcblxuICAgIHJldHVybiBzYXZlVG9EYihpbnNlcnQpO1xuICB9O1xuXG4gIC8vIElmIGZpbGUgaXMgYSB1cmwgcGF0aCwgZG93bmxvYWQgdGhlIGZpbGUgYW5kIHNhdmVcbiAgaWYoaXNVcmwpIHtcbiAgICByZXR1cm4gaHR0cEdldCh1cmwpXG4gICAgICAudGhlbigoYm9keSkgPT4gdXBsb2FkRmlsZShCdWZmZXIuZnJvbShib2R5LCAnYmluYXJ5JyksIGZvcm1hdFR5cGUpKVxuICAgICAgLmNhdGNoKCgpID0+IHtcbiAgICAgICAgdGhyb3cgbmV3IFVzZXJFcnJvcignZmlsZV9yZXF1ZXN0Jyk7XG4gICAgICB9KTtcbiAgfSBlbHNlIGlmKGl0ZW0uYmFzZTY0ICE9PSAnJykge1xuICAgIGNvbnN0IGJ1ZmZlcjogQnVmZmVyID0gQnVmZmVyLmZyb20oaXRlbS5iYXNlNjQpO1xuICAgIHJldHVybiB1cGxvYWRGaWxlKGJ1ZmZlciwgZm9ybWF0VHlwZSk7XG4gIH1cbiAgdGhyb3cgbmV3IEVycm9yKCdmaWxlX3JlcXVpcmVkJyk7XG59O1xuXG4vLyBHaXBoeVxuZXhwb3J0IGNvbnN0IGdldEdpcGh5VHJlbmRzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+IHtcbiAgY29uc3QgZ2lmVXJsID0gYGh0dHA6Ly9hcGkuZ2lwaHkuY29tL3YxL2dpZnMvdHJlbmRpbmc/YXBpX2tleT0ke0NvbmZpZy5nZXQoJ2dpcGh5LmtleScpfSZsaW1pdD0ke2xpbWl0fWA7XG5cbiAgcmV0dXJuIGh0dHBHZXQoZ2lmVXJsKVxuICAgIC50aGVuKChyZXM6IFJlc3BvbnNlKSA9PiByZXMuanNvbigpKVxuICAgIC50aGVuKChqc29uOiBhbnkpID0+IGpzb24/LmRhdGE/Lm1hcCgoZ2lmSW1hZ2UgPSB7aWQ6IG51bGwsIGltYWdlczogbnVsbH0pID0+IHtcbiAgICAgIGNvbnN0IHtcbiAgICAgICAgaWQsXG4gICAgICAgIGltYWdlczoge1xuICAgICAgICAgIG9yaWdpbmFsOiB7dXJsID0gJyd9ID0ge30sXG4gICAgICAgICAgZml4ZWRfaGVpZ2h0X3NtYWxsOiB7dXJsOiB0aHVtYiA9ICcnfSA9IHt9XG4gICAgICAgIH0gPSB7fVxuICAgICAgfSA9IGdpZkltYWdlO1xuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBpZCxcbiAgICAgICAgdGh1bWIsXG4gICAgICAgIHR5cGU6ICdnaXBoeScsXG4gICAgICAgIHVybFxuICAgICAgfTtcbiAgICB9KSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlTZWFyY2ggPSAoY29udGV4dDogQXBpQ29udGV4dCwgcXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxhbnlbXT4gPT4ge1xuICBjb25zdCBmb3JtYXRRdWVyeSA9IGVuY29kZVVSSShxdWVyeSk7XG4gIGNvbnN0IGdpZlVybCA9IGBodHRwOi8vYXBpLmdpcGh5LmNvbS92MS9naWZzL3NlYXJjaD9xPSR7Zm9ybWF0UXVlcnl9JmFwaV9rZXk9JHtDb25maWcuZ2V0KCdnaXBoeS5rZXknKX0mbGltaXQ9JHtsaW1pdH1gO1xuXG4gIHJldHVybiBmZXRjaChnaWZVcmwpXG4gICAgLnRoZW4oKHJlczogUmVzcG9uc2UpID0+IHJlcy5qc29uKCkpXG4gICAgLnRoZW4oKGpzb246IGFueSkgPT4ganNvbj8uZGF0YT8ubWFwKChnaWZJbWFnZSA9IHtpZDogbnVsbCwgaW1hZ2VzOiBudWxsfSkgPT4ge1xuICAgICAgY29uc3Qge1xuICAgICAgICBpZCxcbiAgICAgICAgaW1hZ2VzOiB7XG4gICAgICAgICAgb3JpZ2luYWw6IHt1cmwgPSAnJ30gPSB7fSxcbiAgICAgICAgICBmaXhlZF9oZWlnaHRfc21hbGw6IHt1cmw6IHRodW1iID0gJyd9ID0ge31cbiAgICAgICAgfSA9IHt9XG4gICAgICB9ID0gZ2lmSW1hZ2U7XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGlkLFxuICAgICAgICB0aHVtYixcbiAgICAgICAgdHlwZTogJ2dpcGh5JyxcbiAgICAgICAgdXJsXG4gICAgICB9O1xuICAgIH0pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlVHJlbmRzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+XG4gIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB5b3V0dWJlLnZpZGVvcy5saXN0KHtcbiAgICAgIGNoYXJ0OiAnbW9zdFBvcHVsYXInLFxuICAgICAgbWF4UmVzdWx0czogbGltaXQsXG4gICAgICBwYXJ0OiBbJ3NuaXBwZXQnXSxcbiAgICAgIHJlZ2lvbkNvZGU6ICdVUydcbiAgICB9LCAoZXJyb3I6IEVycm9yLCBkYXRhOiBhbnkpID0+IHtcbiAgICAgIGlmKGVycm9yKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpO1xuICAgICAgICByZWplY3QobmV3IEVycm9yKGVycm9yWzBdLm1lc3NhZ2UpKTtcbiAgICAgIH0gZWxzZSBpZihkYXRhKSB7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBkYXRhLml0ZW1zLm1hcCgoaXRlbSkgPT4gKHtcbiAgICAgICAgICBpZDogaXRlbS5pZCxcbiAgICAgICAgICB0aHVtYjogaXRlbS5zbmlwcGV0LnRodW1ibmFpbHMuaGlnaC51cmwsXG4gICAgICAgICAgdHlwZTogJ3lvdXR1YmUnLFxuICAgICAgICAgIHVybDogYGh0dHA6Ly93d3cueW91dHViZS5jb20vZW1iZWQvJHtpdGVtLmlkfWBcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHJlc29sdmUobGlzdCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xuXG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlU2VhcmNoID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHF1ZXJ5OiBzdHJpbmcsIGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+XG4gIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB5b3V0dWJlLnNlYXJjaC5saXN0KHtcbiAgICAgIG1heFJlc3VsdHM6IGxpbWl0LFxuICAgICAgcGFydDogWydzbmlwcGV0J10sXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICAgIHE6IHF1ZXJ5LFxuICAgICAgcmVnaW9uQ29kZTogJ1VTJ1xuICAgIH0sIChlcnJvcjogRXJyb3IsIGRhdGE6IGFueSkgPT4ge1xuICAgICAgaWYoZXJyb3IpIHtcbiAgICAgICAgY29uc29sZS5lcnJvcihlcnJvcik7XG4gICAgICAgIHJlamVjdChuZXcgRXJyb3IoZXJyb3JbMF0ubWVzc2FnZSkpO1xuICAgICAgfSBlbHNlIGlmKGRhdGEpIHtcbiAgICAgICAgY29uc3Qge2l0ZW1zfSA9IGRhdGE7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBpdGVtcy5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgICAgaWQ6IGl0ZW0uaWQsXG4gICAgICAgICAgdGh1bWI6IGl0ZW0uc25pcHBldC50aHVtYm5haWxzLmhpZ2gudXJsLFxuICAgICAgICAgIHR5cGU6ICd5b3V0dWJlJyxcbiAgICAgICAgICB1cmw6IGBodHRwOi8vd3d3LnlvdXR1YmUuY29tL2VtYmVkLyR7aXRlbS5pZH1gXG4gICAgICAgIH0pKTtcblxuICAgICAgICByZXNvbHZlKGxpc3QpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcblxuLy8gRmlsZXNcbmV4cG9ydCBjb25zdCBnZXRQYXRoVXNlckZpbGVzID0gKHVzZXJJZDogc3RyaW5nLCBmaWxlbmFtZTogc3RyaW5nKTogc3RyaW5nID0+IGB1c2Vycy8ke3VzZXJJZH0vZmlsZXMvJHtmaWxlbmFtZX1gO1xuXG5leHBvcnQgY29uc3QgZ2V0VXJsVXNlckZpbGVzID0gKHVzZXJJZDogc3RyaW5nLCBmaWxlbmFtZTogc3RyaW5nLCBkaXI6IHN0cmluZyA9ICdmaWxlcycsIHR5cGU6IHN0cmluZyA9ICdwcm9maWxlJyk6IHN0cmluZyA9PiB7XG4gIGlmKGZpbGVuYW1lKSB7XG4gICAgcmV0dXJuIGBodHRwczovL2JveC4ke0NvbmZpZy5nZXQoJ2FwcC51cmwnKX0vdXNlcnMvJHt1c2VySWR9LyR7ZGlyfS8ke2ZpbGVuYW1lfWA7XG4gIH1cblxuICBpZih0eXBlID09PSAncHJvZmlsZScpIHtcbiAgICByZXR1cm4gYGh0dHBzOi8vYm94LiR7Q29uZmlnLmdldCgnYXBwLnVybCcpfS9kZWZhdWx0cy91c2VyX2JrLmpwZ2A7XG4gIH1cblxuICByZXR1cm4gYGh0dHBzOi8vYm94LiR7Q29uZmlnLmdldCgnYXBwLnVybCcpfS9kZWZhdWx0cy91c2VyX3doLmpwZ2A7XG59O1xuXG5leHBvcnQgY29uc3QgY3JlYXRlRmlsZSA9IChkYjogRGF0YWJhc2UsIGZpbGU6IEZpbGVUeXBlKTogUHJvbWlzZTxGaWxlVHlwZT4gPT4ge1xuICBjb25zdCB7ZmlsZUlkfSA9IGZpbGU7XG4gIGNvbnN0IGluc2VydDogYW55ID0ge1xuICAgIF9rZXk6IGZpbGVJZCxcbiAgICBhZGRlZDogRGF0ZS5ub3coKVxuICB9O1xuXG4gIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgVVBTRVJUIHtfa2V5OiAke2ZpbGVJZH19XG4gICAgSU5TRVJUICR7aW5zZXJ0fVxuICAgIFVQREFURSB7fVxuICAgIElOIGZpbGVzIFJFVFVSTiBORVdgO1xuXG4gIHJldHVybiBkYi5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHVwZGF0ZWRGaWxlOiBGaWxlVHlwZSA9IHt9KSA9PiB1cGRhdGVkRmlsZSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgbGlua0ZpbGVzID0gKGRiOiBEYXRhYmFzZSwgZmlsZXM6IEZpbGVUeXBlW10sIHBvc3RJZDogc3RyaW5nKTogUHJvbWlzZTxhbnk+ID0+XG4gIFByb21pc2UuYWxsKFxuICAgIGZpbGVzLm1hcCgoZmlsZTogRmlsZVR5cGUpID0+IGNyZWF0ZUZpbGUoZGIsIGZpbGUpXG4gICAgICAudGhlbigoZmlsZTogRmlsZVR5cGUpID0+IGNyZWF0ZVBvc3RFZGdlKGRiLCBmaWxlLCBwb3N0SWQpKSlcbiAgKTtcblxuZXhwb3J0IGNvbnN0IHVwZGF0ZUZpbGVzID0gKGRiOiBEYXRhYmFzZSwgcG9zdElkOiBzdHJpbmcsIGZpbGVzOiBGaWxlVHlwZVtdKTogUHJvbWlzZTxhbnk+ID0+IHtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb246IEVkZ2VDb2xsZWN0aW9uID0gZGIuY29sbGVjdGlvbignaXNQb3N0ZWQnKTtcblxuICByZXR1cm4gZWRnZUNvbGxlY3Rpb24uaW5FZGdlcyhwb3N0SWQsIHt9KVxuICAgIC50aGVuKChlZGdlczogYW55KSA9PiB7XG4gICAgICBpZihlZGdlcy5sZW5ndGgpIHtcbiAgICAgICAgLy8gUmVtb3ZlIGxpbmtlZCBlZGdlc1xuICAgICAgICByZXR1cm4gUHJvbWlzZS5hbGwoXG4gICAgICAgICAgZWRnZXMubWFwKChlZGdlKSA9PiB7XG4gICAgICAgICAgICBjb25zdCB7X2tleTogZWRnZUtleX0gPSBlZGdlO1xuICAgICAgICAgICAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBSRU1PVkUge19rZXk6JHtlZGdlS2V5fX0gSU4gaXNQb3N0ZWRgO1xuXG4gICAgICAgICAgICByZXR1cm4gZGIucXVlcnkoYXFsUXJ5KS5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfSkpXG4gICAgICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICAgICAgaWYoZmlsZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgIC8vIExpbmsgZmlsZXNcbiAgICAgICAgICAgICAgcmV0dXJuIGxpbmtGaWxlcyhkYiwgZmlsZXMsIHBvc3RJZCkudGhlbigoKSA9PiBmaWxlcyk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gZmlsZXM7XG4gICAgICAgICAgfSk7XG4gICAgICB9IGVsc2UgaWYoZmlsZXMubGVuZ3RoKSB7XG4gICAgICAgIC8vIExpbmsgZmlsZXNcbiAgICAgICAgcmV0dXJuIGxpbmtGaWxlcyhkYiwgZmlsZXMsIHBvc3RJZCkudGhlbigoKSA9PiBmaWxlcyk7XG4gICAgICB9XG4gICAgICByZXR1cm4gZmlsZXM7XG4gICAgfSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4ge1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgZW5jb2RlQmFzZTY0ID0gKGJ1ZmZlcjogQnVmZmVyKTogc3RyaW5nID0+IEJ1ZmZlci5mcm9tKGJ1ZmZlcikudG9TdHJpbmcoJ2Jhc2U2NCcpO1xuXG5leHBvcnQgY29uc3QgZGVjb2RlQmFzZTY0ID0gKGRhdGFTdHJpbmc6IHN0cmluZyk6IG9iamVjdCA9PiB7XG4gIGNvbnN0IGdldERhdGEgPSAoc3RyOiBzdHJpbmcpID0+IHN0ci5tYXRjaCgvXmRhdGE6KFtBLVphLXotK1xcL10rKTtiYXNlNjQsKC4rKSQvKSB8fCBbXTtcbiAgLy8gY29uc3QgZ2V0RGF0YSA9IChiYXNlNjQ6IHN0cmluZykgPT4gYmFzZTY0LnN1YnN0cihiYXNlNjQuaW5kZXhPZignLCcpICsgMSk7XG4gIGxldCBtYXRjaGVzID0gZ2V0RGF0YShkYXRhU3RyaW5nKTtcblxuICBpZihtYXRjaGVzLmxlbmd0aCAhPT0gMykge1xuICAgIC8vIElmIGludmFsaWQgbWFrZSBzdXJlIHdlIGRvbid0IG5lZWQgdG8gZGVjb2RlXG4gICAgbWF0Y2hlcyA9IGdldERhdGEoZGVjb2RlVVJJQ29tcG9uZW50KGRhdGFTdHJpbmcpKTtcblxuICAgIC8vIENoZWNrIGl0IGFnYWluLlxuICAgIGlmKG1hdGNoZXMubGVuZ3RoICE9PSAzKSB7XG4gICAgICB0aHJvdyBFcnJvcignSW52YWxpZCBpbnB1dCBzdHJpbmcnKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGRhdGE6IEJ1ZmZlci5mcm9tKG1hdGNoZXNbMl0sICdiYXNlNjQnKSxcbiAgICB0eXBlOiBtYXRjaGVzWzFdXG4gIH07XG59O1xuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUlBLHdCQUE2QjtBQUM3QixtQkFBK0M7QUFDL0Msc0JBQTRCO0FBSTVCLHdCQUFxQjtBQUVyQixvQkFBcUI7QUFHckIsdUJBQXdCO0FBQ3hCLG9CQUE4QjtBQUM5QixtQkFBNkI7QUFFN0IsTUFBTSxVQUFVLHlCQUFPLFFBQVEsRUFBQyxNQUFNLHFCQUFPLElBQUksWUFBWSxHQUFHLFNBQVMsS0FBSSxDQUFDO0FBS3ZFLE1BQU0sVUFBVSxDQUFDLFNBQXFCLE9BQWlCLENBQUMsTUFBeUI7QUFDdEYsUUFBTSxFQUFDLFVBQVUsU0FBUyxFQUFDLFFBQVEsV0FBVyxXQUFVLEVBQUMsSUFBSTtBQUM3RCxRQUFNO0FBQUEsSUFDSjtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxFQUNGLElBQUk7QUFHSixRQUFNLGVBQXVCLGFBQVMsc0JBQVEsTUFBTSxRQUFJLHlCQUFXLFFBQVEsU0FBUyxFQUFFO0FBR3RGLFFBQU0sUUFBaUIsQ0FBQyxDQUFDO0FBR3pCLE1BQUksaUJBQXFCLDBCQUFZLE1BQU0sR0FBRztBQUM5QyxNQUFJLGlCQUFxQiwwQkFBWSxVQUFVLEVBQUU7QUFFakQsTUFBRyxlQUFlLE1BQU0sT0FBTztBQUM3QixpQkFBYSxJQUFJLFVBQVUsSUFBSSxZQUFZLEdBQUcsSUFB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
287
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvZmlsZXMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2dldCBhcyBodHRwR2V0fSBmcm9tICdAbmxhYnMvcmlwLWh1bnRlcic7XG5pbXBvcnQge2NyZWF0ZUhhc2h9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQge2FxbH0gZnJvbSAnYXJhbmdvanMnO1xuaW1wb3J0IHtBcWxRdWVyeX0gZnJvbSAnYXJhbmdvanMvYXFsJztcbmltcG9ydCB7RWRnZUNvbGxlY3Rpb259IGZyb20gJ2FyYW5nb2pzL2NvbGxlY3Rpb24nO1xuaW1wb3J0IHtBcnJheUN1cnNvcn0gZnJvbSAnYXJhbmdvanMvY3Vyc29yJztcbmltcG9ydCB7Z29vZ2xlfSBmcm9tICdnb29nbGVhcGlzJztcblxuaW1wb3J0IHtDb25maWd9IGZyb20gJy4uL2NvbmZpZyc7XG5pbXBvcnQge0FwaUNvbnRleHR9IGZyb20gJy4uL3R5cGVzL2F1dGgnO1xuaW1wb3J0IHtGaWxlVHlwZX0gZnJvbSAnLi4vdHlwZXMvZmlsZXMnO1xuaW1wb3J0IHtsb2dFcnJvciwgbG9nRXhjZXB0aW9ufSBmcm9tICcuLi91dGlscy9hbmFseXRpY3NVdGlscyc7XG5pbXBvcnQge3Jlc2l6ZVNhdmVJbWFnZX0gZnJvbSAnLi9pbWFnZXMnO1xuaW1wb3J0IHtjcmVhdGVQb3N0RWRnZX0gZnJvbSAnLi9wb3N0cyc7XG5pbXBvcnQge0Vycm9yVHlwZXN9IGZyb20gJy4uL3R5cGVzL2Vycm9yJztcbmltcG9ydCB7SW1hZ2VUeXBlfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQge3BhcnNlRmlsZX0gZnJvbSAnLi4vYWRhcHRlcnMvZmlsZUFkYXB0ZXInO1xuXG5jb25zdCBldmVudENhdGVnb3J5OiBzdHJpbmcgPSAnZmlsZXMnO1xuXG5leHBvcnQgY29uc3QgR0lQSFlfVVJMOiBzdHJpbmcgPSAnaHR0cDovL2FwaS5naXBoeS5jb20vdjEvZ2lmcyc7XG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlID0gKCkgPT4gZ29vZ2xlLnlvdXR1YmUoe2F1dGg6IENvbmZpZy5nZXQoJ2dvb2dsZS5rZXknKSwgdmVyc2lvbjogJ3YzJ30pO1xuXG5leHBvcnQgY29uc3QgaW5zZXJ0RmlsZSA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBmaWxlOiBGaWxlVHlwZSkgPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnaW5zZXJ0RmlsZSc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBmb3JtYXR0ZWRGaWxlID0gcGFyc2VGaWxlKGZpbGUpO1xuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYElOU0VSVCAke2Zvcm1hdHRlZEZpbGV9IElOIGZpbGVzIFJFVFVSTiBORVdgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwgY29udGV4dCkpO1xufTtcblxuZXhwb3J0IGNvbnN0IHVwc2VydEZpbGUgPSAoY29udGV4dDogQXBpQ29udGV4dCwgZmlsZTogRmlsZVR5cGUpOiBQcm9taXNlPEZpbGVUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbiA9ICd1cHNlcnRGaWxlJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGZvcm1hdHRlZEZpbGUgPSBwYXJzZUZpbGUoZmlsZSk7XG4gIGNvbnN0IHtmaWxlSWR9ID0gZm9ybWF0dGVkRmlsZTtcbiAgY29uc3QgaW5zZXJ0OiBhbnkgPSB7XG4gICAgLi4uZm9ybWF0dGVkRmlsZSxcbiAgICBfa2V5OiBmaWxlSWQsXG4gICAgYWRkZWQ6IERhdGUubm93KCksXG4gICAgbW9kaWZpZWQ6IERhdGUubm93KClcbiAgfTtcbiAgY29uc3QgdXBkYXRlOiBhbnkgPSB7XG4gICAgLi4uZm9ybWF0dGVkRmlsZSxcbiAgICBfa2V5OiBmaWxlSWQsXG4gICAgbW9kaWZpZWQ6IERhdGUubm93KClcbiAgfTtcblxuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQU0VSVCB7X2tleTogJHtmaWxlSWR9fVxuICAgIElOU0VSVCAke2luc2VydH1cbiAgICBVUERBVEUgJHt1cGRhdGV9XG4gICAgSU4gZmlsZXMgUkVUVVJOIE5FV2A7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAudGhlbigodXBkYXRlZEZpbGU6IEZpbGVUeXBlKSA9PiB1cGRhdGVkRmlsZSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogRXJyb3JUeXBlcy5EQVRBQkFTRV9FUlJPUlxuICAgIH0sIGVycm9yLCBjb250ZXh0KSk7XG59O1xuXG5leHBvcnQgY29uc3QgdXBsb2FkRmlsZSA9IChjb250ZXh0LCBmaWxlOiBGaWxlVHlwZSwgYnVmZmVyOiBCdWZmZXIpID0+IHtcbiAgY29uc3Qge3Nlc3Npb246IHt1c2VySWQ6IHNlc3Npb25JZH19ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0dGVkRmlsZSA9IHBhcnNlRmlsZShmaWxlKTtcbiAgY29uc3Qge1xuICAgIGRlc2NyaXB0aW9uLFxuICAgIGZpbGVJZCxcbiAgICBmaWxlVHlwZSxcbiAgICBuYW1lLFxuICAgIHVybFxuICB9ID0gZm9ybWF0dGVkRmlsZTtcbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgY29uc3QgZm9ybWF0RmlsZUlkOiBzdHJpbmcgPSBmaWxlSWQgfHwgY3JlYXRlSGFzaChgZmlsZS0ke3Nlc3Npb25JZH1gKTtcbiAgbGV0IHVwZGF0ZWROYW1lID0gbmFtZTtcblxuICBpZighdXBkYXRlZE5hbWUgJiYgISF1cmwpIHtcbiAgICB1cGRhdGVkTmFtZSA9IHVybC5zdWJzdHJpbmcodXJsLmxhc3RJbmRleE9mKCcvJykgKyAxKTtcbiAgfVxuXG4gIGlmKGZpbGVUeXBlID09PSAnaW1hZ2UvanBlZycgfHwgZmlsZVR5cGUgPT09ICdpbWFnZS9wbmcnKSB7XG4gICAgcmV0dXJuIHJlc2l6ZVNhdmVJbWFnZShjb250ZXh0LCBmb3JtYXRGaWxlSWQsIGJ1ZmZlciwgZmlsZVR5cGUpXG4gICAgICAudGhlbigocmVzaXplZEltYWdlOiBGaWxlVHlwZSkgPT4gaW5zZXJ0RmlsZShjb250ZXh0LCB7XG4gICAgICAgIC4uLnJlc2l6ZWRJbWFnZSxcbiAgICAgICAgX2tleTogZm9ybWF0RmlsZUlkLFxuICAgICAgICBhZGRlZDogbm93LFxuICAgICAgICBtb2RpZmllZDogbm93LFxuICAgICAgICBuYW1lOiB1cGRhdGVkTmFtZSxcbiAgICAgICAgdXNlcklkOiBzZXNzaW9uSWRcbiAgICAgIH0pKTtcbiAgfVxuXG4gIHJldHVybiBpbnNlcnRGaWxlKGNvbnRleHQsIHtcbiAgICAuLi5mb3JtYXR0ZWRGaWxlLFxuICAgIGFkZGVkOiBub3csXG4gICAgbW9kaWZpZWQ6IG5vdyxcbiAgICB1c2VySWQ6IHNlc3Npb25JZFxuICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBhZGRGaWxlID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGZpbGU6IEZpbGVUeXBlKTogUHJvbWlzZTxGaWxlVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnYWRkRmlsZSc7XG4gIGNvbnN0IHtiYXNlNjQsIHVybH0gPSBmaWxlO1xuXG4gIGlmKCEhdXJsKSB7XG4gICAgcmV0dXJuIGh0dHBHZXQodXJsKVxuICAgICAgLnRoZW4oKGJvZHkpID0+IHVwbG9hZEZpbGUoY29udGV4dCwgZmlsZSwgQnVmZmVyLmZyb20oYm9keSwgJ2JpbmFyeScpKSlcbiAgICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICAgIGFjdGlvbixcbiAgICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICAgIGxhYmVsOiBFcnJvclR5cGVzLkZJTEVfUkVRVUVTVFxuICAgICAgfSwgZXJyb3IsIGNvbnRleHQpKTtcbiAgfSBlbHNlIGlmKCEhYmFzZTY0KSB7XG4gICAgY29uc3QgYnVmZmVyOiBCdWZmZXIgPSBCdWZmZXIuZnJvbShiYXNlNjQpO1xuICAgIHJldHVybiB1cGxvYWRGaWxlKGNvbnRleHQsIGZpbGUsIGJ1ZmZlcik7XG4gIH1cblxuICByZXR1cm4gbG9nRXhjZXB0aW9uKHtcbiAgICBhY3Rpb24sXG4gICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgdmFsdWU6IEVycm9yVHlwZXMuRklMRV9SRVFVSVJFRFxuICB9LCB7fSk7XG59O1xuXG5leHBvcnQgY29uc3QgcGFyc2VHaXBoeUl0ZW0gPSAoZ2lmSW1hZ2U6IGFueSk6IEltYWdlVHlwZSA9PiB7XG4gIGNvbnN0IHtcbiAgICBpZCxcbiAgICBpbWFnZXM6IHtcbiAgICAgIG9yaWdpbmFsOiB7dXJsID0gJyd9ID0ge30sXG4gICAgICBmaXhlZF9oZWlnaHRfc21hbGw6IHt1cmw6IHRodW1iID0gJyd9ID0ge31cbiAgICB9ID0ge31cbiAgfSA9IGdpZkltYWdlO1xuXG4gIGlmKCFpZCB8fCAhdXJsKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGlkLFxuICAgIHRodW1iLFxuICAgIHR5cGU6ICdnaXBoeScsXG4gICAgdXJsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlUcmVuZHMgPSAobGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxJbWFnZVR5cGVbXT4gPT4ge1xuICBjb25zdCBnaWZVcmwgPSBgJHtHSVBIWV9VUkx9L3RyZW5kaW5nP2FwaV9rZXk9JHtDb25maWcuZ2V0KCdnaXBoeS5rZXknKX0mbGltaXQ9JHtsaW1pdH1gO1xuXG4gIHJldHVybiBodHRwR2V0KGdpZlVybClcbiAgICAudGhlbigocmVzOiBSZXNwb25zZSkgPT4gcmVzLmpzb24oKSlcbiAgICAudGhlbigoanNvbjogYW55KSA9PiBqc29uPy5kYXRhPy5tYXAocGFyc2VHaXBoeUl0ZW0pLmZpbHRlcigoaXRlbSkgPT4gISFpdGVtKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0R2lwaHlTZWFyY2ggPSAocXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxJbWFnZVR5cGVbXT4gPT4ge1xuICBjb25zdCBmb3JtYXRRdWVyeSA9IGVuY29kZVVSSShxdWVyeSk7XG4gIGNvbnN0IGdpZlVybCA9IGAke0dJUEhZX1VSTH0vc2VhcmNoP3E9JHtmb3JtYXRRdWVyeX0mYXBpX2tleT0ke0NvbmZpZy5nZXQoJ2dpcGh5LmtleScpfSZsaW1pdD0ke2xpbWl0fWA7XG5cbiAgcmV0dXJuIGh0dHBHZXQoZ2lmVXJsKVxuICAgIC50aGVuKChyZXM6IFJlc3BvbnNlKSA9PiByZXMuanNvbigpKVxuICAgIC50aGVuKChqc29uOiBhbnkpID0+IGpzb24/LmRhdGE/Lm1hcChwYXJzZUdpcGh5SXRlbSkuZmlsdGVyKChpdGVtKSA9PiAhIWl0ZW0pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRZb3VUdWJlVHJlbmRzID0gKGxpbWl0OiBudW1iZXIgPSAzMCk6IFByb21pc2U8YW55W10+ID0+IHtcbiAgY29uc3QgYWN0aW9uID0gJ2dldFlvdVR1YmVUcmVuZHMnO1xuICBjb25zdCB5b3V0dWJlID0gZ2V0WW91VHViZSgpO1xuXG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgeW91dHViZS52aWRlb3MubGlzdCh7XG4gICAgICBjaGFydDogJ21vc3RQb3B1bGFyJyxcbiAgICAgIG1heFJlc3VsdHM6IGxpbWl0LFxuICAgICAgcGFydDogWydzbmlwcGV0J10sXG4gICAgICByZWdpb25Db2RlOiAnVVMnXG4gICAgfSwgKGVycm9yOiBFcnJvciwgZGF0YTogYW55KSA9PiB7XG4gICAgICBpZihlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihFcnJvclR5cGVzLllPVVRVQkVfRVJST1IpKTtcbiAgICAgIH0gZWxzZSBpZihkYXRhKSB7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBkYXRhLml0ZW1zLm1hcCgoaXRlbSkgPT4gKHtcbiAgICAgICAgICBpZDogaXRlbS5pZCxcbiAgICAgICAgICB0aHVtYjogaXRlbS5zbmlwcGV0LnRodW1ibmFpbHMuaGlnaC51cmwsXG4gICAgICAgICAgdHlwZTogJ3lvdXR1YmUnLFxuICAgICAgICAgIHVybDogYGh0dHA6Ly93d3cueW91dHViZS5jb20vZW1iZWQvJHtpdGVtLmlkfWBcbiAgICAgICAgfSkpO1xuXG4gICAgICAgIHJlc29sdmUobGlzdCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldFlvdVR1YmVTZWFyY2ggPSAocXVlcnk6IHN0cmluZywgbGltaXQ6IG51bWJlciA9IDMwKTogUHJvbWlzZTxhbnlbXT4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnZ2V0WW91VHViZVNlYXJjaCc7XG4gIGNvbnN0IHlvdXR1YmUgPSBnZXRZb3VUdWJlKCk7XG5cbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB5b3V0dWJlLnNlYXJjaC5saXN0KHtcbiAgICAgIG1heFJlc3VsdHM6IGxpbWl0LFxuICAgICAgcGFydDogWydzbmlwcGV0J10sXG4gICAgICBxOiBxdWVyeSxcbiAgICAgIHJlZ2lvbkNvZGU6ICdVUydcbiAgICB9LCAoZXJyb3I6IEVycm9yLCBkYXRhOiBhbnkpID0+IHtcbiAgICAgIGlmKGVycm9yKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpO1xuICAgICAgICByZWplY3QobmV3IEVycm9yKEVycm9yVHlwZXMuWU9VVFVCRV9FUlJPUikpO1xuICAgICAgfSBlbHNlIGlmKGRhdGEpIHtcbiAgICAgICAgY29uc3Qge2l0ZW1zfSA9IGRhdGE7XG4gICAgICAgIGNvbnN0IGxpc3QgPSBpdGVtcy5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgICAgaWQ6IGl0ZW0uaWQsXG4gICAgICAgICAgdGh1bWI6IGl0ZW0uc25pcHBldC50aHVtYm5haWxzLmhpZ2gudXJsLFxuICAgICAgICAgIHR5cGU6ICd5b3V0dWJlJyxcbiAgICAgICAgICB1cmw6IGBodHRwOi8vd3d3LnlvdXR1YmUuY29tL2VtYmVkLyR7aXRlbS5pZH1gXG4gICAgICAgIH0pKTtcblxuICAgICAgICByZXNvbHZlKGxpc3QpO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRQYXRoVXNlckZpbGVzID0gKHVzZXJJZDogc3RyaW5nLCBmaWxlbmFtZTogc3RyaW5nKTogc3RyaW5nID0+IGB1c2Vycy8ke3VzZXJJZH0vZmlsZXMvJHtmaWxlbmFtZX1gO1xuXG5leHBvcnQgY29uc3QgbGlua0ZpbGVzID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHBvc3REb2NJZDogc3RyaW5nLCBmaWxlczogRmlsZVR5cGVbXSk6IFByb21pc2U8YW55PiA9PlxuICBQcm9taXNlLmFsbChcbiAgICBmaWxlcy5tYXAoKGZpbGU6IEZpbGVUeXBlKSA9PiB1cHNlcnRGaWxlKGNvbnRleHQsIGZpbGUpXG4gICAgICAudGhlbigoZmlsZTogRmlsZVR5cGUpID0+IGNyZWF0ZVBvc3RFZGdlKGNvbnRleHQsIHBvc3REb2NJZCwgZmlsZS5pZCwgJ2lzUG9zdGVkJywge3R5cGU6IGZpbGUuZmlsZVR5cGV9KSkpXG4gICk7XG5cbmV4cG9ydCBjb25zdCB1cGRhdGVGaWxlcyA9IChjb250ZXh0OiBBcGlDb250ZXh0LCBwb3N0RG9jSWQ6IHN0cmluZywgZmlsZXM6IEZpbGVUeXBlW10pOiBQcm9taXNlPGFueT4gPT4ge1xuICBjb25zdCBhY3Rpb24gPSAndXBkYXRlRmlsZXMnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb246IEVkZ2VDb2xsZWN0aW9uID0gZGF0YWJhc2UuY29sbGVjdGlvbignaXNQb3N0ZWQnKTtcblxuICByZXR1cm4gZWRnZUNvbGxlY3Rpb24uaW5FZGdlcyhwb3N0RG9jSWQsIHt9KVxuICAgIC50aGVuKChlZGdlczogYW55KSA9PiB7XG4gICAgICBpZihlZGdlcy5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIFByb21pc2UuYWxsKFxuICAgICAgICAgIGVkZ2VzLm1hcCgoZWRnZSkgPT4ge1xuICAgICAgICAgICAgY29uc3Qge19rZXk6IGVkZ2VLZXl9ID0gZWRnZTtcbiAgICAgICAgICAgIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgUkVNT1ZFIHtfa2V5OiR7ZWRnZUtleX19IElOIGlzUG9zdGVkYDtcblxuICAgICAgICAgICAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAgICAgICAgICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfSkpXG4gICAgICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICAgICAgaWYoZmlsZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgIHJldHVybiBsaW5rRmlsZXMoY29udGV4dCwgcG9zdERvY0lkLCBmaWxlcykudGhlbigoKSA9PiBmaWxlcyk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiBbXTtcbiAgICAgICAgICB9KTtcbiAgICAgIH0gZWxzZSBpZihmaWxlcy5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIGxpbmtGaWxlcyhjb250ZXh0LCBwb3N0RG9jSWQsIGZpbGVzKVxuICAgICAgICAgIC50aGVuKCgpID0+IGZpbGVzKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGZpbGVzO1xuICAgIH0pXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwgY29udGV4dCkpO1xufTtcblxuZXhwb3J0IGNvbnN0IGVuY29kZUJhc2U2NCA9IChidWZmZXI6IEJ1ZmZlcik6IHN0cmluZyA9PiBCdWZmZXIuZnJvbShidWZmZXIpLnRvU3RyaW5nKCdiYXNlNjQnKTtcblxuZXhwb3J0IGNvbnN0IGRlY29kZUJhc2U2NCA9IChkYXRhU3RyaW5nOiBzdHJpbmcpOiBhbnkgPT4ge1xuICBjb25zdCBhY3Rpb24gPSAnZGVjb2RlQmFzZTY0JztcbiAgY29uc3QgZ2V0RGF0YSA9IChzdHI6IHN0cmluZykgPT4gc3RyLm1hdGNoKC9eZGF0YTooW0EtWmEtei0rL10rKTtiYXNlNjQsKC4rKSQvKSB8fCBbXTtcbiAgbGV0IG1hdGNoZXMgPSBnZXREYXRhKGRhdGFTdHJpbmcpO1xuXG4gIGlmKG1hdGNoZXMubGVuZ3RoICE9PSAzKSB7XG4gICAgbWF0Y2hlcyA9IGdldERhdGEoZGVjb2RlVVJJQ29tcG9uZW50KGRhdGFTdHJpbmcpKTtcblxuICAgIGlmKG1hdGNoZXMubGVuZ3RoICE9PSAzKSB7XG4gICAgICB0aHJvdyBFcnJvcihFcnJvclR5cGVzLklOVkFMSURfSU5QVVQpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB7XG4gICAgZGF0YTogQnVmZmVyLmZyb20obWF0Y2hlc1syXSwgJ2Jhc2U2NCcpLFxuICAgIHR5cGU6IG1hdGNoZXNbMV1cbiAgfTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSx3QkFBNkI7QUFDN0IsbUJBQXlCO0FBQ3pCLHNCQUFrQjtBQUlsQix3QkFBcUI7QUFFckIsb0JBQXFCO0FBR3JCLDRCQUFxQztBQUNyQyxvQkFBOEI7QUFDOUIsbUJBQTZCO0FBQzdCLG1CQUF5QjtBQUV6Qix5QkFBd0I7QUFFeEIsTUFBTSxnQkFBd0I7QUFFdkIsTUFBTSxZQUFvQjtBQUUxQixNQUFNLGFBQWEsTUFBTSx5QkFBTyxRQUFRLEVBQUMsTUFBTSxxQkFBTyxJQUFJLFlBQVksR0FBRyxTQUFTLEtBQUksQ0FBQztBQUV2RixNQUFNLGFBQWEsQ0FBQyxTQUFxQixTQUFtQjtBQUNqRSxRQUFNLFNBQVM7QUFDZixRQUFNLEVBQUMsU0FBUSxJQUFJO0FBQ25CLFFBQU0sb0JBQWdCLDhCQUFVLElBQUk7QUFDcEMsUUFBTSxTQUFtQiw2QkFBYSxhQUFhO0FBRW5ELFNBQU8sU0FBUyxNQUFNLE1BQU0sRUFDekIsS0FBSyxDQUFDLFdBQXdCLE9BQU8sS0FBSyxDQUFDLEVBQzNDLE1BQU0sQ0FBQyxjQUFpQixnQ0FBUztBQUFBLElBQ2hDO0FBQUEsSUFDQSxVQUFVO0FBQUEsSUFDVixPQUFPLHdCQUFXO0FBQUEsRUFDcEIsR0FBRyxPQUFPLE9BQU8sQ0FBQztBQUN0QjtBQUVPLE1BQU0sYUFBYSxDQUFDLFNBQXFCLFNBQXNDO0FBQ3BGLFFBQU0sU0FBUztBQUNmLFFBQU0sRUFBQyxTQUFRLElBQUk7QUFDbkIsUUFBTSxvQkFBZ0IsOEJBQVUsSUFBSTtBQUNwQyxRQUFNLEVBQUMsT0FBTSxJQUFJO0FBQ2pCLFFBQU0sU0FBYztBQUFBLElBQ2xC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
@@ -0,0 +1,14 @@
1
+ import { Database } from 'arangojs';
2
+ import { ApiContext } from '../types/auth';
3
+ import { GroupEdgeType, GroupType, GroupUser } from '../types/groups';
4
+ export declare const getGroupList: (context: ApiContext, from: number, to: number) => Promise<GroupType[]>;
5
+ export declare const getGroupListByUser: (context: ApiContext, from: number, to: number) => Promise<GroupType[]>;
6
+ export declare const getGroupListByTags: (context: ApiContext, tags: string[], from: number, to: number) => Promise<GroupType[]>;
7
+ export declare const getGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
8
+ export declare const getGroupDetails: (context: ApiContext, groupId: string) => Promise<GroupType>;
9
+ export declare const createGroupEdge: (database: Database, userId: string, groupId: string) => Promise<GroupEdgeType>;
10
+ export declare const addGroup: (context: ApiContext, item: GroupType) => Promise<GroupType>;
11
+ export declare const updateGroup: (context: ApiContext, item: GroupType) => Promise<GroupType>;
12
+ export declare const deleteGroup: (context: ApiContext, itemId: string) => Promise<GroupType>;
13
+ export declare const getGroupsByReaction: (context: ApiContext, reaction: string) => Promise<GroupType[]>;
14
+ export declare const isGrouped: (database: Database, userId: string, groupId: string) => Promise<GroupUser>;