@cyberskill/shared 1.49.0 → 1.51.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 (147) hide show
  1. package/dist/_tsup-dts-rollup.d.cts +119 -110
  2. package/dist/_tsup-dts-rollup.d.ts +119 -110
  3. package/dist/cli.cjs +1 -2144
  4. package/dist/cli.d.cts +1 -2
  5. package/dist/cli.d.ts +1 -2
  6. package/dist/cli.js +1 -2064
  7. package/dist/configs/commitlint/base.cjs +1 -64
  8. package/dist/configs/commitlint/base.js +1 -7
  9. package/dist/configs/eslint/base.cjs +1 -121
  10. package/dist/configs/eslint/base.js +1 -52
  11. package/dist/configs/eslint/nestjs.cjs +1 -155
  12. package/dist/configs/eslint/nestjs.js +1 -85
  13. package/dist/configs/eslint/nextjs.cjs +1 -155
  14. package/dist/configs/eslint/nextjs.js +1 -85
  15. package/dist/configs/eslint/nodejs.cjs +1 -156
  16. package/dist/configs/eslint/nodejs.js +1 -86
  17. package/dist/configs/eslint/vite-react.cjs +1 -159
  18. package/dist/configs/eslint/vite-react.js +1 -89
  19. package/dist/configs/graphql/graphql-codegen.cjs +1 -125
  20. package/dist/configs/graphql/graphql-codegen.js +1 -64
  21. package/dist/configs/graphql/index.cjs +1 -126
  22. package/dist/configs/graphql/index.js +1 -64
  23. package/dist/configs/i18n/react/i18next.cjs +1 -80
  24. package/dist/configs/i18n/react/i18next.js +1 -7
  25. package/dist/configs/i18n/react/index.cjs +1 -81
  26. package/dist/configs/i18n/react/index.js +1 -7
  27. package/dist/configs/index.cjs +1 -232
  28. package/dist/configs/index.js +1 -166
  29. package/dist/configs/lint-staged/base.cjs +1 -64
  30. package/dist/configs/lint-staged/base.js +1 -7
  31. package/dist/configs/vitest/react/e2e.cjs +1 -128
  32. package/dist/configs/vitest/react/e2e.js +1 -59
  33. package/dist/configs/vitest/react/unit.cjs +1 -305
  34. package/dist/configs/vitest/react/unit.js +1 -228
  35. package/dist/configs/vitest/react/unit.setup.cjs +1 -60
  36. package/dist/configs/vitest/react/unit.setup.js +1 -8
  37. package/dist/constants/index.cjs +1 -678
  38. package/dist/constants/index.d.cts +8 -3
  39. package/dist/constants/index.d.ts +8 -3
  40. package/dist/constants/index.js +1 -469
  41. package/dist/constants/path.cjs +1 -423
  42. package/dist/constants/path.d.cts +8 -3
  43. package/dist/constants/path.d.ts +8 -3
  44. package/dist/constants/path.js +1 -218
  45. package/dist/constants/response-status.cjs +1 -313
  46. package/dist/constants/response-status.js +1 -252
  47. package/dist/index.cjs +1 -4560
  48. package/dist/index.d.cts +12 -8
  49. package/dist/index.d.ts +12 -8
  50. package/dist/index.js +1 -4143
  51. package/dist/nodejs/index.cjs +1 -2138
  52. package/dist/nodejs/index.js +1 -2054
  53. package/dist/nodejs/mongo.cjs +1 -2137
  54. package/dist/nodejs/mongo.js +1 -2054
  55. package/dist/react/apollo-client.cjs +1 -177
  56. package/dist/react/apollo-client.js +1 -116
  57. package/dist/react/index.cjs +1 -990
  58. package/dist/react/index.js +1 -876
  59. package/dist/react/loading.cjs +1 -301
  60. package/dist/react/loading.js +1 -216
  61. package/dist/react/next-intl.cjs +1 -744
  62. package/dist/react/next-intl.js +1 -655
  63. package/dist/react/storage.cjs +1 -631
  64. package/dist/react/storage.js +1 -558
  65. package/dist/typescript/api-response.cjs +1 -48
  66. package/dist/typescript/apollo.cjs +1 -48
  67. package/dist/typescript/command.cjs +1 -68
  68. package/dist/typescript/command.d.cts +2 -0
  69. package/dist/typescript/command.d.ts +2 -0
  70. package/dist/typescript/command.js +1 -7
  71. package/dist/typescript/config.cjs +1 -48
  72. package/dist/typescript/fs.cjs +1 -48
  73. package/dist/typescript/graphql-codegen.cjs +1 -48
  74. package/dist/typescript/index.cjs +1 -175
  75. package/dist/typescript/index.d.cts +2 -0
  76. package/dist/typescript/index.d.ts +2 -0
  77. package/dist/typescript/index.js +1 -151
  78. package/dist/typescript/loading.cjs +1 -48
  79. package/dist/typescript/log.cjs +1 -48
  80. package/dist/typescript/mongo.cjs +1 -164
  81. package/dist/typescript/mongo.js +1 -145
  82. package/dist/typescript/next-intl.cjs +1 -48
  83. package/dist/typescript/react.cjs +1 -48
  84. package/dist/typescript/serializer.cjs +1 -48
  85. package/dist/typescript/string.cjs +1 -48
  86. package/dist/utils/command.cjs +1 -1387
  87. package/dist/utils/command.d.cts +2 -2
  88. package/dist/utils/command.d.ts +2 -2
  89. package/dist/utils/command.js +1 -1287
  90. package/dist/utils/common.cjs +1 -300
  91. package/dist/utils/common.js +1 -219
  92. package/dist/utils/config.cjs +1 -146
  93. package/dist/utils/config.js +1 -89
  94. package/dist/utils/fs.cjs +1 -132
  95. package/dist/utils/fs.js +1 -47
  96. package/dist/utils/index-nodejs.cjs +1 -1752
  97. package/dist/utils/index-nodejs.d.cts +2 -5
  98. package/dist/utils/index-nodejs.d.ts +2 -5
  99. package/dist/utils/index-nodejs.js +1 -1581
  100. package/dist/utils/index.cjs +1 -727
  101. package/dist/utils/index.js +1 -625
  102. package/dist/utils/log.cjs +1 -330
  103. package/dist/utils/log.js +1 -269
  104. package/dist/utils/package.cjs +1 -941
  105. package/dist/utils/package.js +1 -857
  106. package/dist/utils/path.cjs +1 -291
  107. package/dist/utils/path.d.cts +0 -3
  108. package/dist/utils/path.d.ts +0 -3
  109. package/dist/utils/path.js +1 -191
  110. package/dist/utils/serializer.cjs +1 -91
  111. package/dist/utils/serializer.js +1 -30
  112. package/dist/utils/storage-client.cjs +1 -349
  113. package/dist/utils/storage-client.js +1 -276
  114. package/dist/utils/storage-server.cjs +1 -636
  115. package/dist/utils/storage-server.js +1 -550
  116. package/dist/utils/string.cjs +1 -152
  117. package/dist/utils/string.js +1 -75
  118. package/dist/utils/validate.cjs +1 -90
  119. package/dist/utils/validate.js +1 -33
  120. package/package.json +11 -10
  121. /package/{src/public → public}/favicon/android-icon-144x144.png +0 -0
  122. /package/{src/public → public}/favicon/android-icon-192x192.png +0 -0
  123. /package/{src/public → public}/favicon/android-icon-36x36.png +0 -0
  124. /package/{src/public → public}/favicon/android-icon-48x48.png +0 -0
  125. /package/{src/public → public}/favicon/android-icon-72x72.png +0 -0
  126. /package/{src/public → public}/favicon/android-icon-96x96.png +0 -0
  127. /package/{src/public → public}/favicon/apple-icon-114x114.png +0 -0
  128. /package/{src/public → public}/favicon/apple-icon-120x120.png +0 -0
  129. /package/{src/public → public}/favicon/apple-icon-144x144.png +0 -0
  130. /package/{src/public → public}/favicon/apple-icon-152x152.png +0 -0
  131. /package/{src/public → public}/favicon/apple-icon-180x180.png +0 -0
  132. /package/{src/public → public}/favicon/apple-icon-57x57.png +0 -0
  133. /package/{src/public → public}/favicon/apple-icon-60x60.png +0 -0
  134. /package/{src/public → public}/favicon/apple-icon-72x72.png +0 -0
  135. /package/{src/public → public}/favicon/apple-icon-76x76.png +0 -0
  136. /package/{src/public → public}/favicon/apple-icon-precomposed.png +0 -0
  137. /package/{src/public → public}/favicon/apple-icon.png +0 -0
  138. /package/{src/public → public}/favicon/browserconfig.xml +0 -0
  139. /package/{src/public → public}/favicon/favicon-16x16.png +0 -0
  140. /package/{src/public → public}/favicon/favicon-32x32.png +0 -0
  141. /package/{src/public → public}/favicon/favicon-96x96.png +0 -0
  142. /package/{src/public → public}/favicon/favicon.ico +0 -0
  143. /package/{src/public → public}/favicon/manifest.json +0 -0
  144. /package/{src/public → public}/favicon/ms-icon-144x144.png +0 -0
  145. /package/{src/public → public}/favicon/ms-icon-150x150.png +0 -0
  146. /package/{src/public → public}/favicon/ms-icon-310x310.png +0 -0
  147. /package/{src/public → public}/favicon/ms-icon-70x70.png +0 -0
