@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
@@ -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
- getTagsByOwner: () => getTagsByOwner,
41
- linkTags: () => linkTags,
42
- updateTag: () => updateTag
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 import_utils2 = require("../utils");
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, import_utils2.getLimit)(from, to);
55
- const filter = search.length ? `FILTER LIKE(t.name, "%${search}%")` : "";
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
- ${filter}
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()).then((list = []) => list).catch((error) => (0, import_utils2.logError)({
68
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
62
69
  action,
63
70
  category: eventCategory,
64
- label: "db_error"
65
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
71
+ value: import_error.ErrorTypes.DATABASE_ERROR
72
+ }, error, {}));
66
73
  };
67
- const getTagsByItem = (context, itemId, args) => {
68
- const action = "getList";
69
- const { from = 0, to = 30 } = args;
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, import_utils2.getLimit)(from, to);
72
- const formatItemId = (0, import_utils.parseArangoId)(itemId);
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() || []).catch((error) => (0, import_utils2.logError)({
84
+ return database.query(tagQuery).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
78
85
  action,
79
86
  category: eventCategory,
80
- label: "db_error"
81
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
87
+ value: import_error.ErrorTypes.DATABASE_ERROR
88
+ }, error, {}));
82
89
  };
83
- const getTagsByOwner = (context, args) => {
84
- const action = "getList";
85
- const { from = 0, id, to = 30 } = args;
90
+ const getTag = (context, tagId) => {
91
+ const action = "getTag";
86
92
  const { database } = context;
87
- const limit = (0, import_utils2.getLimit)(from, to);
93
+ const formatId = (0, import_utils.parseId)(tagId);
88
94
  const aqlQry = `FOR t IN tags
89
- FILTER t.userId == "${id}"
90
- ${limit.aql}
91
- SORT t.added
95
+ FILTER t._key == "${formatId}"
96
+ LIMIT 1
92
97
  RETURN t`;
93
- return database.query(aqlQry).then((cursor) => cursor.all()).then((list = []) => list).catch((error) => (0, import_utils2.logError)({
98
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
94
99
  action,
95
100
  category: eventCategory,
96
- label: "db_error"
97
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
101
+ value: import_error.ErrorTypes.DATABASE_ERROR
102
+ }, error, {}));
98
103
  };
99
- const getTag = (context, tagId) => {
100
- const action = "getItem";
104
+ const getTagsByName = (context, tagNames) => {
105
+ const action = "getTagsByName";
101
106
  const { database } = context;
102
- const formatId = JSON.stringify((0, import_utils.parseId)(tagId));
103
- const aqlQry = `FOR t IN tags
104
- FILTER t._key == ${formatId}
105
- LIMIT 1
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.next()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
114
+ return database.query(aqlQry).then((cursor) => cursor.all()).catch((error) => (0, import_analyticsUtils.logError)({
108
115
  action,
109
116
  category: eventCategory,
110
- label: "db_error"
111
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
117
+ value: import_error.ErrorTypes.DATABASE_ERROR
118
+ }, error, {}));
112
119
  };
113
- const addTag = (context, { tag }) => {
120
+ const addTag = (context, tag) => {
114
121
  const action = "addTag";
115
- const { database, session } = context;
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.toLowercase()}`, null);
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()).then((tag2 = {}) => tag2).catch((error) => (0, import_utils2.logError)({
134
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
136
135
  action,
137
136
  category: eventCategory,
138
- label: "db_error"
139
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
137
+ value: import_error.ErrorTypes.DATABASE_ERROR
138
+ }, error, {}));
140
139
  };
141
- const addTagToItem = async (context, { itemId, tagId }) => {
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 formatTagId = (0, import_utils.parseArangoId)(tagId);
146
- const formatItemId = (0, import_utils.parseArangoId)(itemId);
147
- const edgeId = (0, import_utils.createHash)(`isTagged-${formatTagId}-${formatItemId}`, null);
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 edge = { _from: formatTagId, _key: edgeId, _to: formatItemId, added };
150
- console.log({ edge });
151
- await edgeCollection.save(edge, { overwriteMode: "ignore", silent: true }).catch((error) => (0, import_utils2.logError)({
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
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
159
- const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${formatTagId}) RETURN t`;
160
- return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
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
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
165
+ },
166
+ value: import_error.ErrorTypes.DATABASE_ERROR
167
+ }, error, {}));
168
168
  };
169
- const updateTag = (context, item = {}) => {
170
- const action = "update";
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, id, name } = item;
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 formatId = (0, import_utils.parseId)(id);
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
- _key: tagId,
193
- added: now
183
+ _id: `tags/${newTagKey}`,
184
+ _key: newTagKey,
185
+ added: now,
186
+ tagBy: sessionId
194
187
  };
195
- const aqlQry = import_arangojs.aql`UPSERT {_key: ${tagId}}
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()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
192
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
200
193
  action,
201
194
  category: eventCategory,
202
- label: "db_error"
203
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
195
+ value: import_error.ErrorTypes.DATABASE_ERROR
196
+ }, error, {}));
204
197
  };