package/dist/index.js CHANGED
@@ -1,4143 +1 @@
1
- // src/configs/index.ts
2
- function _array_like_to_array(arr, len) {
3
- if (len == null || len > arr.length) len = arr.length;
4
- for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
5
- return arr2;
6
- }
7
- function _array_with_holes(arr) {
8
- if (Array.isArray(arr)) return arr;
9
- }
10
- function _array_without_holes(arr) {
11
- if (Array.isArray(arr)) return _array_like_to_array(arr);
12
- }
13
- function _assert_this_initialized(self) {
14
- if (self === void 0) {
15
- throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
16
- }
17
- return self;
18
- }
19
- function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
20
- try {
21
- var info = gen[key](arg);
22
- var value = info.value;
23
- } catch (error) {
24
- reject(error);
25
- return;
26
- }
27
- if (info.done) {
28
- resolve(value);
29
- } else {
30
- Promise.resolve(value).then(_next, _throw);
31
- }
32
- }
33
- function _async_to_generator(fn) {
34
- return function() {
35
- var self = this, args = arguments;
36
- return new Promise(function(resolve, reject) {
37
- var gen = fn.apply(self, args);
38
- function _next(value) {
39
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
40
- }
41
- function _throw(err) {
42
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
43
- }
44
- _next(undefined);
45
- });
46
- };
47
- }
48
- function _call_super(_this, derived, args) {
49
- derived = _get_prototype_of(derived);
50
- return _possible_constructor_return(_this, _is_native_reflect_construct() ? Reflect.construct(derived, args || [], _get_prototype_of(_this).constructor) : derived.apply(_this, args));
51
- }
52
- function _class_call_check(instance, Constructor) {
53
- if (!(instance instanceof Constructor)) {
54
- throw new TypeError("Cannot call a class as a function");
55
- }
56
- }
57
- function _defineProperties(target, props) {
58
- for(var i = 0; i < props.length; i++){
59
- var descriptor = props[i];
60
- descriptor.enumerable = descriptor.enumerable || false;
61
- descriptor.configurable = true;
62
- if ("value" in descriptor) descriptor.writable = true;
63
- Object.defineProperty(target, descriptor.key, descriptor);
64
- }
65
- }
66
- function _create_class(Constructor, protoProps, staticProps) {
67
- if (protoProps) _defineProperties(Constructor.prototype, protoProps);
68
- if (staticProps) _defineProperties(Constructor, staticProps);
69
- return Constructor;
70
- }
71
- function _define_property(obj, key, value) {
72
- if (key in obj) {
73
- Object.defineProperty(obj, key, {
74
- value: value,
75
- enumerable: true,
76
- configurable: true,
77
- writable: true
78
- });
79
- } else {
80
- obj[key] = value;
81
- }
82
- return obj;
83
- }
84
- function _get_prototype_of(o) {
85
- _get_prototype_of = Object.setPrototypeOf ? Object.getPrototypeOf : function getPrototypeOf(o) {
86
- return o.__proto__ || Object.getPrototypeOf(o);
87
- };
88
- return _get_prototype_of(o);
89
- }
90
- function _inherits(subClass, superClass) {
91
- if (typeof superClass !== "function" && superClass !== null) {
92
- throw new TypeError("Super expression must either be null or a function");
93
- }
94
- subClass.prototype = Object.create(superClass && superClass.prototype, {
95
- constructor: {
96
- value: subClass,
97
- writable: true,
98
- configurable: true
99
- }
100
- });
101
- if (superClass) _set_prototype_of(subClass, superClass);
102
- }
103
- function _instanceof(left, right) {
104
- if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
105
- return !!right[Symbol.hasInstance](left);
106
- } else {
107
- return left instanceof right;
108
- }
109
- }
110
- function _iterable_to_array(iter) {
111
- if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
112
- }
113
- function _iterable_to_array_limit(arr, i) {
114
- var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
115
- if (_i == null) return;
116
- var _arr = [];
117
- var _n = true;
118
- var _d = false;
119
- var _s, _e;
120
- try {
121
- for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
122
- _arr.push(_s.value);
123
- if (i && _arr.length === i) break;
124
- }
125
- } catch (err) {
126
- _d = true;
127
- _e = err;
128
- } finally{
129
- try {
130
- if (!_n && _i["return"] != null) _i["return"]();
131
- } finally{
132
- if (_d) throw _e;
133
- }
134
- }
135
- return _arr;
136
- }
137
- function _non_iterable_rest() {
138
- throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
139
- }
140
- function _non_iterable_spread() {
141
- throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
142
- }
143
- function _object_spread(target) {
144
- for(var i = 1; i < arguments.length; i++){
145
- var source = arguments[i] != null ? arguments[i] : {};
146
- var ownKeys = Object.keys(source);
147
- if (typeof Object.getOwnPropertySymbols === "function") {
148
- ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
149
- return Object.getOwnPropertyDescriptor(source, sym).enumerable;
150
- }));
151
- }
152
- ownKeys.forEach(function(key) {
153
- _define_property(target, key, source[key]);
154
- });
155
- }
156
- return target;
157
- }
158
- function ownKeys(object, enumerableOnly) {
159
- var keys = Object.keys(object);
160
- if (Object.getOwnPropertySymbols) {
161
- var symbols = Object.getOwnPropertySymbols(object);
162
- if (enumerableOnly) {
163
- symbols = symbols.filter(function(sym) {
164
- return Object.getOwnPropertyDescriptor(object, sym).enumerable;
165
- });
166
- }
167
- keys.push.apply(keys, symbols);
168
- }
169
- return keys;
170
- }
171
- function _object_spread_props(target, source) {
172
- source = source != null ? source : {};
173
- if (Object.getOwnPropertyDescriptors) {
174
- Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
175
- } else {
176
- ownKeys(Object(source)).forEach(function(key) {
177
- Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
178
- });
179
- }
180
- return target;
181
- }
182
- function _object_without_properties(source, excluded) {
183
- if (source == null) return {};
184
- var target = _object_without_properties_loose(source, excluded);
185
- var key, i;
186
- if (Object.getOwnPropertySymbols) {
187
- var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
188
- for(i = 0; i < sourceSymbolKeys.length; i++){
189
- key = sourceSymbolKeys[i];
190
- if (excluded.indexOf(key) >= 0) continue;
191
- if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
192
- target[key] = source[key];
193
- }
194
- }
195
- return target;
196
- }
197
- function _object_without_properties_loose(source, excluded) {
198
- if (source == null) return {};
199
- var target = {};
200
- var sourceKeys = Object.keys(source);
201
- var key, i;
202
- for(i = 0; i < sourceKeys.length; i++){
203
- key = sourceKeys[i];
204
- if (excluded.indexOf(key) >= 0) continue;
205
- target[key] = source[key];
206
- }
207
- return target;
208
- }
209
- function _possible_constructor_return(self, call) {
210
- if (call && (_type_of(call) === "object" || typeof call === "function")) {
211
- return call;
212
- }
213
- return _assert_this_initialized(self);
214
- }
215
- function _set_prototype_of(o, p) {
216
- _set_prototype_of = Object.setPrototypeOf || function setPrototypeOf(o, p) {
217
- o.__proto__ = p;
218
- return o;
219
- };
220
- return _set_prototype_of(o, p);
221
- }
222
- function _sliced_to_array(arr, i) {
223
- return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
224
- }
225
- function _to_consumable_array(arr) {
226
- return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
227
- }
228
- function _type_of(obj) {
229
- "@swc/helpers - typeof";
230
- return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
231
- }
232
- function _unsupported_iterable_to_array(o, minLen) {
233
- if (!o) return;
234
- if (typeof o === "string") return _array_like_to_array(o, minLen);
235
- var n = Object.prototype.toString.call(o).slice(8, -1);
236
- if (n === "Object" && o.constructor) n = o.constructor.name;
237
- if (n === "Map" || n === "Set") return Array.from(n);
238
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
239
- }
240
- function _is_native_reflect_construct() {
241
- try {
242
- var result = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function() {}));
243
- } catch (_) {}
244
- return (_is_native_reflect_construct = function() {
245
- return !!result;
246
- })();
247
- }
248
- function _ts_generator(thisArg, body) {
249
- var f, y, t, g, _ = {
250
- label: 0,
251
- sent: function() {
252
- if (t[0] & 1) throw t[1];
253
- return t[1];
254
- },
255
- trys: [],
256
- ops: []
257
- };
258
- return g = {
259
- next: verb(0),
260
- "throw": verb(1),
261
- "return": verb(2)
262
- }, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
263
- return this;
264
- }), g;
265
- function verb(n) {
266
- return function(v) {
267
- return step([
268
- n,
269
- v
270
- ]);
271
- };
272
- }
273
- function step(op) {
274
- if (f) throw new TypeError("Generator is already executing.");
275
- while(_)try {
276
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
277
- if (y = 0, t) op = [
278
- op[0] & 2,
279
- t.value
280
- ];
281
- switch(op[0]){
282
- case 0:
283
- case 1:
284
- t = op;
285
- break;
286
- case 4:
287
- _.label++;
288
- return {
289
- value: op[1],
290
- done: false
291
- };
292
- case 5:
293
- _.label++;
294
- y = op[1];
295
- op = [
296
- 0
297
- ];
298
- continue;
299
- case 7:
300
- op = _.ops.pop();
301
- _.trys.pop();
302
- continue;
303
- default:
304
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
305
- _ = 0;
306
- continue;
307
- }
308
- if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
309
- _.label = op[1];
310
- break;
311
- }
312
- if (op[0] === 6 && _.label < t[1]) {
313
- _.label = t[1];
314
- t = op;
315
- break;
316
- }
317
- if (t && _.label < t[2]) {
318
- _.label = t[2];
319
- _.ops.push(op);
320
- break;
321
- }
322
- if (t[2]) _.ops.pop();
323
- _.trys.pop();
324
- continue;
325
- }
326
- op = body.call(thisArg, _);
327
- } catch (e) {
328
- op = [
329
- 6,
330
- e
331
- ];
332
- y = 0;
333
- } finally{
334
- f = t = 0;
335
- }
336
- if (op[0] & 5) throw op[1];
337
- return {
338
- value: op[0] ? op[1] : void 0,
339
- done: true
340
- };
341
- }
342
- }
343
- import antfu from "@antfu/eslint-config";
344
- // src/utils/config.ts
345
- function deepMerge() {
346
- for(var _len = arguments.length, configs = new Array(_len), _key = 0; _key < _len; _key++){
347
- configs[_key] = arguments[_key];
348
- }
349
- var merge = function(target, source) {
350
- var result = _object_spread({}, target);
351
- Object.keys(source).forEach(function(key) {
352
- if (!Object.hasOwnProperty.call(source, key)) {
353
- return;
354
- }
355
- var sourceValue = source[key];
356
- var targetValue = result[key];
357
- if (Array.isArray(sourceValue)) {
358
- result[key] = _to_consumable_array(/* @__PURE__ */ new Set(_to_consumable_array(Array.isArray(targetValue) ? targetValue : []).concat(_to_consumable_array(sourceValue))));
359
- } else if ((typeof sourceValue === "undefined" ? "undefined" : _type_of(sourceValue)) === "object" && sourceValue !== null && !Array.isArray(sourceValue)) {
360
- result[key] = merge((typeof targetValue === "undefined" ? "undefined" : _type_of(targetValue)) === "object" && targetValue !== null && !Array.isArray(targetValue) ? targetValue : {}, sourceValue);
361
- } else {
362
- result[key] = sourceValue;
363
- }
364
- });
365
- return result;
366
- };
367
- return configs.flatMap(function(config) {
368
- return Array.isArray(config) ? config : [
369
- config
370
- ];
371
- }).reduce(function(acc, config) {
372
- return merge(acc, config);
373
- }, {});
374
- }
375
- // src/constants/path.ts
376
- import process3 from "node:process";
377
- import { fileURLToPath } from "node:url";
378
- // src/utils/command.ts
379
- import boxen from "boxen";
380
- import chalk from "chalk";
381
- import { exec } from "node:child_process";
382
- import process2 from "node:process";
383
- import * as util from "node:util";
384
- // src/typescript/command.ts
385
- var E_ErrorType = /* @__PURE__ */ function(E_ErrorType2) {
386
- E_ErrorType2["Error"] = "error";
387
- E_ErrorType2["Warning"] = "warning";
388
- return E_ErrorType2;
389
- }(E_ErrorType || {});
390
- // src/utils/package.ts
391
- import fetch from "node-fetch";
392
- // src/utils/fs.ts
393
- import * as fs from "node:fs";
394
- var existsSync2 = function(filePath) {
395
- return fs.existsSync(filePath);
396
- };
397
- function readFileSync2(filePath, options) {
398
- var content = fs.readFileSync(filePath, "utf-8");
399
- if (options === null || options === void 0 ? void 0 : options.asJson) {
400
- try {
401
- var parsed = JSON.parse(content);
402
- if ((typeof parsed === "undefined" ? "undefined" : _type_of(parsed)) === "object" && parsed !== null) {
403
- return parsed;
404
- }
405
- throw new Error("Parsed JSON is not an object or array");
406
- } catch (e) {
407
- throw new Error("Failed to parse JSON from file: ".concat(filePath));
408
- }
409
- }
410
- return content;
411
- }
412
- function writeFileSync2(filePath, data) {
413
- var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
414
- var tmp = options.isJson, isJson2 = tmp === void 0 ? false : tmp;
415
- var content = isJson2 && (typeof data === "undefined" ? "undefined" : _type_of(data)) === "object" ? JSON.stringify(data, null, 4) : String(data);
416
- fs.writeFileSync(filePath, content, "utf-8");
417
- }
418
- function appendFileSync2(filePath, data) {
419
- var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
420
- var tmp = options.isJson, isJson2 = tmp === void 0 ? false : tmp;
421
- var content = isJson2 && (typeof data === "undefined" ? "undefined" : _type_of(data)) === "object" ? JSON.stringify(data, null, 4) : String(data);
422
- fs.appendFileSync(filePath, content, "utf-8");
423
- }
424
- function rmSync2(filePaths) {
425
- filePaths.forEach(function(filePath) {
426
- if (existsSync2(filePath)) {
427
- fs.rmSync(filePath, {
428
- recursive: true,
429
- force: true
430
- });
431
- }
432
- });
433
- }
434
- // src/utils/path.ts
435
- import { createRequire } from "node:module";
436
- import * as path from "node:path";
437
- function resolveCyberSkillPath() {
438
- for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
439
- urls[_key] = arguments[_key];
440
- }
441
- var _path;
442
- return (_path = path).resolve.apply(_path, [
443
- CYBERSKILL_DIRECTORY
444
- ].concat(_to_consumable_array(urls)));
445
- }
446
- function resolveWorkingPath() {
447
- for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
448
- urls[_key] = arguments[_key];
449
- }
450
- var _path;
451
- return (_path = path).resolve.apply(_path, [
452
- WORKING_DIRECTORY
453
- ].concat(_to_consumable_array(urls)));
454
- }
455
- function resolve2() {
456
- for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
457
- urls[_key] = arguments[_key];
458
- }
459
- var _path;
460
- return (_path = path).resolve.apply(_path, _to_consumable_array(urls));
461
- }
462
- function dirname2(url) {
463
- return path.dirname(url);
464
- }
465
- function require2() {
466
- return createRequire(CYBERSKILL_DIRECTORY);
467
- }
468
- function join2() {
469
- for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
470
- urls[_key] = arguments[_key];
471
- }
472
- var _path;
473
- return (_path = path).join.apply(_path, _to_consumable_array(urls));
474
- }
475
- // src/utils/storage-server.ts
476
- import nodePersist from "node-persist";
477
- import os from "node:os";
478
- import path2 from "node:path";
479
- import process from "node:process";
480
- function getStorageDir() {
481
- return process.env.CYBERSKILL_STORAGE_DIR || path2.join(os.homedir(), CYBERSKILL_STORAGE);
482
- }
483
- function initNodePersist() {
484
- return _initNodePersist.apply(this, arguments);
485
- }
486
- function _initNodePersist() {
487
- _initNodePersist = _async_to_generator(function() {
488
- return _ts_generator(this, function(_state) {
489
- switch(_state.label){
490
- case 0:
491
- if (!!nodePersist.defaultInstance) return [
492
- 3,
493
- 2
494
- ];
495
- return [
496
- 4,
497
- nodePersist.init({
498
- dir: getStorageDir(),
499
- stringify: JSON.stringify,
500
- parse: JSON.parse,
501
- encoding: "utf8",
502
- logging: false,
503
- forgiveParseErrors: true
504
- })
505
- ];
506
- case 1:
507
- _state.sent();
508
- _state.label = 2;
509
- case 2:
510
- return [
511
- 2
512
- ];
513
- }
514
- });
515
- });
516
- return _initNodePersist.apply(this, arguments);
517
- }
518
- var storageServer = {
519
- get: function get(key) {
520
- return _async_to_generator(function() {
521
- var result, error;
522
- return _ts_generator(this, function(_state) {
523
- switch(_state.label){
524
- case 0:
525
- _state.trys.push([
526
- 0,
527
- 3,
528
- ,
529
- 4
530
- ]);
531
- return [
532
- 4,
533
- initNodePersist()
534
- ];
535
- case 1:
536
- _state.sent();
537
- return [
538
- 4,
539
- nodePersist.getItem(key)
540
- ];
541
- case 2:
542
- result = _state.sent();
543
- return [
544
- 2,
545
- result !== null && result !== void 0 ? result : null
546
- ];
547
- case 3:
548
- error = _state.sent();
549
- console.error('❌ [Storage:get] Error getting key "'.concat(key, '":'), error);
550
- return [
551
- 2,
552
- null
553
- ];
554
- case 4:
555
- return [
556
- 2
557
- ];
558
- }
559
- });
560
- })();
561
- },
562
- set: function set(key, value) {
563
- return _async_to_generator(function() {
564
- var error;
565
- return _ts_generator(this, function(_state) {
566
- switch(_state.label){
567
- case 0:
568
- _state.trys.push([
569
- 0,
570
- 3,
571
- ,
572
- 4
573
- ]);
574
- return [
575
- 4,
576
- initNodePersist()
577
- ];
578
- case 1:
579
- _state.sent();
580
- return [
581
- 4,
582
- nodePersist.setItem(key, value)
583
- ];
584
- case 2:
585
- _state.sent();
586
- return [
587
- 3,
588
- 4
589
- ];
590
- case 3:
591
- error = _state.sent();
592
- console.error('❌ [Storage:set] Error setting key "'.concat(key, '":'), error);
593
- return [
594
- 3,
595
- 4
596
- ];
597
- case 4:
598
- return [
599
- 2
600
- ];
601
- }
602
- });
603
- })();
604
- },
605
- remove: function remove(key) {
606
- return _async_to_generator(function() {
607
- var error;
608
- return _ts_generator(this, function(_state) {
609
- switch(_state.label){
610
- case 0:
611
- _state.trys.push([
612
- 0,
613
- 3,
614
- ,
615
- 4
616
- ]);
617
- return [
618
- 4,
619
- initNodePersist()
620
- ];
621
- case 1:
622
- _state.sent();
623
- return [
624
- 4,
625
- nodePersist.removeItem(key)
626
- ];
627
- case 2:
628
- _state.sent();
629
- return [
630
- 3,
631
- 4
632
- ];
633
- case 3:
634
- error = _state.sent();
635
- console.error('❌ [Storage:remove] Error removing key "'.concat(key, '":'), error);
636
- return [
637
- 3,
638
- 4
639
- ];
640
- case 4:
641
- return [
642
- 2
643
- ];
644
- }
645
- });
646
- })();
647
- },
648
- keys: function keys() {
649
- return _async_to_generator(function() {
650
- var keys, error;
651
- return _ts_generator(this, function(_state) {
652
- switch(_state.label){
653
- case 0:
654
- _state.trys.push([
655
- 0,
656
- 3,
657
- ,
658
- 4
659
- ]);
660
- return [
661
- 4,
662
- initNodePersist()
663
- ];
664
- case 1:
665
- _state.sent();
666
- return [
667
- 4,
668
- nodePersist.keys()
669
- ];
670
- case 2:
671
- keys = _state.sent();
672
- if (!Array.isArray(keys)) {
673
- console.warn("⚠️ [Storage:keys] Invalid keys response:", keys);
674
- return [
675
- 2,
676
- []
677
- ];
678
- }
679
- return [
680
- 2,
681
- keys
682
- ];
683
- case 3:
684
- error = _state.sent();
685
- console.error("❌ [Storage:keys] Error getting keys:", error);
686
- return [
687
- 2,
688
- []
689
- ];
690
- case 4:
691
- return [
692
- 2
693
- ];
694
- }
695
- });
696
- })();
697
- },
698
- getLogLink: function getLogLink(key) {
699
- return _async_to_generator(function() {
700
- var storagePath;
701
- return _ts_generator(this, function(_state) {
702
- try {
703
- storagePath = getStorageDir();
704
- return [
705
- 2,
706
- "".concat(storagePath, " (key: ").concat(key, ")")
707
- ];
708
- } catch (error) {
709
- console.error("❌ [Storage:getLogLink] Error getting log link:", error);
710
- return [
711
- 2,
712
- null
713
- ];
714
- }
715
- return [
716
- 2
717
- ];
718
- });
719
- })();
720
- }
721
- };
722
- // src/utils/package.ts
723
- var CACHE_EXPIRATION_MS = 24 * 60 * 60 * 1e3;
724
- function getPackageJson(packageName) {
725
- var workingPackageJsonPath = join2(WORKING_DIRECTORY, PACKAGE_JSON);
726
- if (existsSync2(workingPackageJsonPath)) {
727
- try {
728
- var pkg = readFileSync2(workingPackageJsonPath, {
729
- asJson: true
730
- });
731
- if (pkg.name === packageName) {
732
- return {
733
- path: workingPackageJsonPath,
734
- file: pkg
735
- };
736
- }
737
- } catch (error) {
738
- commandLog.warning("Failed to read local package.json: ".concat(error.message));
739
- }
740
- }
741
- var externalPackageJsonPath = join2(WORKING_DIRECTORY, NODE_MODULES, packageName, PACKAGE_JSON);
742
- if (existsSync2(externalPackageJsonPath)) {
743
- try {
744
- var pkg1 = readFileSync2(externalPackageJsonPath, {
745
- asJson: true
746
- });
747
- if (pkg1.name === packageName) {
748
- return {
749
- path: externalPackageJsonPath,
750
- file: pkg1
751
- };
752
- }
753
- } catch (error) {
754
- commandLog.warning("Failed to read node_modules package.json for ".concat(packageName, ": ").concat(error.message));
755
- }
756
- }
757
- return false;
758
- }
759
- function getLatestPackageVersion(packageName) {
760
- return _getLatestPackageVersion.apply(this, arguments);
761
- }
762
- function _getLatestPackageVersion() {
763
- _getLatestPackageVersion = _async_to_generator(function(packageName) {
764
- var forceRefresh, versionCacheKey, metadataCacheKey, cached, metadata, isCacheValid, headers, response, data, latestVersion, error;
765
- var _arguments = arguments;
766
- return _ts_generator(this, function(_state) {
767
- switch(_state.label){
768
- case 0:
769
- forceRefresh = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : false;
770
- versionCacheKey = "npm_version:".concat(packageName);
771
- metadataCacheKey = "npm_metadata:".concat(packageName);
772
- return [
773
- 4,
774
- storageServer.get(versionCacheKey)
775
- ];
776
- case 1:
777
- cached = _state.sent();
778
- return [
779
- 4,
780
- storageServer.get(metadataCacheKey)
781
- ];
782
- case 2:
783
- metadata = _state.sent();
784
- isCacheValid = cached && Date.now() - cached.timestamp < CACHE_EXPIRATION_MS;
785
- if (!forceRefresh && isCacheValid) {
786
- return [
787
- 2,
788
- cached.version
789
- ];
790
- }
791
- headers = {};
792
- if (metadata === null || metadata === void 0 ? void 0 : metadata.etag) {
793
- headers["If-None-Match"] = metadata.etag;
794
- }
795
- if (metadata === null || metadata === void 0 ? void 0 : metadata.lastModified) {
796
- headers["If-Modified-Since"] = metadata.lastModified;
797
- }
798
- _state.label = 3;
799
- case 3:
800
- _state.trys.push([
801
- 3,
802
- 8,
803
- ,
804
- 9
805
- ]);
806
- return [
807
- 4,
808
- fetch("https://registry.npmjs.org/".concat(packageName, "/latest"), {
809
- headers: headers
810
- })
811
- ];
812
- case 4:
813
- response = _state.sent();
814
- if (response.status === 304 && cached) {
815
- return [
816
- 2,
817
- cached.version
818
- ];
819
- }
820
- if (!response.ok) {
821
- throw new Error("Failed to fetch latest version: ".concat(response.statusText));
822
- }
823
- return [
824
- 4,
825
- response.json()
826
- ];
827
- case 5:
828
- data = _state.sent();
829
- latestVersion = data.version;
830
- return [
831
- 4,
832
- storageServer.set(versionCacheKey, {
833
- version: latestVersion,
834
- timestamp: Date.now()
835
- })
836
- ];
837
- case 6:
838
- _state.sent();
839
- return [
840
- 4,
841
- storageServer.set(metadataCacheKey, {
842
- etag: response.headers.get("ETag") || void 0,
843
- lastModified: response.headers.get("Last-Modified") || void 0
844
- })
845
- ];
846
- case 7:
847
- _state.sent();
848
- return [
849
- 2,
850
- latestVersion
851
- ];
852
- case 8:
853
- error = _state.sent();
854
- commandLog.error("Error fetching latest version for ".concat(packageName, ": ").concat(error.message));
855
- if (cached) {
856
- commandLog.warning("Falling back to cached version for ".concat(packageName, ": ").concat(cached.version));
857
- return [
858
- 2,
859
- cached.version
860
- ];
861
- }
862
- throw error;
863
- case 9:
864
- return [
865
- 2
866
- ];
867
- }
868
- });
869
- });
870
- return _getLatestPackageVersion.apply(this, arguments);
871
- }
872
- function checkPackage(packageName) {
873
- return _checkPackage.apply(this, arguments);
874
- }
875
- function _checkPackage() {
876
- _checkPackage = _async_to_generator(function(packageName) {
877
- var result, packageFound, cyberskillPackageJsonPath, isCurrentProject, _tmp, error;
878
- return _ts_generator(this, function(_state) {
879
- switch(_state.label){
880
- case 0:
881
- result = {
882
- isInstalled: false,
883
- isCurrentProject: false,
884
- installedPath: "",
885
- installedVersion: "",
886
- latestVersion: "",
887
- file: {}
888
- };
889
- _state.label = 1;
890
- case 1:
891
- _state.trys.push([
892
- 1,
893
- 5,
894
- ,
895
- 6
896
- ]);
897
- packageFound = getPackageJson(packageName);
898
- if (!packageFound) {
899
- return [
900
- 2,
901
- result
902
- ];
903
- }
904
- cyberskillPackageJsonPath = resolveCyberSkillPath(PACKAGE_JSON);
905
- isCurrentProject = packageFound.path === cyberskillPackageJsonPath;
906
- result.file = packageFound.file;
907
- result.isInstalled = true;
908
- result.installedPath = packageFound.path;
909
- result.installedVersion = packageFound.file.version;
910
- result.isCurrentProject = isCurrentProject;
911
- if (!isCurrentProject) return [
912
- 3,
913
- 2
914
- ];
915
- _tmp = packageFound.file.version;
916
- return [
917
- 3,
918
- 4
919
- ];
920
- case 2:
921
- return [
922
- 4,
923
- getLatestPackageVersion(packageName, true)
924
- ];
925
- case 3:
926
- _tmp = _state.sent();
927
- _state.label = 4;
928
- case 4:
929
- result.latestVersion = _tmp;
930
- return [
931
- 2,
932
- result
933
- ];
934
- case 5:
935
- error = _state.sent();
936
- commandLog.error('Error checking package "'.concat(packageName, '": ').concat(error.message));
937
- return [
938
- 2,
939
- result
940
- ];
941
- case 6:
942
- return [
943
- 2
944
- ];
945
- }
946
- });
947
- });
948
- return _checkPackage.apply(this, arguments);
949
- }
950
- // src/utils/command.ts
951
- var DEBUG = process2.env.DEBUG === "true";
952
- var execPromise = util.promisify(exec);
953
- var gray = chalk.gray, blue = chalk.blue;
954
- var getTimeStamp = function() {
955
- return gray("[".concat(/* @__PURE__ */ new Date().toLocaleTimeString(), "]"));
956
- };
957
- function chalkKeyword(color) {
958
- var chalkColor = chalk[color];
959
- return typeof chalkColor === "function" ? chalkColor : chalk.green;
960
- }
961
- function printLog(type, color, icon, message) {
962
- var chalkColor = chalkKeyword(color);
963
- console.log("".concat(getTimeStamp(), " ").concat(chalkColor("".concat(icon, " ").concat(type)), " ").concat(message));
964
- }
965
- function printBoxedLog(title, content) {
966
- var _ref = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}, _ref_color = _ref.color, color = _ref_color === void 0 ? "green" : _ref_color, _ref_padding = _ref.padding, padding = _ref_padding === void 0 ? 1 : _ref_padding, _ref_margin = _ref.margin, margin = _ref_margin === void 0 ? 1 : _ref_margin, _ref_borderStyle = _ref.borderStyle, borderStyle = _ref_borderStyle === void 0 ? "round" : _ref_borderStyle, _ref_titleColor = _ref.titleColor, titleColor = _ref_titleColor === void 0 ? "bold" : _ref_titleColor;
967
- var chalkColor = chalkKeyword(color);
968
- var chalkTitleColor = chalkKeyword(titleColor);
969
- if (typeof content === "string") {
970
- console.log(boxen(chalkTitleColor(chalkColor("".concat(title, "\n").concat(content))), {
971
- padding: padding,
972
- margin: margin,
973
- borderStyle: borderStyle,
974
- borderColor: color
975
- }));
976
- return;
977
- }
978
- if (Array.isArray(content) && content.length) {
979
- content.forEach(function(param) {
980
- var file = param.file, position = param.position, rule = param.rule, message = param.message;
981
- console.log("".concat(getTimeStamp(), " ").concat(chalkColor("File:"), " ").concat(blue("".concat(file).concat(position ? ":".concat(position) : ""))));
982
- if (rule) console.log(" ".concat(chalkColor("Rule:"), " ").concat(chalkColor(rule)));
983
- console.log(" ".concat(chalkColor("Message:"), " ").concat(chalkColor(message)));
984
- });
985
- console.log(boxen(chalkTitleColor(chalkColor("".concat(title, ": ").concat(content.length))), {
986
- padding: padding,
987
- margin: margin,
988
- borderStyle: borderStyle,
989
- borderColor: color
990
- }));
991
- console.log(gray("\u2500".repeat(40)));
992
- }
993
- }
994
- var commandLog = {
995
- success: function(message) {
996
- return printLog("SUCCESS", "green", "\u2714", message);
997
- },
998
- error: function(message) {
999
- return printLog("ERROR", "red", "\u2716", message);
1000
- },
1001
- warning: function(message) {
1002
- return printLog("WARNING", "yellow", "\u26A0", message);
1003
- },
1004
- info: function(message) {
1005
- return printLog("INFO", "blue", "\u2139", message);
1006
- },
1007
- printBoxedLog: printBoxedLog
1008
- };
1009
- var getErrorListKey = function(timestamp) {
1010
- return "error_list:".concat(timestamp);
1011
- };
1012
- function saveErrorListToStorage(errorList) {
1013
- return _saveErrorListToStorage.apply(this, arguments);
1014
- }
1015
- function _saveErrorListToStorage() {
1016
- _saveErrorListToStorage = _async_to_generator(function(errorList) {
1017
- var timestamp, key, error;
1018
- return _ts_generator(this, function(_state) {
1019
- switch(_state.label){
1020
- case 0:
1021
- if (errorList.length === 0) {
1022
- return [
1023
- 2
1024
- ];
1025
- }
1026
- timestamp = Date.now();
1027
- key = getErrorListKey(timestamp);
1028
- _state.label = 1;
1029
- case 1:
1030
- _state.trys.push([
1031
- 1,
1032
- 3,
1033
- ,
1034
- 4
1035
- ]);
1036
- return [
1037
- 4,
1038
- storageServer.set(key, {
1039
- errors: errorList,
1040
- timestamp: timestamp
1041
- })
1042
- ];
1043
- case 2:
1044
- _state.sent();
1045
- setTimeout(/*#__PURE__*/ _async_to_generator(function() {
1046
- var logPath;
1047
- return _ts_generator(this, function(_state) {
1048
- switch(_state.label){
1049
- case 0:
1050
- return [
1051
- 4,
1052
- storageServer.getLogLink(key)
1053
- ];
1054
- case 1:
1055
- logPath = _state.sent();
1056
- if (logPath) {
1057
- commandLog.info("\uD83D\uDCC2 Open the error list manually: ".concat(logPath));
1058
- }
1059
- return [
1060
- 2
1061
- ];
1062
- }
1063
- });
1064
- }), 10);
1065
- return [
1066
- 3,
1067
- 4
1068
- ];
1069
- case 3:
1070
- error = _state.sent();
1071
- commandLog.error("Failed to save errors: ".concat(error.message));
1072
- return [
1073
- 3,
1074
- 4
1075
- ];
1076
- case 4:
1077
- return [
1078
- 2
1079
- ];
1080
- }
1081
- });
1082
- });
1083
- return _saveErrorListToStorage.apply(this, arguments);
1084
- }
1085
- function getStoredErrorLists() {
1086
- return _getStoredErrorLists.apply(this, arguments);
1087
- }
1088
- function _getStoredErrorLists() {
1089
- _getStoredErrorLists = _async_to_generator(function() {
1090
- var keys, errorKeys, allErrors, error;
1091
- return _ts_generator(this, function(_state) {
1092
- switch(_state.label){
1093
- case 0:
1094
- _state.trys.push([
1095
- 0,
1096
- 3,
1097
- ,
1098
- 4
1099
- ]);
1100
- return [
1101
- 4,
1102
- storageServer.keys()
1103
- ];
1104
- case 1:
1105
- keys = _state.sent();
1106
- errorKeys = Array.isArray(keys) ? keys.filter(function(key) {
1107
- var _key_startsWith;
1108
- return key === null || key === void 0 ? void 0 : (_key_startsWith = key.startsWith) === null || _key_startsWith === void 0 ? void 0 : _key_startsWith.call(key, "error_list:");
1109
- }) : [];
1110
- return [
1111
- 4,
1112
- Promise.all(errorKeys.map(/*#__PURE__*/ function() {
1113
- var _ref = _async_to_generator(function(key) {
1114
- var entry;
1115
- return _ts_generator(this, function(_state) {
1116
- switch(_state.label){
1117
- case 0:
1118
- return [
1119
- 4,
1120
- storageServer.get(key)
1121
- ];
1122
- case 1:
1123
- entry = _state.sent();
1124
- return [
1125
- 2,
1126
- (entry === null || entry === void 0 ? void 0 : entry.errors) || []
1127
- ];
1128
- }
1129
- });
1130
- });
1131
- return function(key) {
1132
- return _ref.apply(this, arguments);
1133
- };
1134
- }()))
1135
- ];
1136
- case 2:
1137
- allErrors = _state.sent();
1138
- return [
1139
- 2,
1140
- allErrors.flat()
1141
- ];
1142
- case 3:
1143
- error = _state.sent();
1144
- commandLog.error("Failed to retrieve stored errors: ".concat(error.message));
1145
- return [
1146
- 2,
1147
- []
1148
- ];
1149
- case 4:
1150
- return [
1151
- 2
1152
- ];
1153
- }
1154
- });
1155
- });
1156
- return _getStoredErrorLists.apply(this, arguments);
1157
- }
1158
- function clearAllErrorLists() {
1159
- return _clearAllErrorLists.apply(this, arguments);
1160
- }
1161
- function _clearAllErrorLists() {
1162
- _clearAllErrorLists = _async_to_generator(function() {
1163
- var keys, errorKeys, error;
1164
- return _ts_generator(this, function(_state) {
1165
- switch(_state.label){
1166
- case 0:
1167
- _state.trys.push([
1168
- 0,
1169
- 3,
1170
- ,
1171
- 4
1172
- ]);
1173
- return [
1174
- 4,
1175
- storageServer.keys()
1176
- ];
1177
- case 1:
1178
- keys = _state.sent();
1179
- errorKeys = Array.isArray(keys) ? keys.filter(function(key) {
1180
- var _key_startsWith;
1181
- return key === null || key === void 0 ? void 0 : (_key_startsWith = key.startsWith) === null || _key_startsWith === void 0 ? void 0 : _key_startsWith.call(key, "error_list:");
1182
- }) : [];
1183
- return [
1184
- 4,
1185
- Promise.all(errorKeys.map(function(key) {
1186
- return storageServer.remove(key);
1187
- }))
1188
- ];
1189
- case 2:
1190
- _state.sent();
1191
- return [
1192
- 3,
1193
- 4
1194
- ];
1195
- case 3:
1196
- error = _state.sent();
1197
- commandLog.error("Failed to clear error lists: ".concat(error.message));
1198
- return [
1199
- 3,
1200
- 4
1201
- ];
1202
- case 4:
1203
- return [
1204
- 2
1205
- ];
1206
- }
1207
- });
1208
- });
1209
- return _clearAllErrorLists.apply(this, arguments);
1210
- }
1211
- function parseTextErrors(output) {
1212
- var errorList = [];
1213
- var unmatchedLines = [];
1214
- var lastFilePath = "";
1215
- var eslintErrorDetailsRegex = /^\s*(\d+):(\d+)\s+(error|warning)\s+(.+?)\s+(\S+)$/;
1216
- var tsRegex = /^(.+?)\((\d+),(\d+)\):\s+(error|warning)\s+TS\d+:\s+(\S.+)$/;
1217
- var commitlintRegex = /^✖\s+(.*?)\s+\[(.*?)\]$/;
1218
- output.split("\n").forEach(function(line) {
1219
- if (line.startsWith("/")) {
1220
- lastFilePath = line.trim();
1221
- } else {
1222
- var eslintMatch = eslintErrorDetailsRegex.exec(line) || [];
1223
- var tsMatch = tsRegex.exec(line) || [];
1224
- var commitlintMatch = commitlintRegex.exec(line) || [];
1225
- if (eslintMatch.length && lastFilePath) {
1226
- errorList.push({
1227
- file: lastFilePath,
1228
- position: "".concat(eslintMatch[1], ":").concat(eslintMatch[2]),
1229
- type: eslintMatch[3] === "error" /* Error */ ? "error" /* Error */ : "warning" /* Warning */ ,
1230
- message: eslintMatch[4].trim(),
1231
- rule: eslintMatch[5].trim()
1232
- });
1233
- } else if (tsMatch.length) {
1234
- errorList.push({
1235
- file: tsMatch[1],
1236
- position: "".concat(tsMatch[2], ":").concat(tsMatch[3]),
1237
- type: tsMatch[4] === "error" /* Error */ ? "error" /* Error */ : "warning" /* Warning */ ,
1238
- message: tsMatch[5].trim()
1239
- });
1240
- } else if (commitlintMatch.length) {
1241
- errorList.push({
1242
- file: "commitlint",
1243
- type: "error" /* Error */ ,
1244
- message: commitlintMatch[1].trim(),
1245
- rule: commitlintMatch[2].trim()
1246
- });
1247
- } else {
1248
- unmatchedLines.push(line.trim());
1249
- }
1250
- }
1251
- });
1252
- if (errorList.length) {
1253
- saveErrorListToStorage(errorList);
1254
- }
1255
- if (unmatchedLines.length && DEBUG) {
1256
- commandLog.warning("Unmatched lines:");
1257
- unmatchedLines.forEach(function(line) {
1258
- return console.log(" ".concat(line));
1259
- });
1260
- }
1261
- }
1262
- function parseCommandOutput(output) {
1263
- try {
1264
- var results = JSON.parse(output);
1265
- var errorList = [];
1266
- results.forEach(function(param) {
1267
- var filePath = param.filePath, messages = param.messages;
1268
- messages.forEach(function(param) {
1269
- var severity = param.severity, line = param.line, column = param.column, ruleId = param.ruleId, message = param.message;
1270
- errorList.push({
1271
- type: severity === 2 ? "error" /* Error */ : "warning" /* Warning */ ,
1272
- file: filePath,
1273
- position: "".concat(line, ":").concat(column),
1274
- rule: ruleId,
1275
- message: message
1276
- });
1277
- });
1278
- });
1279
- if (errorList.length) {
1280
- saveErrorListToStorage(errorList);
1281
- }
1282
- } catch (e) {
1283
- parseTextErrors(output);
1284
- }
1285
- }
1286
- function executeCommand(command) {
1287
- return _executeCommand.apply(this, arguments);
1288
- }
1289
- function _executeCommand() {
1290
- _executeCommand = _async_to_generator(function(command) {
1291
- var parser, controller, _ref, stdout, stderr, error, stdout1, stderr1, message;
1292
- var _arguments = arguments;
1293
- return _ts_generator(this, function(_state) {
1294
- switch(_state.label){
1295
- case 0:
1296
- parser = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : parseCommandOutput;
1297
- controller = new AbortController();
1298
- process2.on("SIGINT", function() {
1299
- commandLog.warning("Process interrupted. Terminating...");
1300
- controller.abort();
1301
- process2.exit();
1302
- });
1303
- _state.label = 1;
1304
- case 1:
1305
- _state.trys.push([
1306
- 1,
1307
- 3,
1308
- ,
1309
- 4
1310
- ]);
1311
- return [
1312
- 4,
1313
- execPromise(command, {
1314
- maxBuffer: 1024 * 1024 * 100,
1315
- signal: controller.signal
1316
- })
1317
- ];
1318
- case 2:
1319
- _ref = _state.sent(), stdout = _ref.stdout, stderr = _ref.stderr;
1320
- [
1321
- stdout,
1322
- stderr
1323
- ].forEach(function(output) {
1324
- return output && parser(output);
1325
- });
1326
- return [
1327
- 3,
1328
- 4
1329
- ];
1330
- case 3:
1331
- error = _state.sent();
1332
- stdout1 = error.stdout, stderr1 = error.stderr, message = error.message;
1333
- [
1334
- stdout1,
1335
- stderr1
1336
- ].forEach(function(output) {
1337
- return output && parser(output);
1338
- });
1339
- if (!stderr1 && !stdout1) {
1340
- commandLog.error("Command failed: ".concat(message));
1341
- }
1342
- return [
1343
- 3,
1344
- 4
1345
- ];
1346
- case 4:
1347
- return [
1348
- 2
1349
- ];
1350
- }
1351
- });
1352
- });
1353
- return _executeCommand.apply(this, arguments);
1354
- }
1355
- var commandFormatter = {
1356
- raw: function(cmd) {
1357
- return {
1358
- raw: true,
1359
- cmd: cmd
1360
- };
1361
- },
1362
- isRaw: function isRaw(cmd) {
1363
- return (typeof cmd === "undefined" ? "undefined" : _type_of(cmd)) === "object" && cmd !== null && cmd.raw === true;
1364
- },
1365
- format: function format(command, context) {
1366
- if (typeof command === "function") {
1367
- return commandFormatter.formatCLI(command(context), context);
1368
- }
1369
- if (commandFormatter.isRaw(command)) {
1370
- return command.cmd;
1371
- }
1372
- return commandFormatter.formatCLI(command, context);
1373
- },
1374
- formatCLI: function formatCLI(command, context) {
1375
- if (context === null || context === void 0 ? void 0 : context.isRemote) {
1376
- return "".concat(PNPM_DLX_CLI, " ").concat(CYBERSKILL_PACKAGE_NAME, " ").concat(command);
1377
- }
1378
- if (context === null || context === void 0 ? void 0 : context.isCurrentProject) {
1379
- return "".concat(PNPM_EXEC_CLI, " ").concat(TSX_CLI, " src/cli.ts ").concat(command);
1380
- }
1381
- return "".concat(PNPM_EXEC_CLI, " ").concat(CYBERSKILL_CLI, " ").concat(command);
1382
- }
1383
- };
1384
- function resolveCommands(input) {
1385
- return _resolveCommands.apply(this, arguments);
1386
- }
1387
- function _resolveCommands() {
1388
- _resolveCommands = _async_to_generator(function(input) {
1389
- var context, _context_isRemote, isRemote, isCurrentProject, _tmp, ctx, commands;
1390
- var _arguments = arguments;
1391
- return _ts_generator(this, function(_state) {
1392
- switch(_state.label){
1393
- case 0:
1394
- context = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : {};
1395
- isRemote = (_context_isRemote = context === null || context === void 0 ? void 0 : context.isRemote) !== null && _context_isRemote !== void 0 ? _context_isRemote : false;
1396
- if (!isRemote) return [
1397
- 3,
1398
- 1
1399
- ];
1400
- _tmp = false;
1401
- return [
1402
- 3,
1403
- 3
1404
- ];
1405
- case 1:
1406
- return [
1407
- 4,
1408
- checkPackage(CYBERSKILL_PACKAGE_NAME)
1409
- ];
1410
- case 2:
1411
- _tmp = _state.sent().isCurrentProject;
1412
- _state.label = 3;
1413
- case 3:
1414
- isCurrentProject = _tmp;
1415
- ctx = {
1416
- isRemote: isRemote,
1417
- isCurrentProject: isCurrentProject
1418
- };
1419
- commands = typeof input === "function" ? input(ctx) : input;
1420
- return [
1421
- 2,
1422
- Object.fromEntries(Object.entries(commands).map(function(param) {
1423
- var _param = _sliced_to_array(param, 2), key = _param[0], cmd = _param[1];
1424
- return [
1425
- key,
1426
- commandFormatter.format(cmd, ctx)
1427
- ];
1428
- }))
1429
- ];
1430
- }
1431
- });
1432
- });
1433
- return _resolveCommands.apply(this, arguments);
1434
- }
1435
- // src/constants/path.ts
1436
- var __filename2 = fileURLToPath(import.meta.url);
1437
- var __dirname2 = dirname2(__filename2);
1438
- var CYBERSKILL_DIRECTORY = resolve2(__dirname2, "../../");
1439
- var WORKING_DIRECTORY = process3.env.INIT_CWD || process3.cwd();
1440
- var CYBERSKILL_PACKAGE_NAME = "@cyberskill/shared";
1441
- var CYBERSKILL_STORAGE = ".cyberskill-storage";
1442
- var NODE_MODULES = "node_modules";
1443
- var BUILD_DIRECTORY = "dist";
1444
- var PACKAGE_JSON = "package.json";
1445
- var PACKAGE_LOCK_JSON = "package-lock.json";
1446
- var TSCONFIG_JSON = "tsconfig.json";
1447
- var GIT_IGNORE = ".gitignore";
1448
- var SIMPLE_GIT_HOOK_JSON = ".simple-git-hooks.json";
1449
- var PNPM_LOCK_YAML = "pnpm-lock.yaml";
1450
- var GIT_HOOK = ".git/hooks";
1451
- var GIT_COMMIT_EDITMSG = ".git/COMMIT_EDITMSG";
1452
- var CYBERSKILL_CLI = "cyberskill";
1453
- var ESLINT_CLI = "eslint";
1454
- var VITEST_CLI = "vitest";
1455
- var COMMIT_LINT_CLI = "commitlint";
1456
- var LINT_STAGED_CLI = "lint-staged";
1457
- var RIMRAF_CLI = "rimraf";
1458
- var TSC_CLI = "tsc";
1459
- var TSX_CLI = "tsx";
1460
- var GIT_CLI = "git";
1461
- var PNPM_CLI = "pnpm";
1462
- var PNPM_DLX_CLI = "pnpm dlx";
1463
- var PNPM_EXEC_CLI = "pnpm exec";
1464
- var SIMPLE_GIT_HOOK_CLI = "simple-git-hooks";
1465
- var ESLINT_INSPECT_CLI = "@eslint/config-inspector";
1466
- var NODE_MODULES_INSPECT_CLI = "node_modules-inspect";
1467
- var PATH = {
1468
- CYBERSKILL_DIRECTORY: CYBERSKILL_DIRECTORY,
1469
- WORKING_DIRECTORY: WORKING_DIRECTORY,
1470
- TS_CONFIG: resolveWorkingPath(TSCONFIG_JSON),
1471
- GIT_IGNORE: resolveWorkingPath(GIT_IGNORE),
1472
- GIT_HOOK: resolveWorkingPath(GIT_HOOK),
1473
- GIT_COMMIT_MSG: resolveWorkingPath(GIT_COMMIT_EDITMSG),
1474
- SIMPLE_GIT_HOOKS: resolveWorkingPath(SIMPLE_GIT_HOOK_JSON),
1475
- PACKAGE_JSON: resolveWorkingPath(PACKAGE_JSON),
1476
- PACKAGE_LOCK_JSON: resolveWorkingPath(PACKAGE_LOCK_JSON),
1477
- PNPM_LOCK_YAML: resolveWorkingPath(PNPM_LOCK_YAML),
1478
- NODE_MODULES: resolveWorkingPath(NODE_MODULES),
1479
- CYBERSKILL: {
1480
- LINT_STAGED_CONFIG: resolveCyberSkillPath("./configs/lint-staged/base.js"),
1481
- COMMITLINT_CONFIG: resolveCyberSkillPath("./configs/commitlint/base.js"),
1482
- UNIT_TEST_CONFIG: resolveCyberSkillPath("./configs/vitest/react/unit.js"),
1483
- E2E_TEST_CONFIG: resolveCyberSkillPath("./configs/vitest/react/e2e.js")
1484
- }
1485
- };
1486
- function HOOK(param) {
1487
- var isCurrentProject = param.isCurrentProject;
1488
- return _object_spread({
1489
- "postinstall": "setup",
1490
- "pre-commit": LINT_STAGED_CLI,
1491
- "commit-msg": COMMIT_LINT_CLI
1492
- }, isCurrentProject && {
1493
- "pre-push": commandFormatter.raw("".concat(GIT_CLI, " pull"))
1494
- });
1495
- }
1496
- var COMMAND = {
1497
- SIMPLE_GIT_HOOKS: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(SIMPLE_GIT_HOOK_CLI)),
1498
- ESLINT_INSPECT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_INSPECT_CLI)),
1499
- NODE_MODULES_INSPECT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(NODE_MODULES_INSPECT_CLI)),
1500
- RESET: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(RIMRAF_CLI, " ").concat(NODE_MODULES, " ").concat(PNPM_LOCK_YAML)),
1501
- ESLINT_CHECK: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_CLI, " ").concat(PATH.WORKING_DIRECTORY)),
1502
- ESLINT_FIX: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_CLI, " ").concat(PATH.WORKING_DIRECTORY, " --fix")),
1503
- TYPESCRIPT_CHECK: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(TSC_CLI, " -p ").concat(PATH.TS_CONFIG, " --noEmit")),
1504
- CYBERSKILL: {
1505
- TEST_UNIT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(VITEST_CLI, " --config ").concat(PATH.CYBERSKILL.UNIT_TEST_CONFIG)),
1506
- TEST_E2E: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(VITEST_CLI, " --config ").concat(PATH.CYBERSKILL.E2E_TEST_CONFIG)),
1507
- COMMIT_LINT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(COMMIT_LINT_CLI, " --edit ").concat(PATH.GIT_COMMIT_MSG, " --config ").concat(PATH.CYBERSKILL.COMMITLINT_CONFIG)),
1508
- LINT_STAGED: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(LINT_STAGED_CLI, " --config ").concat(PATH.CYBERSKILL.LINT_STAGED_CONFIG))
1509
- },
1510
- CONFIGURE_GIT_HOOK: commandFormatter.raw("".concat(GIT_CLI, " config core.hooksPath ").concat(PATH.GIT_HOOK)),
1511
- BUILD: commandFormatter.raw("".concat(PNPM_CLI, " run build")),
1512
- STAGE_BUILD_DIRECTORY: commandFormatter.raw("".concat(GIT_CLI, " add ").concat(BUILD_DIRECTORY)),
1513
- PNPM_INSTALL_STANDARD: commandFormatter.raw("".concat(PNPM_CLI, " install")),
1514
- PNPM_INSTALL_LEGACY: commandFormatter.raw("".concat(PNPM_CLI, " install --legacy-peer-deps")),
1515
- PNPM_INSTALL_FORCE: commandFormatter.raw("".concat(PNPM_CLI, " install --force"))
1516
- };
1517
- // src/constants/response-status.ts
1518
- var RESPONSE_STATUS = {
1519
- GRAPHQL_PARSE_FAILED: {
1520
- CODE: "GRAPHQL_PARSE_FAILED",
1521
- MESSAGE: "The GraphQL operation string contains a syntax error."
1522
- },
1523
- GRAPHQL_VALIDATION_FAILED: {
1524
- CODE: "GRAPHQL_VALIDATION_FAILED",
1525
- MESSAGE: "The GraphQL operation is not valid against the server's schema."
1526
- },
1527
- BAD_USER_INPUT: {
1528
- CODE: "BAD_USER_INPUT",
1529
- MESSAGE: "The GraphQL operation includes an invalid value for a field argument."
1530
- },
1531
- PERSISTED_QUERY_NOT_FOUND: {
1532
- CODE: "PERSISTED_QUERY_NOT_FOUND",
1533
- MESSAGE: "A client sent the hash of a query string to execute via automatic persisted queries, but the query was not in the APQ cache."
1534
- },
1535
- PERSISTED_QUERY_NOT_SUPPORTED: {
1536
- CODE: "PERSISTED_QUERY_NOT_SUPPORTED",
1537
- MESSAGE: "A client sent the hash of a query string to execute via automatic persisted queries, but the server has disabled APQ."
1538
- },
1539
- OPERATION_RESOLUTION_FAILURE: {
1540
- CODE: "OPERATION_RESOLUTION_FAILURE",
1541
- MESSAGE: "The request was parsed successfully and is valid against the server's schema, but the server couldn't resolve which operation to run. This occurs when a request containing multiple named operations doesn't specify which operation to run (i.e.,operationName), or if the named operation isn't included in the request."
1542
- },
1543
- CONTINUE: {
1544
- CODE: 100,
1545
- MESSAGE: "Continue"
1546
- },
1547
- SWITCHING_PROTOCOLS: {
1548
- CODE: 101,
1549
- MESSAGE: "Switching Protocols"
1550
- },
1551
- PROCESSING: {
1552
- CODE: 102,
1553
- MESSAGE: "Processing"
1554
- },
1555
- OK: {
1556
- CODE: 200,
1557
- MESSAGE: "OK"
1558
- },
1559
- CREATED: {
1560
- CODE: 201,
1561
- MESSAGE: "Created"
1562
- },
1563
- ACCEPTED: {
1564
- CODE: 202,
1565
- MESSAGE: "Accepted"
1566
- },
1567
- NON_AUTHORITATIVE_INFORMATION: {
1568
- CODE: 203,
1569
- MESSAGE: "Non Authoritative Information"
1570
- },
1571
- NO_CONTENT: {
1572
- CODE: 204,
1573
- MESSAGE: "No Content"
1574
- },
1575
- RESET_CONTENT: {
1576
- CODE: 205,
1577
- MESSAGE: "Reset Content"
1578
- },
1579
- PARTIAL_CONTENT: {
1580
- CODE: 206,
1581
- MESSAGE: "Partial Content"
1582
- },
1583
- MULTI_STATUS: {
1584
- CODE: 207,
1585
- MESSAGE: "Multi-Status"
1586
- },
1587
- MULTIPLE_CHOICES: {
1588
- CODE: 300,
1589
- MESSAGE: "Multiple Choices"
1590
- },
1591
- MOVED_PERMANENTLY: {
1592
- CODE: 301,
1593
- MESSAGE: "Moved Permanently"
1594
- },
1595
- MOVED_TEMPORARILY: {
1596
- CODE: 302,
1597
- MESSAGE: "Moved Temporarily"
1598
- },
1599
- SEE_OTHER: {
1600
- CODE: 303,
1601
- MESSAGE: "See Other"
1602
- },
1603
- NOT_MODIFIED: {
1604
- CODE: 304,
1605
- MESSAGE: "Not Modified"
1606
- },
1607
- USE_PROXY: {
1608
- CODE: 305,
1609
- MESSAGE: "Use Proxy"
1610
- },
1611
- TEMPORARY_REDIRECT: {
1612
- CODE: 307,
1613
- MESSAGE: "Temporary Redirect"
1614
- },
1615
- PERMANENT_REDIRECT: {
1616
- CODE: 308,
1617
- MESSAGE: "Permanent Redirect"
1618
- },
1619
- BAD_REQUEST: {
1620
- CODE: 400,
1621
- MESSAGE: "Bad Request"
1622
- },
1623
- UNAUTHORIZED: {
1624
- CODE: 401,
1625
- MESSAGE: "Unauthorized"
1626
- },
1627
- PAYMENT_REQUIRED: {
1628
- CODE: 402,
1629
- MESSAGE: "Payment Required"
1630
- },
1631
- FORBIDDEN: {
1632
- CODE: 403,
1633
- MESSAGE: "Forbidden"
1634
- },
1635
- NOT_FOUND: {
1636
- CODE: 404,
1637
- MESSAGE: "Not Found"
1638
- },
1639
- METHOD_NOT_ALLOWED: {
1640
- CODE: 405,
1641
- MESSAGE: "Method Not Allowed"
1642
- },
1643
- NOT_ACCEPTABLE: {
1644
- CODE: 406,
1645
- MESSAGE: "Not Acceptable"
1646
- },
1647
- PROXY_AUTHENTICATION_REQUIRED: {
1648
- CODE: 407,
1649
- MESSAGE: "Proxy Authentication Required"
1650
- },
1651
- REQUEST_TIMEOUT: {
1652
- CODE: 408,
1653
- MESSAGE: "Request Timeout"
1654
- },
1655
- CONFLICT: {
1656
- CODE: 409,
1657
- MESSAGE: "Conflict"
1658
- },
1659
- GONE: {
1660
- CODE: 410,
1661
- MESSAGE: "Gone"
1662
- },
1663
- LENGTH_REQUIRED: {
1664
- CODE: 411,
1665
- MESSAGE: "Length Required"
1666
- },
1667
- PRECONDITION_FAILED: {
1668
- CODE: 412,
1669
- MESSAGE: "Precondition Failed"
1670
- },
1671
- REQUEST_TOO_LONG: {
1672
- CODE: 413,
1673
- MESSAGE: "Request Entity Too Large"
1674
- },
1675
- REQUEST_URI_TOO_LONG: {
1676
- CODE: 414,
1677
- MESSAGE: "Request-URI Too Long"
1678
- },
1679
- UNSUPPORTED_MEDIA_TYPE: {
1680
- CODE: 415,
1681
- MESSAGE: "Unsupported Media Type"
1682
- },
1683
- REQUESTED_RANGE_NOT_SATISFIABLE: {
1684
- CODE: 416,
1685
- MESSAGE: "Requested Range Not Satisfiable"
1686
- },
1687
- EXPECTATION_FAILED: {
1688
- CODE: 417,
1689
- MESSAGE: "Expectation Failed"
1690
- },
1691
- IM_A_TEAPOT: {
1692
- CODE: 418,
1693
- MESSAGE: "I'm a teapot"
1694
- },
1695
- INSUFFICIENT_SPACE_ON_RESOURCE: {
1696
- CODE: 419,
1697
- MESSAGE: "Insufficient Space on Resource"
1698
- },
1699
- METHOD_FAILURE: {
1700
- CODE: 420,
1701
- MESSAGE: "Method Failure"
1702
- },
1703
- MISDIRECTED_REQUEST: {
1704
- CODE: 421,
1705
- MESSAGE: "Misdirected Request"
1706
- },
1707
- UNPROCESSABLE_ENTITY: {
1708
- CODE: 422,
1709
- MESSAGE: "Unprocessable Entity"
1710
- },
1711
- LOCKED: {
1712
- CODE: 423,
1713
- MESSAGE: "Locked"
1714
- },
1715
- FAILED_DEPENDENCY: {
1716
- CODE: 424,
1717
- MESSAGE: "Failed Dependency"
1718
- },
1719
- PRECONDITION_REQUIRED: {
1720
- CODE: 428,
1721
- MESSAGE: "Precondition Required"
1722
- },
1723
- TOO_MANY_REQUESTS: {
1724
- CODE: 429,
1725
- MESSAGE: "Too Many Requests"
1726
- },
1727
- REQUEST_HEADER_FIELDS_TOO_LARGE: {
1728
- CODE: 431,
1729
- MESSAGE: "Request Header Fields Too Large"
1730
- },
1731
- UNAVAILABLE_FOR_LEGAL_REASONS: {
1732
- CODE: 451,
1733
- MESSAGE: "Unavailable For Legal Reasons"
1734
- },
1735
- INTERNAL_SERVER_ERROR: {
1736
- CODE: 500,
1737
- MESSAGE: "Internal Server Error"
1738
- },
1739
- NOT_IMPLEMENTED: {
1740
- CODE: 501,
1741
- MESSAGE: "Not Implemented"
1742
- },
1743
- BAD_GATEWAY: {
1744
- CODE: 502,
1745
- MESSAGE: "Bad Gateway"
1746
- },
1747
- SERVICE_UNAVAILABLE: {
1748
- CODE: 503,
1749
- MESSAGE: "Service Unavailable"
1750
- },
1751
- GATEWAY_TIMEOUT: {
1752
- CODE: 504,
1753
- MESSAGE: "Gateway Timeout"
1754
- },
1755
- HTTP_VERSION_NOT_SUPPORTED: {
1756
- CODE: 505,
1757
- MESSAGE: "HTTP Version Not Supported"
1758
- },
1759
- INSUFFICIENT_STORAGE: {
1760
- CODE: 507,
1761
- MESSAGE: "Insufficient Storage"
1762
- },
1763
- NETWORK_AUTHENTICATION_REQUIRED: {
1764
- CODE: 511,
1765
- MESSAGE: "Network Authentication Required"
1766
- }
1767
- };
1768
- // src/nodejs/mongo.ts
1769
- import { format } from "date-fns";
1770
- import { Document } from "mongoose";
1771
- import aggregatePaginate from "mongoose-aggregate-paginate-v2";
1772
- import mongoosePaginate from "mongoose-paginate-v2";
1773
- import { v4 as uuidv4 } from "uuid";
1774
- // src/utils/string.ts
1775
- import cryptoJS from "crypto-js";
1776
- import slugifyRaw from "slugify";
1777
- var slugify = slugifyRaw.default || slugifyRaw;
1778
- function generateSlug() {
1779
- var str = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : "", options = arguments.length > 1 ? arguments[1] : void 0;
1780
- var _ref = options || {}, _ref_lower = _ref.lower, lower = _ref_lower === void 0 ? true : _ref_lower, _ref_locale = _ref.locale, locale = _ref_locale === void 0 ? "vi" : _ref_locale, rest = _object_without_properties(_ref, [
1781
- "lower",
1782
- "locale"
1783
- ]);
1784
- return slugify(str, _object_spread({
1785
- lower: lower,
1786
- locale: locale
1787
- }, rest));
1788
- }
1789
- function generateShortId(uuid) {
1790
- var length = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 4;
1791
- return cryptoJS.SHA256(uuid).toString(cryptoJS.enc.Hex).slice(0, length);
1792
- }
1793
- // src/utils/validate.ts
1794
- var validate = {
1795
- isEmpty: function isEmpty(value) {
1796
- if (value === null || value === void 0) {
1797
- return true;
1798
- }
1799
- if (Array.isArray(value)) {
1800
- return value.length === 0;
1801
- }
1802
- if ((typeof value === "undefined" ? "undefined" : _type_of(value)) === "object") {
1803
- if (_instanceof(value, Date)) {
1804
- return false;
1805
- }
1806
- return Object.keys(value).length === 0;
1807
- }
1808
- if (typeof value === "string") {
1809
- return value.trim().length === 0;
1810
- }
1811
- return false;
1812
- }
1813
- };
1814
- // src/nodejs/mongo.ts
1815
- var mongo = {
1816
- getDateTime: function getDateTime() {
1817
- var now = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : /* @__PURE__ */ new Date();
1818
- return format(now, "yyyy-MM-dd HH:mm:ss.SSS");
1819
- },
1820
- createGenericFields: function createGenericFields() {
1821
- var _ref = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, _ref_returnDateAs = _ref.returnDateAs, returnDateAs = _ref_returnDateAs === void 0 ? "string" : _ref_returnDateAs;
1822
- var now = returnDateAs === "string" ? mongo.getDateTime() : /* @__PURE__ */ new Date();
1823
- return {
1824
- id: uuidv4(),
1825
- isDel: false,
1826
- createdAt: now,
1827
- updatedAt: now
1828
- };
1829
- },
1830
- applyPlugins: function applyPlugins(schema, plugins) {
1831
- plugins.filter(function(plugin) {
1832
- return typeof plugin === "function";
1833
- }).forEach(function(plugin) {
1834
- return schema.plugin(plugin);
1835
- });
1836
- },
1837
- applyMiddlewares: function applyMiddlewares(schema, middlewares) {
1838
- middlewares.forEach(function(param) {
1839
- var method = param.method, pre = param.pre, post = param.post;
1840
- if (method && pre) {
1841
- schema.pre(method, pre);
1842
- }
1843
- if (method && post) {
1844
- schema.post(method, post);
1845
- }
1846
- });
1847
- },
1848
- createGenericSchema: function createGenericSchema(mongoose) {
1849
- return new mongoose.Schema({
1850
- id: {
1851
- type: String,
1852
- default: uuidv4,
1853
- required: true,
1854
- unique: true
1855
- },
1856
- isDel: {
1857
- type: Boolean,
1858
- default: false,
1859
- required: true
1860
- }
1861
- }, {
1862
- timestamps: true
1863
- });
1864
- },
1865
- createSchema: function createSchema(param) {
1866
- var mongoose = param.mongoose, schema = param.schema, _param_virtuals = param.virtuals, virtuals = _param_virtuals === void 0 ? [] : _param_virtuals, _param_standalone = param.standalone, standalone = _param_standalone === void 0 ? false : _param_standalone;
1867
- var createdSchema = new mongoose.Schema(schema, {
1868
- strict: true
1869
- });
1870
- virtuals.forEach(function(param) {
1871
- var name = param.name, options = param.options, get = param.get;
1872
- var virtualInstance = createdSchema.virtual(name, options);
1873
- if (get) virtualInstance.get(get);
1874
- });
1875
- if (!standalone) {
1876
- createdSchema.add(mongo.createGenericSchema(mongoose));
1877
- }
1878
- return createdSchema;
1879
- },
1880
- createModel: function createModel(param) {
1881
- var currentMongooseInstance = param.mongoose, name = param.name, schema = param.schema, _param_pagination = param.pagination, pagination = _param_pagination === void 0 ? false : _param_pagination, _param_aggregate = param.aggregate, aggregate = _param_aggregate === void 0 ? false : _param_aggregate, _param_virtuals = param.virtuals, virtuals = _param_virtuals === void 0 ? [] : _param_virtuals, _param_middlewares = param.middlewares, middlewares = _param_middlewares === void 0 ? [] : _param_middlewares;
1882
- if (!name) {
1883
- throw new Error("Model name is required.");
1884
- }
1885
- if (currentMongooseInstance.models[name]) {
1886
- return currentMongooseInstance.models[name];
1887
- }
1888
- var createdSchema = mongo.createSchema({
1889
- mongoose: currentMongooseInstance,
1890
- schema: schema,
1891
- virtuals: virtuals
1892
- });
1893
- mongo.applyPlugins(createdSchema, [
1894
- pagination && mongoosePaginate,
1895
- aggregate && aggregatePaginate
1896
- ]);
1897
- mongo.applyMiddlewares(createdSchema, middlewares);
1898
- return currentMongooseInstance.model(name, createdSchema);
1899
- },
1900
- createSlugQuery: function createSlugQuery(slug) {
1901
- var filters = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, id = arguments.length > 2 ? arguments[2] : void 0;
1902
- return _object_spread_props(_object_spread({}, filters, id && {
1903
- id: {
1904
- $ne: id
1905
- }
1906
- }), {
1907
- $or: [
1908
- {
1909
- slug: slug
1910
- },
1911
- {
1912
- slugHistory: slug
1913
- }
1914
- ]
1915
- });
1916
- },
1917
- validator: {
1918
- isEmpty: function isEmpty() {
1919
- return /*#__PURE__*/ function() {
1920
- var _ref = _async_to_generator(function(value) {
1921
- return _ts_generator(this, function(_state) {
1922
- return [
1923
- 2,
1924
- !validate.isEmpty(value)
1925
- ];
1926
- });
1927
- });
1928
- return function(value) {
1929
- return _ref.apply(this, arguments);
1930
- };
1931
- }();
1932
- },
1933
- isUnique: function isUnique(fields) {
1934
- return /*#__PURE__*/ function() {
1935
- var _ref = _async_to_generator(function(value) {
1936
- var query, existingDocument;
1937
- return _ts_generator(this, function(_state) {
1938
- switch(_state.label){
1939
- case 0:
1940
- if (!Array.isArray(fields) || fields.length === 0) {
1941
- throw new Error("Fields must be a non-empty array of strings.");
1942
- }
1943
- query = {
1944
- $or: fields.map(function(field) {
1945
- return _define_property({}, field, value);
1946
- })
1947
- };
1948
- return [
1949
- 4,
1950
- this.constructor.findOne(query)
1951
- ];
1952
- case 1:
1953
- existingDocument = _state.sent();
1954
- return [
1955
- 2,
1956
- !existingDocument
1957
- ];
1958
- }
1959
- });
1960
- });
1961
- return function(value) {
1962
- return _ref.apply(this, arguments);
1963
- };
1964
- }();
1965
- },
1966
- matchesRegex: function matchesRegex(regexArray) {
1967
- return /*#__PURE__*/ function() {
1968
- var _ref = _async_to_generator(function(value) {
1969
- return _ts_generator(this, function(_state) {
1970
- if (!Array.isArray(regexArray) || regexArray.some(function(r) {
1971
- return !_instanceof(r, RegExp);
1972
- })) {
1973
- throw new Error("regexArray must be an array of valid RegExp objects.");
1974
- }
1975
- return [
1976
- 2,
1977
- regexArray.every(function(regex) {
1978
- return regex.test(value);
1979
- })
1980
- ];
1981
- });
1982
- });
1983
- return function(value) {
1984
- return _ref.apply(this, arguments);
1985
- };
1986
- }();
1987
- }
1988
- }
1989
- };
1990
- var MongoController = /*#__PURE__*/ function() {
1991
- "use strict";
1992
- function MongoController(db, collectionName) {
1993
- _class_call_check(this, MongoController);
1994
- this.collection = db.collection(collectionName);
1995
- }
1996
- _create_class(MongoController, [
1997
- {
1998
- key: "createOne",
1999
- value: function createOne(document) {
2000
- var _this = this;
2001
- return _async_to_generator(function() {
2002
- var finalDocument, result, error;
2003
- return _ts_generator(this, function(_state) {
2004
- switch(_state.label){
2005
- case 0:
2006
- _state.trys.push([
2007
- 0,
2008
- 2,
2009
- ,
2010
- 3
2011
- ]);
2012
- finalDocument = _object_spread({}, mongo.createGenericFields(), document);
2013
- return [
2014
- 4,
2015
- _this.collection.insertOne(finalDocument)
2016
- ];
2017
- case 1:
2018
- result = _state.sent();
2019
- return [
2020
- 2,
2021
- {
2022
- success: true,
2023
- message: "Document created successfully",
2024
- result: result
2025
- }
2026
- ];
2027
- case 2:
2028
- error = _state.sent();
2029
- return [
2030
- 2,
2031
- {
2032
- success: false,
2033
- message: error.message
2034
- }
2035
- ];
2036
- case 3:
2037
- return [
2038
- 2
2039
- ];
2040
- }
2041
- });
2042
- })();
2043
- }
2044
- },
2045
- {
2046
- key: "createMany",
2047
- value: function createMany(documents) {
2048
- var _this = this;
2049
- return _async_to_generator(function() {
2050
- var finalDocuments, result, error;
2051
- return _ts_generator(this, function(_state) {
2052
- switch(_state.label){
2053
- case 0:
2054
- _state.trys.push([
2055
- 0,
2056
- 2,
2057
- ,
2058
- 3
2059
- ]);
2060
- finalDocuments = documents.map(function(document) {
2061
- return _object_spread({}, mongo.createGenericFields(), document);
2062
- });
2063
- return [
2064
- 4,
2065
- _this.collection.insertMany(finalDocuments)
2066
- ];
2067
- case 1:
2068
- result = _state.sent();
2069
- if (result.insertedCount === 0) {
2070
- return [
2071
- 2,
2072
- {
2073
- success: false,
2074
- message: "No documents were inserted"
2075
- }
2076
- ];
2077
- }
2078
- return [
2079
- 2,
2080
- {
2081
- success: true,
2082
- message: "".concat(result.insertedCount, " documents created successfully"),
2083
- result: result
2084
- }
2085
- ];
2086
- case 2:
2087
- error = _state.sent();
2088
- return [
2089
- 2,
2090
- {
2091
- success: false,
2092
- message: error.message
2093
- }
2094
- ];
2095
- case 3:
2096
- return [
2097
- 2
2098
- ];
2099
- }
2100
- });
2101
- })();
2102
- }
2103
- },
2104
- {
2105
- key: "findOne",
2106
- value: function findOne(filter) {
2107
- var _this = this;
2108
- return _async_to_generator(function() {
2109
- var result, error;
2110
- return _ts_generator(this, function(_state) {
2111
- switch(_state.label){
2112
- case 0:
2113
- _state.trys.push([
2114
- 0,
2115
- 2,
2116
- ,
2117
- 3
2118
- ]);
2119
- return [
2120
- 4,
2121
- _this.collection.findOne(filter)
2122
- ];
2123
- case 1:
2124
- result = _state.sent();
2125
- if (!result) {
2126
- return [
2127
- 2,
2128
- {
2129
- success: false,
2130
- message: "Document not found"
2131
- }
2132
- ];
2133
- }
2134
- return [
2135
- 2,
2136
- {
2137
- success: true,
2138
- message: "Document found",
2139
- result: result
2140
- }
2141
- ];
2142
- case 2:
2143
- error = _state.sent();
2144
- return [
2145
- 2,
2146
- {
2147
- success: false,
2148
- message: error.message
2149
- }
2150
- ];
2151
- case 3:
2152
- return [
2153
- 2
2154
- ];
2155
- }
2156
- });
2157
- })();
2158
- }
2159
- },
2160
- {
2161
- key: "findAll",
2162
- value: function findAll() {
2163
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};
2164
- var _this = this;
2165
- return _async_to_generator(function() {
2166
- var result, error;
2167
- return _ts_generator(this, function(_state) {
2168
- switch(_state.label){
2169
- case 0:
2170
- _state.trys.push([
2171
- 0,
2172
- 2,
2173
- ,
2174
- 3
2175
- ]);
2176
- return [
2177
- 4,
2178
- _this.collection.find(filter).toArray()
2179
- ];
2180
- case 1:
2181
- result = _state.sent();
2182
- return [
2183
- 2,
2184
- {
2185
- success: true,
2186
- message: "Documents retrieved successfully",
2187
- result: result
2188
- }
2189
- ];
2190
- case 2:
2191
- error = _state.sent();
2192
- return [
2193
- 2,
2194
- {
2195
- success: false,
2196
- message: error.message
2197
- }
2198
- ];
2199
- case 3:
2200
- return [
2201
- 2
2202
- ];
2203
- }
2204
- });
2205
- })();
2206
- }
2207
- },
2208
- {
2209
- key: "count",
2210
- value: function count() {
2211
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};
2212
- var _this = this;
2213
- return _async_to_generator(function() {
2214
- var result, error;
2215
- return _ts_generator(this, function(_state) {
2216
- switch(_state.label){
2217
- case 0:
2218
- _state.trys.push([
2219
- 0,
2220
- 2,
2221
- ,
2222
- 3
2223
- ]);
2224
- return [
2225
- 4,
2226
- _this.collection.countDocuments(filter)
2227
- ];
2228
- case 1:
2229
- result = _state.sent();
2230
- return [
2231
- 2,
2232
- {
2233
- success: true,
2234
- message: "Count retrieved successfully",
2235
- result: result
2236
- }
2237
- ];
2238
- case 2:
2239
- error = _state.sent();
2240
- return [
2241
- 2,
2242
- {
2243
- success: false,
2244
- message: error.message
2245
- }
2246
- ];
2247
- case 3:
2248
- return [
2249
- 2
2250
- ];
2251
- }
2252
- });
2253
- })();
2254
- }
2255
- },
2256
- {
2257
- key: "updateOne",
2258
- value: function updateOne(filter, update) {
2259
- var _this = this;
2260
- return _async_to_generator(function() {
2261
- var result, error;
2262
- return _ts_generator(this, function(_state) {
2263
- switch(_state.label){
2264
- case 0:
2265
- _state.trys.push([
2266
- 0,
2267
- 2,
2268
- ,
2269
- 3
2270
- ]);
2271
- return [
2272
- 4,
2273
- _this.collection.updateOne(filter, {
2274
- $set: update
2275
- })
2276
- ];
2277
- case 1:
2278
- result = _state.sent();
2279
- if (result.matchedCount === 0) {
2280
- return [
2281
- 2,
2282
- {
2283
- success: false,
2284
- message: "No documents matched the filter"
2285
- }
2286
- ];
2287
- }
2288
- return [
2289
- 2,
2290
- {
2291
- success: true,
2292
- message: "Document updated successfully",
2293
- result: result
2294
- }
2295
- ];
2296
- case 2:
2297
- error = _state.sent();
2298
- return [
2299
- 2,
2300
- {
2301
- success: false,
2302
- message: error.message
2303
- }
2304
- ];
2305
- case 3:
2306
- return [
2307
- 2
2308
- ];
2309
- }
2310
- });
2311
- })();
2312
- }
2313
- },
2314
- {
2315
- key: "updateMany",
2316
- value: function updateMany(filter, update) {
2317
- var _this = this;
2318
- return _async_to_generator(function() {
2319
- var result, error;
2320
- return _ts_generator(this, function(_state) {
2321
- switch(_state.label){
2322
- case 0:
2323
- _state.trys.push([
2324
- 0,
2325
- 2,
2326
- ,
2327
- 3
2328
- ]);
2329
- return [
2330
- 4,
2331
- _this.collection.updateMany(filter, {
2332
- $set: update
2333
- })
2334
- ];
2335
- case 1:
2336
- result = _state.sent();
2337
- if (result.matchedCount === 0) {
2338
- return [
2339
- 2,
2340
- {
2341
- success: false,
2342
- message: "No documents matched the filter"
2343
- }
2344
- ];
2345
- }
2346
- return [
2347
- 2,
2348
- {
2349
- success: true,
2350
- message: "Documents updated successfully",
2351
- result: result
2352
- }
2353
- ];
2354
- case 2:
2355
- error = _state.sent();
2356
- return [
2357
- 2,
2358
- {
2359
- success: false,
2360
- message: error.message
2361
- }
2362
- ];
2363
- case 3:
2364
- return [
2365
- 2
2366
- ];
2367
- }
2368
- });
2369
- })();
2370
- }
2371
- },
2372
- {
2373
- key: "deleteOne",
2374
- value: function deleteOne(filter) {
2375
- var _this = this;
2376
- return _async_to_generator(function() {
2377
- var result, error;
2378
- return _ts_generator(this, function(_state) {
2379
- switch(_state.label){
2380
- case 0:
2381
- _state.trys.push([
2382
- 0,
2383
- 2,
2384
- ,
2385
- 3
2386
- ]);
2387
- return [
2388
- 4,
2389
- _this.collection.deleteOne(filter)
2390
- ];
2391
- case 1:
2392
- result = _state.sent();
2393
- if (result.deletedCount === 0) {
2394
- return [
2395
- 2,
2396
- {
2397
- success: false,
2398
- message: "No documents matched the filter"
2399
- }
2400
- ];
2401
- }
2402
- return [
2403
- 2,
2404
- {
2405
- success: true,
2406
- message: "Document deleted successfully",
2407
- result: result
2408
- }
2409
- ];
2410
- case 2:
2411
- error = _state.sent();
2412
- return [
2413
- 2,
2414
- {
2415
- success: false,
2416
- message: error.message
2417
- }
2418
- ];
2419
- case 3:
2420
- return [
2421
- 2
2422
- ];
2423
- }
2424
- });
2425
- })();
2426
- }
2427
- },
2428
- {
2429
- key: "deleteMany",
2430
- value: function deleteMany(filter) {
2431
- var _this = this;
2432
- return _async_to_generator(function() {
2433
- var result, error;
2434
- return _ts_generator(this, function(_state) {
2435
- switch(_state.label){
2436
- case 0:
2437
- _state.trys.push([
2438
- 0,
2439
- 2,
2440
- ,
2441
- 3
2442
- ]);
2443
- return [
2444
- 4,
2445
- _this.collection.deleteMany(filter)
2446
- ];
2447
- case 1:
2448
- result = _state.sent();
2449
- if (result.deletedCount === 0) {
2450
- return [
2451
- 2,
2452
- {
2453
- success: false,
2454
- message: "No documents matched the filter"
2455
- }
2456
- ];
2457
- }
2458
- return [
2459
- 2,
2460
- {
2461
- success: true,
2462
- message: "Documents deleted successfully",
2463
- result: result
2464
- }
2465
- ];
2466
- case 2:
2467
- error = _state.sent();
2468
- return [
2469
- 2,
2470
- {
2471
- success: false,
2472
- message: error.message
2473
- }
2474
- ];
2475
- case 3:
2476
- return [
2477
- 2
2478
- ];
2479
- }
2480
- });
2481
- })();
2482
- }
2483
- }
2484
- ]);
2485
- return MongoController;
2486
- }();
2487
- var MongooseController = /*#__PURE__*/ function() {
2488
- "use strict";
2489
- function MongooseController(model) {
2490
- _class_call_check(this, MongooseController);
2491
- this.model = model;
2492
- }
2493
- _create_class(MongooseController, [
2494
- {
2495
- key: "getModelName",
2496
- value: function getModelName() {
2497
- return this.model.modelName;
2498
- }
2499
- },
2500
- {
2501
- key: "findOne",
2502
- value: function findOne() {
2503
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, projection = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}, populate = arguments.length > 3 ? arguments[3] : void 0;
2504
- var _this = this;
2505
- return _async_to_generator(function() {
2506
- var query, result, error;
2507
- return _ts_generator(this, function(_state) {
2508
- switch(_state.label){
2509
- case 0:
2510
- _state.trys.push([
2511
- 0,
2512
- 2,
2513
- ,
2514
- 3
2515
- ]);
2516
- query = _this.model.findOne(filter, projection, options);
2517
- if (populate) {
2518
- query.populate(populate);
2519
- }
2520
- return [
2521
- 4,
2522
- query.exec()
2523
- ];
2524
- case 1:
2525
- result = _state.sent();
2526
- if (!result) {
2527
- return [
2528
- 2,
2529
- {
2530
- success: false,
2531
- message: "No ".concat(_this.getModelName(), " found."),
2532
- code: RESPONSE_STATUS.NOT_FOUND.CODE
2533
- }
2534
- ];
2535
- }
2536
- return [
2537
- 2,
2538
- {
2539
- success: true,
2540
- result: result
2541
- }
2542
- ];
2543
- case 2:
2544
- error = _state.sent();
2545
- return [
2546
- 2,
2547
- {
2548
- success: false,
2549
- message: error.message,
2550
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2551
- }
2552
- ];
2553
- case 3:
2554
- return [
2555
- 2
2556
- ];
2557
- }
2558
- });
2559
- })();
2560
- }
2561
- },
2562
- {
2563
- key: "findAll",
2564
- value: function findAll() {
2565
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, projection = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}, populate = arguments.length > 3 ? arguments[3] : void 0;
2566
- var _this = this;
2567
- return _async_to_generator(function() {
2568
- var query, result, error;
2569
- return _ts_generator(this, function(_state) {
2570
- switch(_state.label){
2571
- case 0:
2572
- _state.trys.push([
2573
- 0,
2574
- 2,
2575
- ,
2576
- 3
2577
- ]);
2578
- query = _this.model.find(filter, projection, options);
2579
- if (populate) {
2580
- query.populate(populate);
2581
- }
2582
- return [
2583
- 4,
2584
- query.exec()
2585
- ];
2586
- case 1:
2587
- result = _state.sent();
2588
- return [
2589
- 2,
2590
- {
2591
- success: true,
2592
- result: result
2593
- }
2594
- ];
2595
- case 2:
2596
- error = _state.sent();
2597
- return [
2598
- 2,
2599
- {
2600
- success: false,
2601
- message: error.message,
2602
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2603
- }
2604
- ];
2605
- case 3:
2606
- return [
2607
- 2
2608
- ];
2609
- }
2610
- });
2611
- })();
2612
- }
2613
- },
2614
- {
2615
- key: "findPaging",
2616
- value: function findPaging() {
2617
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
2618
- var _this = this;
2619
- return _async_to_generator(function() {
2620
- var result, error;
2621
- return _ts_generator(this, function(_state) {
2622
- switch(_state.label){
2623
- case 0:
2624
- _state.trys.push([
2625
- 0,
2626
- 2,
2627
- ,
2628
- 3
2629
- ]);
2630
- return [
2631
- 4,
2632
- _this.model.paginate(filter, options)
2633
- ];
2634
- case 1:
2635
- result = _state.sent();
2636
- return [
2637
- 2,
2638
- {
2639
- success: true,
2640
- result: result
2641
- }
2642
- ];
2643
- case 2:
2644
- error = _state.sent();
2645
- return [
2646
- 2,
2647
- {
2648
- success: false,
2649
- message: error.message,
2650
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2651
- }
2652
- ];
2653
- case 3:
2654
- return [
2655
- 2
2656
- ];
2657
- }
2658
- });
2659
- })();
2660
- }
2661
- },
2662
- {
2663
- key: "findPagingAggregate",
2664
- value: function findPagingAggregate(pipeline) {
2665
- var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
2666
- var _this = this;
2667
- return _async_to_generator(function() {
2668
- var result, error;
2669
- return _ts_generator(this, function(_state) {
2670
- switch(_state.label){
2671
- case 0:
2672
- _state.trys.push([
2673
- 0,
2674
- 2,
2675
- ,
2676
- 3
2677
- ]);
2678
- return [
2679
- 4,
2680
- _this.model.aggregatePaginate(_this.model.aggregate(pipeline), options)
2681
- ];
2682
- case 1:
2683
- result = _state.sent();
2684
- return [
2685
- 2,
2686
- {
2687
- success: true,
2688
- result: result
2689
- }
2690
- ];
2691
- case 2:
2692
- error = _state.sent();
2693
- return [
2694
- 2,
2695
- {
2696
- success: false,
2697
- message: error.message,
2698
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2699
- }
2700
- ];
2701
- case 3:
2702
- return [
2703
- 2
2704
- ];
2705
- }
2706
- });
2707
- })();
2708
- }
2709
- },
2710
- {
2711
- key: "count",
2712
- value: function count() {
2713
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};
2714
- var _this = this;
2715
- return _async_to_generator(function() {
2716
- var result, error;
2717
- return _ts_generator(this, function(_state) {
2718
- switch(_state.label){
2719
- case 0:
2720
- _state.trys.push([
2721
- 0,
2722
- 2,
2723
- ,
2724
- 3
2725
- ]);
2726
- return [
2727
- 4,
2728
- _this.model.countDocuments(filter)
2729
- ];
2730
- case 1:
2731
- result = _state.sent();
2732
- return [
2733
- 2,
2734
- {
2735
- success: true,
2736
- result: result
2737
- }
2738
- ];
2739
- case 2:
2740
- error = _state.sent();
2741
- return [
2742
- 2,
2743
- {
2744
- success: false,
2745
- message: error.message,
2746
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2747
- }
2748
- ];
2749
- case 3:
2750
- return [
2751
- 2
2752
- ];
2753
- }
2754
- });
2755
- })();
2756
- }
2757
- },
2758
- {
2759
- key: "createOne",
2760
- value: function createOne(doc) {
2761
- var _this = this;
2762
- return _async_to_generator(function() {
2763
- var result, error;
2764
- return _ts_generator(this, function(_state) {
2765
- switch(_state.label){
2766
- case 0:
2767
- _state.trys.push([
2768
- 0,
2769
- 2,
2770
- ,
2771
- 3
2772
- ]);
2773
- return [
2774
- 4,
2775
- _this.model.create(doc)
2776
- ];
2777
- case 1:
2778
- result = _state.sent();
2779
- return [
2780
- 2,
2781
- {
2782
- success: true,
2783
- result: result
2784
- }
2785
- ];
2786
- case 2:
2787
- error = _state.sent();
2788
- return [
2789
- 2,
2790
- {
2791
- success: false,
2792
- message: error.message,
2793
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2794
- }
2795
- ];
2796
- case 3:
2797
- return [
2798
- 2
2799
- ];
2800
- }
2801
- });
2802
- })();
2803
- }
2804
- },
2805
- {
2806
- key: "createMany",
2807
- value: function createMany(docs) {
2808
- var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
2809
- var _this = this;
2810
- return _async_to_generator(function() {
2811
- var createdDocuments, result, error;
2812
- return _ts_generator(this, function(_state) {
2813
- switch(_state.label){
2814
- case 0:
2815
- _state.trys.push([
2816
- 0,
2817
- 2,
2818
- ,
2819
- 3
2820
- ]);
2821
- return [
2822
- 4,
2823
- _this.model.insertMany(docs, options)
2824
- ];
2825
- case 1:
2826
- createdDocuments = _state.sent();
2827
- result = createdDocuments.map(function(doc) {
2828
- if (_instanceof(doc, Document)) {
2829
- return doc.toObject();
2830
- }
2831
- return null;
2832
- }).filter(function(doc) {
2833
- return doc !== null;
2834
- });
2835
- return [
2836
- 2,
2837
- {
2838
- success: true,
2839
- result: result
2840
- }
2841
- ];
2842
- case 2:
2843
- error = _state.sent();
2844
- return [
2845
- 2,
2846
- {
2847
- success: false,
2848
- message: error.message,
2849
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2850
- }
2851
- ];
2852
- case 3:
2853
- return [
2854
- 2
2855
- ];
2856
- }
2857
- });
2858
- })();
2859
- }
2860
- },
2861
- {
2862
- key: "updateOne",
2863
- value: function updateOne() {
2864
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, update = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
2865
- var _this = this;
2866
- return _async_to_generator(function() {
2867
- var result, error;
2868
- return _ts_generator(this, function(_state) {
2869
- switch(_state.label){
2870
- case 0:
2871
- _state.trys.push([
2872
- 0,
2873
- 2,
2874
- ,
2875
- 3
2876
- ]);
2877
- return [
2878
- 4,
2879
- _this.model.findOneAndUpdate(filter, update, _object_spread({
2880
- new: true
2881
- }, options)).exec()
2882
- ];
2883
- case 1:
2884
- result = _state.sent();
2885
- if (!result) {
2886
- return [
2887
- 2,
2888
- {
2889
- success: false,
2890
- message: "Failed to update ".concat(_this.getModelName(), "."),
2891
- code: RESPONSE_STATUS.NOT_FOUND.CODE
2892
- }
2893
- ];
2894
- }
2895
- return [
2896
- 2,
2897
- {
2898
- success: true,
2899
- result: result
2900
- }
2901
- ];
2902
- case 2:
2903
- error = _state.sent();
2904
- return [
2905
- 2,
2906
- {
2907
- success: false,
2908
- message: error.message,
2909
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2910
- }
2911
- ];
2912
- case 3:
2913
- return [
2914
- 2
2915
- ];
2916
- }
2917
- });
2918
- })();
2919
- }
2920
- },
2921
- {
2922
- key: "updateMany",
2923
- value: function updateMany() {
2924
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, update = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}, options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
2925
- var _this = this;
2926
- return _async_to_generator(function() {
2927
- var result, error;
2928
- return _ts_generator(this, function(_state) {
2929
- switch(_state.label){
2930
- case 0:
2931
- _state.trys.push([
2932
- 0,
2933
- 2,
2934
- ,
2935
- 3
2936
- ]);
2937
- return [
2938
- 4,
2939
- _this.model.updateMany(filter, update, options).exec()
2940
- ];
2941
- case 1:
2942
- result = _state.sent();
2943
- return [
2944
- 2,
2945
- {
2946
- success: true,
2947
- result: result
2948
- }
2949
- ];
2950
- case 2:
2951
- error = _state.sent();
2952
- return [
2953
- 2,
2954
- {
2955
- success: false,
2956
- message: error.message,
2957
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
2958
- }
2959
- ];
2960
- case 3:
2961
- return [
2962
- 2
2963
- ];
2964
- }
2965
- });
2966
- })();
2967
- }
2968
- },
2969
- {
2970
- key: "deleteOne",
2971
- value: function deleteOne() {
2972
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
2973
- var _this = this;
2974
- return _async_to_generator(function() {
2975
- var result, error;
2976
- return _ts_generator(this, function(_state) {
2977
- switch(_state.label){
2978
- case 0:
2979
- _state.trys.push([
2980
- 0,
2981
- 2,
2982
- ,
2983
- 3
2984
- ]);
2985
- return [
2986
- 4,
2987
- _this.model.findOneAndDelete(filter, options).exec()
2988
- ];
2989
- case 1:
2990
- result = _state.sent();
2991
- if (!result) {
2992
- return [
2993
- 2,
2994
- {
2995
- success: false,
2996
- message: "No ".concat(_this.getModelName(), " found to delete."),
2997
- code: RESPONSE_STATUS.NOT_FOUND.CODE
2998
- }
2999
- ];
3000
- }
3001
- return [
3002
- 2,
3003
- {
3004
- success: true,
3005
- result: result
3006
- }
3007
- ];
3008
- case 2:
3009
- error = _state.sent();
3010
- return [
3011
- 2,
3012
- {
3013
- success: false,
3014
- message: error.message,
3015
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3016
- }
3017
- ];
3018
- case 3:
3019
- return [
3020
- 2
3021
- ];
3022
- }
3023
- });
3024
- })();
3025
- }
3026
- },
3027
- {
3028
- key: "deleteMany",
3029
- value: function deleteMany() {
3030
- var filter = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
3031
- var _this = this;
3032
- return _async_to_generator(function() {
3033
- var result, error;
3034
- return _ts_generator(this, function(_state) {
3035
- switch(_state.label){
3036
- case 0:
3037
- _state.trys.push([
3038
- 0,
3039
- 2,
3040
- ,
3041
- 3
3042
- ]);
3043
- return [
3044
- 4,
3045
- _this.model.deleteMany(filter, options).exec()
3046
- ];
3047
- case 1:
3048
- result = _state.sent();
3049
- if (result.deletedCount === 0) {
3050
- return [
3051
- 2,
3052
- {
3053
- success: false,
3054
- message: "No documents found to delete.",
3055
- code: RESPONSE_STATUS.NOT_FOUND.CODE
3056
- }
3057
- ];
3058
- }
3059
- return [
3060
- 2,
3061
- {
3062
- success: true,
3063
- result: result
3064
- }
3065
- ];
3066
- case 2:
3067
- error = _state.sent();
3068
- return [
3069
- 2,
3070
- {
3071
- success: false,
3072
- message: error.message,
3073
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3074
- }
3075
- ];
3076
- case 3:
3077
- return [
3078
- 2
3079
- ];
3080
- }
3081
- });
3082
- })();
3083
- }
3084
- },
3085
- {
3086
- key: "createShortId",
3087
- value: function createShortId(id) {
3088
- var length = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 4;
3089
- var _this = this;
3090
- return _async_to_generator(function() {
3091
- var maxRetries, existingShortIds, retries, shortId, shortIdExists;
3092
- return _ts_generator(this, function(_state) {
3093
- switch(_state.label){
3094
- case 0:
3095
- maxRetries = 10;
3096
- existingShortIds = /* @__PURE__ */ new Set();
3097
- retries = 0;
3098
- _state.label = 1;
3099
- case 1:
3100
- if (!(retries < maxRetries)) return [
3101
- 3,
3102
- 4
3103
- ];
3104
- shortId = generateShortId(id, retries + length);
3105
- if (!!existingShortIds.has(shortId)) return [
3106
- 3,
3107
- 3
3108
- ];
3109
- existingShortIds.add(shortId);
3110
- return [
3111
- 4,
3112
- _this.model.exists({
3113
- shortId: shortId
3114
- })
3115
- ];
3116
- case 2:
3117
- shortIdExists = _state.sent();
3118
- if (!shortIdExists) {
3119
- return [
3120
- 2,
3121
- {
3122
- success: true,
3123
- result: shortId
3124
- }
3125
- ];
3126
- }
3127
- _state.label = 3;
3128
- case 3:
3129
- retries++;
3130
- return [
3131
- 3,
3132
- 1
3133
- ];
3134
- case 4:
3135
- return [
3136
- 2,
3137
- {
3138
- success: false,
3139
- message: "Failed to create a unique shortId",
3140
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3141
- }
3142
- ];
3143
- }
3144
- });
3145
- })();
3146
- }
3147
- },
3148
- {
3149
- key: "createSlug",
3150
- value: function createSlug(fieldName, fields) {
3151
- var filters = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
3152
- var _this = this;
3153
- return _async_to_generator(function() {
3154
- var fieldValue, createUniqueSlug, slugResults, _tmp, _tmp1, _i, lang, slug, slug1, uniqueSlug, error;
3155
- return _ts_generator(this, function(_state) {
3156
- switch(_state.label){
3157
- case 0:
3158
- _state.trys.push([
3159
- 0,
3160
- 8,
3161
- ,
3162
- 9
3163
- ]);
3164
- fieldValue = fields[fieldName];
3165
- createUniqueSlug = /*#__PURE__*/ function() {
3166
- var _ref = _async_to_generator(function(slug) {
3167
- var existingDoc, suffix, uniqueSlug;
3168
- return _ts_generator(this, function(_state) {
3169
- switch(_state.label){
3170
- case 0:
3171
- return [
3172
- 4,
3173
- _this.model.findOne(mongo.createSlugQuery(slug, filters, fields.id))
3174
- ];
3175
- case 1:
3176
- existingDoc = _state.sent();
3177
- if (!existingDoc) return [
3178
- 2,
3179
- slug
3180
- ];
3181
- suffix = 1;
3182
- _state.label = 2;
3183
- case 2:
3184
- uniqueSlug = "".concat(slug, "-").concat(suffix);
3185
- return [
3186
- 4,
3187
- _this.model.findOne(mongo.createSlugQuery(uniqueSlug, filters, fields.id))
3188
- ];
3189
- case 3:
3190
- existingDoc = _state.sent();
3191
- suffix++;
3192
- _state.label = 4;
3193
- case 4:
3194
- if (existingDoc) return [
3195
- 3,
3196
- 2
3197
- ];
3198
- _state.label = 5;
3199
- case 5:
3200
- return [
3201
- 2,
3202
- uniqueSlug
3203
- ];
3204
- }
3205
- });
3206
- });
3207
- return function createUniqueSlug(slug) {
3208
- return _ref.apply(this, arguments);
3209
- };
3210
- }();
3211
- if (!((typeof fieldValue === "undefined" ? "undefined" : _type_of(fieldValue)) === "object")) return [
3212
- 3,
3213
- 5
3214
- ];
3215
- slugResults = {};
3216
- _tmp = [];
3217
- for(_tmp1 in fieldValue)_tmp.push(_tmp1);
3218
- _i = 0;
3219
- _state.label = 1;
3220
- case 1:
3221
- if (!(_i < _tmp.length)) return [
3222
- 3,
3223
- 4
3224
- ];
3225
- lang = _tmp[_i];
3226
- slug = generateSlug(fieldValue[lang]);
3227
- return [
3228
- 4,
3229
- createUniqueSlug(slug)
3230
- ];
3231
- case 2:
3232
- slugResults[lang] = _state.sent();
3233
- _state.label = 3;
3234
- case 3:
3235
- _i++;
3236
- return [
3237
- 3,
3238
- 1
3239
- ];
3240
- case 4:
3241
- return [
3242
- 2,
3243
- {
3244
- success: true,
3245
- result: slugResults
3246
- }
3247
- ];
3248
- case 5:
3249
- slug1 = generateSlug(fieldValue);
3250
- return [
3251
- 4,
3252
- createUniqueSlug(slug1)
3253
- ];
3254
- case 6:
3255
- uniqueSlug = _state.sent();
3256
- return [
3257
- 2,
3258
- {
3259
- success: true,
3260
- result: uniqueSlug
3261
- }
3262
- ];
3263
- case 7:
3264
- return [
3265
- 3,
3266
- 9
3267
- ];
3268
- case 8:
3269
- error = _state.sent();
3270
- return [
3271
- 2,
3272
- {
3273
- success: false,
3274
- message: "Failed to create a unique slug: ".concat(error.message),
3275
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3276
- }
3277
- ];
3278
- case 9:
3279
- return [
3280
- 2
3281
- ];
3282
- }
3283
- });
3284
- })();
3285
- }
3286
- },
3287
- {
3288
- key: "aggregate",
3289
- value: function aggregate(pipeline) {
3290
- var _this = this;
3291
- return _async_to_generator(function() {
3292
- var result, error;
3293
- return _ts_generator(this, function(_state) {
3294
- switch(_state.label){
3295
- case 0:
3296
- _state.trys.push([
3297
- 0,
3298
- 2,
3299
- ,
3300
- 3
3301
- ]);
3302
- return [
3303
- 4,
3304
- _this.model.aggregate(pipeline)
3305
- ];
3306
- case 1:
3307
- result = _state.sent();
3308
- return [
3309
- 2,
3310
- {
3311
- success: true,
3312
- result: result
3313
- }
3314
- ];
3315
- case 2:
3316
- error = _state.sent();
3317
- return [
3318
- 2,
3319
- {
3320
- success: false,
3321
- message: error.message,
3322
- code: RESPONSE_STATUS.INTERNAL_SERVER_ERROR.CODE
3323
- }
3324
- ];
3325
- case 3:
3326
- return [
3327
- 2
3328
- ];
3329
- }
3330
- });
3331
- })();
3332
- }
3333
- }
3334
- ]);
3335
- return MongooseController;
3336
- }();
3337
- // src/react/apollo-client.tsx
3338
- import { ApolloClient, ApolloLink, ApolloProvider as ApolloProviderDefault, HttpLink, InMemoryCache, split } from "@apollo/client";
3339
- import { onError } from "@apollo/client/link/error";
3340
- import { GraphQLWsLink } from "@apollo/client/link/subscriptions";
3341
- import { getMainDefinition } from "@apollo/client/utilities";
3342
- import { createClient as createGraphqlWebSocketClient } from "graphql-ws";
3343
- import { jsx } from "react/jsx-runtime";
3344
- function createLinks(options) {
3345
- var errorLink = onError(function(param) {
3346
- var graphQLErrors = param.graphQLErrors, networkError = param.networkError;
3347
- graphQLErrors === null || graphQLErrors === void 0 ? void 0 : graphQLErrors.forEach(function(param) {
3348
- var message = param.message, locations = param.locations, path3 = param.path;
3349
- return console.error("[GraphQL error]: Message: ".concat(message, ", Location: ").concat(locations, ", Path: ").concat(path3));
3350
- });
3351
- if (networkError) {
3352
- console.error("[Network error]: ".concat(networkError));
3353
- }
3354
- });
3355
- var httpLink = new HttpLink({
3356
- uri: options === null || options === void 0 ? void 0 : options.uri,
3357
- credentials: "include"
3358
- });
3359
- var wsLink = (options === null || options === void 0 ? void 0 : options.wsUrl) ? new GraphQLWsLink(createGraphqlWebSocketClient({
3360
- url: options.wsUrl
3361
- })) : null;
3362
- var splitLink = wsLink ? split(function(param) {
3363
- var query = param.query;
3364
- var mainDefinition = getMainDefinition(query);
3365
- if (mainDefinition.kind === "OperationDefinition") {
3366
- var operation = mainDefinition.operation;
3367
- return operation === "subscription";
3368
- }
3369
- return false;
3370
- }, wsLink, httpLink) : httpLink;
3371
- var cleanTypeName = new ApolloLink(function(operation, forward) {
3372
- if (operation.variables) {
3373
- operation.variables = JSON.parse(JSON.stringify(operation.variables), function(key, value) {
3374
- return key === "__typename" ? void 0 : value;
3375
- });
3376
- }
3377
- return forward(operation);
3378
- });
3379
- return {
3380
- errorLink: errorLink,
3381
- httpLink: httpLink,
3382
- wsLink: wsLink,
3383
- splitLink: splitLink,
3384
- cleanTypeName: cleanTypeName
3385
- };
3386
- }
3387
- function ApolloProvider(param) {
3388
- var isNextJS = param.isNextJS, options = param.options, children = param.children, CustomClient = param.client, CustomProvider = param.provider, CustomCache = param.cache;
3389
- var Client = CustomClient !== null && CustomClient !== void 0 ? CustomClient : ApolloClient;
3390
- if (typeof Client !== "function") {
3391
- throw new TypeError("Invalid ApolloClient provided. Ensure CustomClient is a class.");
3392
- }
3393
- var Provider = CustomProvider || ApolloProviderDefault;
3394
- var Cache = CustomCache || InMemoryCache;
3395
- var _createLinks = createLinks(options), cleanTypeName = _createLinks.cleanTypeName, errorLink = _createLinks.errorLink, splitLink = _createLinks.splitLink;
3396
- var client = new Client(_object_spread({
3397
- cache: _instanceof(Cache, InMemoryCache) ? Cache : new InMemoryCache(),
3398
- link: ApolloLink.from([
3399
- cleanTypeName,
3400
- errorLink,
3401
- splitLink
3402
- ].filter(Boolean))
3403
- }, options));
3404
- if (isNextJS) {
3405
- return /* @__PURE__ */ jsx(Provider, {
3406
- makeClient: function() {
3407
- return client;
3408
- },
3409
- children: children
3410
- });
3411
- }
3412
- return /* @__PURE__ */ jsx(Provider, {
3413
- client: client,
3414
- children: children
3415
- });
3416
- }
3417
- // src/react/loading.tsx
3418
- import cn from "classnames";
3419
- import { createContext, use, useCallback, useMemo, useState } from "react";
3420
- import styles from "./react/loading.module.scss";
3421
- import { jsx as jsx2, jsxs } from "react/jsx-runtime";
3422
- var LoadingContext = createContext(void 0);
3423
- function useLoading() {
3424
- var context = use(LoadingContext);
3425
- if (!context) {
3426
- throw new Error("useLoading must be used within a LoadingProvider");
3427
- }
3428
- return context;
3429
- }
3430
- function Loading(_param) {
3431
- var _param_full = _param.full, full = _param_full === void 0 ? false : _param_full, _param_block = _param.block, block = _param_block === void 0 ? false : _param_block, _param_className = _param.className, className = _param_className === void 0 ? "" : _param_className, _param_message = _param.message, message = _param_message === void 0 ? "Loading" : _param_message, rest = _object_without_properties(_param, [
3432
- "full",
3433
- "block",
3434
- "className",
3435
- "message"
3436
- ]);
3437
- function _renderLoading() {
3438
- return /* @__PURE__ */ jsxs("div", _object_spread_props(_object_spread({
3439
- className: styles.container
3440
- }, rest), {
3441
- children: [
3442
- /* @__PURE__ */ jsx2("div", {
3443
- className: styles.ring
3444
- }),
3445
- /* @__PURE__ */ jsx2("div", {
3446
- className: styles.ring
3447
- }),
3448
- /* @__PURE__ */ jsx2("div", {
3449
- className: styles.ring
3450
- }),
3451
- /* @__PURE__ */ jsx2("div", {
3452
- className: styles.ring
3453
- }),
3454
- message && /* @__PURE__ */ jsx2("div", {
3455
- className: styles.message,
3456
- children: message
3457
- })
3458
- ]
3459
- }));
3460
- }
3461
- if (full) {
3462
- return /* @__PURE__ */ jsx2("div", {
3463
- className: cn(styles.fullscreen, className),
3464
- children: _renderLoading()
3465
- });
3466
- } else if (block) {
3467
- return /* @__PURE__ */ jsx2("div", {
3468
- className: cn(styles.block, className),
3469
- children: _renderLoading()
3470
- });
3471
- }
3472
- return _renderLoading();
3473
- }
3474
- function LoadingProvider(param) {
3475
- var children = param.children;
3476
- var _useState = _sliced_to_array(useState(false), 2), isLoading = _useState[0], setIsLoading = _useState[1];
3477
- var _useState1 = _sliced_to_array(useState(false), 2), isGlobalLoading = _useState1[0], setIsGlobalLoading = _useState1[1];
3478
- var showLoading = useCallback(function() {
3479
- var global = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : false;
3480
- setIsLoading(true);
3481
- setIsGlobalLoading(global);
3482
- }, []);
3483
- var hideLoading = useCallback(function() {
3484
- setIsLoading(false);
3485
- setIsGlobalLoading(false);
3486
- }, []);
3487
- var contextValue = useMemo(function() {
3488
- return {
3489
- isLoading: isLoading,
3490
- isGlobalLoading: isGlobalLoading,
3491
- showLoading: showLoading,
3492
- hideLoading: hideLoading
3493
- };
3494
- }, [
3495
- isLoading,
3496
- isGlobalLoading,
3497
- showLoading,
3498
- hideLoading
3499
- ]);
3500
- return /* @__PURE__ */ jsx2(LoadingContext, {
3501
- value: contextValue,
3502
- children: isLoading ? /* @__PURE__ */ jsx2(Loading, {
3503
- full: isGlobalLoading
3504
- }) : children
3505
- });
3506
- }
3507
- // src/react/next-intl.tsx
3508
- import { NextIntlClientProvider, useTranslations } from "next-intl";
3509
- import { createContext as createContext2, use as use2, useMemo as useMemo2 } from "react";
3510
- // src/react/storage.tsx
3511
- import { useCallback as useCallback2, useEffect, useState as useState2 } from "react";
3512
- // src/utils/serializer.ts
3513
- var serializer = {
3514
- serialize: function(value) {
3515
- return JSON.stringify(value, function(_, v) {
3516
- if (_instanceof(v, Date)) {
3517
- return {
3518
- __type: "Date",
3519
- value: v.toISOString()
3520
- };
3521
- }
3522
- return v;
3523
- });
3524
- },
3525
- deserialize: function(value) {
3526
- return JSON.parse(value, function(_, v) {
3527
- if ((v === null || v === void 0 ? void 0 : v.__type) === "Date") {
3528
- return new Date(v.value);
3529
- }
3530
- return v;
3531
- });
3532
- }
3533
- };
3534
- // src/utils/storage-client.ts
3535
- import localForage from "localforage";
3536
- var storageClient = {
3537
- get: function get(key) {
3538
- return _async_to_generator(function() {
3539
- var error;
3540
- return _ts_generator(this, function(_state) {
3541
- switch(_state.label){
3542
- case 0:
3543
- _state.trys.push([
3544
- 0,
3545
- 2,
3546
- ,
3547
- 3
3548
- ]);
3549
- return [
3550
- 4,
3551
- localForage.getItem(key)
3552
- ];
3553
- case 1:
3554
- return [
3555
- 2,
3556
- _state.sent()
3557
- ];
3558
- case 2:
3559
- error = _state.sent();
3560
- console.error('❌ [Storage:get] Error getting key "'.concat(key, '":'), error);
3561
- return [
3562
- 2,
3563
- null
3564
- ];
3565
- case 3:
3566
- return [
3567
- 2
3568
- ];
3569
- }
3570
- });
3571
- })();
3572
- },
3573
- set: function set(key, value) {
3574
- return _async_to_generator(function() {
3575
- var error;
3576
- return _ts_generator(this, function(_state) {
3577
- switch(_state.label){
3578
- case 0:
3579
- _state.trys.push([
3580
- 0,
3581
- 2,
3582
- ,
3583
- 3
3584
- ]);
3585
- return [
3586
- 4,
3587
- localForage.setItem(key, value)
3588
- ];
3589
- case 1:
3590
- _state.sent();
3591
- return [
3592
- 3,
3593
- 3
3594
- ];
3595
- case 2:
3596
- error = _state.sent();
3597
- console.error('❌ [Storage:set] Error setting key "'.concat(key, '":'), error);
3598
- return [
3599
- 3,
3600
- 3
3601
- ];
3602
- case 3:
3603
- return [
3604
- 2
3605
- ];
3606
- }
3607
- });
3608
- })();
3609
- },
3610
- remove: function remove(key) {
3611
- return _async_to_generator(function() {
3612
- var error;
3613
- return _ts_generator(this, function(_state) {
3614
- switch(_state.label){
3615
- case 0:
3616
- _state.trys.push([
3617
- 0,
3618
- 2,
3619
- ,
3620
- 3
3621
- ]);
3622
- return [
3623
- 4,
3624
- localForage.removeItem(key)
3625
- ];
3626
- case 1:
3627
- _state.sent();
3628
- return [
3629
- 3,
3630
- 3
3631
- ];
3632
- case 2:
3633
- error = _state.sent();
3634
- console.error('❌ [Storage:remove] Error removing key "'.concat(key, '":'), error);
3635
- return [
3636
- 3,
3637
- 3
3638
- ];
3639
- case 3:
3640
- return [
3641
- 2
3642
- ];
3643
- }
3644
- });
3645
- })();
3646
- },
3647
- keys: function keys() {
3648
- return _async_to_generator(function() {
3649
- var keys, error;
3650
- return _ts_generator(this, function(_state) {
3651
- switch(_state.label){
3652
- case 0:
3653
- _state.trys.push([
3654
- 0,
3655
- 2,
3656
- ,
3657
- 3
3658
- ]);
3659
- return [
3660
- 4,
3661
- localForage.keys()
3662
- ];
3663
- case 1:
3664
- keys = _state.sent();
3665
- return [
3666
- 2,
3667
- keys !== null && keys !== void 0 ? keys : []
3668
- ];
3669
- case 2:
3670
- error = _state.sent();
3671
- console.error("❌ [Storage:keys] Error getting keys:", error);
3672
- return [
3673
- 2,
3674
- []
3675
- ];
3676
- case 3:
3677
- return [
3678
- 2
3679
- ];
3680
- }
3681
- });
3682
- })();
3683
- }
3684
- };
3685
- // src/react/storage.tsx
3686
- function useStorage(key, initialValue) {
3687
- var serializer2 = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : serializer;
3688
- var _useState2 = _sliced_to_array(useState2(initialValue), 2), value = _useState2[0], setValue = _useState2[1];
3689
- var _useState21 = _sliced_to_array(useState2(false), 2), isLoaded = _useState21[0], setIsLoaded = _useState21[1];
3690
- useEffect(function() {
3691
- var isMounted = true;
3692
- var loadValue = /*#__PURE__*/ function() {
3693
- var _ref = _async_to_generator(function() {
3694
- var valueFound, parsedValue, serialized, error;
3695
- return _ts_generator(this, function(_state) {
3696
- switch(_state.label){
3697
- case 0:
3698
- _state.trys.push([
3699
- 0,
3700
- 6,
3701
- 7,
3702
- 8
3703
- ]);
3704
- return [
3705
- 4,
3706
- storageClient.get(key)
3707
- ];
3708
- case 1:
3709
- valueFound = _state.sent();
3710
- if (!isMounted) return [
3711
- 3,
3712
- 5
3713
- ];
3714
- if (!(valueFound !== null)) return [
3715
- 3,
3716
- 2
3717
- ];
3718
- parsedValue = serializer2.deserialize(valueFound);
3719
- setValue(parsedValue);
3720
- return [
3721
- 3,
3722
- 5
3723
- ];
3724
- case 2:
3725
- if (!(initialValue !== void 0)) return [
3726
- 3,
3727
- 4
3728
- ];
3729
- serialized = serializer2.serialize(initialValue);
3730
- return [
3731
- 4,
3732
- storageClient.set(key, serialized)
3733
- ];
3734
- case 3:
3735
- _state.sent();
3736
- setValue(initialValue);
3737
- return [
3738
- 3,
3739
- 5
3740
- ];
3741
- case 4:
3742
- setValue(void 0);
3743
- _state.label = 5;
3744
- case 5:
3745
- return [
3746
- 3,
3747
- 8
3748
- ];
3749
- case 6:
3750
- error = _state.sent();
3751
- console.error('Error loading value for key "'.concat(key, '":'), error);
3752
- if (isMounted) {
3753
- setValue(initialValue);
3754
- }
3755
- return [
3756
- 3,
3757
- 8
3758
- ];
3759
- case 7:
3760
- if (isMounted) setIsLoaded(true);
3761
- return [
3762
- 7
3763
- ];
3764
- case 8:
3765
- return [
3766
- 2
3767
- ];
3768
- }
3769
- });
3770
- });
3771
- return function loadValue() {
3772
- return _ref.apply(this, arguments);
3773
- };
3774
- }();
3775
- loadValue();
3776
- return function() {
3777
- isMounted = false;
3778
- setIsLoaded(false);
3779
- };
3780
- }, [
3781
- key,
3782
- initialValue,
3783
- serializer2
3784
- ]);
3785
- useEffect(function() {
3786
- if (!isLoaded) return;
3787
- var saveValue = /*#__PURE__*/ function() {
3788
- var _ref = _async_to_generator(function() {
3789
- var serialized, error;
3790
- return _ts_generator(this, function(_state) {
3791
- switch(_state.label){
3792
- case 0:
3793
- _state.trys.push([
3794
- 0,
3795
- 3,
3796
- ,
3797
- 4
3798
- ]);
3799
- if (!(value !== void 0)) return [
3800
- 3,
3801
- 2
3802
- ];
3803
- serialized = serializer2.serialize(value);
3804
- return [
3805
- 4,
3806
- storageClient.set(key, serialized)
3807
- ];
3808
- case 1:
3809
- _state.sent();
3810
- _state.label = 2;
3811
- case 2:
3812
- return [
3813
- 3,
3814
- 4
3815
- ];
3816
- case 3:
3817
- error = _state.sent();
3818
- console.error('Error saving value for key "'.concat(key, '":'), error);
3819
- return [
3820
- 3,
3821
- 4
3822
- ];
3823
- case 4:
3824
- return [
3825
- 2
3826
- ];
3827
- }
3828
- });
3829
- });
3830
- return function saveValue() {
3831
- return _ref.apply(this, arguments);
3832
- };
3833
- }();
3834
- saveValue();
3835
- }, [
3836
- value,
3837
- key,
3838
- serializer2,
3839
- isLoaded
3840
- ]);
3841
- var set = useCallback2(function(newValue) {
3842
- setValue(function(prev) {
3843
- return typeof newValue === "function" ? newValue(prev) : newValue;
3844
- });
3845
- }, []);
3846
- var remove = useCallback2(/*#__PURE__*/ _async_to_generator(function() {
3847
- var error;
3848
- return _ts_generator(this, function(_state) {
3849
- switch(_state.label){
3850
- case 0:
3851
- _state.trys.push([
3852
- 0,
3853
- 2,
3854
- ,
3855
- 3
3856
- ]);
3857
- return [
3858
- 4,
3859
- storageClient.remove(key)
3860
- ];
3861
- case 1:
3862
- _state.sent();
3863
- setValue(void 0);
3864
- return [
3865
- 3,
3866
- 3
3867
- ];
3868
- case 2:
3869
- error = _state.sent();
3870
- console.error('Error removing key "'.concat(key, '":'), error);
3871
- return [
3872
- 3,
3873
- 3
3874
- ];
3875
- case 3:
3876
- return [
3877
- 2
3878
- ];
3879
- }
3880
- });
3881
- }), [
3882
- key
3883
- ]);
3884
- return {
3885
- value: value,
3886
- set: set,
3887
- remove: remove
3888
- };
3889
- }
3890
- // src/react/next-intl.tsx
3891
- import { Fragment, jsx as jsx3 } from "react/jsx-runtime";
3892
- var NextIntlContext = createContext2(void 0);
3893
- function useNextIntl() {
3894
- var context = use2(NextIntlContext);
3895
- if (!context) {
3896
- throw new Error("useNextIntl must be used within a NextIntlProvider");
3897
- }
3898
- return context;
3899
- }
3900
- var useTranslateNextIntl = useTranslations;
3901
- function withNextIntl(Component) {
3902
- var PageWithI18n = function(props) {
3903
- var _languages_find;
3904
- var currentLanguage = useNextIntl().currentLanguage;
3905
- var messages = props.messages, languages = props.languages;
3906
- var defaultLang = "en";
3907
- var defaultMessages = messages[(currentLanguage === null || currentLanguage === void 0 ? void 0 : currentLanguage.value) || defaultLang];
3908
- var timeZone = (_languages_find = languages.find(function(lang) {
3909
- return lang.value === (currentLanguage === null || currentLanguage === void 0 ? void 0 : currentLanguage.value);
3910
- })) === null || _languages_find === void 0 ? void 0 : _languages_find.timezone;
3911
- if (!messages) {
3912
- console.warn("Missing messages for language: ".concat((currentLanguage === null || currentLanguage === void 0 ? void 0 : currentLanguage.value) || defaultLang));
3913
- return null;
3914
- }
3915
- return /* @__PURE__ */ jsx3(NextIntlClientProvider, {
3916
- locale: (currentLanguage === null || currentLanguage === void 0 ? void 0 : currentLanguage.value) || defaultLang,
3917
- messages: defaultMessages,
3918
- timeZone: timeZone,
3919
- children: /* @__PURE__ */ jsx3(Component, _object_spread({}, props))
3920
- });
3921
- };
3922
- PageWithI18n.displayName = "withNextIntl(".concat(Component.displayName || Component.name || "Component", ")");
3923
- return PageWithI18n;
3924
- }
3925
- function LanguageWrapperBase(param) {
3926
- var children = param.children;
3927
- return /* @__PURE__ */ jsx3(Fragment, {
3928
- children: children
3929
- });
3930
- }
3931
- var LanguageWrapper = withNextIntl(LanguageWrapperBase);
3932
- function NextIntlProvider(param) {
3933
- var children = param.children, languages = param.languages, messages = param.messages;
3934
- var _languages_;
3935
- var _useStorage = useStorage("lang", (_languages_ = languages === null || languages === void 0 ? void 0 : languages[0]) !== null && _languages_ !== void 0 ? _languages_ : {}), value = _useStorage.value, set = _useStorage.set;
3936
- var contextValue = useMemo2(function() {
3937
- return {
3938
- languages: languages,
3939
- currentLanguage: value,
3940
- setCurrentLanguage: set
3941
- };
3942
- }, [
3943
- languages,
3944
- set,
3945
- value
3946
- ]);
3947
- return /* @__PURE__ */ jsx3(NextIntlContext, {
3948
- value: contextValue,
3949
- children: /* @__PURE__ */ jsx3(LanguageWrapper, {
3950
- languages: languages,
3951
- messages: messages,
3952
- children: children
3953
- })
3954
- });
3955
- }
3956
- // src/typescript/mongo.ts
3957
- import { Collection, Db } from "mongodb";
3958
- import { Document as Document2, Model } from "mongoose";
3959
- var C_Db = /*#__PURE__*/ function(Db) {
3960
- "use strict";
3961
- _inherits(C_Db, Db);
3962
- function C_Db() {
3963
- _class_call_check(this, C_Db);
3964
- return _call_super(this, C_Db, arguments);
3965
- }
3966
- return C_Db;
3967
- }(Db);
3968
- var C_Document = /*#__PURE__*/ function(Document2) {
3969
- "use strict";
3970
- _inherits(C_Document, Document2);
3971
- function C_Document() {
3972
- _class_call_check(this, C_Document);
3973
- return _call_super(this, C_Document, arguments);
3974
- }
3975
- return C_Document;
3976
- }(Document2);
3977
- var C_Model = /*#__PURE__*/ function(Model) {
3978
- "use strict";
3979
- _inherits(C_Model, Model);
3980
- function C_Model() {
3981
- _class_call_check(this, C_Model);
3982
- return _call_super(this, C_Model, arguments);
3983
- }
3984
- return C_Model;
3985
- }(Model);
3986
- var C_Collection = /*#__PURE__*/ function(Collection) {
3987
- "use strict";
3988
- _inherits(C_Collection, Collection);
3989
- function C_Collection() {
3990
- _class_call_check(this, C_Collection);
3991
- return _call_super(this, C_Collection, arguments);
3992
- }
3993
- return C_Collection;
3994
- }(Collection);
3995
- // src/utils/log.ts
3996
- import { GraphQLError } from "graphql";
3997
- function throwResponse(param) {
3998
- var message = param.message, _param_status = param.status, status = _param_status === void 0 ? RESPONSE_STATUS.INTERNAL_SERVER_ERROR : _param_status, _param_type = param.type, type = _param_type === void 0 ? "graphql" : _param_type;
3999
- var _ref;
4000
- var responseMessage = (_ref = message !== null && message !== void 0 ? message : status.MESSAGE) !== null && _ref !== void 0 ? _ref : "Internal server error";
4001
- if (type === "graphql") {
4002
- throw new GraphQLError(responseMessage, {
4003
- extensions: {
4004
- code: status.CODE
4005
- }
4006
- });
4007
- } else {
4008
- throw new Error(responseMessage);
4009
- }
4010
- }
4011
- // src/utils/common.ts
4012
- import unorm from "unorm";
4013
- function isJson(str) {
4014
- try {
4015
- JSON.parse(str);
4016
- return true;
4017
- } catch (e) {
4018
- return false;
4019
- }
4020
- }
4021
- var charMap = {
4022
- a: [
4023
- "\xE0",
4024
- "\xE1",
4025
- "\u1EA1",
4026
- "\u1EA3",
4027
- "\xE3",
4028
- "\xE2",
4029
- "\u1EA7",
4030
- "\u1EA5",
4031
- "\u1EAD",
4032
- "\u1EA9",
4033
- "\u1EAB",
4034
- "\u0103",
4035
- "\u1EB1",
4036
- "\u1EAF",
4037
- "\u1EB7",
4038
- "\u1EB3",
4039
- "\u1EB5"
4040
- ],
4041
- e: [
4042
- "\xE8",
4043
- "\xE9",
4044
- "\u1EB9",
4045
- "\u1EBB",
4046
- "\u1EBD",
4047
- "\xEA",
4048
- "\u1EC1",
4049
- "\u1EBF",
4050
- "\u1EC7",
4051
- "\u1EC3",
4052
- "\u1EC5"
4053
- ],
4054
- i: [
4055
- "\xEC",
4056
- "\xED",
4057
- "\u1ECB",
4058
- "\u1EC9",
4059
- "\u0129"
4060
- ],
4061
- o: [
4062
- "\xF2",
4063
- "\xF3",
4064
- "\u1ECD",
4065
- "\u1ECF",
4066
- "\xF5",
4067
- "\xF4",
4068
- "\u1ED3",
4069
- "\u1ED1",
4070
- "\u1ED9",
4071
- "\u1ED5",
4072
- "\u1ED7",
4073
- "\u01A1",
4074
- "\u1EDD",
4075
- "\u1EDB",
4076
- "\u1EE3",
4077
- "\u1EDF",
4078
- "\u1EE1"
4079
- ],
4080
- u: [
4081
- "\xF9",
4082
- "\xFA",
4083
- "\u1EE5",
4084
- "\u1EE7",
4085
- "\u0169",
4086
- "\u01B0",
4087
- "\u1EEB",
4088
- "\u1EE9",
4089
- "\u1EF1",
4090
- "\u1EED",
4091
- "\u1EEF"
4092
- ],
4093
- y: [
4094
- "\u1EF3",
4095
- "\xFD",
4096
- "\u1EF5",
4097
- "\u1EF7",
4098
- "\u1EF9"
4099
- ],
4100
- d: [
4101
- "\u0111"
4102
- ]
4103
- };
4104
- var upperCharMap = Object.entries(charMap).reduce(function(map, param) {
4105
- var _param = _sliced_to_array(param, 2), key = _param[0], value = _param[1];
4106
- map[key.toUpperCase()] = value.map(function(char) {
4107
- return char.toUpperCase();
4108
- });
4109
- return map;
4110
- }, {});
4111
- function regexSearchMapper(str) {
4112
- str = unorm.nfkc(str);
4113
- var combinedMap = _object_spread({}, charMap, upperCharMap);
4114
- var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
4115
- try {
4116
- for(var _iterator = Object.entries(combinedMap)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
4117
- var _step_value = _sliced_to_array(_step.value, 2), baseChar = _step_value[0], variations = _step_value[1];
4118
- var pattern = "[".concat(baseChar).concat(variations.join(""), "]");
4119
- var replacement = "(".concat([
4120
- baseChar
4121
- ].concat(_to_consumable_array(variations)).join("|"), ")");
4122
- str = str.replace(new RegExp(pattern, "g"), replacement);
4123
- }
4124
- } catch (err) {
4125
- _didIteratorError = true;
4126
- _iteratorError = err;
4127
- } finally{
4128
- try {
4129
- if (!_iteratorNormalCompletion && _iterator.return != null) {
4130
- _iterator.return();
4131
- }
4132
- } finally{
4133
- if (_didIteratorError) {
4134
- throw _iteratorError;
4135
- }
4136
- }
4137
- }
4138
- return str;
4139
- }
4140
- function removeAccent(str) {
4141
- return str.normalize("NFD").replace(RegExp("\\p{Diacritic}", "gu"), "");
4142
- }
4143
- export { ApolloProvider, BUILD_DIRECTORY, COMMAND, COMMIT_LINT_CLI, CYBERSKILL_CLI, CYBERSKILL_DIRECTORY, CYBERSKILL_PACKAGE_NAME, CYBERSKILL_STORAGE, C_Collection, C_Db, C_Document, C_Model, ESLINT_CLI, ESLINT_INSPECT_CLI, E_ErrorType, GIT_CLI, GIT_COMMIT_EDITMSG, GIT_HOOK, GIT_IGNORE, HOOK, LINT_STAGED_CLI, Loading, LoadingContext, LoadingProvider, MongoController, MongooseController, NODE_MODULES, NODE_MODULES_INSPECT_CLI, NextIntlContext, NextIntlProvider, PACKAGE_JSON, PACKAGE_LOCK_JSON, PATH, PNPM_CLI, PNPM_DLX_CLI, PNPM_EXEC_CLI, PNPM_LOCK_YAML, RESPONSE_STATUS, RIMRAF_CLI, SIMPLE_GIT_HOOK_CLI, SIMPLE_GIT_HOOK_JSON, TSCONFIG_JSON, TSC_CLI, TSX_CLI, VITEST_CLI, WORKING_DIRECTORY, aggregatePaginate, appendFileSync2 as appendFileSync, checkPackage, clearAllErrorLists, commandFormatter, commandLog, deepMerge, dirname2 as dirname, executeCommand, existsSync2 as existsSync, generateShortId, generateSlug, getLatestPackageVersion, getPackageJson, getStorageDir, getStoredErrorLists, initNodePersist, isJson, join2 as join, mongo, mongoosePaginate, readFileSync2 as readFileSync, regexSearchMapper, removeAccent, require2 as require, resolve2 as resolve, resolveCommands, resolveCyberSkillPath, resolveWorkingPath, rmSync2 as rmSync, saveErrorListToStorage, serializer, storageClient, storageServer, throwResponse, useLoading, useNextIntl, useStorage, useTranslateNextIntl, validate, withNextIntl, writeFileSync2 as writeFileSync };
1
+ function e(e,t){if(t==null||t>e.length)t=e.length;for(var r=0,n=new Array(t);r<t;r++)n[r]=e[r];return n}function t(e){if(Array.isArray(e))return e}function r(t){if(Array.isArray(t))return e(t)}function n(e){if(e===void 0){throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}return e}function s(e,t,r,n,s,o,a){try{var c=e[o](a);var i=c.value}catch(e){r(e);return}if(c.done){t(i)}else{Promise.resolve(i).then(n,s)}}function o(e){return function(){var t=this,r=arguments;return new Promise(function(n,o){var a=e.apply(t,r);function c(e){s(a,n,o,c,i,"next",e)}function i(e){s(a,n,o,c,i,"throw",e)}c(undefined)})}}function a(e,t,r){t=f(t);return R(e,D()?Reflect.construct(t,r||[],f(e).constructor):t.apply(e,r))}function c(e,t){if(!(e instanceof t)){throw new TypeError("Cannot call a class as a function")}}function i(e,t){for(var r=0;r<t.length;r++){var n=t[r];n.enumerable=n.enumerable||false;n.configurable=true;if("value"in n)n.writable=true;Object.defineProperty(e,n.key,n)}}function u(e,t,r){if(t)i(e.prototype,t);if(r)i(e,r);return e}function l(e,t,r){if(t in e){Object.defineProperty(e,t,{value:r,enumerable:true,configurable:true,writable:true})}else{e[t]=r}return e}function f(e){f=Object.setPrototypeOf?Object.getPrototypeOf:function e(e){return e.__proto__||Object.getPrototypeOf(e)};return f(e)}function E(e,t){if(typeof t!=="function"&&t!==null){throw new TypeError("Super expression must either be null or a function")}e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:true,configurable:true}});if(t)A(e,t)}function d(e,t){if(t!=null&&typeof Symbol!=="undefined"&&t[Symbol.hasInstance]){return!!t[Symbol.hasInstance](e)}else{return e instanceof t}}function v(e){if(typeof Symbol!=="undefined"&&e[Symbol.iterator]!=null||e["@@iterator"]!=null)return Array.from(e)}function g(e,t){var r=e==null?null:typeof Symbol!=="undefined"&&e[Symbol.iterator]||e["@@iterator"];if(r==null)return;var n=[];var s=true;var o=false;var a,c;try{for(r=r.call(e);!(s=(a=r.next()).done);s=true){n.push(a.value);if(t&&n.length===t)break}}catch(e){o=true;c=e}finally{try{if(!s&&r["return"]!=null)r["return"]()}finally{if(o)throw c}}return n}function h(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function m(){throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function p(e){for(var t=1;t<arguments.length;t++){var r=arguments[t]!=null?arguments[t]:{};var n=Object.keys(r);if(typeof Object.getOwnPropertySymbols==="function"){n=n.concat(Object.getOwnPropertySymbols(r).filter(function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable}))}n.forEach(function(t){l(e,t,r[t])})}return e}function S(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);if(t){n=n.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})}r.push.apply(r,n)}return r}function y(e,t){t=t!=null?t:{};if(Object.getOwnPropertyDescriptors){Object.defineProperties(e,Object.getOwnPropertyDescriptors(t))}else{S(Object(t)).forEach(function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))})}return e}function O(e,t){if(e==null)return{};var r=_(e,t);var n,s;if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(s=0;s<o.length;s++){n=o[s];if(t.indexOf(n)>=0)continue;if(!Object.prototype.propertyIsEnumerable.call(e,n))continue;r[n]=e[n]}}return r}function _(e,t){if(e==null)return{};var r={};var n=Object.keys(e);var s,o;for(o=0;o<n.length;o++){s=n[o];if(t.indexOf(s)>=0)continue;r[s]=e[s]}return r}function R(e,t){if(t&&(N(t)==="object"||typeof t==="function")){return t}return n(e)}function A(e,t){A=Object.setPrototypeOf||function e(e,t){e.__proto__=t;return e};return A(e,t)}function C(e,r){return t(e)||g(e,r)||T(e,r)||h()}function I(e){return r(e)||v(e)||T(e)||m()}function N(e){"@swc/helpers - typeof";return e&&typeof Symbol!=="undefined"&&e.constructor===Symbol?"symbol":typeof e}function T(t,r){if(!t)return;if(typeof t==="string")return e(t,r);var n=Object.prototype.toString.call(t).slice(8,-1);if(n==="Object"&&t.constructor)n=t.constructor.name;if(n==="Map"||n==="Set")return Array.from(n);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return e(t,r)}function D(){try{var e=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(e){}return(D=function(){return!!e})()}function b(e,t){var r,n,s,o,a={label:0,sent:function(){if(s[0]&1)throw s[1];return s[1]},trys:[],ops:[]};return o={next:c(0),"throw":c(1),"return":c(2)},typeof Symbol==="function"&&(o[Symbol.iterator]=function(){return this}),o;function c(e){return function(t){return i([e,t])}}function i(o){if(r)throw new TypeError("Generator is already executing.");while(a)try{if(r=1,n&&(s=o[0]&2?n["return"]:o[0]?n["throw"]||((s=n["return"])&&s.call(n),0):n.next)&&!(s=s.call(n,o[1])).done)return s;if(n=0,s)o=[o[0]&2,s.value];switch(o[0]){case 0:case 1:s=o;break;case 4:a.label++;return{value:o[1],done:false};case 5:a.label++;n=o[1];o=[0];continue;case 7:o=a.ops.pop();a.trys.pop();continue;default:if(!(s=a.trys,s=s.length>0&&s[s.length-1])&&(o[0]===6||o[0]===2)){a=0;continue}if(o[0]===3&&(!s||o[1]>s[0]&&o[1]<s[3])){a.label=o[1];break}if(o[0]===6&&a.label<s[1]){a.label=s[1];s=o;break}if(s&&a.label<s[2]){a.label=s[2];a.ops.push(o);break}if(s[2])a.ops.pop();a.trys.pop();continue}o=t.call(e,a)}catch(e){o=[6,e];n=0}finally{r=s=0}if(o[0]&5)throw o[1];return{value:o[0]?o[1]:void 0,done:true}}}import L from"@antfu/eslint-config";function M(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++){t[r]=arguments[r]}var n=function(e,t){var r=p({},e);return Object.keys(t).forEach(function(e){if(!Object.hasOwnProperty.call(t,e))return;var s=t[e],o=r[e];Array.isArray(s)?r[e]=I(new Set(I(Array.isArray(o)?o:[]).concat(I(s)))):(typeof s==="undefined"?"undefined":N(s))=="object"&&s!==null&&!Array.isArray(s)?r[e]=n((typeof o==="undefined"?"undefined":N(o))=="object"&&o!==null&&!Array.isArray(o)?o:{},s):r[e]=s}),r};return t.flatMap(function(e){return Array.isArray(e)?e:[e]}).reduce(function(e,t){return n(e,t)},{})}import w from"node:process";import P from"boxen";import G from"chalk";import{exec as k}from"node:child_process";import U from"node:process";import*as j from"node:util";var F=function(e){return e.Error="error",e.Warning="warning",e}(F||{});import x from"node-fetch";import*as K from"node:fs";var Y=function(e){return K.existsSync(e)};function H(e,t){var r=K.readFileSync(e,"utf-8");if(t===null||t===void 0?void 0:t.asJson)try{var n=JSON.parse(r);if((typeof n==="undefined"?"undefined":N(n))=="object"&&n!==null)return n;throw new Error("Parsed JSON is not an object or array")}catch(t){throw new Error("Failed to parse JSON from file: ".concat(e))}return r}function B(e,t){var r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=r.isJson,s=n===void 0?!1:n,o=s&&(typeof t==="undefined"?"undefined":N(t))=="object"?JSON.stringify(t,null,4):String(t);K.writeFileSync(e,o,"utf-8")}function Q(e,t){var r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=r.isJson,s=n===void 0?!1:n,o=s&&(typeof t==="undefined"?"undefined":N(t))=="object"?JSON.stringify(t,null,4):String(t);K.appendFileSync(e,o,"utf-8")}function q(e){e.forEach(function(e){Y(e)&&K.rmSync(e,{recursive:!0,force:!0})})}import*as V from"node:path";function J(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++){t[r]=arguments[r]}var n;return(n=V).resolve.apply(n,[eG].concat(I(t)))}function W(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++){t[r]=arguments[r]}var n;return(n=V).resolve.apply(n,I(t))}function z(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++){t[r]=arguments[r]}var n;return(n=V).join.apply(n,I(t))}import $ from"node-persist";import X from"node:os";import Z from"node:process";function ee(){return Z.env.CYBERSKILL_STORAGE_DIR||z(X.homedir(),eU)}function et(){return er.apply(this,arguments)}function er(){er=o(function(){var e;return b(this,function(t){switch(t.label){case 0:e=$.defaultInstance;if(e)return[3,2];return[4,$.init({dir:ee(),stringify:JSON.stringify,parse:JSON.parse,encoding:"utf8",logging:!1,forgiveParseErrors:!0})];case 1:e=t.sent();t.label=2;case 2:e;return[2]}})});return er.apply(this,arguments)}var en={get:function e(e){return o(function(){var t,r;return b(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,et()];case 1:n.sent();return[4,$.getItem(e)];case 2:return[2,(t=n.sent())!==null&&t!==void 0?t:null];case 3:r=n.sent();return[2,(console.error('❌ [Storage:get] Error getting key "'.concat(e,'":'),r),null)];case 4:return[2]}})})()},set:function e(e,t){return o(function(){var r;return b(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,et()];case 1:n.sent();return[4,$.setItem(e,t)];case 2:n.sent();return[3,4];case 3:r=n.sent();console.error('❌ [Storage:set] Error setting key "'.concat(e,'":'),r);return[3,4];case 4:return[2]}})})()},remove:function e(e){return o(function(){var t;return b(this,function(r){switch(r.label){case 0:r.trys.push([0,3,,4]);return[4,et()];case 1:r.sent();return[4,$.removeItem(e)];case 2:r.sent();return[3,4];case 3:t=r.sent();console.error('❌ [Storage:remove] Error removing key "'.concat(e,'":'),t);return[3,4];case 4:return[2]}})})()},keys:function e(){return o(function(){var e,t;return b(this,function(r){switch(r.label){case 0:r.trys.push([0,3,,4]);return[4,et()];case 1:r.sent();return[4,$.keys()];case 2:e=r.sent();return[2,Array.isArray(e)?e:(console.warn("⚠️ [Storage:keys] Invalid keys response:",e),[])];case 3:t=r.sent();return[2,(console.error("❌ [Storage:keys] Error getting keys:",t),[])];case 4:return[2]}})})()},getLogLink:function e(e){return o(function(){return b(this,function(t){try{return[2,"".concat(ee()," (key: ").concat(e,")")]}catch(e){return[2,(console.error("❌ [Storage:getLogLink] Error getting log link:",e),null)]}return[2]})})()}};var es=24*60*60*1e3;function eo(e){var t=z(eG,ex);if(Y(t))try{var r=H(t,{asJson:!0});if(r.name===e)return{path:t,file:r,isCurrentProject:!0}}catch(e){ep.warning("Failed to read local package.json: ".concat(e.message))}var n=z(eG,ej,e,ex);if(Y(n))try{var s=H(n,{asJson:!0});if(s.name===e)return{path:n,file:s,isCurrentProject:!1}}catch(t){ep.warning("Failed to read node_modules package.json for ".concat(e,": ").concat(t.message))}return!1}function ea(e){return ec.apply(this,arguments)}function ec(){ec=o(function(e){var t,r,n,s,o,a,c,i,u,l;var f=arguments;return b(this,function(E){switch(E.label){case 0:t=f.length>1&&f[1]!==void 0?f[1]:!1;r="npm_version:".concat(e),n="npm_metadata:".concat(e);return[4,en.get(r)];case 1:s=E.sent();return[4,en.get(n)];case 2:o=E.sent(),a=s&&Date.now()-s.timestamp<es;if(!t&&a)return[2,s.version];c={};(o===null||o===void 0?void 0:o.etag)&&(c["If-None-Match"]=o.etag),(o===null||o===void 0?void 0:o.lastModified)&&(c["If-Modified-Since"]=o.lastModified);E.label=3;case 3:E.trys.push([3,8,,9]);return[4,x("https://registry.npmjs.org/".concat(e,"/latest"),{headers:c})];case 4:i=E.sent();if(i.status===304&&s)return[2,s.version];if(!i.ok)throw new Error("Failed to fetch latest version: ".concat(i.statusText));return[4,i.json()];case 5:u=E.sent().version;return[4,en.set(r,{version:u,timestamp:Date.now()})];case 6:E.sent();return[4,en.set(n,{etag:i.headers.get("ETag")||void 0,lastModified:i.headers.get("Last-Modified")||void 0})];case 7:return[2,(E.sent(),u)];case 8:l=E.sent();if(ep.error("Error fetching latest version for ".concat(e,": ").concat(l.message)),s)return[2,(ep.warning("Falling back to cached version for ".concat(e,": ").concat(s.version)),s.version)];throw l;case 9:return[2]}})});return ec.apply(this,arguments)}function ei(e){return eu.apply(this,arguments)}function eu(){eu=o(function(e){var t,r,n,s,o;return b(this,function(a){switch(a.label){case 0:t={isInstalled:!1,isCurrentProject:!1,installedPath:"",installedVersion:"",latestVersion:"",file:{}};a.label=1;case 1:a.trys.push([1,6,,7]);r=eo(e);n=r;if(!n)return[3,5];t.file=r.file,t.isInstalled=!0,t.installedPath=r.path,t.installedVersion=r.file.version,t.isCurrentProject=r.isCurrentProject;if(!r.isCurrentProject)return[3,2];s=r.file.version;return[3,4];case 2:return[4,ea(e,!0)];case 3:s=a.sent();a.label=4;case 4:n=t.latestVersion=s;a.label=5;case 5:return[2,(n,t)];case 6:o=a.sent();return[2,(ep.error('Error checking package "'.concat(e,'": ').concat(o.message)),t)];case 7:return[2]}})});return eu.apply(this,arguments)}var el=U.env.DEBUG==="true",ef=j.promisify(k),eE=G.gray,ed=G.blue;function ev(){return eE("[".concat(new Date().toLocaleTimeString(),"]"))}function eg(e){var t=G[e];return typeof t=="function"?t:G.green}function eh(e,t,r,n){var s=eg(t);console.log("".concat(ev()," ").concat(s("".concat(r," ").concat(e))," ").concat(n))}function em(e,t){var r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},n=r.color,s=n===void 0?"green":n,o=r.padding,a=o===void 0?1:o,c=r.margin,i=c===void 0?1:c,u=r.borderStyle,l=u===void 0?"round":u,f=r.titleColor,E=f===void 0?"bold":f;var d=eg(s),v=eg(E);if(typeof t=="string"){console.log(P(v(d("".concat(e,"\n").concat(t))),{padding:a,margin:i,borderStyle:l,borderColor:s}));return}Array.isArray(t)&&t.length&&(t.forEach(function(e){var t=e.file,r=e.position,n=e.rule,s=e.message;console.log("".concat(ev()," ").concat(d("File:")," ").concat(ed("".concat(t).concat(r?":".concat(r):"")))),n&&console.log(" ".concat(d("Rule:")," ").concat(d(n))),console.log(" ".concat(d("Message:")," ").concat(d(s)))}),console.log(P(v(d("".concat(e,": ").concat(t.length))),{padding:a,margin:i,borderStyle:l,borderColor:s})),console.log(eE("─".repeat(40))))}var ep={success:function(e){return eh("SUCCESS","green","✔",e)},error:function(e){return eh("ERROR","red","✖",e)},warning:function(e){return eh("WARNING","yellow","⚠",e)},info:function(e){return eh("INFO","blue","ℹ",e)},printBoxedLog:em};function eS(e){return"error_list:".concat(e)}function ey(e){return eO.apply(this,arguments)}function eO(){eO=o(function(e){var t,r,n;return b(this,function(s){switch(s.label){case 0:if(e.length===0)return[2];t=Date.now(),r=eS(t);s.label=1;case 1:s.trys.push([1,3,,4]);return[4,en.set(r,{errors:e,timestamp:t})];case 2:s.sent(),setTimeout(/*#__PURE__*/o(function(){var e;return b(this,function(t){switch(t.label){case 0:return[4,en.getLogLink(r)];case 1:e=t.sent();e&&ep.info("\uD83D\uDCC2 Open the error list manually: ".concat(e));return[2]}})}),10);return[3,4];case 3:n=s.sent();ep.error("Failed to save errors: ".concat(n.message));return[3,4];case 4:return[2]}})});return eO.apply(this,arguments)}function e_(){return eR.apply(this,arguments)}function eR(){eR=o(function(){var e,t,r;return b(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,en.keys()];case 1:e=n.sent(),t=Array.isArray(e)?e.filter(function(e){var t;return e===null||e===void 0?void 0:(t=e.startsWith)===null||t===void 0?void 0:t.call(e,"error_list:")}):[];return[4,Promise.all(t.map(/*#__PURE__*/function(){var e=o(function(e){var t;return b(this,function(r){switch(r.label){case 0:return[4,en.get(e)];case 1:return[2,((t=r.sent())===null||t===void 0?void 0:t.errors)||[]]}})});return function(t){return e.apply(this,arguments)}}()))];case 2:return[2,n.sent().flat()];case 3:r=n.sent();return[2,(ep.error("Failed to retrieve stored errors: ".concat(r.message)),[])];case 4:return[2]}})});return eR.apply(this,arguments)}function eA(){return eC.apply(this,arguments)}function eC(){eC=o(function(){var e,t,r;return b(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,en.keys()];case 1:e=n.sent(),t=Array.isArray(e)?e.filter(function(e){var t;return e===null||e===void 0?void 0:(t=e.startsWith)===null||t===void 0?void 0:t.call(e,"error_list:")}):[];return[4,Promise.all(t.map(function(e){return en.remove(e)}))];case 2:n.sent();return[3,4];case 3:r=n.sent();ep.error("Failed to clear error lists: ".concat(r.message));return[3,4];case 4:return[2]}})});return eC.apply(this,arguments)}function eI(e){var t=[],r=[],n="",s=/^\s*(\d+):(\d+)\s+(error|warning)\s+(.+?)\s+(\S+)$/,o=/^(.+?)\((\d+),(\d+)\):\s+(error|warning)\s+TS\d+:\s+(\S.+)$/,a=/^✖\s+(.*?)\s+\[(.*?)\]$/;e.split("\n").forEach(function(e){if(e.startsWith("/"))n=e.trim();else{var c=s.exec(e)||[],i=o.exec(e)||[],u=a.exec(e)||[];c.length&&n?t.push({file:n,position:"".concat(c[1],":").concat(c[2]),type:c[3]==="error"?"error":"warning",message:c[4].trim(),rule:c[5].trim()}):i.length?t.push({file:i[1],position:"".concat(i[2],":").concat(i[3]),type:i[4]==="error"?"error":"warning",message:i[5].trim()}):u.length?t.push({file:"commitlint",type:"error",message:u[1].trim(),rule:u[2].trim()}):r.push(e.trim())}}),t.length&&ey(t),r.length&&el&&(ep.warning("Unmatched lines:"),r.forEach(function(e){return console.log(" ".concat(e))}))}function eN(e){try{var t=JSON.parse(e),r=[];t.forEach(function(e){var t=e.filePath,n=e.messages;n.forEach(function(e){var n=e.severity,s=e.line,o=e.column,a=e.ruleId,c=e.message;r.push({type:n===2?"error":"warning",file:t,position:"".concat(s,":").concat(o),rule:a,message:c})})}),r.length&&ey(r)}catch(t){eI(e)}}function eT(e){return eD.apply(this,arguments)}function eD(){eD=o(function(e){var t,r,n,s,o,a,c,i,u;var l=arguments;return b(this,function(f){switch(f.label){case 0:t=l.length>1&&l[1]!==void 0?l[1]:eN;r=new AbortController;U.on("SIGINT",function(){ep.warning("Process interrupted. Terminating..."),r.abort(),U.exit()});f.label=1;case 1:f.trys.push([1,3,,4]);return[4,ef(e,{maxBuffer:0x6400000,signal:r.signal})];case 2:n=f.sent(),s=n.stdout,o=n.stderr;[s,o].forEach(function(e){return e&&t(e)});return[3,4];case 3:a=f.sent();c=a.stdout,i=a.stderr,u=a.message;[c,i].forEach(function(e){return e&&t(e)}),!i&&!c&&ep.error("Command failed: ".concat(u));return[3,4];case 4:return[2]}})});return eD.apply(this,arguments)}function eb(e){return{raw:!0,cmd:e}}function eL(e,t){return(t===null||t===void 0?void 0:t.isRemote)?"".concat(e7," ").concat(ek," ").concat(e):(t===null||t===void 0?void 0:t.isCurrentProject)?"".concat(e7," ").concat(e5," src/cli.ts ").concat(e):"".concat(e7," ").concat(eW," ").concat(e)}function eM(e,t){return typeof e=="function"?eL(e(t),t):(typeof e==="undefined"?"undefined":N(e))=="object"&&(e===null||e===void 0?void 0:e.raw)===!0?e.cmd:typeof e=="string"?eL(e,t):e}function ew(e){return eP.apply(this,arguments)}function eP(){eP=o(function(e){var t,r,n,s,o,a,c;var i=arguments;return b(this,function(u){switch(u.label){case 0:t=i.length>1&&i[1]!==void 0?i[1]:{};n=(r=t===null||t===void 0?void 0:t.isRemote)!==null&&r!==void 0?r:!1;if(!n)return[3,1];c=!1;return[3,3];case 1:return[4,ei(ek)];case 2:c=u.sent().isCurrentProject;u.label=3;case 3:s=c,o={isRemote:n,isCurrentProject:s},a=typeof e=="function"?e(o):e;return[2,Object.fromEntries(Object.entries(a).map(function(e){var t=C(e,2),r=t[0],n=t[1];return[r,eM(n,o)]}))]}})});return eP.apply(this,arguments)}var eG=w.env.INIT_CWD||w.cwd(),ek="@cyberskill/shared",eU=".cyberskill-storage",ej="node_modules",eF="dist",ex="package.json",eK="package-lock.json",eY="tsconfig.json",eH=".gitignore",eB=".simple-git-hooks.json",eQ="pnpm-lock.yaml",eq=".git/hooks/",eV=".git/COMMIT_EDITMSG",eJ=z(eG,ej,ek,eF),eW="cyberskill",ez="eslint",e$="vitest",eX="vitest",eZ="@commitlint/cli",e0="commitlint",e2="lint-staged",e1="lint-staged",e3="tsc",e4="tsc",e5="tsx",e8="git",e6="pnpm",e7="pnpm exec",e9="simple-git-hooks",te="simple-git-hooks",tt="@eslint/config-inspector",tr="eslint-config-inspector",tn="node-modules-inspector",ts="node-modules-inspector",to={CYBERSKILL_DIRECTORY:eJ,WORKING_DIRECTORY:eG,TS_CONFIG:J(eY),GIT_IGNORE:J(eH),GIT_HOOK:J(eq),GIT_COMMIT_MSG:J(eV),SIMPLE_GIT_HOOKS_JSON:J(eB),PACKAGE_JSON:J(ex),PACKAGE_LOCK_JSON:J(eK),PNPM_LOCK_YAML:J(eQ),NODE_MODULES:J(ej),CYBERSKILL:{LINT_STAGED_CONFIG:J("".concat(eJ,"/configs/lint-staged/base.js")),COMMITLINT_CONFIG:J("".concat(eJ,"/configs/commitlint/base.js")),UNIT_TEST_CONFIG:J("".concat(eJ,"/configs/vitest/react/unit.js")),E2E_TEST_CONFIG:J("".concat(eJ,"/configs/vitest/react/e2e.js"))}};function ta(e){var t=e.isCurrentProject;return p({"pre-commit":e1,"commit-msg":e0},t&&{"pre-push":eb("".concat(e8," pull"))})}function tc(e,t){return eb("".concat(e6," add -D ").concat(e," && ").concat(e7," ").concat(t))}function ti(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:"";return eb("".concat(e7," ").concat(e," ").concat(t).trim())}var tu={SIMPLE_GIT_HOOKS:tc(e9,te),ESLINT_INSPECT:tc(tt,tr),NODE_MODULES_INSPECT:tc(tn,ts),ESLINT_CHECK:ti(ez,to.WORKING_DIRECTORY),ESLINT_FIX:ti(ez,"".concat(to.WORKING_DIRECTORY," --fix")),TYPESCRIPT_CHECK:tc(e3,"".concat(e4," -p ").concat(to.TS_CONFIG," --noEmit")),CONFIGURE_GIT_HOOK:eb("".concat(e8," config core.hooksPath ").concat(to.GIT_HOOK)),BUILD:eb("".concat(e6," run build")),STAGE_BUILD_DIRECTORY:eb("".concat(e8," add ").concat(eF)),PNPM_INSTALL_STANDARD:eb("".concat(e6," install")),PNPM_INSTALL_LEGACY:eb("".concat(e6," install --legacy-peer-deps")),PNPM_INSTALL_FORCE:eb("".concat(e6," install --force")),CYBERSKILL:{TEST_UNIT:tc(e$,"".concat(eX," --config ").concat(to.CYBERSKILL.UNIT_TEST_CONFIG)),TEST_E2E:tc(e$,"".concat(eX," --config ").concat(to.CYBERSKILL.E2E_TEST_CONFIG)),COMMIT_LINT:tc(eZ,"".concat(e0," --edit ").concat(to.GIT_COMMIT_MSG," --config ").concat(to.CYBERSKILL.COMMITLINT_CONFIG)),LINT_STAGED:tc(e2,"".concat(e1," --config ").concat(to.CYBERSKILL.LINT_STAGED_CONFIG))}};var tl={GRAPHQL_PARSE_FAILED:{CODE:"GRAPHQL_PARSE_FAILED",MESSAGE:"The GraphQL operation string contains a syntax error."},GRAPHQL_VALIDATION_FAILED:{CODE:"GRAPHQL_VALIDATION_FAILED",MESSAGE:"The GraphQL operation is not valid against the server's schema."},BAD_USER_INPUT:{CODE:"BAD_USER_INPUT",MESSAGE:"The GraphQL operation includes an invalid value for a field argument."},PERSISTED_QUERY_NOT_FOUND:{CODE:"PERSISTED_QUERY_NOT_FOUND",MESSAGE:"A client sent the hash of a query string to execute via automatic persisted queries, but the query was not in the APQ cache."},PERSISTED_QUERY_NOT_SUPPORTED:{CODE:"PERSISTED_QUERY_NOT_SUPPORTED",MESSAGE:"A client sent the hash of a query string to execute via automatic persisted queries, but the server has disabled APQ."},OPERATION_RESOLUTION_FAILURE:{CODE:"OPERATION_RESOLUTION_FAILURE",MESSAGE:"The request was parsed successfully and is valid against the server's schema, but the server couldn't resolve which operation to run. This occurs when a request containing multiple named operations doesn't specify which operation to run (i.e.,operationName), or if the named operation isn't included in the request."},CONTINUE:{CODE:100,MESSAGE:"Continue"},SWITCHING_PROTOCOLS:{CODE:101,MESSAGE:"Switching Protocols"},PROCESSING:{CODE:102,MESSAGE:"Processing"},OK:{CODE:200,MESSAGE:"OK"},CREATED:{CODE:201,MESSAGE:"Created"},ACCEPTED:{CODE:202,MESSAGE:"Accepted"},NON_AUTHORITATIVE_INFORMATION:{CODE:203,MESSAGE:"Non Authoritative Information"},NO_CONTENT:{CODE:204,MESSAGE:"No Content"},RESET_CONTENT:{CODE:205,MESSAGE:"Reset Content"},PARTIAL_CONTENT:{CODE:206,MESSAGE:"Partial Content"},MULTI_STATUS:{CODE:207,MESSAGE:"Multi-Status"},MULTIPLE_CHOICES:{CODE:300,MESSAGE:"Multiple Choices"},MOVED_PERMANENTLY:{CODE:301,MESSAGE:"Moved Permanently"},MOVED_TEMPORARILY:{CODE:302,MESSAGE:"Moved Temporarily"},SEE_OTHER:{CODE:303,MESSAGE:"See Other"},NOT_MODIFIED:{CODE:304,MESSAGE:"Not Modified"},USE_PROXY:{CODE:305,MESSAGE:"Use Proxy"},TEMPORARY_REDIRECT:{CODE:307,MESSAGE:"Temporary Redirect"},PERMANENT_REDIRECT:{CODE:308,MESSAGE:"Permanent Redirect"},BAD_REQUEST:{CODE:400,MESSAGE:"Bad Request"},UNAUTHORIZED:{CODE:401,MESSAGE:"Unauthorized"},PAYMENT_REQUIRED:{CODE:402,MESSAGE:"Payment Required"},FORBIDDEN:{CODE:403,MESSAGE:"Forbidden"},NOT_FOUND:{CODE:404,MESSAGE:"Not Found"},METHOD_NOT_ALLOWED:{CODE:405,MESSAGE:"Method Not Allowed"},NOT_ACCEPTABLE:{CODE:406,MESSAGE:"Not Acceptable"},PROXY_AUTHENTICATION_REQUIRED:{CODE:407,MESSAGE:"Proxy Authentication Required"},REQUEST_TIMEOUT:{CODE:408,MESSAGE:"Request Timeout"},CONFLICT:{CODE:409,MESSAGE:"Conflict"},GONE:{CODE:410,MESSAGE:"Gone"},LENGTH_REQUIRED:{CODE:411,MESSAGE:"Length Required"},PRECONDITION_FAILED:{CODE:412,MESSAGE:"Precondition Failed"},REQUEST_TOO_LONG:{CODE:413,MESSAGE:"Request Entity Too Large"},REQUEST_URI_TOO_LONG:{CODE:414,MESSAGE:"Request-URI Too Long"},UNSUPPORTED_MEDIA_TYPE:{CODE:415,MESSAGE:"Unsupported Media Type"},REQUESTED_RANGE_NOT_SATISFIABLE:{CODE:416,MESSAGE:"Requested Range Not Satisfiable"},EXPECTATION_FAILED:{CODE:417,MESSAGE:"Expectation Failed"},IM_A_TEAPOT:{CODE:418,MESSAGE:"I'm a teapot"},INSUFFICIENT_SPACE_ON_RESOURCE:{CODE:419,MESSAGE:"Insufficient Space on Resource"},METHOD_FAILURE:{CODE:420,MESSAGE:"Method Failure"},MISDIRECTED_REQUEST:{CODE:421,MESSAGE:"Misdirected Request"},UNPROCESSABLE_ENTITY:{CODE:422,MESSAGE:"Unprocessable Entity"},LOCKED:{CODE:423,MESSAGE:"Locked"},FAILED_DEPENDENCY:{CODE:424,MESSAGE:"Failed Dependency"},PRECONDITION_REQUIRED:{CODE:428,MESSAGE:"Precondition Required"},TOO_MANY_REQUESTS:{CODE:429,MESSAGE:"Too Many Requests"},REQUEST_HEADER_FIELDS_TOO_LARGE:{CODE:431,MESSAGE:"Request Header Fields Too Large"},UNAVAILABLE_FOR_LEGAL_REASONS:{CODE:451,MESSAGE:"Unavailable For Legal Reasons"},INTERNAL_SERVER_ERROR:{CODE:500,MESSAGE:"Internal Server Error"},NOT_IMPLEMENTED:{CODE:501,MESSAGE:"Not Implemented"},BAD_GATEWAY:{CODE:502,MESSAGE:"Bad Gateway"},SERVICE_UNAVAILABLE:{CODE:503,MESSAGE:"Service Unavailable"},GATEWAY_TIMEOUT:{CODE:504,MESSAGE:"Gateway Timeout"},HTTP_VERSION_NOT_SUPPORTED:{CODE:505,MESSAGE:"HTTP Version Not Supported"},INSUFFICIENT_STORAGE:{CODE:507,MESSAGE:"Insufficient Storage"},NETWORK_AUTHENTICATION_REQUIRED:{CODE:511,MESSAGE:"Network Authentication Required"}};import{format as tf}from"date-fns";import{Document as tE}from"mongoose";import td from"mongoose-aggregate-paginate-v2";import tv from"mongoose-paginate-v2";import{v4 as tg}from"uuid";import th from"crypto-js";import tm from"slugify";var tp=tm.default||tm;function tS(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:"",t=arguments.length>1?arguments[1]:void 0;var r=t||{},n=r.lower,s=n===void 0?!0:n,o=r.locale,a=o===void 0?"vi":o,c=O(r,["lower","locale"]);return tp(e,p({lower:s,locale:a},c))}function ty(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:4;return th.SHA256(e).toString(th.enc.Hex).slice(0,t)}var tO={isEmpty:function e(e){return e==null?!0:Array.isArray(e)?e.length===0:(typeof e==="undefined"?"undefined":N(e))=="object"?d(e,Date)?!1:Object.keys(e).length===0:typeof e=="string"?e.trim().length===0:!1}};var t_={getDateTime:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:new Date;return tf(e,"yyyy-MM-dd HH:mm:ss.SSS")},createGenericFields:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=e.returnDateAs,r=t===void 0?"string":t;var n=r==="string"?t_.getDateTime():new Date;return{id:tg(),isDel:!1,createdAt:n,updatedAt:n}},applyPlugins:function e(e,t){t.filter(function(e){return typeof e=="function"}).forEach(function(t){return e.plugin(t)})},applyMiddlewares:function e(e,t){t.forEach(function(t){var r=t.method,n=t.pre,s=t.post;r&&n&&e.pre(r,n),r&&s&&e.post(r,s)})},createGenericSchema:function e(e){return new e.Schema({id:{type:String,default:tg,required:!0,unique:!0},isDel:{type:Boolean,default:!1,required:!0}},{timestamps:!0})},createSchema:function e(e){var t=e.mongoose,r=e.schema,n=e.virtuals,s=n===void 0?[]:n,o=e.standalone,a=o===void 0?!1:o;var c=new t.Schema(r,{strict:!0});return s.forEach(function(e){var t=e.name,r=e.options,n=e.get;var s=c.virtual(t,r);n&&s.get(n)}),a||c.add(t_.createGenericSchema(t)),c},createModel:function e(e){var t=e.mongoose,r=e.name,n=e.schema,s=e.pagination,o=s===void 0?!1:s,a=e.aggregate,c=a===void 0?!1:a,i=e.virtuals,u=i===void 0?[]:i,l=e.middlewares,f=l===void 0?[]:l;if(!r)throw new Error("Model name is required.");if(t.models[r])return t.models[r];var E=t_.createSchema({mongoose:t,schema:n,virtuals:u});return t_.applyPlugins(E,[o&&tv,c&&td]),t_.applyMiddlewares(E,f),t.model(r,E)},createSlugQuery:function e(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},r=arguments.length>2?arguments[2]:void 0;return y(p({},t,r&&{id:{$ne:r}}),{$or:[{slug:e},{slugHistory:e}]})},validator:{isEmpty:function e(){return /*#__PURE__*/function(){var e=o(function(e){return b(this,function(t){return[2,!tO.isEmpty(e)]})});return function(t){return e.apply(this,arguments)}}()},isUnique:function e(e){return /*#__PURE__*/function(){var t=o(function(t){var r;return b(this,function(n){switch(n.label){case 0:if(!Array.isArray(e)||e.length===0)throw new Error("Fields must be a non-empty array of strings.");r={$or:e.map(function(e){return l({},e,t)})};return[4,this.constructor.findOne(r)];case 1:return[2,!n.sent()]}})});return function(e){return t.apply(this,arguments)}}()},matchesRegex:function e(e){return /*#__PURE__*/function(){var t=o(function(t){return b(this,function(r){if(!Array.isArray(e)||e.some(function(e){return!d(e,RegExp)}))throw new Error("regexArray must be an array of valid RegExp objects.");return[2,e.every(function(e){return e.test(t)})]})});return function(e){return t.apply(this,arguments)}}()}}},tR=/*#__PURE__*/function(){"use strict";function e(t,r){c(this,e);this.collection=t.collection(r)}u(e,[{key:"createOne",value:function e(e){var t=this;return o(function(){var r,n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);r=p({},t_.createGenericFields(),e);n={success:!0,message:"Document created successfully"};return[4,t.collection.insertOne(r)];case 1:return[2,(n.result=o.sent(),n)];case 2:s=o.sent();return[2,{success:!1,message:s.message}];case 3:return[2]}})})()}},{key:"createMany",value:function e(e){var t=this;return o(function(){var r,n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);r=e.map(function(e){return p({},t_.createGenericFields(),e)});return[4,t.collection.insertMany(r)];case 1:n=o.sent();return[2,n.insertedCount===0?{success:!1,message:"No documents were inserted"}:{success:!0,message:"".concat(n.insertedCount," documents created successfully"),result:n}];case 2:s=o.sent();return[2,{success:!1,message:s.message}];case 3:return[2]}})})()}},{key:"findOne",value:function e(e){var t=this;return o(function(){var r,n;return b(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);return[4,t.collection.findOne(e)];case 1:r=s.sent();return[2,r?{success:!0,message:"Document found",result:r}:{success:!1,message:"Document not found"}];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}},{key:"findAll",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};var t=this;return o(function(){var r,n;return b(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);r={success:!0,message:"Documents retrieved successfully"};return[4,t.collection.find(e).toArray()];case 1:return[2,(r.result=s.sent(),r)];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}},{key:"count",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};var t=this;return o(function(){var r,n;return b(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);r={success:!0,message:"Count retrieved successfully"};return[4,t.collection.countDocuments(e)];case 1:return[2,(r.result=s.sent(),r)];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}},{key:"updateOne",value:function e(e,t){var r=this;return o(function(){var n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);return[4,r.collection.updateOne(e,{$set:t})];case 1:n=o.sent();return[2,n.matchedCount===0?{success:!1,message:"No documents matched the filter"}:{success:!0,message:"Document updated successfully",result:n}];case 2:s=o.sent();return[2,{success:!1,message:s.message}];case 3:return[2]}})})()}},{key:"updateMany",value:function e(e,t){var r=this;return o(function(){var n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);return[4,r.collection.updateMany(e,{$set:t})];case 1:n=o.sent();return[2,n.matchedCount===0?{success:!1,message:"No documents matched the filter"}:{success:!0,message:"Documents updated successfully",result:n}];case 2:s=o.sent();return[2,{success:!1,message:s.message}];case 3:return[2]}})})()}},{key:"deleteOne",value:function e(e){var t=this;return o(function(){var r,n;return b(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);return[4,t.collection.deleteOne(e)];case 1:r=s.sent();return[2,r.deletedCount===0?{success:!1,message:"No documents matched the filter"}:{success:!0,message:"Document deleted successfully",result:r}];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}},{key:"deleteMany",value:function e(e){var t=this;return o(function(){var r,n;return b(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);return[4,t.collection.deleteMany(e)];case 1:r=s.sent();return[2,r.deletedCount===0?{success:!1,message:"No documents matched the filter"}:{success:!0,message:"Documents deleted successfully",result:r}];case 2:n=s.sent();return[2,{success:!1,message:n.message}];case 3:return[2]}})})()}}]);return e}(),tA=/*#__PURE__*/function(){"use strict";function e(t){c(this,e);this.model=t}u(e,[{key:"getModelName",value:function e(){return this.model.modelName}},{key:"findOne",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},n=arguments.length>3?arguments[3]:void 0;var s=this;return o(function(){var o,a,c;return b(this,function(i){switch(i.label){case 0:i.trys.push([0,2,,3]);o=s.model.findOne(e,t,r);n&&o.populate(n);return[4,o.exec()];case 1:a=i.sent();return[2,a?{success:!0,result:a}:{success:!1,message:"No ".concat(s.getModelName()," found."),code:tl.NOT_FOUND.CODE}];case 2:c=i.sent();return[2,{success:!1,message:c.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"findAll",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},n=arguments.length>3?arguments[3]:void 0;var s=this;return o(function(){var o,a,c;return b(this,function(i){switch(i.label){case 0:i.trys.push([0,2,,3]);o=s.model.find(e,t,r);n&&o.populate(n);a={success:!0};return[4,o.exec()];case 1:return[2,(a.result=i.sent(),a)];case 2:c=i.sent();return[2,{success:!1,message:c.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"findPaging",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var r=this;return o(function(){var n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);n={success:!0};return[4,r.model.paginate(e,t)];case 1:return[2,(n.result=o.sent(),n)];case 2:s=o.sent();return[2,{success:!1,message:s.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"findPagingAggregate",value:function e(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var r=this;return o(function(){var n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);n={success:!0};return[4,r.model.aggregatePaginate(r.model.aggregate(e),t)];case 1:return[2,(n.result=o.sent(),n)];case 2:s=o.sent();return[2,{success:!1,message:s.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"count",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{};var t=this;return o(function(){var r,n;return b(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);r={success:!0};return[4,t.model.countDocuments(e)];case 1:return[2,(r.result=s.sent(),r)];case 2:n=s.sent();return[2,{success:!1,message:n.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"createOne",value:function e(e){var t=this;return o(function(){var r,n;return b(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);r={success:!0};return[4,t.model.create(e)];case 1:return[2,(r.result=s.sent(),r)];case 2:n=s.sent();return[2,{success:!1,message:n.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"createMany",value:function e(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var r=this;return o(function(){var n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);n={success:!0};return[4,r.model.insertMany(e,t)];case 1:return[2,(n.result=o.sent().map(function(e){return d(e,tE)?e.toObject():null}).filter(function(e){return e!==null}),n)];case 2:s=o.sent();return[2,{success:!1,message:s.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"updateOne",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=this;return o(function(){var s,o;return b(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);return[4,n.model.findOneAndUpdate(e,t,p({new:!0},r)).exec()];case 1:s=a.sent();return[2,s?{success:!0,result:s}:{success:!1,message:"Failed to update ".concat(n.getModelName(),"."),code:tl.NOT_FOUND.CODE}];case 2:o=a.sent();return[2,{success:!1,message:o.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"updateMany",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=this;return o(function(){var s,o;return b(this,function(a){switch(a.label){case 0:a.trys.push([0,2,,3]);s={success:!0};return[4,n.model.updateMany(e,t,r).exec()];case 1:return[2,(s.result=a.sent(),s)];case 2:o=a.sent();return[2,{success:!1,message:o.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"deleteOne",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var r=this;return o(function(){var n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);return[4,r.model.findOneAndDelete(e,t).exec()];case 1:n=o.sent();return[2,n?{success:!0,result:n}:{success:!1,message:"No ".concat(r.getModelName()," found to delete."),code:tl.NOT_FOUND.CODE}];case 2:s=o.sent();return[2,{success:!1,message:s.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"deleteMany",value:function e(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:{},t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{};var r=this;return o(function(){var n,s;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,2,,3]);return[4,r.model.deleteMany(e,t).exec()];case 1:n=o.sent();return[2,n.deletedCount===0?{success:!1,message:"No documents found to delete.",code:tl.NOT_FOUND.CODE}:{success:!0,result:n}];case 2:s=o.sent();return[2,{success:!1,message:s.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}},{key:"createShortId",value:function e(e){var t=arguments.length>1&&arguments[1]!==void 0?arguments[1]:4;var r=this;return o(function(){var n,s,o,a;return b(this,function(c){switch(c.label){case 0:n=new Set;s=0;c.label=1;case 1:if(!(s<10))return[3,5];o=ty(e,s+t);a=!n.has(o);if(!a)return[3,3];n.add(o);return[4,r.model.exists({shortId:o})];case 2:a=!c.sent();c.label=3;case 3:if(a)return[2,{success:!0,result:o}];c.label=4;case 4:s++;return[3,1];case 5:return[2,{success:!1,message:"Failed to create a unique shortId",code:tl.INTERNAL_SERVER_ERROR.CODE}]}})})()}},{key:"createSlug",value:function e(e,t){var r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=this;return o(function(){var s,a,c,i,u,l,f,E,d,v,g;return b(this,function(h){switch(h.label){case 0:h.trys.push([0,8,,9]);s=t[e],a=/*#__PURE__*/function(){var e=o(function(e){var s,o,a;return b(this,function(c){switch(c.label){case 0:return[4,n.model.findOne(t_.createSlugQuery(e,r,t.id))];case 1:s=c.sent();if(!s)return[2,e];o=1;c.label=2;case 2:a="".concat(e,"-").concat(o);return[4,n.model.findOne(t_.createSlugQuery(a,r,t.id))];case 3:s=c.sent(),o++;c.label=4;case 4:if(s)return[3,2];c.label=5;case 5:return[2,a]}})});return function t(t){return e.apply(this,arguments)}}();if(!((typeof s==="undefined"?"undefined":N(s))=="object"))return[3,5];c={};i=[];for(u in s)i.push(u);l=0;h.label=1;case 1:if(!(l<i.length))return[3,4];f=i[l];E=tS(s[f]);return[4,a(E)];case 2:c[f]=h.sent();h.label=3;case 3:l++;return[3,1];case 4:return[2,{success:!0,result:c}];case 5:d=tS(s);v={success:!0};return[4,a(d)];case 6:return[2,(v.result=h.sent(),v)];case 7:return[3,9];case 8:g=h.sent();return[2,{success:!1,message:"Failed to create a unique slug: ".concat(g.message),code:tl.INTERNAL_SERVER_ERROR.CODE}];case 9:return[2]}})})()}},{key:"aggregate",value:function e(e){var t=this;return o(function(){var r,n;return b(this,function(s){switch(s.label){case 0:s.trys.push([0,2,,3]);r={success:!0};return[4,t.model.aggregate(e)];case 1:return[2,(r.result=s.sent(),r)];case 2:n=s.sent();return[2,{success:!1,message:n.message,code:tl.INTERNAL_SERVER_ERROR.CODE}];case 3:return[2]}})})()}}]);return e}();import{ApolloClient as tC,ApolloLink as tI,ApolloProvider as tN,HttpLink as tT,InMemoryCache as tD,split as tb}from"@apollo/client";import{onError as tL}from"@apollo/client/link/error";import{GraphQLWsLink as tM}from"@apollo/client/link/subscriptions";import{getMainDefinition as tw}from"@apollo/client/utilities";import{createClient as tP}from"graphql-ws";import{jsx as tG}from"react/jsx-runtime";function tk(e){var t=tL(function(e){var t=e.graphQLErrors,r=e.networkError;t===null||t===void 0?void 0:t.forEach(function(e){var t=e.message,r=e.locations,n=e.path;return console.error("[GraphQL error]: Message: ".concat(t,", Location: ").concat(r,", Path: ").concat(n))}),r&&console.error("[Network error]: ".concat(r))}),r=new tT({uri:e===null||e===void 0?void 0:e.uri,credentials:"include"}),n=(e===null||e===void 0?void 0:e.wsUrl)?new tM(tP({url:e.wsUrl})):null,s=n?tb(function(e){var t=e.query;var r=tw(t);if(r.kind==="OperationDefinition"){var n=r.operation;return n==="subscription"}return!1},n,r):r,o=new tI(function(e,t){return e.variables&&(e.variables=JSON.parse(JSON.stringify(e.variables),function(e,t){return e==="__typename"?void 0:t})),t(e)});return{errorLink:t,httpLink:r,wsLink:n,splitLink:s,cleanTypeName:o}}function tU(e){var t=e.isNextJS,r=e.options,n=e.children,s=e.client,o=e.provider,a=e.cache;var c=s!==null&&s!==void 0?s:tC;if(typeof c!="function")throw new TypeError("Invalid ApolloClient provided. Ensure CustomClient is a class.");var i=o||tN,u=a||tD,l=tk(r),f=l.cleanTypeName,E=l.errorLink,v=l.splitLink,g=new c(p({cache:d(u,tD)?u:new tD,link:tI.from([f,E,v].filter(Boolean))},r));return t?tG(i,{makeClient:function(){return g},children:n}):tG(i,{client:g,children:n})}import tj from"classnames";import{createContext as tF,use as tx,useCallback as tK,useMemo as tY,useState as tH}from"react";import tB from"./react/loading.module.scss";import{jsx as tQ,jsxs as tq}from"react/jsx-runtime";var tV=tF(void 0);function tJ(){var e=tx(tV);if(!e)throw new Error("useLoading must be used within a LoadingProvider");return e}function tW(e){var t=e.full,r=t===void 0?!1:t,n=e.block,s=n===void 0?!1:n,o=e.className,a=o===void 0?"":o,c=e.message,i=c===void 0?"Loading":c,u=O(e,["full","block","className","message"]);function l(){return tq("div",y(p({className:tB.container},u),{children:[tQ("div",{className:tB.ring}),tQ("div",{className:tB.ring}),tQ("div",{className:tB.ring}),tQ("div",{className:tB.ring}),i&&tQ("div",{className:tB.message,children:i})]}))}return r?tQ("div",{className:tj(tB.fullscreen,a),children:l()}):s?tQ("div",{className:tj(tB.block,a),children:l()}):l()}function tz(e){var t=e.children;var r=C(tH(!1),2),n=r[0],s=r[1],o=C(tH(!1),2),a=o[0],c=o[1],i=tK(function(){var e=arguments.length>0&&arguments[0]!==void 0?arguments[0]:!1;s(!0),c(e)},[]),u=tK(function(){s(!1),c(!1)},[]),l=tY(function(){return{isLoading:n,isGlobalLoading:a,showLoading:i,hideLoading:u}},[n,a,i,u]);return tQ(tV,{value:l,children:n?tQ(tW,{full:a}):t})}import{NextIntlClientProvider as t$,useTranslations as tX}from"next-intl";import{createContext as tZ,use as t0,useMemo as t2}from"react";import{useCallback as t1,useEffect as t3,useState as t4}from"react";var t5={serialize:function(e){return JSON.stringify(e,function(e,t){return d(t,Date)?{__type:"Date",value:t.toISOString()}:t})},deserialize:function(e){return JSON.parse(e,function(e,t){return(t===null||t===void 0?void 0:t.__type)==="Date"?new Date(t.value):t})}};import t8 from"localforage";var t6={get:function e(e){return o(function(){var t;return b(this,function(r){switch(r.label){case 0:r.trys.push([0,2,,3]);return[4,t8.getItem(e)];case 1:return[2,r.sent()];case 2:t=r.sent();return[2,(console.error('❌ [Storage:get] Error getting key "'.concat(e,'":'),t),null)];case 3:return[2]}})})()},set:function e(e,t){return o(function(){var r;return b(this,function(n){switch(n.label){case 0:n.trys.push([0,2,,3]);return[4,t8.setItem(e,t)];case 1:n.sent();return[3,3];case 2:r=n.sent();console.error('❌ [Storage:set] Error setting key "'.concat(e,'":'),r);return[3,3];case 3:return[2]}})})()},remove:function e(e){return o(function(){var t;return b(this,function(r){switch(r.label){case 0:r.trys.push([0,2,,3]);return[4,t8.removeItem(e)];case 1:r.sent();return[3,3];case 2:t=r.sent();console.error('❌ [Storage:remove] Error removing key "'.concat(e,'":'),t);return[3,3];case 3:return[2]}})})()},keys:function e(){return o(function(){var e,t;return b(this,function(r){switch(r.label){case 0:r.trys.push([0,2,,3]);return[4,t8.keys()];case 1:return[2,(e=r.sent())!==null&&e!==void 0?e:[]];case 2:t=r.sent();return[2,(console.error("❌ [Storage:keys] Error getting keys:",t),[])];case 3:return[2]}})})()}};function t7(e,t){var r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:t5;var n=C(t4(t),2),s=n[0],a=n[1],c=C(t4(!1),2),i=c[0],u=c[1];t3(function(){var n=!0;return o(function(){var s,o,c,i;return b(this,function(l){switch(l.label){case 0:l.trys.push([0,6,7,8]);return[4,t6.get(e)];case 1:s=l.sent();if(!n)return[3,5];if(!(s!==null))return[3,2];o=r.deserialize(s);a(o);return[3,5];case 2:if(!(t!==void 0))return[3,4];c=r.serialize(t);return[4,t6.set(e,c)];case 3:l.sent(),a(t);return[3,5];case 4:a(void 0);l.label=5;case 5:return[3,8];case 6:i=l.sent();console.error('Error loading value for key "'.concat(e,'":'),i),n&&a(t);return[3,8];case 7:n&&u(!0);return[7];case 8:return[2]}})})(),function(){n=!1,u(!1)}},[e,t,r]),t3(function(){if(!i)return;o(function(){var t,n;return b(this,function(o){switch(o.label){case 0:o.trys.push([0,3,,4]);if(!(s!==void 0))return[3,2];t=r.serialize(s);return[4,t6.set(e,t)];case 1:o.sent();o.label=2;case 2:return[3,4];case 3:n=o.sent();console.error('Error saving value for key "'.concat(e,'":'),n);return[3,4];case 4:return[2]}})})()},[s,e,r,i]);var l=t1(function(e){a(function(t){return typeof e=="function"?e(t):e})},[]),f=t1(/*#__PURE__*/o(function(){var t;return b(this,function(r){switch(r.label){case 0:r.trys.push([0,2,,3]);return[4,t6.remove(e)];case 1:r.sent(),a(void 0);return[3,3];case 2:t=r.sent();console.error('Error removing key "'.concat(e,'":'),t);return[3,3];case 3:return[2]}})}),[e]);return{value:s,set:l,remove:f}}import{Fragment as t9,jsx as re}from"react/jsx-runtime";var rt=tZ(void 0);function rr(){var e=t0(rt);if(!e)throw new Error("useNextIntl must be used within a NextIntlProvider");return e}var rn=tX;function rs(e){var t=function(t){var r;var n=rr(),s=n.currentLanguage,o=t.messages,a=t.languages,c="en",i=o[(s===null||s===void 0?void 0:s.value)||c],u=(r=a.find(function(e){return e.value===(s===null||s===void 0?void 0:s.value)}))===null||r===void 0?void 0:r.timezone;return o?re(t$,{locale:(s===null||s===void 0?void 0:s.value)||c,messages:i,timeZone:u,children:re(e,p({},t))}):(console.warn("Missing messages for language: ".concat((s===null||s===void 0?void 0:s.value)||c)),null)};return t.displayName="withNextIntl(".concat(e.displayName||e.name||"Component",")"),t}function ro(e){var t=e.children;return re(t9,{children:t})}var ra=rs(ro);function rc(e){var t=e.children,r=e.languages,n=e.messages;var s;var o=t7("lang",(s=r===null||r===void 0?void 0:r[0])!==null&&s!==void 0?s:{}),a=o.value,c=o.set,i=t2(function(){return{languages:r,currentLanguage:a,setCurrentLanguage:c}},[r,c,a]);return re(rt,{value:i,children:re(ra,{languages:r,messages:n,children:t})})}import{Collection as ri,Db as ru}from"mongodb";import{Document as rl,Model as rf}from"mongoose";var rE=/*#__PURE__*/function(e){"use strict";E(t,e);function t(){c(this,t);return a(this,t,arguments)}return t}(ru),rd=/*#__PURE__*/function(e){"use strict";E(t,e);function t(){c(this,t);return a(this,t,arguments)}return t}(rl),rv=/*#__PURE__*/function(e){"use strict";E(t,e);function t(){c(this,t);return a(this,t,arguments)}return t}(rf),rg=/*#__PURE__*/function(e){"use strict";E(t,e);function t(){c(this,t);return a(this,t,arguments)}return t}(ri);import{GraphQLError as rh}from"graphql";function rm(e){var t=e.message,r=e.status,n=r===void 0?tl.INTERNAL_SERVER_ERROR:r,s=e.type,o=s===void 0?"graphql":s;var a;var c=(a=t!==null&&t!==void 0?t:n.MESSAGE)!==null&&a!==void 0?a:"Internal server error";throw o==="graphql"?new rh(c,{extensions:{code:n.CODE}}):new Error(c)}import rp from"unorm";function rS(e){try{return JSON.parse(e),!0}catch(e){return!1}}var ry={a:["\xe0","\xe1","ạ","ả","\xe3","\xe2","ầ","ấ","ậ","ẩ","ẫ","ă","ằ","ắ","ặ","ẳ","ẵ"],e:["\xe8","\xe9","ẹ","ẻ","ẽ","\xea","ề","ế","ệ","ể","ễ"],i:["\xec","\xed","ị","ỉ","ĩ"],o:["\xf2","\xf3","ọ","ỏ","\xf5","\xf4","ồ","ố","ộ","ổ","ỗ","ơ","ờ","ớ","ợ","ở","ỡ"],u:["\xf9","\xfa","ụ","ủ","ũ","ư","ừ","ứ","ự","ử","ữ"],y:["ỳ","\xfd","ỵ","ỷ","ỹ"],d:["đ"]},rO=Object.entries(ry).reduce(function(e,t){var r=C(t,2),n=r[0],s=r[1];return e[n.toUpperCase()]=s.map(function(e){return e.toUpperCase()}),e},{});function r_(e){e=rp.nfkc(e);var t=p({},ry,rO);var r=true,n=false,s=undefined;try{for(var o=Object.entries(t)[Symbol.iterator](),a;!(r=(a=o.next()).done);r=true){var c=C(a.value,2),i=c[0],u=c[1];var l="[".concat(i).concat(u.join(""),"]"),f="(".concat([i].concat(I(u)).join("|"),")");e=e.replace(new RegExp(l,"g"),f)}}catch(e){n=true;s=e}finally{try{if(!r&&o.return!=null){o.return()}}finally{if(n){throw s}}}return e}function rR(e){return e.normalize("NFD").replace(RegExp("\\p{Diacritic}","gu"),"")}export{tU as ApolloProvider,eF as BUILD_DIRECTORY,tu as COMMAND,e0 as COMMIT_LINT_CLI,eZ as COMMIT_LINT_PACKAGE_NAME,eW as CYBERSKILL_CLI,eJ as CYBERSKILL_DIRECTORY,ek as CYBERSKILL_PACKAGE_NAME,eU as CYBERSKILL_STORAGE,rg as C_Collection,rE as C_Db,rd as C_Document,rv as C_Model,ez as ESLINT_CLI,tr as ESLINT_INSPECT_CLI,tt as ESLINT_INSPECT_PACKAGE_NAME,F as E_ErrorType,e8 as GIT_CLI,eV as GIT_COMMIT_EDITMSG,eq as GIT_HOOK,eH as GIT_IGNORE,ta as HOOK,e1 as LINT_STAGED_CLI,e2 as LINT_STAGED_PACKAGE_NAME,tW as Loading,tV as LoadingContext,tz as LoadingProvider,tR as MongoController,tA as MongooseController,ej as NODE_MODULES,ts as NODE_MODULES_INSPECT_CLI,tn as NODE_MODULES_INSPECT_PACKAGE_NAME,rt as NextIntlContext,rc as NextIntlProvider,ex as PACKAGE_JSON,eK as PACKAGE_LOCK_JSON,to as PATH,e6 as PNPM_CLI,e7 as PNPM_EXEC_CLI,eQ as PNPM_LOCK_YAML,tl as RESPONSE_STATUS,e9 as SIMPLE_GIT_HOOKS_PACKAGE_NAME,te as SIMPLE_GIT_HOOK_CLI,eB as SIMPLE_GIT_HOOK_JSON,eY as TSCONFIG_JSON,e4 as TSC_CLI,e3 as TSC_PACKAGE_NAME,e5 as TSX_CLI,eX as VITEST_CLI,e$ as VITEST_PACKAGE_NAME,eG as WORKING_DIRECTORY,td as aggregatePaginate,Q as appendFileSync,ei as checkPackage,eA as clearAllErrorLists,ep as commandLog,M as deepMerge,eT as executeCommand,Y as existsSync,eM as formatCommand,ty as generateShortId,tS as generateSlug,ea as getLatestPackageVersion,eo as getPackageJson,ee as getStorageDir,e_ as getStoredErrorLists,et as initNodePersist,rS as isJson,z as join,t_ as mongo,tv as mongoosePaginate,eb as rawCommand,H as readFileSync,r_ as regexSearchMapper,rR as removeAccent,W as resolve,ew as resolveCommands,J as resolveWorkingPath,q as rmSync,t5 as serializer,t6 as storageClient,en as storageServer,rm as throwResponse,tJ as useLoading,rr as useNextIntl,t7 as useStorage,rn as useTranslateNextIntl,tO as validate,rs as withNextIntl,B as writeFileSync};