205
- const deleteTag = (context, { tagId }) => {
198
+ const deleteTag = async (context, tag) => {
206
199
  const action = "deleteTag";
207
- const { database, session } = context;
208
- const { userAccess } = session;
209
- if (userAccess < 3) {
210
- return (0, import_utils2.logException)({
211
- action,
212
- category: eventCategory,
213
- label: "db_error"
214
- }, session);
215
- }
216
- const formatTagId = (0, import_utils.parseId)(tagId);
217
- const aqlQry = import_arangojs.aql`FOR t IN tags
218
- FILTER t._key == ${formatTagId}
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()).then((tag = {}) => tag).catch((error) => (0, import_utils2.logError)({
214
+ return database.query(aqlQry).then((cursor) => cursor.next()).catch((error) => (0, import_analyticsUtils.logError)({
222
215
  action,
223
216
  category: eventCategory,
224
- label: "db_error"
225
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
217
+ value: import_error.ErrorTypes.DATABASE_ERROR
218
+ }, error, {}));
226
219
  };
227
- const deleteTagFromItem = async (context, { itemId, tagId }) => {
220
+ const deleteTagFromItem = async (context, { tagDocId, edgeDocId }) => {
228
221
  const action = "deleteTagFromItem";
229
222
  const { database } = context;
230
- const formatTagId = (0, import_utils.parseArangoId)(tagId);
231
- const formatItemId = (0, import_utils.parseArangoId)(itemId);
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 = { _key: edgeId };
235
- await edgeCollection.remove(edge, { silent: true }).catch((error) => (0, import_utils2.logError)({
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
- label: "db_error"
239
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
240
- const tagQuery = import_arangojs.aql`LET t = DOCUMENT(${tagId}) RETURN t`;
241
- return database.query(tagQuery).then((cursor) => cursor.next()).catch((error) => (0, import_utils2.logError)({
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
- label: "db_error"
245
- }, error, {}).then(() => null).catch((error2) => Promise.reject(error2)));
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 = (db, itemId, content) => {
294
- const tags = (0, import_words.default)(content, /#[a-zA-Z\d-]+/g).map((tag) => (0, import_utils.parseId)(tag));
295
- const edgeCollection = db.collection("isTagged");
296
- return edgeCollection.inEdges(itemId, {}).then((edges) => {
297
- if (edges.length) {
298
- return Promise.all(
299
- edges.map((edge) => {
300
- const { _key: edgeKey } = edge;
301
- const aqlQry = import_arangojs.aql`REMOVE {_key:${edgeKey}} IN isTagged`;
302
- return db.query(aqlQry).catch((error) => {
303
- throw error;
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
- getTagsByOwner,
333
- linkTags,
334
- updateTag
263
+ getTagsByName,
264
+ updateTag,
265
+ updateTagsInItem
335
266
  });
336
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvdGFncy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Y3JlYXRlSGFzaCwgcGFyc2VBcmFuZ29JZCwgcGFyc2VJZCwgcGFyc2VWYXJDaGFyfSBmcm9tICdAbmxhYnMvdXRpbHMnO1xuaW1wb3J0IHthcWwsIERhdGFiYXNlfSBmcm9tICdhcmFuZ29qcyc7XG5pbXBvcnQge0FxbFF1ZXJ5fSBmcm9tICdhcmFuZ29qcy9hcWwnO1xuaW1wb3J0IHtFZGdlQ29sbGVjdGlvbn0gZnJvbSAnYXJhbmdvanMvY29sbGVjdGlvbic7XG5pbXBvcnQge0FycmF5Q3Vyc29yfSBmcm9tICdhcmFuZ29qcy9jdXJzb3InO1xuaW1wb3J0IHdvcmRzIGZyb20gJ2xvZGFzaC93b3Jkcyc7XG5cbmltcG9ydCB7QXJhbmdvREJMaW1pdH0gZnJvbSAnLi4vdHlwZXMvYXJhbmdvZGInO1xuaW1wb3J0IHtBcGlDb250ZXh0fSBmcm9tICcuLi90eXBlcy9hdXRoJztcbmltcG9ydCB7VGFnVHlwZX0gZnJvbSAnLi4vdHlwZXMvdGFncyc7XG5pbXBvcnQge2dldExpbWl0LCBsb2dFcnJvciwgbG9nRXhjZXB0aW9ufSBmcm9tICcuLi91dGlscyc7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICd0YWdzJztcbmV4cG9ydCBpbnRlcmZhY2UgVGFnT3B0aW9ucyB7XG4gIHJlYWRvbmx5IHNlYXJjaD86IHN0cmluZztcbiAgcmVhZG9ubHkgZnJvbT86IG51bWJlcjtcbiAgcmVhZG9ubHkgdG8/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBjb25zdCBnZXRUYWdzID0gKFxuICBjb250ZXh0OiBBcGlDb250ZXh0LFxuICBvcHRpb25zPzogVGFnT3B0aW9uc1xuKTogUHJvbWlzZTxUYWdUeXBlW10+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0TGlzdCc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCB7c2VhcmNoID0gJycsIGZyb20gPSAwLCB0byA9IDMwfSA9IG9wdGlvbnM7XG4gIGNvbnN0IGxpbWl0OiBBcmFuZ29EQkxpbWl0ID0gZ2V0TGltaXQoZnJvbSwgdG8pO1xuICBjb25zdCBmaWx0ZXI6IHN0cmluZyA9IHNlYXJjaC5sZW5ndGggPyBgRklMVEVSIExJS0UodC5uYW1lLCBcIiUke3NlYXJjaH0lXCIpYCA6ICcnO1xuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgdCBJTiB0YWdzXG4gICAgJHtmaWx0ZXJ9XG4gICAgJHtsaW1pdC5hcWx9XG4gICAgU09SVCB0Lm5hbWVcbiAgICBSRVRVUk4gdGA7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKVxuICAgIC50aGVuKChsaXN0ID0gW10pID0+IGxpc3QpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRUYWdzQnlJdGVtID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIGl0ZW1JZDogc3RyaW5nLCAgYXJncyk6IFByb21pc2U8VGFnVHlwZVtdPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldExpc3QnO1xuICBjb25zdCB7ZnJvbSA9IDAsIHRvID0gMzB9ID0gYXJncztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGxpbWl0OiBBcmFuZ29EQkxpbWl0ID0gZ2V0TGltaXQoZnJvbSwgdG8pO1xuICBjb25zdCBmb3JtYXRJdGVtSWQ6IHN0cmluZyA9IHBhcnNlQXJhbmdvSWQoaXRlbUlkKTtcblxuICBjb25zdCB0YWdRdWVyeTogc3RyaW5nID0gYEZPUiB0LCBpdCBJTiBJTkJPVU5EIFwiJHtmb3JtYXRJdGVtSWR9XCIgaXNUYWdnZWRcbiAgICAke2xpbWl0LmFxbH1cbiAgICBTT1JUIGl0LmFkZGVkXG4gICAgUkVUVVJOIHRgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeSh0YWdRdWVyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpIHx8IFtdKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIHt9KS50aGVuKCgpID0+IG51bGwpLmNhdGNoKChlcnJvcikgPT4gUHJvbWlzZS5yZWplY3QoZXJyb3IpKSk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VGFnc0J5T3duZXIgPSAoY29udGV4dDogQXBpQ29udGV4dCwgYXJncyk6IFByb21pc2U8VGFnVHlwZVtdPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldExpc3QnO1xuICBjb25zdCB7ZnJvbSA9IDAsIGlkLCB0byA9IDMwfSA9IGFyZ3M7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBsaW1pdDogQXJhbmdvREJMaW1pdCA9IGdldExpbWl0KGZyb20sIHRvKTtcbiAgY29uc3QgYXFsUXJ5OiBzdHJpbmcgPSBgRk9SIHQgSU4gdGFnc1xuICAgIEZJTFRFUiB0LnVzZXJJZCA9PSBcIiR7aWR9XCJcbiAgICAke2xpbWl0LmFxbH1cbiAgICBTT1JUIHQuYWRkZWRcbiAgICBSRVRVUk4gdGA7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKVxuICAgIC50aGVuKChsaXN0ID0gW10pID0+IGxpc3QpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRUYWcgPSAoY29udGV4dDogQXBpQ29udGV4dCwgdGFnSWQ6IHN0cmluZyk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRJdGVtJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGZvcm1hdElkOiBzdHJpbmcgPSBKU09OLnN0cmluZ2lmeShwYXJzZUlkKHRhZ0lkKSk7XG4gIGNvbnN0IGFxbFFyeTogc3RyaW5nID0gYEZPUiB0IElOIHRhZ3NcbiAgICBGSUxURVIgdC5fa2V5ID09ICR7Zm9ybWF0SWR9XG4gICAgTElNSVQgMVxuICAgIFJFVFVSTiB0YDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKCh0YWcgPSB7fSkgPT4gdGFnKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIHt9KS50aGVuKCgpID0+IG51bGwpLmNhdGNoKChlcnJvcikgPT4gUHJvbWlzZS5yZWplY3QoZXJyb3IpKSk7XG59O1xuXG5leHBvcnQgY29uc3QgYWRkVGFnID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHt0YWd9KTogUHJvbWlzZTxUYWdUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2FkZFRhZyc7XG4gIGNvbnN0IHtkYXRhYmFzZSwgc2Vzc2lvbn0gPSBjb250ZXh0O1xuICBjb25zdCB7dXNlckFjY2Vzc30gPSBzZXNzaW9uO1xuXG4gIGlmKHVzZXJBY2Nlc3MgPCAzKSB7XG4gICAgcmV0dXJuIGxvZ0V4Y2VwdGlvbih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgc2Vzc2lvbik7XG4gIH1cblxuICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG4gIGNvbnN0IHtkZXNjcmlwdGlvbiwgbmFtZX0gPSB0YWc7XG4gIGNvbnN0IGZvcm1hdElkOiBzdHJpbmcgPSBjcmVhdGVIYXNoKGB0YWctJHtuYW1lLnRvTG93ZXJjYXNlKCl9YCwgbnVsbCk7XG5cbiAgY29uc3QgaW5zZXJ0OiBhbnkgPSB7XG4gICAgX2tleTogZm9ybWF0SWQsXG4gICAgYWRkZWQ6IG5vdyxcbiAgICBkZXNjcmlwdGlvbjogcGFyc2VWYXJDaGFyKGRlc2NyaXB0aW9uLCA2NCksXG4gICAgbW9kaWZpZWQ6IG5vdyxcbiAgICBuYW1lOiBwYXJzZVZhckNoYXIobmFtZSwgMzIpXG4gIH07XG5cbiAgY29uc3QgYXFsUXJ5OiBBcWxRdWVyeSA9IGFxbGBJTlNFUlQgJHtpbnNlcnR9IElOIHRhZ3MgUkVUVVJOIE5FV2A7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KGFxbFFyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAudGhlbigodGFnOiBUYWdUeXBlID0ge30pID0+IHRhZylcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJ1xuICAgIH0sIGVycm9yLCB7fSkudGhlbigoKSA9PiBudWxsKS5jYXRjaCgoZXJyb3IpID0+IFByb21pc2UucmVqZWN0KGVycm9yKSkpO1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZFRhZ1RvSXRlbSA9IGFzeW5jIChjb250ZXh0OiBBcGlDb250ZXh0LCB7aXRlbUlkLCB0YWdJZH0pOiBQcm9taXNlPFRhZ1R5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnYWRkVGFnVG9JdGVtJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IGFkZGVkOiBudW1iZXIgPSBEYXRlLm5vdygpO1xuICBjb25zdCBmb3JtYXRUYWdJZDogc3RyaW5nID0gcGFyc2VBcmFuZ29JZCh0YWdJZCk7XG4gIGNvbnN0IGZvcm1hdEl0ZW1JZDogc3RyaW5nID0gcGFyc2VBcmFuZ29JZChpdGVtSWQpO1xuICBjb25zdCBlZGdlSWQ6IHN0cmluZyA9IGNyZWF0ZUhhc2goYGlzVGFnZ2VkLSR7Zm9ybWF0VGFnSWR9LSR7Zm9ybWF0SXRlbUlkfWAsIG51bGwpO1xuICBjb25zdCBlZGdlQ29sbGVjdGlvbjogRWRnZUNvbGxlY3Rpb24gPSBkYXRhYmFzZS5jb2xsZWN0aW9uKCdpc1RhZ2dlZCcpO1xuICBjb25zdCBlZGdlOiBhbnkgPSB7X2Zyb206IGZvcm1hdFRhZ0lkLCBfa2V5OiBlZGdlSWQsIF90bzogZm9ybWF0SXRlbUlkLCBhZGRlZH07XG4gIGNvbnNvbGUubG9nKHtlZGdlfSk7XG4gIGF3YWl0IGVkZ2VDb2xsZWN0aW9uLnNhdmUoZWRnZSwge292ZXJ3cml0ZU1vZGU6ICdpZ25vcmUnLCBzaWxlbnQ6IHRydWV9KVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InLFxuICAgICAgcGFyYW1zOiB7XG4gICAgICAgIGVkZ2VcbiAgICAgIH1cbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcblxuXG4gIGNvbnN0IHRhZ1F1ZXJ5OiBBcWxRdWVyeSA9IGFxbGBMRVQgdCA9IERPQ1VNRU5UKCR7Zm9ybWF0VGFnSWR9KSBSRVRVUk4gdGA7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KHRhZ1F1ZXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InLFxuICAgICAgcGFyYW1zOiB7XG4gICAgICAgIGVkZ2VcbiAgICAgIH1cbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCB1cGRhdGVUYWcgPSAoY29udGV4dDogQXBpQ29udGV4dCwgaXRlbTogVGFnVHlwZSA9IHt9KTogUHJvbWlzZTxUYWdUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ3VwZGF0ZSc7XG4gIGNvbnN0IHtkYXRhYmFzZSwgc2Vzc2lvbn0gPSBjb250ZXh0O1xuICBjb25zdCB7dXNlckFjY2Vzc30gPSBzZXNzaW9uO1xuXG4gIGlmKHVzZXJBY2Nlc3MgPCAzKSB7XG4gICAgcmV0dXJuIGxvZ0V4Y2VwdGlvbih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgc2Vzc2lvbik7XG4gIH1cblxuICBjb25zdCBub3c6IG51bWJlciA9IERhdGUubm93KCk7XG4gIGNvbnN0IHtkZXNjcmlwdGlvbiwgaWQsIG5hbWV9ID0gaXRlbTtcbiAgY29uc3QgZm9ybWF0TmFtZTogc3RyaW5nID0gcGFyc2VWYXJDaGFyKG5hbWUsIDMyKTtcblxuICBjb25zdCB1cGRhdGU6IFRhZ1R5cGUgPSB7XG4gICAgZGVzY3JpcHRpb246IHBhcnNlVmFyQ2hhcihkZXNjcmlwdGlvbiwgNjQpLFxuICAgIG1vZGlmaWVkOiBub3csXG4gICAgbmFtZTogZm9ybWF0TmFtZVxuICB9O1xuXG4gIGNvbnN0IGZvcm1hdElkOiBzdHJpbmcgPSBwYXJzZUlkKGlkKTtcbiAgY29uc3QgdGFnSWQ6IHN0cmluZyA9ICFmb3JtYXRJZCA/IGNyZWF0ZUhhc2goYHRhZy0ke2Zvcm1hdE5hbWUudG9Mb3dlckNhc2UoKX1gLCBudWxsKSA6IGZvcm1hdElkO1xuXG4gIGNvbnN0IGluc2VydDogVGFnVHlwZSA9IHtcbiAgICAuLi51cGRhdGUsXG4gICAgX2tleTogdGFnSWQsXG4gICAgYWRkZWQ6IG5vd1xuICB9O1xuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYFVQU0VSVCB7X2tleTogJHt0YWdJZH19XG4gICAgSU5TRVJUICR7aW5zZXJ0fVxuICAgIFVQREFURSAke3VwZGF0ZX1cbiAgICBJTiB0YWdzIFJFVFVSTiBORVdgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHRhZyA9IHt9KSA9PiB0YWcpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCBkZWxldGVUYWcgPSAoY29udGV4dDogQXBpQ29udGV4dCwge3RhZ0lkfSk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdkZWxldGVUYWcnO1xuICBjb25zdCB7ZGF0YWJhc2UsIHNlc3Npb259ID0gY29udGV4dDtcbiAgY29uc3Qge3VzZXJBY2Nlc3N9ID0gc2Vzc2lvbjtcblxuICBpZih1c2VyQWNjZXNzIDwgMykge1xuICAgIHJldHVybiBsb2dFeGNlcHRpb24oe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBsYWJlbDogJ2RiX2Vycm9yJ1xuICAgIH0sIHNlc3Npb24pO1xuICB9XG5cbiAgY29uc3QgZm9ybWF0VGFnSWQ6IHN0cmluZyA9IHBhcnNlSWQodGFnSWQpO1xuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiB0IElOIHRhZ3NcbiAgICBGSUxURVIgdC5fa2V5ID09ICR7Zm9ybWF0VGFnSWR9XG4gICAgUkVNT1ZFIHQgSU4gdGFnc1xuICAgIFJFVFVSTiBPTERgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLnRoZW4oKHRhZzogVGFnVHlwZSA9IHt9KSA9PiB0YWcpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCBkZWxldGVUYWdGcm9tSXRlbSA9IGFzeW5jIChjb250ZXh0OiBBcGlDb250ZXh0LCB7aXRlbUlkLCB0YWdJZH0pOiBQcm9taXNlPFRhZ1R5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZGVsZXRlVGFnRnJvbUl0ZW0nO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0VGFnSWQ6IHN0cmluZyA9IHBhcnNlQXJhbmdvSWQodGFnSWQpO1xuICBjb25zdCBmb3JtYXRJdGVtSWQ6IHN0cmluZyA9IHBhcnNlQXJhbmdvSWQoaXRlbUlkKTtcbiAgY29uc3QgZWRnZUlkOiBzdHJpbmcgPSBjcmVhdGVIYXNoKGBpc1RhZ2dlZC0ke2Zvcm1hdFRhZ0lkfS0ke2Zvcm1hdEl0ZW1JZH1gLCBudWxsKTtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb246IEVkZ2VDb2xsZWN0aW9uID0gZGF0YWJhc2UuY29sbGVjdGlvbignaXNUYWdnZWQnKTtcbiAgY29uc3QgZWRnZTogYW55ID0ge19rZXk6IGVkZ2VJZH07XG5cbiAgYXdhaXQgZWRnZUNvbGxlY3Rpb24ucmVtb3ZlKGVkZ2UsIHtzaWxlbnQ6IHRydWV9KVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIGxhYmVsOiAnZGJfZXJyb3InXG4gICAgfSwgZXJyb3IsIHt9KS50aGVuKCgpID0+IG51bGwpLmNhdGNoKChlcnJvcikgPT4gUHJvbWlzZS5yZWplY3QoZXJyb3IpKSk7XG5cbiAgY29uc3QgdGFnUXVlcnk6IEFxbFF1ZXJ5ID0gYXFsYExFVCB0ID0gRE9DVU1FTlQoJHt0YWdJZH0pIFJFVFVSTiB0YDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkodGFnUXVlcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgbGFiZWw6ICdkYl9lcnJvcidcbiAgICB9LCBlcnJvciwge30pLnRoZW4oKCkgPT4gbnVsbCkuY2F0Y2goKGVycm9yKSA9PiBQcm9taXNlLnJlamVjdChlcnJvcikpKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVUYWcgPSAoZGI6IERhdGFiYXNlLCB0YWdOYW1lOiBzdHJpbmcpOiBQcm9taXNlPFRhZ1R5cGU+ID0+IHtcbiAgY29uc3QgdGFnSWQ6IHN0cmluZyA9IGNyZWF0ZUhhc2goYHRhZy0ke3RhZ05hbWUudG9Mb3dlckNhc2UoKX1gLCBudWxsKTtcbiAgY29uc3QgaW5zZXJ0OiBUYWdUeXBlID0ge1xuICAgIF9rZXk6IHRhZ0lkLFxuICAgIGFkZGVkOiBEYXRlLm5vdygpLFxuICAgIG5hbWU6IHRhZ05hbWVcbiAgfTtcblxuICBjb25zdCBhcWxRcnkgPSBhcWxgVVBTRVJUIHtfa2V5OiAke3RhZ0lkfX1cbiAgICBJTlNFUlQgJHtpbnNlcnR9XG4gICAgVVBEQVRFIHt9XG4gICAgSU4gdGFncyBSRVRVUk4gTkVXYDtcblxuICByZXR1cm4gZGIucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC50aGVuKCh0YWcgPSB7fSkgPT4gdGFnKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiB7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVUYWdFZGdlID0gKGRiOiBEYXRhYmFzZSwgdGFnOiBUYWdUeXBlLCBpdGVtSWQ6IHN0cmluZyk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCBlZGdlQ29sbGVjdGlvbiA9IGRiLmNvbGxlY3Rpb24oJ2lzVGFnZ2VkJyk7XG4gIGNvbnN0IHtfaWQ6IHRhZ0lkfSA9IHRhZztcbiAgY29uc3QgZWRnZUlkID0gY3JlYXRlSGFzaChgaXNUYWdnZWQtJHt0YWdJZH0tJHtpdGVtSWR9YCk7XG4gIGNvbnN0IHR5cGU6IHN0cmluZyA9IGl0ZW1JZC5zcGxpdCgnLycpWzBdO1xuICBjb25zdCBlZGdlOiBhbnkgPSB7XG4gICAgX2Zyb206IHRhZ0lkLFxuICAgIF9rZXk6IGVkZ2VJZCxcbiAgICBfdG86IGl0ZW1JZCxcbiAgICBhZGRlZDogRGF0ZS5ub3coKSxcbiAgICB0eXBlXG4gIH07XG5cbiAgcmV0dXJuIGVkZ2VDb2xsZWN0aW9uLnNhdmUoZWRnZSwge3JldHVybk5ldzogdHJ1ZX0pLnRoZW4oKCkgPT4gdGFnKTtcbn07XG5cbmV4cG9ydCBjb25zdCBsaW5rVGFncyA9IGFzeW5jIChkYjogRGF0YWJhc2UsIHRhZ05hbWVzOiBzdHJpbmdbXSwgaXRlbUlkOiBzdHJpbmcpOiBQcm9taXNlPFRhZ1R5cGVbXT4gPT4ge1xuICBjb25zdCBlZGdlQ29sbGVjdGlvbiA9IGRiLmNvbGxlY3Rpb24oJ2lzVGFnZ2VkJyk7XG4gIGNvbnN0IGVkZ2VzOiBhbnkgPSBhd2FpdCBlZGdlQ29sbGVjdGlvbi5pbkVkZ2VzKGl0ZW1JZCwge30pO1xuXG4gIGNvbnNvbGUubG9nKHtlZGdlc30pO1xuICBpZihlZGdlcy5sZW5ndGgpIHtcbiAgICBhd2FpdCBQcm9taXNlLmFsbChcbiAgICAgIGVkZ2VzLm1hcCgoZWRnZSkgPT4ge1xuICAgICAgICBjb25zdCB7X2tleTogZWRnZUtleX0gPSBlZGdlO1xuICAgICAgICBjb25zdCBhcWxRcnkgPSBhcWxgUkVNT1ZFIHtfa2V5OiR7ZWRnZUtleX19IElOIGlzVGFnZ2VkYDtcbiAgICAgICAgcmV0dXJuIGRiLnF1ZXJ5KGFxbFFyeSk7XG4gICAgICB9KVxuICAgICk7XG4gIH1cblxuICByZXR1cm4gUHJvbWlzZS5hbGwodGFnTmFtZXMubWFwKCh0YWdOYW1lOiBzdHJpbmcpID0+IGNyZWF0ZVRhZyhkYiwgdGFnTmFtZSlcbiAgICAudGhlbigodGFnOiBUYWdUeXBlKSA9PiBjcmVhdGVUYWdFZGdlKGRiLCB0YWcsIGl0ZW1JZCkpKVxuICApO1xufTtcblxuZXhwb3J0IGNvbnN0IGV4dHJhY3RUYWdzID0gKGRiOiBEYXRhYmFzZSwgaXRlbUlkLCBjb250ZW50KTogUHJvbWlzZTxUYWdUeXBlW10+ID0+IHtcbiAgY29uc3QgdGFnczogc3RyaW5nW10gPSB3b3Jkcyhjb250ZW50LCAvI1thLXpBLVpcXGQtXSsvZykubWFwKCh0YWc6IHN0cmluZykgPT4gcGFyc2VJZCh0YWcpKTtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb24gPSBkYi5jb2xsZWN0aW9uKCdpc1RhZ2dlZCcpO1xuXG4gIHJldHVybiBlZGdlQ29sbGVjdGlvbi5pbkVkZ2VzKGl0ZW1JZCwge30pXG4gICAgLnRoZW4oKGVkZ2VzOiBhbnkpID0+IHtcbiAgICAgIGlmKGVkZ2VzLmxlbmd0aCkge1xuICAgICAgICAvLyBSZW1vdmUgbGlua2VkIGVkZ2VzXG4gICAgICAgIHJldHVybiBQcm9taXNlLmFsbChcbiAgICAgICAgICBlZGdlcy5tYXAoKGVkZ2UpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHtfa2V5OiBlZGdlS2V5fSA9IGVkZ2U7XG4gICAgICAgICAgICBjb25zdCBhcWxRcnkgPSBhcWxgUkVNT1ZFIHtfa2V5OiR7ZWRnZUtleX19IElOIGlzVGFnZ2VkYDtcbiAgICAgICAgICAgIHJldHVybiBkYi5xdWVyeShhcWxRcnkpLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9KSlcbiAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICBpZih0YWdzLmxlbmd0aCkge1xuICAgICAgICAgICAgICAvLyBDcmVhdGUgdGFnc1xuICAgICAgICAgICAgICByZXR1cm4gbGlua1RhZ3MoZGIsIHRhZ3MsIGl0ZW1JZCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gW107XG4gICAgICAgICAgfSk7XG4gICAgICB9IGVsc2UgaWYodGFncy5sZW5ndGgpIHtcbiAgICAgICAgLy8gQ3JlYXRlIHRhZ3NcbiAgICAgICAgcmV0dXJuIGxpbmtUYWdzKGRiLCB0YWdzLCBpdGVtSWQpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIFtdO1xuICAgIH0pXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IHtcbiAgICAgIHRocm93IGVycm9yO1xuICAgIH0pO1xufTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSxtQkFBK0Q7QUFDL0Qsc0JBQTRCO0FBSTVCLG1CQUFrQjtBQUtsQixJQUFBQSxnQkFBK0M7QUFFL0MsTUFBTSxnQkFBd0I7QUFPdkIsTUFBTSxVQUFVLENBQ3JCLFNBQ0EsWUFDdUI7QUFDdkIsUUFBTSxTQUFpQjtBQUN2QixRQUFNLEVBQUMsU0FBUSxJQUFJO0FBQ25CLFFBQU0sRUFBQyxTQUFTLElBQUksT0FBTyxHQUFHLEtBQUssR0FBRSxJQUFJO0FBQ3pDLFFBQU0sWUFBdUIsd0JBQVMsTUFBTSxFQUFFO0FBQzlDLFFBQU0sU0FBaUIsT0FBTyxTQUFTLHlCQUF5QixNQUFNLFFBQVE7QUFDOUUsUUFBTSxTQUFpQjtBQUFBLE1BQ25CLE1BQU07QUFBQSxNQUNOLE1BQU0sR0FBRztBQUFBO0FBQUE7QUFJYixTQUFPLFNBQVMsTUFBTSxNQUFNLEVBQ3pCLEtBQUssQ0FBQyxXQUF3QixPQUFPLElBQUksQ0FBQyxFQUMxQyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sSUFBSSxFQUN4QixNQUFNLENBQUMsY0FBaUIsd0JBQVM7QUFB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LENBQUMsQ0FBQztBQUUxRCxVQUFRLElBQUksRUFBQyxNQUFLLENBQUM7QUFDbkIsTUFBRyxNQUFNLFFBQVE7QUFDZixVQUFNLFFBQVE7QUFBQSxNQUNaLE1BQU0sSUFBSSxDQUFDLFNBQVM7QUFDbEIsY0FBTSxFQUFDLE1BQU0sUUFBTyxJQUFJO0FBQ3hCLGNBQU0sU0FBUyxtQ0FBbUIsT0FBTztBQUN6QyxlQUFPLEdBQUcsTUFBTSxNQUFNO0FBQUEsTUFDeEIsQ0FBQztBQUFBLElBQ0g7QUFBQSxFQUNGO0FBRUEsU0FBTyxRQUFRO0FBQUEsSUFBSSxTQUFTLElBQUksQ0FBQyxZQUFvQixVQUFVLElBQUksT0FBTyxFQUN2RSxLQUFLLENBQUMsUUFBaUIsY0FBYyxJQUFJLEtBQUssTUFBTSxDQUFDLENBQUM7QUFBQSxFQUN6RDtBQUNGO0FBRU8sTUFBTSxjQUFjLENBQUMsSUFBYyxRQUFRLFlBQWdDO0FBQ2hGLFFBQU0sV0FBaUIsYUFBQUUsU0FBTSxTQUFTLGdCQUFnQixFQUFFLElBQUksQ0FBQyxZQUFnQixzQkFBUSxHQUFHLENBQUM7QUFDekYsUUFBTSxpQkFBaUIsR0FBRyxXQUFXLFVBQVU7QUFFL0MsU0FBTyxlQUFlLFFBQVEsUUFBUSxDQUFDLENBQUMsRUFDckMsS0FBSyxDQUFDLFVBQWU7QUFDcEIsUUFBRyxNQUFNLFFBQVE7QUFFZixhQUFPLFFBQVE7QUFBQSxRQUNiLE1BQU0sSUFBSSxDQUFDLFNBQVM7QUFDbEIsZ0JBQU0sRUFBQyxNQUFNLFFBQU8sSUFBSTtBQUN4QixnQkFBTSxTQUFTLG1DQUFtQixPQUFPO0FBQ3pDLGlCQUFPLEdBQUcsTUFBTSxNQUFNLEVBQUUsTUFBTSxDQUFDLFVBQWlCO0FBQzlDLGtCQUFNO0FBQUEsVUFDUixDQUFDO0FBQUEsUUFDSCxDQUFDO0FBQUEsTUFBQyxFQUNELEtBQUssTUFBTTtBQUNWLFlBQUcsS0FBSyxRQUFRO0FBRWQsaUJBQU8sU0FBUyxJQUFJLE1BQU0sTUFBTTtBQUFBLFFBQ2xDO0FBQ0EsZUFBTyxDQUFDO0FBQUEsTUFDVixDQUFDO0FBQUEsSUFDTCxXQUFVLEtBQUssUUFBUTtBQUVyQixhQUFPLFNBQVMsSUFBSSxNQUFNLE1BQU07QUFBQSxJQUNsQztBQUNBLFdBQU8sQ0FBQztBQUFBLEVBQ1YsQ0FBQyxFQUNBLE1BQU0sQ0FBQyxVQUFpQjtBQUN2QixVQUFNO0FBQUEsRUFDUixDQUFDO0FBQ0w7IiwKICAibmFtZXMiOiBbImltcG9ydF91dGlscyIsICJlcnJvciIsICJ0YWciLCAid29yZHMiXQp9Cg==
267
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2FjdGlvbnMvdGFncy50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTktUHJlc2VudCwgTml0cm9nZW4gTGFicywgSW5jLlxuICogQ29weXJpZ2h0cyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIExpY2Vuc2UuIFNlZSB0aGUgYWNjb21wYW55aW5nIExJQ0VOU0UgZmlsZSBmb3IgdGVybXMuXG4gKi9cbmltcG9ydCB7Y3JlYXRlSGFzaCwgcGFyc2VBcmFuZ29JZCwgcGFyc2VJZCwgcGFyc2VWYXJDaGFyfSBmcm9tICdAbmxhYnMvdXRpbHMnO1xuaW1wb3J0IHthcWx9IGZyb20gJ2FyYW5nb2pzJztcbmltcG9ydCB7QXFsUXVlcnl9IGZyb20gJ2FyYW5nb2pzL2FxbCc7XG5pbXBvcnQge0VkZ2VDb2xsZWN0aW9ufSBmcm9tICdhcmFuZ29qcy9jb2xsZWN0aW9uJztcbmltcG9ydCB7QXJyYXlDdXJzb3J9IGZyb20gJ2FyYW5nb2pzL2N1cnNvcic7XG5pbXBvcnQge0VkZ2V9IGZyb20gJ2FyYW5nb2pzL2RvY3VtZW50cyc7XG5pbXBvcnQgd29yZHMgZnJvbSAnbG9kYXNoL3dvcmRzJztcblxuaW1wb3J0IHtwYXJzZVRhZ30gZnJvbSAnLi4vYWRhcHRlcnMvdGFnQWRhcHRlcic7XG5pbXBvcnQgdHlwZSB7QXJhbmdvRGJMaW1pdH0gZnJvbSAnLi4vdHlwZXMvYXJhbmdvZGInO1xuaW1wb3J0IHR5cGUge0FwaUNvbnRleHR9IGZyb20gJy4uL3R5cGVzL2F1dGgnO1xuaW1wb3J0IHtFcnJvclR5cGVzfSBmcm9tICcuLi90eXBlcy9lcnJvcic7XG5pbXBvcnQgdHlwZSB7VGFnVHlwZX0gZnJvbSAnLi4vdHlwZXMvdGFncyc7XG5pbXBvcnQge2xvZ0Vycm9yfSBmcm9tICcuLi91dGlscy9hbmFseXRpY3NVdGlscyc7XG5pbXBvcnQge2dldERvY0lkLCBnZXRMaW1pdH0gZnJvbSAnLi4vdXRpbHMvYXJhbmdvZGJVdGlscyc7XG5cbmNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICd0YWdzJztcbmV4cG9ydCBpbnRlcmZhY2UgVGFnT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGZyb20/OiBudW1iZXI7XG4gIHJlYWRvbmx5IHNlYXJjaD86IHN0cmluZztcbiAgcmVhZG9ubHkgdG8/OiBudW1iZXI7XG4gIHJlYWRvbmx5IHVzZXJJZD86IHN0cmluZztcbn1cblxuZXhwb3J0IGNvbnN0IGdldFRhZ3MgPSAoXG4gIGNvbnRleHQ6IEFwaUNvbnRleHQsXG4gIG9wdGlvbnM6IFRhZ09wdGlvbnMgPSB7fVxuKTogUHJvbWlzZTxUYWdUeXBlW10+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnZ2V0TGlzdCc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCB7c2VhcmNoID0gJycsIGZyb20gPSAwLCB0byA9IDMwLCB1c2VySWR9ID0gb3B0aW9ucztcbiAgY29uc3QgbGltaXQ6IEFyYW5nb0RiTGltaXQgPSBnZXRMaW1pdChmcm9tLCB0byk7XG5cbiAgY29uc3QgZmlsdGVyczogc3RyaW5nW10gPSBbXTtcblxuICBpZihzZWFyY2gpIHtcbiAgICBmaWx0ZXJzLnB1c2goYExJS0UodC5uYW1lLCBcIiUke3NlYXJjaH0lXCIpYCk7XG4gIH1cblxuICBpZih1c2VySWQpIHtcbiAgICBmaWx0ZXJzLnB1c2goYHQudXNlcklkID09IFwiJHt1c2VySWR9XCJgKTtcbiAgfVxuXG4gIGNvbnN0IGFxbFFyeTogc3RyaW5nID0gYEZPUiB0IElOIHRhZ3NcbiAgICBGSUxURVIgJHtmaWx0ZXJzLmpvaW4oJyB8fCAnKX1cbiAgICAke2xpbWl0LmFxbH1cbiAgICBTT1JUIHQubmFtZVxuICAgIFJFVFVSTiB0YDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgdmFsdWU6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwge30pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRUYWdzQnlJdGVtID0gKFxuICBjb250ZXh0OiBBcGlDb250ZXh0LFxuICBpdGVtRG9jSWQ6IHN0cmluZyxcbiAgb3B0aW9uczogVGFnT3B0aW9ucyA9IHt9XG4pOiBQcm9taXNlPFRhZ1R5cGVbXT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRUYWdzQnlJdGVtJztcbiAgY29uc3Qge2Zyb20gPSAwLCB0byA9IDMwfSA9IG9wdGlvbnM7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBsaW1pdDogQXJhbmdvRGJMaW1pdCA9IGdldExpbWl0KGZyb20sIHRvKTtcbiAgY29uc3QgZm9ybWF0SXRlbUlkOiBzdHJpbmcgPSBwYXJzZUFyYW5nb0lkKGl0ZW1Eb2NJZCk7XG4gIGNvbnN0IHRhZ1F1ZXJ5OiBzdHJpbmcgPSBgRk9SIHQsIGl0IElOIElOQk9VTkQgXCIke2Zvcm1hdEl0ZW1JZH1cIiBpc1RhZ2dlZFxuICAgICR7bGltaXQuYXFsfVxuICAgIFNPUlQgaXQuYWRkZWRcbiAgICBSRVRVUk4gdGA7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KHRhZ1F1ZXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IuYWxsKCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgdmFsdWU6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwge30pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRUYWcgPSAoY29udGV4dDogQXBpQ29udGV4dCwgdGFnSWQ6IHN0cmluZyk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdnZXRUYWcnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0SWQ6IHN0cmluZyA9IHBhcnNlSWQodGFnSWQpO1xuICBjb25zdCBhcWxRcnk6IHN0cmluZyA9IGBGT1IgdCBJTiB0YWdzXG4gICAgRklMVEVSIHQuX2tleSA9PSBcIiR7Zm9ybWF0SWR9XCJcbiAgICBMSU1JVCAxXG4gICAgUkVUVVJOIHRgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5uZXh0KCkpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgdmFsdWU6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwge30pKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRUYWdzQnlOYW1lID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHRhZ05hbWVzOiBzdHJpbmdbXSk6IFByb21pc2U8VGFnVHlwZVtdPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2dldFRhZ3NCeU5hbWUnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0VGFnTmFtZXMgPSB0YWdOYW1lc1xuICAgIC5tYXAoKHRhZ05hbWUpID0+IHBhcnNlVmFyQ2hhcih0YWdOYW1lLCAzMikpXG4gICAgLmZpbHRlcigodGFnTmFtZSkgPT4gISF0YWdOYW1lKTtcblxuICBpZighZm9ybWF0VGFnTmFtZXMubGVuZ3RoKSB7XG4gICAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShbXSk7XG4gIH1cblxuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYEZPUiB0IElOIHRhZ3NcbiAgICBGSUxURVIgUE9TSVRJT04oJHtKU09OLnN0cmluZ2lmeShmb3JtYXRUYWdOYW1lcyl9LCB0Lm5hbWUpXG4gICAgUkVUVVJOIHRgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeShhcWxRcnkpXG4gICAgLnRoZW4oKGN1cnNvcjogQXJyYXlDdXJzb3IpID0+IGN1cnNvci5hbGwoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICB2YWx1ZTogRXJyb3JUeXBlcy5EQVRBQkFTRV9FUlJPUlxuICAgIH0sIGVycm9yLCB7fSkpO1xufTtcblxuZXhwb3J0IGNvbnN0IGFkZFRhZyA9IChjb250ZXh0OiBBcGlDb250ZXh0LCB0YWc6IFRhZ1R5cGUpOiBQcm9taXNlPFRhZ1R5cGU+ID0+IHtcbiAgY29uc3QgYWN0aW9uOiBzdHJpbmcgPSAnYWRkVGFnJztcbiAgY29uc3Qge2RhdGFiYXNlfSA9IGNvbnRleHQ7XG4gIGNvbnN0IG5vdzogbnVtYmVyID0gRGF0ZS5ub3coKTtcbiAgY29uc3Qge2Rlc2NyaXB0aW9uLCBuYW1lfSA9IHBhcnNlVGFnKHRhZyk7XG4gIGNvbnN0IGZvcm1hdElkOiBzdHJpbmcgPSBjcmVhdGVIYXNoKGB0YWctJHtuYW1lLnRvTG93ZXJDYXNlKCl9YCwgbnVsbCk7XG4gIGNvbnN0IGluc2VydDogYW55ID0ge1xuICAgIF9rZXk6IGZvcm1hdElkLFxuICAgIGFkZGVkOiBub3csXG4gICAgZGVzY3JpcHRpb246IHBhcnNlVmFyQ2hhcihkZXNjcmlwdGlvbiwgNjQpLFxuICAgIG1vZGlmaWVkOiBub3csXG4gICAgbmFtZTogcGFyc2VWYXJDaGFyKG5hbWUsIDMyKVxuICB9O1xuICBjb25zdCBhcWxRcnk6IEFxbFF1ZXJ5ID0gYXFsYElOU0VSVCAke2luc2VydH0gSU4gdGFncyBSRVRVUk4gTkVXYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIHZhbHVlOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIHt9KSk7XG59O1xuXG5leHBvcnQgY29uc3QgYWRkVGFnVG9JdGVtID0gYXN5bmMgKFxuICBjb250ZXh0OiBBcGlDb250ZXh0LFxuICB7aXRlbURvY0lkLCB0YWdCeSwgdGFnRG9jSWR9OiB7aXRlbURvY0lkOiBzdHJpbmcsIHRhZ0J5Pzogc3RyaW5nLCB0YWdEb2NJZDogc3RyaW5nfVxuKTogUHJvbWlzZTxUYWdUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbjogc3RyaW5nID0gJ2FkZFRhZ1RvSXRlbSc7XG4gIGNvbnN0IHtkYXRhYmFzZSwgc2Vzc2lvbjoge3VzZXJJZDogc2Vzc2lvbklkfX0gPSBjb250ZXh0O1xuICBjb25zdCBhZGRlZDogbnVtYmVyID0gRGF0ZS5ub3coKTtcbiAgY29uc3QgZm9ybWF0VGFnRG9jSWQ6IHN0cmluZyA9IHBhcnNlQXJhbmdvSWQodGFnRG9jSWQpO1xuICBjb25zdCBmb3JtYXRJdGVtRG9jSWQ6IHN0cmluZyA9IHBhcnNlQXJhbmdvSWQoaXRlbURvY0lkKTtcbiAgY29uc3QgZWRnZUlkOiBzdHJpbmcgPSBjcmVhdGVIYXNoKGBpc1RhZ2dlZC0ke2Zvcm1hdFRhZ0RvY0lkfS0ke2Zvcm1hdEl0ZW1Eb2NJZH1gLCBudWxsKTtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb246IEVkZ2VDb2xsZWN0aW9uID0gZGF0YWJhc2UuY29sbGVjdGlvbignaXNUYWdnZWQnKTtcbiAgY29uc3QgdHlwZTogc3RyaW5nID0gZm9ybWF0SXRlbURvY0lkLnNwbGl0KCcvJylbMF07XG4gIGNvbnN0IGZvcm1hdFRhZ0J5OiBzdHJpbmcgPSBwYXJzZUlkKHRhZ0J5KSB8fCBzZXNzaW9uSWQ7XG4gIGNvbnN0IGVkZ2U6IEVkZ2UgPSB7X2Zyb206IGZvcm1hdFRhZ0RvY0lkLCBfa2V5OiBlZGdlSWQsIF90bzogZm9ybWF0SXRlbURvY0lkLCBhZGRlZCwgdGFnQnk6IGZvcm1hdFRhZ0J5LCB0eXBlfTtcblxuICBhd2FpdCBlZGdlQ29sbGVjdGlvbi5zYXZlKGVkZ2UsIHtvdmVyd3JpdGVNb2RlOiAnaWdub3JlJywgcmV0dXJuTmV3OiB0cnVlLCBzaWxlbnQ6IHRydWV9KVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIHBhcmFtczoge1xuICAgICAgICBlZGdlXG4gICAgICB9LFxuICAgICAgdmFsdWU6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwge30pKTtcblxuICBjb25zdCB0YWdRdWVyeTogQXFsUXVlcnkgPSBhcWxgTEVUIHQgPSBET0NVTUVOVCgke2Zvcm1hdFRhZ0RvY0lkfSkgUkVUVVJOIHRgO1xuXG4gIHJldHVybiBkYXRhYmFzZS5xdWVyeSh0YWdRdWVyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLm5leHQoKSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICBwYXJhbXM6IHtcbiAgICAgICAgZWRnZVxuICAgICAgfSxcbiAgICAgIHZhbHVlOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIHt9KSk7XG59O1xuXG5leHBvcnQgY29uc3QgdXBkYXRlVGFnID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHRhZzogVGFnVHlwZSk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICd1cGRhdGVUYWcnO1xuICBjb25zdCB7ZGF0YWJhc2UsIHNlc3Npb246IHt1c2VySWQ6IHNlc3Npb25JZH19ID0gY29udGV4dDtcbiAgY29uc3Qgbm93OiBudW1iZXIgPSBEYXRlLm5vdygpO1xuICBjb25zdCB7ZGVzY3JpcHRpb24sIG5hbWUsIHRhZ0lkfSA9IHBhcnNlVGFnKHRhZyk7XG4gIGNvbnN0IGZvcm1hdE5hbWU6IHN0cmluZyA9IHBhcnNlVmFyQ2hhcihuYW1lLCAzMik7XG4gIGNvbnN0IHVwZGF0ZTogVGFnVHlwZSA9IHtcbiAgICBkZXNjcmlwdGlvbjogcGFyc2VWYXJDaGFyKGRlc2NyaXB0aW9uLCA2NCksXG4gICAgbW9kaWZpZWQ6IG5vdyxcbiAgICBuYW1lOiBmb3JtYXROYW1lXG4gIH07XG4gIGNvbnN0IG5ld1RhZ0tleTogc3RyaW5nID0gdGFnSWQgfHwgY3JlYXRlSGFzaChgdGFnLSR7Zm9ybWF0TmFtZS50b0xvd2VyQ2FzZSgpfWAsIG51bGwpO1xuICBjb25zdCBpbnNlcnQ6IFRhZ1R5cGUgPSB7XG4gICAgLi4udXBkYXRlLFxuICAgIF9pZDogYHRhZ3MvJHtuZXdUYWdLZXl9YCxcbiAgICBfa2V5OiBuZXdUYWdLZXksXG4gICAgYWRkZWQ6IG5vdyxcbiAgICB0YWdCeTogc2Vzc2lvbklkXG4gIH07XG4gIGNvbnN0IGFxbFFyeTogQXFsUXVlcnkgPSBhcWxgVVBTRVJUIHtuYW1lOiAke2Zvcm1hdE5hbWV9fVxuICAgIElOU0VSVCAke2luc2VydH1cbiAgICBVUERBVEUgJHt1cGRhdGV9XG4gICAgSU4gdGFncyBSRVRVUk4gTkVXYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIHZhbHVlOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIHt9KSk7XG59O1xuXG5leHBvcnQgY29uc3QgZGVsZXRlVGFnID0gYXN5bmMgKGNvbnRleHQ6IEFwaUNvbnRleHQsIHRhZzogVGFnVHlwZSk6IFByb21pc2U8VGFnVHlwZT4gPT4ge1xuICBjb25zdCBhY3Rpb246IHN0cmluZyA9ICdkZWxldGVUYWcnO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZm9ybWF0SXRlbUlkID0gZ2V0RG9jSWQoJ3RhZ3MnLCB0YWcpO1xuICBjb25zdCB0YWdRdWVyeTogc3RyaW5nID0gYEZPUiBpdCBGUk9NIGlzVGFnZ2VkXG4gICAgRklMVEVSIGl0Ll9mcm9tID09IFwiJHtmb3JtYXRJdGVtSWR9XCIgfHwgaXQuX3RvID09IFwiJHtmb3JtYXRJdGVtSWR9XCJcbiAgICBSRU1PVkUgaXQgSU4gaXNUYWdnZWRcbiAgICBSRVRVUk4gT0xEYDtcblxuICBhd2FpdCBkYXRhYmFzZS5xdWVyeSh0YWdRdWVyeSlcbiAgICAudGhlbigoY3Vyc29yOiBBcnJheUN1cnNvcikgPT4gY3Vyc29yLmFsbCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIHZhbHVlOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIHt9KSk7XG5cbiAgY29uc3QgYXFsUXJ5ID0gYExFVCB0ID0gRE9DVU1FTlQoJHtmb3JtYXRJdGVtSWR9KVxuICAgIFJFTU9WRSB0IElOIHRhZ3NcbiAgICBSRVRVUk4gT0xEYDtcblxuICByZXR1cm4gZGF0YWJhc2UucXVlcnkoYXFsUXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIHZhbHVlOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIHt9KSk7XG59O1xuXG5leHBvcnQgY29uc3QgZGVsZXRlVGFnRnJvbUl0ZW0gPSBhc3luYyAoY29udGV4dDogQXBpQ29udGV4dCwge3RhZ0RvY0lkLCBlZGdlRG9jSWR9KTogUHJvbWlzZTxUYWdUeXBlPiA9PiB7XG4gIGNvbnN0IGFjdGlvbiA9ICdkZWxldGVUYWdGcm9tSXRlbSc7XG4gIGNvbnN0IHtkYXRhYmFzZX0gPSBjb250ZXh0O1xuICBjb25zdCBmb3JtYXRUYWdEb2NJZCA9IHBhcnNlQXJhbmdvSWQodGFnRG9jSWQpO1xuICBjb25zdCBmb3JtYXRFZGdlRG9jSWQgPSBwYXJzZUFyYW5nb0lkKGVkZ2VEb2NJZCk7XG4gIGNvbnN0IGVkZ2VDb2xsZWN0aW9uOiBFZGdlQ29sbGVjdGlvbiA9IGRhdGFiYXNlLmNvbGxlY3Rpb24oJ2lzVGFnZ2VkJyk7XG4gIGNvbnN0IGVkZ2UgPSB7X2lkOiBmb3JtYXRFZGdlRG9jSWR9O1xuXG4gIGF3YWl0IGVkZ2VDb2xsZWN0aW9uLnJlbW92ZShlZGdlLCB7c2lsZW50OiB0cnVlfSlcbiAgICAuY2F0Y2goKGVycm9yOiBFcnJvcikgPT4gbG9nRXJyb3Ioe1xuICAgICAgYWN0aW9uLFxuICAgICAgY2F0ZWdvcnk6IGV2ZW50Q2F0ZWdvcnksXG4gICAgICB2YWx1ZTogRXJyb3JUeXBlcy5EQVRBQkFTRV9FUlJPUlxuICAgIH0sIGVycm9yLCB7fSkpO1xuXG4gIGNvbnN0IHRhZ1F1ZXJ5OiBBcWxRdWVyeSA9IGFxbGBMRVQgdCA9IERPQ1VNRU5UKCR7Zm9ybWF0VGFnRG9jSWR9KSBSRVRVUk4gdGA7XG5cbiAgcmV0dXJuIGRhdGFiYXNlLnF1ZXJ5KHRhZ1F1ZXJ5KVxuICAgIC50aGVuKChjdXJzb3I6IEFycmF5Q3Vyc29yKSA9PiBjdXJzb3IubmV4dCgpKVxuICAgIC5jYXRjaCgoZXJyb3I6IEVycm9yKSA9PiBsb2dFcnJvcih7XG4gICAgICBhY3Rpb24sXG4gICAgICBjYXRlZ29yeTogZXZlbnRDYXRlZ29yeSxcbiAgICAgIHZhbHVlOiBFcnJvclR5cGVzLkRBVEFCQVNFX0VSUk9SXG4gICAgfSwgZXJyb3IsIHt9KSk7XG59O1xuXG5leHBvcnQgY29uc3QgZXh0cmFjdFRhZ3MgPSAoY29udGVudDogc3RyaW5nKTogc3RyaW5nW10gPT5cbiAgd29yZHMoY29udGVudCwgLyNbYS16QS1aXFxkLV0rL2cpLm1hcCgodGFnOiBzdHJpbmcpID0+IHBhcnNlSWQodGFnKSk7XG5cbmV4cG9ydCBjb25zdCB1cGRhdGVUYWdzSW5JdGVtID0gKGNvbnRleHQ6IEFwaUNvbnRleHQsIHtpdGVtRG9jSWQsIHRhZ3N9KTogUHJvbWlzZTxUYWdUeXBlW10+ID0+IHtcbiAgY29uc3QgYWN0aW9uID0gJ3VwZGF0ZVRhZ3NJbkl0ZW0nO1xuICBjb25zdCB7ZGF0YWJhc2V9ID0gY29udGV4dDtcbiAgY29uc3QgZWRnZUNvbGxlY3Rpb24gPSBkYXRhYmFzZS5jb2xsZWN0aW9uKCdpc1RhZ2dlZCcpO1xuXG4gIHJldHVybiBlZGdlQ29sbGVjdGlvbi5pbkVkZ2VzKGl0ZW1Eb2NJZCwge30pXG4gICAgLnRoZW4oKGVkZ2VzOiBhbnkpID0+IFByb21pc2UuYWxsKFtcbiAgICAgIC4uLmVkZ2VzXG4gICAgICAgIC5maWx0ZXIoKHtuYW1lOiBleGlzdGluZ1RhZ05hbWV9KSA9PiAhdGFncy5maW5kKCh7bmFtZTogdGFnTmFtZX0pID0+IGV4aXN0aW5nVGFnTmFtZSA9PT0gdGFnTmFtZSkpXG4gICAgICAgIC5tYXAoKHtfaWQ6IGVkZ2VEb2NJZCwgX2Zyb206IHRhZ0RvY0lkfSkgPT5cbiAgICAgICAgICBkZWxldGVUYWdGcm9tSXRlbShjb250ZXh0LCB7dGFnRG9jSWQsIGVkZ2VEb2NJZH0pKSxcbiAgICAgIC4uLnRhZ3NcbiAgICAgICAgLmZpbHRlcigoe25hbWU6IHRhZ05hbWV9KSA9PiAhZWRnZXMuZmluZCgoe25hbWU6IGV4aXN0aW5nVGFnTmFtZX0pID0+IGV4aXN0aW5nVGFnTmFtZSA9PT0gdGFnTmFtZSkpXG4gICAgICAgIC5tYXAoKHtfaWQ6IHRhZ0RvY0lkLCB0YWdCeX0pID0+XG4gICAgICAgICAgYWRkVGFnVG9JdGVtKGNvbnRleHQsIHtpdGVtRG9jSWQsIHRhZ0J5LCB0YWdEb2NJZH0pKVxuICAgIF0pLnRoZW4oKCkgPT4gdGFncykpXG4gICAgLmNhdGNoKChlcnJvcjogRXJyb3IpID0+IGxvZ0Vycm9yKHtcbiAgICAgIGFjdGlvbixcbiAgICAgIGNhdGVnb3J5OiBldmVudENhdGVnb3J5LFxuICAgICAgdmFsdWU6IEVycm9yVHlwZXMuREFUQUJBU0VfRVJST1JcbiAgICB9LCBlcnJvciwge30pKTtcbn07XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFJQSxtQkFBK0Q7QUFDL0Qsc0JBQWtCO0FBS2xCLG1CQUFrQjtBQUVsQix3QkFBdUI7QUFHdkIsbUJBQXlCO0FBRXpCLDRCQUF1QjtBQUN2QiwyQkFBaUM7QUFFakMsTUFBTSxnQkFBd0I7QUFRdkIsTUFBTSxVQUFVLENBQ3JCLFNBQ0EsVUFBc0IsQ0FBQyxNQUNBO0FBQ3ZCLFFBQU0sU0FBaUI7QUFDdkIsUUFBTSxFQUFDLFNBQVEsSUFBSTtBQUNuQixRQUFNLEVBQUMsU0FBUyxJQUFJLE9BQU8sR0FBRyxLQUFLLElBQUksT0FBTSxJQUFJO0FBQ2pELFFBQU0sWUFBdUIsK0JBQVMsTUFBTSxFQUFFO0FBRTlDLFFBQU0sVUFBb0IsQ0FBQztBQUUzQixNQUFHLFFBQVE7QUFDVCxZQUFRLEtBQUssa0JBQWtCLE1BQU0sS0FBSztBQUFBLEVBQzVDO0FBRUEsTUFBRyxRQUFRO0FBQ1QsWUFBUSxLQUFLLGdCQUFnQixNQUFNLEdBQUc7QUFB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QUFBQSxJQUNBLFVBQVU7QUFBQSxJQUNWLE9BQU8sd0JBQVc7QUFBQSxFQUNwQixHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUM7QUFFZixRQUFNLFdBQXFCLHVDQUF1QixjQUFjO0FBRWhFLFNBQU8sU0FBUyxNQUFNLFFBQVEsRUFDM0IsS0FBSyxDQUFDLFdBQXdCLE9BQU8sS0FBSyxDQUFDLEVBQzNDLE1BQU0sQ0FBQyxjQUFpQixnQ0FBUztBQUFBLElBQ2hDO0FBQUEsSUFDQSxVQUFVO0FBQUEsSUFDVixPQUFPLHdCQUFXO0FBQUEsRUFDcEIsR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDO0FBQ2pCO0FBRU8sTUFBTSxjQUFjLENBQUMsZ0JBQzFCLGFBQUFBLFNBQU0sU0FBUyxnQkFBZ0IsRUFBRSxJQUFJLENBQUMsWUFBZ0Isc0JBQVEsR0FBRyxDQUFDO0FBRTdELE1BQU0sbUJBQW1CLENBQUMsU0FBcUIsRUFBQyxXQUFXLEtBQUksTUFBMEI7QUFDOUYsUUFBTSxTQUFTO0FBQ2YsUUFBTSxFQUFDLFNBQVEsSUFBSTtBQUNuQixRQUFNLGlCQUFpQixTQUFTLFdBQVcsVUFBVTtBQUVyRCxTQUFPLGVBQWUsUUFBUSxXQUFXLENBQUMsQ0FBQyxFQUN4QyxLQUFLLENBQUMsVUFBZSxRQUFRLElBQUk7QUFBQSxJQUNoQyxHQUFHLE1BQ0EsT0FBTyxDQUFDLEVBQUMsTUFBTSxnQkFBZSxNQUFNLENBQUMsS0FBSyxLQUFLLENBQUMsRUFBQyxNQUFNLFFBQU8sTUFBTSxvQkFBb0IsT0FBTyxDQUFDLEVBQ2hHLElBQUksQ0FBQyxFQUFDLEtBQUssV0FBVyxPQUFPLFNBQVEsTUFDcEMsa0JBQWtCLFNBQVMsRUFBQyxVQUFVLFVBQVMsQ0FBQyxDQUFDO0FBQUEsSUFDckQsR0FBRyxLQUNBLE9BQU8sQ0FBQyxFQUFDLE1BQU0sUUFBTyxNQUFNLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBQyxNQUFNLGdCQUFlLE1BQU0sb0JBQW9CLE9BQU8sQ0FBQyxFQUNqRyxJQUFJLENBQUMsRUFBQyxLQUFLLFVBQVUsTUFBSyxNQUN6QixhQUFhLFNBQVMsRUFBQyxXQUFXLE9BQU8sU0FBUSxDQUFDLENBQUM7QUFBQSxFQUN6RCxDQUFDLEVBQUUsS0FBSyxNQUFNLElBQUksQ0FBQyxFQUNsQixNQUFNLENBQUMsY0FBaUIsZ0NBQVM7QUFBQSxJQUNoQztBQUFBLElBQ0EsVUFBVTtBQUFBLElBQ1YsT0FBTyx3QkFBVztBQUFBLEVBQ3BCLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQztBQUNqQjsiLAogICJuYW1lcyI6IFsid29yZHMiXQp9Cg==
@@ -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>;