@cyberskill/shared 1.50.0 → 1.52.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 +100 -129
  2. package/dist/_tsup-dts-rollup.d.ts +100 -129
  3. package/dist/cli.cjs +1 -2146
  4. package/dist/cli.d.cts +1 -2
  5. package/dist/cli.d.ts +1 -2
  6. package/dist/cli.js +1 -2066
  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 -677
  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 -468
  41. package/dist/constants/path.cjs +1 -422
  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 -217
  45. package/dist/constants/response-status.cjs +1 -313
  46. package/dist/constants/response-status.js +1 -252
  47. package/dist/index.cjs +1 -4559
  48. package/dist/index.d.cts +13 -8
  49. package/dist/index.d.ts +13 -8
  50. package/dist/index.js +1 -4142
  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 +3 -0
  69. package/dist/typescript/command.d.ts +3 -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 +3 -0
  76. package/dist/typescript/index.d.ts +3 -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 +15 -13
  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
@@ -1,1581 +1 @@
1
- // src/utils/command.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 asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
14
- try {
15
- var info = gen[key](arg);
16
- var value = info.value;
17
- } catch (error) {
18
- reject(error);
19
- return;
20
- }
21
- if (info.done) {
22
- resolve(value);
23
- } else {
24
- Promise.resolve(value).then(_next, _throw);
25
- }
26
- }
27
- function _async_to_generator(fn) {
28
- return function() {
29
- var self = this, args = arguments;
30
- return new Promise(function(resolve, reject) {
31
- var gen = fn.apply(self, args);
32
- function _next(value) {
33
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
34
- }
35
- function _throw(err) {
36
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
37
- }
38
- _next(undefined);
39
- });
40
- };
41
- }
42
- function _iterable_to_array(iter) {
43
- if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
44
- }
45
- function _iterable_to_array_limit(arr, i) {
46
- var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
47
- if (_i == null) return;
48
- var _arr = [];
49
- var _n = true;
50
- var _d = false;
51
- var _s, _e;
52
- try {
53
- for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
54
- _arr.push(_s.value);
55
- if (i && _arr.length === i) break;
56
- }
57
- } catch (err) {
58
- _d = true;
59
- _e = err;
60
- } finally{
61
- try {
62
- if (!_n && _i["return"] != null) _i["return"]();
63
- } finally{
64
- if (_d) throw _e;
65
- }
66
- }
67
- return _arr;
68
- }
69
- function _non_iterable_rest() {
70
- throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
71
- }
72
- function _non_iterable_spread() {
73
- throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
74
- }
75
- function _sliced_to_array(arr, i) {
76
- return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
77
- }
78
- function _to_consumable_array(arr) {
79
- return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
80
- }
81
- function _type_of(obj) {
82
- "@swc/helpers - typeof";
83
- return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
84
- }
85
- function _unsupported_iterable_to_array(o, minLen) {
86
- if (!o) return;
87
- if (typeof o === "string") return _array_like_to_array(o, minLen);
88
- var n = Object.prototype.toString.call(o).slice(8, -1);
89
- if (n === "Object" && o.constructor) n = o.constructor.name;
90
- if (n === "Map" || n === "Set") return Array.from(n);
91
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
92
- }
93
- function _ts_generator(thisArg, body) {
94
- var f, y, t, g, _ = {
95
- label: 0,
96
- sent: function() {
97
- if (t[0] & 1) throw t[1];
98
- return t[1];
99
- },
100
- trys: [],
101
- ops: []
102
- };
103
- return g = {
104
- next: verb(0),
105
- "throw": verb(1),
106
- "return": verb(2)
107
- }, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
108
- return this;
109
- }), g;
110
- function verb(n) {
111
- return function(v) {
112
- return step([
113
- n,
114
- v
115
- ]);
116
- };
117
- }
118
- function step(op) {
119
- if (f) throw new TypeError("Generator is already executing.");
120
- while(_)try {
121
- 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;
122
- if (y = 0, t) op = [
123
- op[0] & 2,
124
- t.value
125
- ];
126
- switch(op[0]){
127
- case 0:
128
- case 1:
129
- t = op;
130
- break;
131
- case 4:
132
- _.label++;
133
- return {
134
- value: op[1],
135
- done: false
136
- };
137
- case 5:
138
- _.label++;
139
- y = op[1];
140
- op = [
141
- 0
142
- ];
143
- continue;
144
- case 7:
145
- op = _.ops.pop();
146
- _.trys.pop();
147
- continue;
148
- default:
149
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
150
- _ = 0;
151
- continue;
152
- }
153
- if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
154
- _.label = op[1];
155
- break;
156
- }
157
- if (op[0] === 6 && _.label < t[1]) {
158
- _.label = t[1];
159
- t = op;
160
- break;
161
- }
162
- if (t && _.label < t[2]) {
163
- _.label = t[2];
164
- _.ops.push(op);
165
- break;
166
- }
167
- if (t[2]) _.ops.pop();
168
- _.trys.pop();
169
- continue;
170
- }
171
- op = body.call(thisArg, _);
172
- } catch (e) {
173
- op = [
174
- 6,
175
- e
176
- ];
177
- y = 0;
178
- } finally{
179
- f = t = 0;
180
- }
181
- if (op[0] & 5) throw op[1];
182
- return {
183
- value: op[0] ? op[1] : void 0,
184
- done: true
185
- };
186
- }
187
- }
188
- import boxen from "boxen";
189
- import chalk from "chalk";
190
- import { exec } from "node:child_process";
191
- import process3 from "node:process";
192
- import * as util from "node:util";
193
- // src/constants/path.ts
194
- import process from "node:process";
195
- import { fileURLToPath } from "node:url";
196
- // src/utils/path.ts
197
- import { createRequire } from "node:module";
198
- import * as path from "node:path";
199
- function resolveCyberSkillPath() {
200
- for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
201
- urls[_key] = arguments[_key];
202
- }
203
- var _path;
204
- return (_path = path).resolve.apply(_path, [
205
- CYBERSKILL_DIRECTORY
206
- ].concat(_to_consumable_array(urls)));
207
- }
208
- function resolveWorkingPath() {
209
- for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
210
- urls[_key] = arguments[_key];
211
- }
212
- var _path;
213
- return (_path = path).resolve.apply(_path, [
214
- WORKING_DIRECTORY
215
- ].concat(_to_consumable_array(urls)));
216
- }
217
- function resolve2() {
218
- for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
219
- urls[_key] = arguments[_key];
220
- }
221
- var _path;
222
- return (_path = path).resolve.apply(_path, _to_consumable_array(urls));
223
- }
224
- function dirname2(url) {
225
- return path.dirname(url);
226
- }
227
- function require2() {
228
- return createRequire(CYBERSKILL_DIRECTORY);
229
- }
230
- function join2() {
231
- for(var _len = arguments.length, urls = new Array(_len), _key = 0; _key < _len; _key++){
232
- urls[_key] = arguments[_key];
233
- }
234
- var _path;
235
- return (_path = path).join.apply(_path, _to_consumable_array(urls));
236
- }
237
- // src/constants/path.ts
238
- var __filename2 = fileURLToPath(import.meta.url);
239
- var __dirname2 = dirname2(__filename2);
240
- var CYBERSKILL_DIRECTORY = resolve2(__dirname2, "../../");
241
- var WORKING_DIRECTORY = process.env.INIT_CWD || process.cwd();
242
- var CYBERSKILL_PACKAGE_NAME = "@cyberskill/shared";
243
- var CYBERSKILL_STORAGE = ".cyberskill-storage";
244
- var NODE_MODULES = "node_modules";
245
- var BUILD_DIRECTORY = "dist";
246
- var PACKAGE_JSON = "package.json";
247
- var PACKAGE_LOCK_JSON = "package-lock.json";
248
- var TSCONFIG_JSON = "tsconfig.json";
249
- var GIT_IGNORE = ".gitignore";
250
- var SIMPLE_GIT_HOOK_JSON = ".simple-git-hooks.json";
251
- var PNPM_LOCK_YAML = "pnpm-lock.yaml";
252
- var GIT_HOOK = ".git/hooks";
253
- var GIT_COMMIT_EDITMSG = ".git/COMMIT_EDITMSG";
254
- var CYBERSKILL_CLI = "cyberskill";
255
- var ESLINT_CLI = "eslint";
256
- var VITEST_CLI = "vitest";
257
- var COMMIT_LINT_CLI = "commitlint";
258
- var LINT_STAGED_CLI = "lint-staged";
259
- var RIMRAF_CLI = "rimraf";
260
- var TSC_CLI = "tsc";
261
- var TSX_CLI = "tsx";
262
- var GIT_CLI = "git";
263
- var PNPM_CLI = "pnpm";
264
- var PNPM_DLX_CLI = "pnpm dlx";
265
- var PNPM_EXEC_CLI = "pnpm exec";
266
- var SIMPLE_GIT_HOOK_CLI = "simple-git-hooks";
267
- var ESLINT_INSPECT_CLI = "@eslint/config-inspector";
268
- var NODE_MODULES_INSPECT_CLI = "node_modules-inspect";
269
- var PATH = {
270
- CYBERSKILL_DIRECTORY: CYBERSKILL_DIRECTORY,
271
- WORKING_DIRECTORY: WORKING_DIRECTORY,
272
- TS_CONFIG: resolveWorkingPath(TSCONFIG_JSON),
273
- GIT_IGNORE: resolveWorkingPath(GIT_IGNORE),
274
- GIT_HOOK: resolveWorkingPath(GIT_HOOK),
275
- GIT_COMMIT_MSG: resolveWorkingPath(GIT_COMMIT_EDITMSG),
276
- SIMPLE_GIT_HOOKS_JSON: resolveWorkingPath(SIMPLE_GIT_HOOK_JSON),
277
- PACKAGE_JSON: resolveWorkingPath(PACKAGE_JSON),
278
- PACKAGE_LOCK_JSON: resolveWorkingPath(PACKAGE_LOCK_JSON),
279
- PNPM_LOCK_YAML: resolveWorkingPath(PNPM_LOCK_YAML),
280
- NODE_MODULES: resolveWorkingPath(NODE_MODULES),
281
- CYBERSKILL: {
282
- LINT_STAGED_CONFIG: resolveCyberSkillPath("./configs/lint-staged/base.js"),
283
- COMMITLINT_CONFIG: resolveCyberSkillPath("./configs/commitlint/base.js"),
284
- UNIT_TEST_CONFIG: resolveCyberSkillPath("./configs/vitest/react/unit.js"),
285
- E2E_TEST_CONFIG: resolveCyberSkillPath("./configs/vitest/react/e2e.js")
286
- }
287
- };
288
- var COMMAND = {
289
- SIMPLE_GIT_HOOKS: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(SIMPLE_GIT_HOOK_CLI)),
290
- ESLINT_INSPECT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_INSPECT_CLI)),
291
- NODE_MODULES_INSPECT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(NODE_MODULES_INSPECT_CLI)),
292
- RESET: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(RIMRAF_CLI, " ").concat(NODE_MODULES, " ").concat(PNPM_LOCK_YAML)),
293
- ESLINT_CHECK: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_CLI, " ").concat(PATH.WORKING_DIRECTORY)),
294
- ESLINT_FIX: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(ESLINT_CLI, " ").concat(PATH.WORKING_DIRECTORY, " --fix")),
295
- TYPESCRIPT_CHECK: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(TSC_CLI, " -p ").concat(PATH.TS_CONFIG, " --noEmit")),
296
- CYBERSKILL: {
297
- TEST_UNIT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(VITEST_CLI, " --config ").concat(PATH.CYBERSKILL.UNIT_TEST_CONFIG)),
298
- TEST_E2E: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(VITEST_CLI, " --config ").concat(PATH.CYBERSKILL.E2E_TEST_CONFIG)),
299
- COMMIT_LINT: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(COMMIT_LINT_CLI, " --edit ").concat(PATH.GIT_COMMIT_MSG, " --config ").concat(PATH.CYBERSKILL.COMMITLINT_CONFIG)),
300
- LINT_STAGED: commandFormatter.raw("".concat(PNPM_EXEC_CLI, " ").concat(LINT_STAGED_CLI, " --config ").concat(PATH.CYBERSKILL.LINT_STAGED_CONFIG))
301
- },
302
- CONFIGURE_GIT_HOOK: commandFormatter.raw("".concat(GIT_CLI, " config core.hooksPath ").concat(PATH.GIT_HOOK)),
303
- BUILD: commandFormatter.raw("".concat(PNPM_CLI, " run build")),
304
- STAGE_BUILD_DIRECTORY: commandFormatter.raw("".concat(GIT_CLI, " add ").concat(BUILD_DIRECTORY)),
305
- PNPM_INSTALL_STANDARD: commandFormatter.raw("".concat(PNPM_CLI, " install")),
306
- PNPM_INSTALL_LEGACY: commandFormatter.raw("".concat(PNPM_CLI, " install --legacy-peer-deps")),
307
- PNPM_INSTALL_FORCE: commandFormatter.raw("".concat(PNPM_CLI, " install --force"))
308
- };
309
- // src/utils/package.ts
310
- import fetch from "node-fetch";
311
- // src/utils/fs.ts
312
- import * as fs from "node:fs";
313
- var existsSync2 = function(filePath) {
314
- return fs.existsSync(filePath);
315
- };
316
- function readFileSync2(filePath, options) {
317
- var content = fs.readFileSync(filePath, "utf-8");
318
- if (options === null || options === void 0 ? void 0 : options.asJson) {
319
- try {
320
- var parsed = JSON.parse(content);
321
- if ((typeof parsed === "undefined" ? "undefined" : _type_of(parsed)) === "object" && parsed !== null) {
322
- return parsed;
323
- }
324
- throw new Error("Parsed JSON is not an object or array");
325
- } catch (e) {
326
- throw new Error("Failed to parse JSON from file: ".concat(filePath));
327
- }
328
- }
329
- return content;
330
- }
331
- function writeFileSync2(filePath, data) {
332
- var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
333
- var _options_isJson = options.isJson, isJson = _options_isJson === void 0 ? false : _options_isJson;
334
- var content = isJson && (typeof data === "undefined" ? "undefined" : _type_of(data)) === "object" ? JSON.stringify(data, null, 4) : String(data);
335
- fs.writeFileSync(filePath, content, "utf-8");
336
- }
337
- function appendFileSync2(filePath, data) {
338
- var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
339
- var _options_isJson = options.isJson, isJson = _options_isJson === void 0 ? false : _options_isJson;
340
- var content = isJson && (typeof data === "undefined" ? "undefined" : _type_of(data)) === "object" ? JSON.stringify(data, null, 4) : String(data);
341
- fs.appendFileSync(filePath, content, "utf-8");
342
- }
343
- function rmSync2(filePaths) {
344
- filePaths.forEach(function(filePath) {
345
- if (existsSync2(filePath)) {
346
- fs.rmSync(filePath, {
347
- recursive: true,
348
- force: true
349
- });
350
- }
351
- });
352
- }
353
- // src/utils/storage-server.ts
354
- import nodePersist from "node-persist";
355
- import os from "node:os";
356
- import path2 from "node:path";
357
- import process2 from "node:process";
358
- function getStorageDir() {
359
- return process2.env.CYBERSKILL_STORAGE_DIR || path2.join(os.homedir(), CYBERSKILL_STORAGE);
360
- }
361
- function initNodePersist() {
362
- return _initNodePersist.apply(this, arguments);
363
- }
364
- function _initNodePersist() {
365
- _initNodePersist = _async_to_generator(function() {
366
- return _ts_generator(this, function(_state) {
367
- switch(_state.label){
368
- case 0:
369
- if (!!nodePersist.defaultInstance) return [
370
- 3,
371
- 2
372
- ];
373
- return [
374
- 4,
375
- nodePersist.init({
376
- dir: getStorageDir(),
377
- stringify: JSON.stringify,
378
- parse: JSON.parse,
379
- encoding: "utf8",
380
- logging: false,
381
- forgiveParseErrors: true
382
- })
383
- ];
384
- case 1:
385
- _state.sent();
386
- _state.label = 2;
387
- case 2:
388
- return [
389
- 2
390
- ];
391
- }
392
- });
393
- });
394
- return _initNodePersist.apply(this, arguments);
395
- }
396
- var storageServer = {
397
- get: function get(key) {
398
- return _async_to_generator(function() {
399
- var result, error;
400
- return _ts_generator(this, function(_state) {
401
- switch(_state.label){
402
- case 0:
403
- _state.trys.push([
404
- 0,
405
- 3,
406
- ,
407
- 4
408
- ]);
409
- return [
410
- 4,
411
- initNodePersist()
412
- ];
413
- case 1:
414
- _state.sent();
415
- return [
416
- 4,
417
- nodePersist.getItem(key)
418
- ];
419
- case 2:
420
- result = _state.sent();
421
- return [
422
- 2,
423
- result !== null && result !== void 0 ? result : null
424
- ];
425
- case 3:
426
- error = _state.sent();
427
- console.error('❌ [Storage:get] Error getting key "'.concat(key, '":'), error);
428
- return [
429
- 2,
430
- null
431
- ];
432
- case 4:
433
- return [
434
- 2
435
- ];
436
- }
437
- });
438
- })();
439
- },
440
- set: function set(key, value) {
441
- return _async_to_generator(function() {
442
- var error;
443
- return _ts_generator(this, function(_state) {
444
- switch(_state.label){
445
- case 0:
446
- _state.trys.push([
447
- 0,
448
- 3,
449
- ,
450
- 4
451
- ]);
452
- return [
453
- 4,
454
- initNodePersist()
455
- ];
456
- case 1:
457
- _state.sent();
458
- return [
459
- 4,
460
- nodePersist.setItem(key, value)
461
- ];
462
- case 2:
463
- _state.sent();
464
- return [
465
- 3,
466
- 4
467
- ];
468
- case 3:
469
- error = _state.sent();
470
- console.error('❌ [Storage:set] Error setting key "'.concat(key, '":'), error);
471
- return [
472
- 3,
473
- 4
474
- ];
475
- case 4:
476
- return [
477
- 2
478
- ];
479
- }
480
- });
481
- })();
482
- },
483
- remove: function remove(key) {
484
- return _async_to_generator(function() {
485
- var error;
486
- return _ts_generator(this, function(_state) {
487
- switch(_state.label){
488
- case 0:
489
- _state.trys.push([
490
- 0,
491
- 3,
492
- ,
493
- 4
494
- ]);
495
- return [
496
- 4,
497
- initNodePersist()
498
- ];
499
- case 1:
500
- _state.sent();
501
- return [
502
- 4,
503
- nodePersist.removeItem(key)
504
- ];
505
- case 2:
506
- _state.sent();
507
- return [
508
- 3,
509
- 4
510
- ];
511
- case 3:
512
- error = _state.sent();
513
- console.error('❌ [Storage:remove] Error removing key "'.concat(key, '":'), error);
514
- return [
515
- 3,
516
- 4
517
- ];
518
- case 4:
519
- return [
520
- 2
521
- ];
522
- }
523
- });
524
- })();
525
- },
526
- keys: function keys() {
527
- return _async_to_generator(function() {
528
- var keys, error;
529
- return _ts_generator(this, function(_state) {
530
- switch(_state.label){
531
- case 0:
532
- _state.trys.push([
533
- 0,
534
- 3,
535
- ,
536
- 4
537
- ]);
538
- return [
539
- 4,
540
- initNodePersist()
541
- ];
542
- case 1:
543
- _state.sent();
544
- return [
545
- 4,
546
- nodePersist.keys()
547
- ];
548
- case 2:
549
- keys = _state.sent();
550
- if (!Array.isArray(keys)) {
551
- console.warn("⚠️ [Storage:keys] Invalid keys response:", keys);
552
- return [
553
- 2,
554
- []
555
- ];
556
- }
557
- return [
558
- 2,
559
- keys
560
- ];
561
- case 3:
562
- error = _state.sent();
563
- console.error("❌ [Storage:keys] Error getting keys:", error);
564
- return [
565
- 2,
566
- []
567
- ];
568
- case 4:
569
- return [
570
- 2
571
- ];
572
- }
573
- });
574
- })();
575
- },
576
- getLogLink: function getLogLink(key) {
577
- return _async_to_generator(function() {
578
- var storagePath;
579
- return _ts_generator(this, function(_state) {
580
- try {
581
- storagePath = getStorageDir();
582
- return [
583
- 2,
584
- "".concat(storagePath, " (key: ").concat(key, ")")
585
- ];
586
- } catch (error) {
587
- console.error("❌ [Storage:getLogLink] Error getting log link:", error);
588
- return [
589
- 2,
590
- null
591
- ];
592
- }
593
- return [
594
- 2
595
- ];
596
- });
597
- })();
598
- }
599
- };
600
- // src/utils/package.ts
601
- var CACHE_EXPIRATION_MS = 24 * 60 * 60 * 1e3;
602
- function getPackageJson(packageName) {
603
- var workingPackageJsonPath = join2(WORKING_DIRECTORY, PACKAGE_JSON);
604
- if (existsSync2(workingPackageJsonPath)) {
605
- try {
606
- var pkg = readFileSync2(workingPackageJsonPath, {
607
- asJson: true
608
- });
609
- if (pkg.name === packageName) {
610
- return {
611
- path: workingPackageJsonPath,
612
- file: pkg
613
- };
614
- }
615
- } catch (error) {
616
- commandLog.warning("Failed to read local package.json: ".concat(error.message));
617
- }
618
- }
619
- var externalPackageJsonPath = join2(WORKING_DIRECTORY, NODE_MODULES, packageName, PACKAGE_JSON);
620
- if (existsSync2(externalPackageJsonPath)) {
621
- try {
622
- var pkg1 = readFileSync2(externalPackageJsonPath, {
623
- asJson: true
624
- });
625
- if (pkg1.name === packageName) {
626
- return {
627
- path: externalPackageJsonPath,
628
- file: pkg1
629
- };
630
- }
631
- } catch (error) {
632
- commandLog.warning("Failed to read node_modules package.json for ".concat(packageName, ": ").concat(error.message));
633
- }
634
- }
635
- return false;
636
- }
637
- function getLatestPackageVersion(packageName) {
638
- return _getLatestPackageVersion.apply(this, arguments);
639
- }
640
- function _getLatestPackageVersion() {
641
- _getLatestPackageVersion = _async_to_generator(function(packageName) {
642
- var forceRefresh, versionCacheKey, metadataCacheKey, cached, metadata, isCacheValid, headers, response, data, latestVersion, error;
643
- var _arguments = arguments;
644
- return _ts_generator(this, function(_state) {
645
- switch(_state.label){
646
- case 0:
647
- forceRefresh = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : false;
648
- versionCacheKey = "npm_version:".concat(packageName);
649
- metadataCacheKey = "npm_metadata:".concat(packageName);
650
- return [
651
- 4,
652
- storageServer.get(versionCacheKey)
653
- ];
654
- case 1:
655
- cached = _state.sent();
656
- return [
657
- 4,
658
- storageServer.get(metadataCacheKey)
659
- ];
660
- case 2:
661
- metadata = _state.sent();
662
- isCacheValid = cached && Date.now() - cached.timestamp < CACHE_EXPIRATION_MS;
663
- if (!forceRefresh && isCacheValid) {
664
- return [
665
- 2,
666
- cached.version
667
- ];
668
- }
669
- headers = {};
670
- if (metadata === null || metadata === void 0 ? void 0 : metadata.etag) {
671
- headers["If-None-Match"] = metadata.etag;
672
- }
673
- if (metadata === null || metadata === void 0 ? void 0 : metadata.lastModified) {
674
- headers["If-Modified-Since"] = metadata.lastModified;
675
- }
676
- _state.label = 3;
677
- case 3:
678
- _state.trys.push([
679
- 3,
680
- 8,
681
- ,
682
- 9
683
- ]);
684
- return [
685
- 4,
686
- fetch("https://registry.npmjs.org/".concat(packageName, "/latest"), {
687
- headers: headers
688
- })
689
- ];
690
- case 4:
691
- response = _state.sent();
692
- if (response.status === 304 && cached) {
693
- return [
694
- 2,
695
- cached.version
696
- ];
697
- }
698
- if (!response.ok) {
699
- throw new Error("Failed to fetch latest version: ".concat(response.statusText));
700
- }
701
- return [
702
- 4,
703
- response.json()
704
- ];
705
- case 5:
706
- data = _state.sent();
707
- latestVersion = data.version;
708
- return [
709
- 4,
710
- storageServer.set(versionCacheKey, {
711
- version: latestVersion,
712
- timestamp: Date.now()
713
- })
714
- ];
715
- case 6:
716
- _state.sent();
717
- return [
718
- 4,
719
- storageServer.set(metadataCacheKey, {
720
- etag: response.headers.get("ETag") || void 0,
721
- lastModified: response.headers.get("Last-Modified") || void 0
722
- })
723
- ];
724
- case 7:
725
- _state.sent();
726
- return [
727
- 2,
728
- latestVersion
729
- ];
730
- case 8:
731
- error = _state.sent();
732
- commandLog.error("Error fetching latest version for ".concat(packageName, ": ").concat(error.message));
733
- if (cached) {
734
- commandLog.warning("Falling back to cached version for ".concat(packageName, ": ").concat(cached.version));
735
- return [
736
- 2,
737
- cached.version
738
- ];
739
- }
740
- throw error;
741
- case 9:
742
- return [
743
- 2
744
- ];
745
- }
746
- });
747
- });
748
- return _getLatestPackageVersion.apply(this, arguments);
749
- }
750
- function checkPackage(packageName) {
751
- return _checkPackage.apply(this, arguments);
752
- }
753
- function _checkPackage() {
754
- _checkPackage = _async_to_generator(function(packageName) {
755
- var result, packageFound, cyberskillPackageJsonPath, isCurrentProject, _tmp, error;
756
- return _ts_generator(this, function(_state) {
757
- switch(_state.label){
758
- case 0:
759
- result = {
760
- isInstalled: false,
761
- isCurrentProject: false,
762
- installedPath: "",
763
- installedVersion: "",
764
- latestVersion: "",
765
- file: {}
766
- };
767
- _state.label = 1;
768
- case 1:
769
- _state.trys.push([
770
- 1,
771
- 5,
772
- ,
773
- 6
774
- ]);
775
- packageFound = getPackageJson(packageName);
776
- if (!packageFound) {
777
- return [
778
- 2,
779
- result
780
- ];
781
- }
782
- cyberskillPackageJsonPath = resolveCyberSkillPath(PACKAGE_JSON);
783
- isCurrentProject = packageFound.path === cyberskillPackageJsonPath;
784
- result.file = packageFound.file;
785
- result.isInstalled = true;
786
- result.installedPath = packageFound.path;
787
- result.installedVersion = packageFound.file.version;
788
- result.isCurrentProject = isCurrentProject;
789
- if (!isCurrentProject) return [
790
- 3,
791
- 2
792
- ];
793
- _tmp = packageFound.file.version;
794
- return [
795
- 3,
796
- 4
797
- ];
798
- case 2:
799
- return [
800
- 4,
801
- getLatestPackageVersion(packageName, true)
802
- ];
803
- case 3:
804
- _tmp = _state.sent();
805
- _state.label = 4;
806
- case 4:
807
- result.latestVersion = _tmp;
808
- return [
809
- 2,
810
- result
811
- ];
812
- case 5:
813
- error = _state.sent();
814
- commandLog.error('Error checking package "'.concat(packageName, '": ').concat(error.message));
815
- return [
816
- 2,
817
- result
818
- ];
819
- case 6:
820
- return [
821
- 2
822
- ];
823
- }
824
- });
825
- });
826
- return _checkPackage.apply(this, arguments);
827
- }
828
- // src/utils/command.ts
829
- var DEBUG = process3.env.DEBUG === "true";
830
- var execPromise = util.promisify(exec);
831
- var gray = chalk.gray, blue = chalk.blue;
832
- var getTimeStamp = function() {
833
- return gray("[".concat(/* @__PURE__ */ new Date().toLocaleTimeString(), "]"));
834
- };
835
- function chalkKeyword(color) {
836
- var chalkColor = chalk[color];
837
- return typeof chalkColor === "function" ? chalkColor : chalk.green;
838
- }
839
- function printLog(type, color, icon, message) {
840
- var chalkColor = chalkKeyword(color);
841
- console.log("".concat(getTimeStamp(), " ").concat(chalkColor("".concat(icon, " ").concat(type)), " ").concat(message));
842
- }
843
- function printBoxedLog(title, content) {
844
- 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;
845
- var chalkColor = chalkKeyword(color);
846
- var chalkTitleColor = chalkKeyword(titleColor);
847
- if (typeof content === "string") {
848
- console.log(boxen(chalkTitleColor(chalkColor("".concat(title, "\n").concat(content))), {
849
- padding: padding,
850
- margin: margin,
851
- borderStyle: borderStyle,
852
- borderColor: color
853
- }));
854
- return;
855
- }
856
- if (Array.isArray(content) && content.length) {
857
- content.forEach(function(param) {
858
- var file = param.file, position = param.position, rule = param.rule, message = param.message;
859
- console.log("".concat(getTimeStamp(), " ").concat(chalkColor("File:"), " ").concat(blue("".concat(file).concat(position ? ":".concat(position) : ""))));
860
- if (rule) console.log(" ".concat(chalkColor("Rule:"), " ").concat(chalkColor(rule)));
861
- console.log(" ".concat(chalkColor("Message:"), " ").concat(chalkColor(message)));
862
- });
863
- console.log(boxen(chalkTitleColor(chalkColor("".concat(title, ": ").concat(content.length))), {
864
- padding: padding,
865
- margin: margin,
866
- borderStyle: borderStyle,
867
- borderColor: color
868
- }));
869
- console.log(gray("\u2500".repeat(40)));
870
- }
871
- }
872
- var commandLog = {
873
- success: function(message) {
874
- return printLog("SUCCESS", "green", "\u2714", message);
875
- },
876
- error: function(message) {
877
- return printLog("ERROR", "red", "\u2716", message);
878
- },
879
- warning: function(message) {
880
- return printLog("WARNING", "yellow", "\u26A0", message);
881
- },
882
- info: function(message) {
883
- return printLog("INFO", "blue", "\u2139", message);
884
- },
885
- printBoxedLog: printBoxedLog
886
- };
887
- var getErrorListKey = function(timestamp) {
888
- return "error_list:".concat(timestamp);
889
- };
890
- function saveErrorListToStorage(errorList) {
891
- return _saveErrorListToStorage.apply(this, arguments);
892
- }
893
- function _saveErrorListToStorage() {
894
- _saveErrorListToStorage = _async_to_generator(function(errorList) {
895
- var timestamp, key, error;
896
- return _ts_generator(this, function(_state) {
897
- switch(_state.label){
898
- case 0:
899
- if (errorList.length === 0) {
900
- return [
901
- 2
902
- ];
903
- }
904
- timestamp = Date.now();
905
- key = getErrorListKey(timestamp);
906
- _state.label = 1;
907
- case 1:
908
- _state.trys.push([
909
- 1,
910
- 3,
911
- ,
912
- 4
913
- ]);
914
- return [
915
- 4,
916
- storageServer.set(key, {
917
- errors: errorList,
918
- timestamp: timestamp
919
- })
920
- ];
921
- case 2:
922
- _state.sent();
923
- setTimeout(/*#__PURE__*/ _async_to_generator(function() {
924
- var logPath;
925
- return _ts_generator(this, function(_state) {
926
- switch(_state.label){
927
- case 0:
928
- return [
929
- 4,
930
- storageServer.getLogLink(key)
931
- ];
932
- case 1:
933
- logPath = _state.sent();
934
- if (logPath) {
935
- commandLog.info("\uD83D\uDCC2 Open the error list manually: ".concat(logPath));
936
- }
937
- return [
938
- 2
939
- ];
940
- }
941
- });
942
- }), 10);
943
- return [
944
- 3,
945
- 4
946
- ];
947
- case 3:
948
- error = _state.sent();
949
- commandLog.error("Failed to save errors: ".concat(error.message));
950
- return [
951
- 3,
952
- 4
953
- ];
954
- case 4:
955
- return [
956
- 2
957
- ];
958
- }
959
- });
960
- });
961
- return _saveErrorListToStorage.apply(this, arguments);
962
- }
963
- function getStoredErrorLists() {
964
- return _getStoredErrorLists.apply(this, arguments);
965
- }
966
- function _getStoredErrorLists() {
967
- _getStoredErrorLists = _async_to_generator(function() {
968
- var keys, errorKeys, allErrors, error;
969
- return _ts_generator(this, function(_state) {
970
- switch(_state.label){
971
- case 0:
972
- _state.trys.push([
973
- 0,
974
- 3,
975
- ,
976
- 4
977
- ]);
978
- return [
979
- 4,
980
- storageServer.keys()
981
- ];
982
- case 1:
983
- keys = _state.sent();
984
- errorKeys = Array.isArray(keys) ? keys.filter(function(key) {
985
- var _key_startsWith;
986
- 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:");
987
- }) : [];
988
- return [
989
- 4,
990
- Promise.all(errorKeys.map(/*#__PURE__*/ function() {
991
- var _ref = _async_to_generator(function(key) {
992
- var entry;
993
- return _ts_generator(this, function(_state) {
994
- switch(_state.label){
995
- case 0:
996
- return [
997
- 4,
998
- storageServer.get(key)
999
- ];
1000
- case 1:
1001
- entry = _state.sent();
1002
- return [
1003
- 2,
1004
- (entry === null || entry === void 0 ? void 0 : entry.errors) || []
1005
- ];
1006
- }
1007
- });
1008
- });
1009
- return function(key) {
1010
- return _ref.apply(this, arguments);
1011
- };
1012
- }()))
1013
- ];
1014
- case 2:
1015
- allErrors = _state.sent();
1016
- return [
1017
- 2,
1018
- allErrors.flat()
1019
- ];
1020
- case 3:
1021
- error = _state.sent();
1022
- commandLog.error("Failed to retrieve stored errors: ".concat(error.message));
1023
- return [
1024
- 2,
1025
- []
1026
- ];
1027
- case 4:
1028
- return [
1029
- 2
1030
- ];
1031
- }
1032
- });
1033
- });
1034
- return _getStoredErrorLists.apply(this, arguments);
1035
- }
1036
- function clearAllErrorLists() {
1037
- return _clearAllErrorLists.apply(this, arguments);
1038
- }
1039
- function _clearAllErrorLists() {
1040
- _clearAllErrorLists = _async_to_generator(function() {
1041
- var keys, errorKeys, error;
1042
- return _ts_generator(this, function(_state) {
1043
- switch(_state.label){
1044
- case 0:
1045
- _state.trys.push([
1046
- 0,
1047
- 3,
1048
- ,
1049
- 4
1050
- ]);
1051
- return [
1052
- 4,
1053
- storageServer.keys()
1054
- ];
1055
- case 1:
1056
- keys = _state.sent();
1057
- errorKeys = Array.isArray(keys) ? keys.filter(function(key) {
1058
- var _key_startsWith;
1059
- 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:");
1060
- }) : [];
1061
- return [
1062
- 4,
1063
- Promise.all(errorKeys.map(function(key) {
1064
- return storageServer.remove(key);
1065
- }))
1066
- ];
1067
- case 2:
1068
- _state.sent();
1069
- return [
1070
- 3,
1071
- 4
1072
- ];
1073
- case 3:
1074
- error = _state.sent();
1075
- commandLog.error("Failed to clear error lists: ".concat(error.message));
1076
- return [
1077
- 3,
1078
- 4
1079
- ];
1080
- case 4:
1081
- return [
1082
- 2
1083
- ];
1084
- }
1085
- });
1086
- });
1087
- return _clearAllErrorLists.apply(this, arguments);
1088
- }
1089
- function parseTextErrors(output) {
1090
- var errorList = [];
1091
- var unmatchedLines = [];
1092
- var lastFilePath = "";
1093
- var eslintErrorDetailsRegex = /^\s*(\d+):(\d+)\s+(error|warning)\s+(.+?)\s+(\S+)$/;
1094
- var tsRegex = /^(.+?)\((\d+),(\d+)\):\s+(error|warning)\s+TS\d+:\s+(\S.+)$/;
1095
- var commitlintRegex = /^✖\s+(.*?)\s+\[(.*?)\]$/;
1096
- output.split("\n").forEach(function(line) {
1097
- if (line.startsWith("/")) {
1098
- lastFilePath = line.trim();
1099
- } else {
1100
- var eslintMatch = eslintErrorDetailsRegex.exec(line) || [];
1101
- var tsMatch = tsRegex.exec(line) || [];
1102
- var commitlintMatch = commitlintRegex.exec(line) || [];
1103
- if (eslintMatch.length && lastFilePath) {
1104
- errorList.push({
1105
- file: lastFilePath,
1106
- position: "".concat(eslintMatch[1], ":").concat(eslintMatch[2]),
1107
- type: eslintMatch[3] === "error" /* Error */ ? "error" /* Error */ : "warning" /* Warning */ ,
1108
- message: eslintMatch[4].trim(),
1109
- rule: eslintMatch[5].trim()
1110
- });
1111
- } else if (tsMatch.length) {
1112
- errorList.push({
1113
- file: tsMatch[1],
1114
- position: "".concat(tsMatch[2], ":").concat(tsMatch[3]),
1115
- type: tsMatch[4] === "error" /* Error */ ? "error" /* Error */ : "warning" /* Warning */ ,
1116
- message: tsMatch[5].trim()
1117
- });
1118
- } else if (commitlintMatch.length) {
1119
- errorList.push({
1120
- file: "commitlint",
1121
- type: "error" /* Error */ ,
1122
- message: commitlintMatch[1].trim(),
1123
- rule: commitlintMatch[2].trim()
1124
- });
1125
- } else {
1126
- unmatchedLines.push(line.trim());
1127
- }
1128
- }
1129
- });
1130
- if (errorList.length) {
1131
- saveErrorListToStorage(errorList);
1132
- }
1133
- if (unmatchedLines.length && DEBUG) {
1134
- commandLog.warning("Unmatched lines:");
1135
- unmatchedLines.forEach(function(line) {
1136
- return console.log(" ".concat(line));
1137
- });
1138
- }
1139
- }
1140
- function parseCommandOutput(output) {
1141
- try {
1142
- var results = JSON.parse(output);
1143
- var errorList = [];
1144
- results.forEach(function(param) {
1145
- var filePath = param.filePath, messages = param.messages;
1146
- messages.forEach(function(param) {
1147
- var severity = param.severity, line = param.line, column = param.column, ruleId = param.ruleId, message = param.message;
1148
- errorList.push({
1149
- type: severity === 2 ? "error" /* Error */ : "warning" /* Warning */ ,
1150
- file: filePath,
1151
- position: "".concat(line, ":").concat(column),
1152
- rule: ruleId,
1153
- message: message
1154
- });
1155
- });
1156
- });
1157
- if (errorList.length) {
1158
- saveErrorListToStorage(errorList);
1159
- }
1160
- } catch (e) {
1161
- parseTextErrors(output);
1162
- }
1163
- }
1164
- function executeCommand(command) {
1165
- return _executeCommand.apply(this, arguments);
1166
- }
1167
- function _executeCommand() {
1168
- _executeCommand = _async_to_generator(function(command) {
1169
- var parser, controller, _ref, stdout, stderr, error, stdout1, stderr1, message;
1170
- var _arguments = arguments;
1171
- return _ts_generator(this, function(_state) {
1172
- switch(_state.label){
1173
- case 0:
1174
- parser = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : parseCommandOutput;
1175
- controller = new AbortController();
1176
- process3.on("SIGINT", function() {
1177
- commandLog.warning("Process interrupted. Terminating...");
1178
- controller.abort();
1179
- process3.exit();
1180
- });
1181
- _state.label = 1;
1182
- case 1:
1183
- _state.trys.push([
1184
- 1,
1185
- 3,
1186
- ,
1187
- 4
1188
- ]);
1189
- return [
1190
- 4,
1191
- execPromise(command, {
1192
- maxBuffer: 1024 * 1024 * 100,
1193
- signal: controller.signal
1194
- })
1195
- ];
1196
- case 2:
1197
- _ref = _state.sent(), stdout = _ref.stdout, stderr = _ref.stderr;
1198
- [
1199
- stdout,
1200
- stderr
1201
- ].forEach(function(output) {
1202
- return output && parser(output);
1203
- });
1204
- return [
1205
- 3,
1206
- 4
1207
- ];
1208
- case 3:
1209
- error = _state.sent();
1210
- stdout1 = error.stdout, stderr1 = error.stderr, message = error.message;
1211
- [
1212
- stdout1,
1213
- stderr1
1214
- ].forEach(function(output) {
1215
- return output && parser(output);
1216
- });
1217
- if (!stderr1 && !stdout1) {
1218
- commandLog.error("Command failed: ".concat(message));
1219
- }
1220
- return [
1221
- 3,
1222
- 4
1223
- ];
1224
- case 4:
1225
- return [
1226
- 2
1227
- ];
1228
- }
1229
- });
1230
- });
1231
- return _executeCommand.apply(this, arguments);
1232
- }
1233
- var commandFormatter = {
1234
- raw: function(cmd) {
1235
- return {
1236
- raw: true,
1237
- cmd: cmd
1238
- };
1239
- },
1240
- isRaw: function isRaw(cmd) {
1241
- return (typeof cmd === "undefined" ? "undefined" : _type_of(cmd)) === "object" && cmd !== null && cmd.raw === true;
1242
- },
1243
- format: function format(command, context) {
1244
- if (typeof command === "function") {
1245
- return commandFormatter.formatCLI(command(context), context);
1246
- }
1247
- if (commandFormatter.isRaw(command)) {
1248
- return command.cmd;
1249
- }
1250
- return commandFormatter.formatCLI(command, context);
1251
- },
1252
- formatCLI: function formatCLI(command, context) {
1253
- if (context === null || context === void 0 ? void 0 : context.isRemote) {
1254
- return "".concat(PNPM_DLX_CLI, " ").concat(CYBERSKILL_PACKAGE_NAME, " ").concat(command);
1255
- }
1256
- if (context === null || context === void 0 ? void 0 : context.isCurrentProject) {
1257
- return "".concat(PNPM_EXEC_CLI, " ").concat(TSX_CLI, " src/cli.ts ").concat(command);
1258
- }
1259
- return "".concat(PNPM_EXEC_CLI, " ").concat(CYBERSKILL_CLI, " ").concat(command);
1260
- }
1261
- };
1262
- function resolveCommands(input) {
1263
- return _resolveCommands.apply(this, arguments);
1264
- }
1265
- function _resolveCommands() {
1266
- _resolveCommands = _async_to_generator(function(input) {
1267
- var context, _context_isRemote, isRemote, isCurrentProject, _tmp, ctx, commands;
1268
- var _arguments = arguments;
1269
- return _ts_generator(this, function(_state) {
1270
- switch(_state.label){
1271
- case 0:
1272
- context = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : {};
1273
- isRemote = (_context_isRemote = context === null || context === void 0 ? void 0 : context.isRemote) !== null && _context_isRemote !== void 0 ? _context_isRemote : false;
1274
- if (!isRemote) return [
1275
- 3,
1276
- 1
1277
- ];
1278
- _tmp = false;
1279
- return [
1280
- 3,
1281
- 3
1282
- ];
1283
- case 1:
1284
- return [
1285
- 4,
1286
- checkPackage(CYBERSKILL_PACKAGE_NAME)
1287
- ];
1288
- case 2:
1289
- _tmp = _state.sent().isCurrentProject;
1290
- _state.label = 3;
1291
- case 3:
1292
- isCurrentProject = _tmp;
1293
- ctx = {
1294
- isRemote: isRemote,
1295
- isCurrentProject: isCurrentProject
1296
- };
1297
- commands = typeof input === "function" ? input(ctx) : input;
1298
- return [
1299
- 2,
1300
- Object.fromEntries(Object.entries(commands).map(function(param) {
1301
- var _param = _sliced_to_array(param, 2), key = _param[0], cmd = _param[1];
1302
- return [
1303
- key,
1304
- commandFormatter.format(cmd, ctx)
1305
- ];
1306
- }))
1307
- ];
1308
- }
1309
- });
1310
- });
1311
- return _resolveCommands.apply(this, arguments);
1312
- }
1313
- // src/utils/log.ts
1314
- import { GraphQLError } from "graphql";
1315
- // src/constants/response-status.ts
1316
- var RESPONSE_STATUS = {
1317
- GRAPHQL_PARSE_FAILED: {
1318
- CODE: "GRAPHQL_PARSE_FAILED",
1319
- MESSAGE: "The GraphQL operation string contains a syntax error."
1320
- },
1321
- GRAPHQL_VALIDATION_FAILED: {
1322
- CODE: "GRAPHQL_VALIDATION_FAILED",
1323
- MESSAGE: "The GraphQL operation is not valid against the server's schema."
1324
- },
1325
- BAD_USER_INPUT: {
1326
- CODE: "BAD_USER_INPUT",
1327
- MESSAGE: "The GraphQL operation includes an invalid value for a field argument."
1328
- },
1329
- PERSISTED_QUERY_NOT_FOUND: {
1330
- CODE: "PERSISTED_QUERY_NOT_FOUND",
1331
- 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."
1332
- },
1333
- PERSISTED_QUERY_NOT_SUPPORTED: {
1334
- CODE: "PERSISTED_QUERY_NOT_SUPPORTED",
1335
- MESSAGE: "A client sent the hash of a query string to execute via automatic persisted queries, but the server has disabled APQ."
1336
- },
1337
- OPERATION_RESOLUTION_FAILURE: {
1338
- CODE: "OPERATION_RESOLUTION_FAILURE",
1339
- 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."
1340
- },
1341
- CONTINUE: {
1342
- CODE: 100,
1343
- MESSAGE: "Continue"
1344
- },
1345
- SWITCHING_PROTOCOLS: {
1346
- CODE: 101,
1347
- MESSAGE: "Switching Protocols"
1348
- },
1349
- PROCESSING: {
1350
- CODE: 102,
1351
- MESSAGE: "Processing"
1352
- },
1353
- OK: {
1354
- CODE: 200,
1355
- MESSAGE: "OK"
1356
- },
1357
- CREATED: {
1358
- CODE: 201,
1359
- MESSAGE: "Created"
1360
- },
1361
- ACCEPTED: {
1362
- CODE: 202,
1363
- MESSAGE: "Accepted"
1364
- },
1365
- NON_AUTHORITATIVE_INFORMATION: {
1366
- CODE: 203,
1367
- MESSAGE: "Non Authoritative Information"
1368
- },
1369
- NO_CONTENT: {
1370
- CODE: 204,
1371
- MESSAGE: "No Content"
1372
- },
1373
- RESET_CONTENT: {
1374
- CODE: 205,
1375
- MESSAGE: "Reset Content"
1376
- },
1377
- PARTIAL_CONTENT: {
1378
- CODE: 206,
1379
- MESSAGE: "Partial Content"
1380
- },
1381
- MULTI_STATUS: {
1382
- CODE: 207,
1383
- MESSAGE: "Multi-Status"
1384
- },
1385
- MULTIPLE_CHOICES: {
1386
- CODE: 300,
1387
- MESSAGE: "Multiple Choices"
1388
- },
1389
- MOVED_PERMANENTLY: {
1390
- CODE: 301,
1391
- MESSAGE: "Moved Permanently"
1392
- },
1393
- MOVED_TEMPORARILY: {
1394
- CODE: 302,
1395
- MESSAGE: "Moved Temporarily"
1396
- },
1397
- SEE_OTHER: {
1398
- CODE: 303,
1399
- MESSAGE: "See Other"
1400
- },
1401
- NOT_MODIFIED: {
1402
- CODE: 304,
1403
- MESSAGE: "Not Modified"
1404
- },
1405
- USE_PROXY: {
1406
- CODE: 305,
1407
- MESSAGE: "Use Proxy"
1408
- },
1409
- TEMPORARY_REDIRECT: {
1410
- CODE: 307,
1411
- MESSAGE: "Temporary Redirect"
1412
- },
1413
- PERMANENT_REDIRECT: {
1414
- CODE: 308,
1415
- MESSAGE: "Permanent Redirect"
1416
- },
1417
- BAD_REQUEST: {
1418
- CODE: 400,
1419
- MESSAGE: "Bad Request"
1420
- },
1421
- UNAUTHORIZED: {
1422
- CODE: 401,
1423
- MESSAGE: "Unauthorized"
1424
- },
1425
- PAYMENT_REQUIRED: {
1426
- CODE: 402,
1427
- MESSAGE: "Payment Required"
1428
- },
1429
- FORBIDDEN: {
1430
- CODE: 403,
1431
- MESSAGE: "Forbidden"
1432
- },
1433
- NOT_FOUND: {
1434
- CODE: 404,
1435
- MESSAGE: "Not Found"
1436
- },
1437
- METHOD_NOT_ALLOWED: {
1438
- CODE: 405,
1439
- MESSAGE: "Method Not Allowed"
1440
- },
1441
- NOT_ACCEPTABLE: {
1442
- CODE: 406,
1443
- MESSAGE: "Not Acceptable"
1444
- },
1445
- PROXY_AUTHENTICATION_REQUIRED: {
1446
- CODE: 407,
1447
- MESSAGE: "Proxy Authentication Required"
1448
- },
1449
- REQUEST_TIMEOUT: {
1450
- CODE: 408,
1451
- MESSAGE: "Request Timeout"
1452
- },
1453
- CONFLICT: {
1454
- CODE: 409,
1455
- MESSAGE: "Conflict"
1456
- },
1457
- GONE: {
1458
- CODE: 410,
1459
- MESSAGE: "Gone"
1460
- },
1461
- LENGTH_REQUIRED: {
1462
- CODE: 411,
1463
- MESSAGE: "Length Required"
1464
- },
1465
- PRECONDITION_FAILED: {
1466
- CODE: 412,
1467
- MESSAGE: "Precondition Failed"
1468
- },
1469
- REQUEST_TOO_LONG: {
1470
- CODE: 413,
1471
- MESSAGE: "Request Entity Too Large"
1472
- },
1473
- REQUEST_URI_TOO_LONG: {
1474
- CODE: 414,
1475
- MESSAGE: "Request-URI Too Long"
1476
- },
1477
- UNSUPPORTED_MEDIA_TYPE: {
1478
- CODE: 415,
1479
- MESSAGE: "Unsupported Media Type"
1480
- },
1481
- REQUESTED_RANGE_NOT_SATISFIABLE: {
1482
- CODE: 416,
1483
- MESSAGE: "Requested Range Not Satisfiable"
1484
- },
1485
- EXPECTATION_FAILED: {
1486
- CODE: 417,
1487
- MESSAGE: "Expectation Failed"
1488
- },
1489
- IM_A_TEAPOT: {
1490
- CODE: 418,
1491
- MESSAGE: "I'm a teapot"
1492
- },
1493
- INSUFFICIENT_SPACE_ON_RESOURCE: {
1494
- CODE: 419,
1495
- MESSAGE: "Insufficient Space on Resource"
1496
- },
1497
- METHOD_FAILURE: {
1498
- CODE: 420,
1499
- MESSAGE: "Method Failure"
1500
- },
1501
- MISDIRECTED_REQUEST: {
1502
- CODE: 421,
1503
- MESSAGE: "Misdirected Request"
1504
- },
1505
- UNPROCESSABLE_ENTITY: {
1506
- CODE: 422,
1507
- MESSAGE: "Unprocessable Entity"
1508
- },
1509
- LOCKED: {
1510
- CODE: 423,
1511
- MESSAGE: "Locked"
1512
- },
1513
- FAILED_DEPENDENCY: {
1514
- CODE: 424,
1515
- MESSAGE: "Failed Dependency"
1516
- },
1517
- PRECONDITION_REQUIRED: {
1518
- CODE: 428,
1519
- MESSAGE: "Precondition Required"
1520
- },
1521
- TOO_MANY_REQUESTS: {
1522
- CODE: 429,
1523
- MESSAGE: "Too Many Requests"
1524
- },
1525
- REQUEST_HEADER_FIELDS_TOO_LARGE: {
1526
- CODE: 431,
1527
- MESSAGE: "Request Header Fields Too Large"
1528
- },
1529
- UNAVAILABLE_FOR_LEGAL_REASONS: {
1530
- CODE: 451,
1531
- MESSAGE: "Unavailable For Legal Reasons"
1532
- },
1533
- INTERNAL_SERVER_ERROR: {
1534
- CODE: 500,
1535
- MESSAGE: "Internal Server Error"
1536
- },
1537
- NOT_IMPLEMENTED: {
1538
- CODE: 501,
1539
- MESSAGE: "Not Implemented"
1540
- },
1541
- BAD_GATEWAY: {
1542
- CODE: 502,
1543
- MESSAGE: "Bad Gateway"
1544
- },
1545
- SERVICE_UNAVAILABLE: {
1546
- CODE: 503,
1547
- MESSAGE: "Service Unavailable"
1548
- },
1549
- GATEWAY_TIMEOUT: {
1550
- CODE: 504,
1551
- MESSAGE: "Gateway Timeout"
1552
- },
1553
- HTTP_VERSION_NOT_SUPPORTED: {
1554
- CODE: 505,
1555
- MESSAGE: "HTTP Version Not Supported"
1556
- },
1557
- INSUFFICIENT_STORAGE: {
1558
- CODE: 507,
1559
- MESSAGE: "Insufficient Storage"
1560
- },
1561
- NETWORK_AUTHENTICATION_REQUIRED: {
1562
- CODE: 511,
1563
- MESSAGE: "Network Authentication Required"
1564
- }
1565
- };
1566
- // src/utils/log.ts
1567
- function throwResponse(param) {
1568
- 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;
1569
- var _ref;
1570
- var responseMessage = (_ref = message !== null && message !== void 0 ? message : status.MESSAGE) !== null && _ref !== void 0 ? _ref : "Internal server error";
1571
- if (type === "graphql") {
1572
- throw new GraphQLError(responseMessage, {
1573
- extensions: {
1574
- code: status.CODE
1575
- }
1576
- });
1577
- } else {
1578
- throw new Error(responseMessage);
1579
- }
1580
- }
1581
- export { appendFileSync2 as appendFileSync, checkPackage, clearAllErrorLists, commandFormatter, commandLog, dirname2 as dirname, executeCommand, existsSync2 as existsSync, getLatestPackageVersion, getPackageJson, getStorageDir, getStoredErrorLists, initNodePersist, join2 as join, readFileSync2 as readFileSync, require2 as require, resolve2 as resolve, resolveCommands, resolveCyberSkillPath, resolveWorkingPath, rmSync2 as rmSync, saveErrorListToStorage, storageServer, throwResponse, 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,t,r,n,o,a,i){try{var c=e[a](i);var s=c.value}catch(e){r(e);return}if(c.done){t(s)}else{Promise.resolve(s).then(n,o)}}function o(e){return function(){var t=this,r=arguments;return new Promise(function(o,a){var i=e.apply(t,r);function c(e){n(i,o,a,c,s,"next",e)}function s(e){n(i,o,a,c,s,"throw",e)}c(undefined)})}}function a(e){if(typeof Symbol!=="undefined"&&e[Symbol.iterator]!=null||e["@@iterator"]!=null)return Array.from(e)}function i(e,t){var r=e==null?null:typeof Symbol!=="undefined"&&e[Symbol.iterator]||e["@@iterator"];if(r==null)return;var n=[];var o=true;var a=false;var i,c;try{for(r=r.call(e);!(o=(i=r.next()).done);o=true){n.push(i.value);if(t&&n.length===t)break}}catch(e){a=true;c=e}finally{try{if(!o&&r["return"]!=null)r["return"]()}finally{if(a)throw c}}return n}function c(){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 s(){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 u(e,r){return t(e)||i(e,r)||f(e,r)||c()}function E(e){return r(e)||a(e)||f(e)||s()}function l(e){"@swc/helpers - typeof";return e&&typeof Symbol!=="undefined"&&e.constructor===Symbol?"symbol":typeof e}function f(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 S(e,t){var r,n,o,a,i={label:0,sent:function(){if(o[0]&1)throw o[1];return o[1]},trys:[],ops:[]};return a={next:c(0),"throw":c(1),"return":c(2)},typeof Symbol==="function"&&(a[Symbol.iterator]=function(){return this}),a;function c(e){return function(t){return s([e,t])}}function s(a){if(r)throw new TypeError("Generator is already executing.");while(i)try{if(r=1,n&&(o=a[0]&2?n["return"]:a[0]?n["throw"]||((o=n["return"])&&o.call(n),0):n.next)&&!(o=o.call(n,a[1])).done)return o;if(n=0,o)a=[a[0]&2,o.value];switch(a[0]){case 0:case 1:o=a;break;case 4:i.label++;return{value:a[1],done:false};case 5:i.label++;n=a[1];a=[0];continue;case 7:a=i.ops.pop();i.trys.pop();continue;default:if(!(o=i.trys,o=o.length>0&&o[o.length-1])&&(a[0]===6||a[0]===2)){i=0;continue}if(a[0]===3&&(!o||a[1]>o[0]&&a[1]<o[3])){i.label=a[1];break}if(a[0]===6&&i.label<o[1]){i.label=o[1];o=a;break}if(o&&i.label<o[2]){i.label=o[2];i.ops.push(a);break}if(o[2])i.ops.pop();i.trys.pop();continue}a=t.call(e,i)}catch(e){a=[6,e];n=0}finally{r=o=0}if(a[0]&5)throw a[1];return{value:a[0]?a[1]:void 0,done:true}}}import d from"boxen";import p from"chalk";import{exec as O}from"node:child_process";import h from"node:process";import*as A from"node:util";import T from"node:process";import*as g from"node:path";function m(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++){t[r]=arguments[r]}var n;return(n=g).resolve.apply(n,[_].concat(E(t)))}function v(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++){t[r]=arguments[r]}var n;return(n=g).resolve.apply(n,E(t))}function I(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++){t[r]=arguments[r]}var n;return(n=g).join.apply(n,E(t))}var _=T.env.INIT_CWD||T.cwd(),y="@cyberskill/shared",C=".cyberskill-storage",R="node_modules",N="dist",D="package.json",M="package-lock.json",G="tsconfig.json",L=".gitignore",P=".simple-git-hooks.json",b="pnpm-lock.yaml",w=".git/hooks/",U=".git/COMMIT_EDITMSG",F=I(_,R,y,N),k="cyberskill",x="eslint",j="vitest",Y="vitest",Q="@commitlint/cli",K="commitlint",q="lint-staged",B="lint-staged",H="tsc",J="tsc",V="tsx",W="git",$="pnpm",X="pnpm exec",z="simple-git-hooks",Z="simple-git-hooks",ee="@eslint/config-inspector",et="eslint-config-inspector",er="node-modules-inspector",en="node-modules-inspector",eo={CYBERSKILL_DIRECTORY:F,WORKING_DIRECTORY:_,TS_CONFIG:m(G),GIT_IGNORE:m(L),GIT_HOOK:m(w),GIT_COMMIT_MSG:m(U),SIMPLE_GIT_HOOKS_JSON:m(P),PACKAGE_JSON:m(D),PACKAGE_LOCK_JSON:m(M),PNPM_LOCK_YAML:m(b),NODE_MODULES:m(R),CYBERSKILL:{LINT_STAGED_CONFIG:m("".concat(F,"/configs/lint-staged/base.js")),COMMITLINT_CONFIG:m("".concat(F,"/configs/commitlint/base.js")),UNIT_TEST_CONFIG:m("".concat(F,"/configs/vitest/react/unit.js")),E2E_TEST_CONFIG:m("".concat(F,"/configs/vitest/react/e2e.js"))}};function ea(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n<t;n++){r[n-1]=arguments[n]}var o=u(r,2),a=o[0],i=o[1];switch(e){case"pnpmAddAndExec":return eW(eJ("".concat($," add -D ").concat(a," && ").concat(X," ").concat(i)));case"pnpmExec":return eW(eJ("".concat(X," ").concat(a," ").concat(i||"").trim()));case"raw":return eW(eJ(a))}}var ei={SIMPLE_GIT_HOOKS:ea("pnpmAddAndExec",z,Z),ESLINT_INSPECT:ea("pnpmAddAndExec",ee,et),NODE_MODULES_INSPECT:ea("pnpmAddAndExec",er,en),ESLINT_CHECK:ea("pnpmExec",x,eo.WORKING_DIRECTORY),ESLINT_FIX:ea("pnpmExec",x,"".concat(eo.WORKING_DIRECTORY," --fix")),TYPESCRIPT_CHECK:ea("pnpmAddAndExec",H,"".concat(J," -p ").concat(eo.TS_CONFIG," --noEmit")),CONFIGURE_GIT_HOOK:ea("raw","".concat(W," config core.hooksPath ").concat(eo.GIT_HOOK)),BUILD:ea("raw","".concat($," run build")),STAGE_BUILD_DIRECTORY:ea("raw","".concat(W," add ").concat(N)),PNPM_INSTALL_STANDARD:ea("raw","".concat($," install")),PNPM_INSTALL_LEGACY:ea("raw","".concat($," install --legacy-peer-deps")),PNPM_INSTALL_FORCE:ea("raw","".concat($," install --force")),CYBERSKILL:{TEST_UNIT:ea("pnpmAddAndExec",j,"".concat(Y," --config ").concat(eo.CYBERSKILL.UNIT_TEST_CONFIG)),TEST_E2E:ea("pnpmAddAndExec",j,"".concat(Y," --config ").concat(eo.CYBERSKILL.E2E_TEST_CONFIG)),COMMIT_LINT:ea("pnpmAddAndExec",Q,"".concat(K," --edit ").concat(eo.GIT_COMMIT_MSG," --config ").concat(eo.CYBERSKILL.COMMITLINT_CONFIG)),LINT_STAGED:ea("pnpmAddAndExec",q,"".concat(B," --config ").concat(eo.CYBERSKILL.LINT_STAGED_CONFIG))}};import ec from"node-fetch";import*as es from"node:fs";var eu=function(e){return es.existsSync(e)};function eE(e,t){var r=es.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":l(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 el(e,t){var r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=r.isJson,o=n===void 0?!1:n,a=o&&(typeof t==="undefined"?"undefined":l(t))=="object"?JSON.stringify(t,null,4):String(t);es.writeFileSync(e,a,"utf-8")}function ef(e,t){var r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};var n=r.isJson,o=n===void 0?!1:n,a=o&&(typeof t==="undefined"?"undefined":l(t))=="object"?JSON.stringify(t,null,4):String(t);es.appendFileSync(e,a,"utf-8")}function eS(e){e.forEach(function(e){eu(e)&&es.rmSync(e,{recursive:!0,force:!0})})}import ed from"node-persist";import ep from"node:os";import eO from"node:process";function eh(){return eO.env.CYBERSKILL_STORAGE_DIR||I(ep.homedir(),C)}function eA(){return eT.apply(this,arguments)}function eT(){eT=o(function(){var e;return S(this,function(t){switch(t.label){case 0:e=ed.defaultInstance;if(e)return[3,2];return[4,ed.init({dir:eh(),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 eT.apply(this,arguments)}var eg={get:function e(e){return o(function(){var t,r;return S(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,eA()];case 1:n.sent();return[4,ed.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 S(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,eA()];case 1:n.sent();return[4,ed.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 S(this,function(r){switch(r.label){case 0:r.trys.push([0,3,,4]);return[4,eA()];case 1:r.sent();return[4,ed.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 S(this,function(r){switch(r.label){case 0:r.trys.push([0,3,,4]);return[4,eA()];case 1:r.sent();return[4,ed.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 S(this,function(t){try{return[2,"".concat(eh()," (key: ").concat(e,")")]}catch(e){return[2,(console.error("❌ [Storage:getLogLink] Error getting log link:",e),null)]}return[2]})})()}};var em=24*60*60*1e3;function ev(e){var t=I(_,D);if(eu(t))try{var r=eE(t,{asJson:!0});if(r.name===e)return{path:t,file:r,isCurrentProject:!0}}catch(e){ew.warning("Failed to read local package.json: ".concat(e.message))}var n=I(_,R,e,D);if(eu(n))try{var o=eE(n,{asJson:!0});if(o.name===e)return{path:n,file:o,isCurrentProject:!1}}catch(t){ew.warning("Failed to read node_modules package.json for ".concat(e,": ").concat(t.message))}return!1}function eI(e){return e_.apply(this,arguments)}function e_(){e_=o(function(e){var t,r,n,o,a,i,c,s,u,E;var l=arguments;return S(this,function(f){switch(f.label){case 0:t=l.length>1&&l[1]!==void 0?l[1]:!1;r="npm_version:".concat(e),n="npm_metadata:".concat(e);return[4,eg.get(r)];case 1:o=f.sent();return[4,eg.get(n)];case 2:a=f.sent(),i=o&&Date.now()-o.timestamp<em;if(!t&&i)return[2,o.version];c={};(a===null||a===void 0?void 0:a.etag)&&(c["If-None-Match"]=a.etag),(a===null||a===void 0?void 0:a.lastModified)&&(c["If-Modified-Since"]=a.lastModified);f.label=3;case 3:f.trys.push([3,8,,9]);return[4,ec("https://registry.npmjs.org/".concat(e,"/latest"),{headers:c})];case 4:s=f.sent();if(s.status===304&&o)return[2,o.version];if(!s.ok)throw new Error("Failed to fetch latest version: ".concat(s.statusText));return[4,s.json()];case 5:u=f.sent().version;return[4,eg.set(r,{version:u,timestamp:Date.now()})];case 6:f.sent();return[4,eg.set(n,{etag:s.headers.get("ETag")||void 0,lastModified:s.headers.get("Last-Modified")||void 0})];case 7:return[2,(f.sent(),u)];case 8:E=f.sent();if(ew.error("Error fetching latest version for ".concat(e,": ").concat(E.message)),o)return[2,(ew.warning("Falling back to cached version for ".concat(e,": ").concat(o.version)),o.version)];throw E;case 9:return[2]}})});return e_.apply(this,arguments)}function ey(e){return eC.apply(this,arguments)}function eC(){eC=o(function(e){var t,r,n,o,a;return S(this,function(i){switch(i.label){case 0:t={isInstalled:!1,isCurrentProject:!1,installedPath:"",installedVersion:"",latestVersion:"",file:{}};i.label=1;case 1:i.trys.push([1,6,,7]);r=ev(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];o=r.file.version;return[3,4];case 2:return[4,eI(e,!0)];case 3:o=i.sent();i.label=4;case 4:n=t.latestVersion=o;i.label=5;case 5:return[2,(n,t)];case 6:a=i.sent();return[2,(ew.error('Error checking package "'.concat(e,'": ').concat(a.message)),t)];case 7:return[2]}})});return eC.apply(this,arguments)}var eR=h.env.DEBUG==="true",eN=A.promisify(O),eD=p.gray,eM=p.blue;function eG(){return eD("[".concat(new Date().toLocaleTimeString(),"]"))}function eL(e){var t=p[e];return typeof t=="function"?t:p.green}function eP(e,t,r,n){var o=eL(t);console.log("".concat(eG()," ").concat(o("".concat(r," ").concat(e))," ").concat(n))}function eb(e,t){var r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},n=r.color,o=n===void 0?"green":n,a=r.padding,i=a===void 0?1:a,c=r.margin,s=c===void 0?1:c,u=r.borderStyle,E=u===void 0?"round":u,l=r.titleColor,f=l===void 0?"bold":l;var S=eL(o),p=eL(f);if(typeof t=="string"){console.log(d(p(S("".concat(e,"\n").concat(t))),{padding:i,margin:s,borderStyle:E,borderColor:o}));return}Array.isArray(t)&&t.length&&(t.forEach(function(e){var t=e.file,r=e.position,n=e.rule,o=e.message;console.log("".concat(eG()," ").concat(S("File:")," ").concat(eM("".concat(t).concat(r?":".concat(r):"")))),n&&console.log(" ".concat(S("Rule:")," ").concat(S(n))),console.log(" ".concat(S("Message:")," ").concat(S(o)))}),console.log(d(p(S("".concat(e,": ").concat(t.length))),{padding:i,margin:s,borderStyle:E,borderColor:o})),console.log(eD("─".repeat(40))))}var ew={success:function(e){return eP("SUCCESS","green","✔",e)},error:function(e){return eP("ERROR","red","✖",e)},warning:function(e){return eP("WARNING","yellow","⚠",e)},info:function(e){return eP("INFO","blue","ℹ",e)},printBoxedLog:eb};function eU(e){return"error_list:".concat(e)}function eF(e){return ek.apply(this,arguments)}function ek(){ek=o(function(e){var t,r,n;return S(this,function(a){switch(a.label){case 0:if(e.length===0)return[2];t=Date.now(),r=eU(t);a.label=1;case 1:a.trys.push([1,3,,4]);return[4,eg.set(r,{errors:e,timestamp:t})];case 2:a.sent(),setTimeout(/*#__PURE__*/o(function(){var e;return S(this,function(t){switch(t.label){case 0:return[4,eg.getLogLink(r)];case 1:e=t.sent();e&&ew.info("\uD83D\uDCC2 Open the error list manually: ".concat(e));return[2]}})}),10);return[3,4];case 3:n=a.sent();ew.error("Failed to save errors: ".concat(n.message));return[3,4];case 4:return[2]}})});return ek.apply(this,arguments)}function ex(){return ej.apply(this,arguments)}function ej(){ej=o(function(){var e,t,r;return S(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,eg.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 S(this,function(r){switch(r.label){case 0:return[4,eg.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,(ew.error("Failed to retrieve stored errors: ".concat(r.message)),[])];case 4:return[2]}})});return ej.apply(this,arguments)}function eY(){return eQ.apply(this,arguments)}function eQ(){eQ=o(function(){var e,t,r;return S(this,function(n){switch(n.label){case 0:n.trys.push([0,3,,4]);return[4,eg.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 eg.remove(e)}))];case 2:n.sent();return[3,4];case 3:r=n.sent();ew.error("Failed to clear error lists: ".concat(r.message));return[3,4];case 4:return[2]}})});return eQ.apply(this,arguments)}function eK(e){var t=[],r=[],n="",o=/^\s*(\d+):(\d+)\s+(error|warning)\s+(.+?)\s+(\S+)$/,a=/^(.+?)\((\d+),(\d+)\):\s+(error|warning)\s+TS\d+:\s+(\S.+)$/,i=/^✖\s+(.*?)\s+\[(.*?)\]$/;e.split("\n").forEach(function(e){if(e.startsWith("/"))n=e.trim();else{var c=o.exec(e)||[],s=a.exec(e)||[],u=i.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()}):s.length?t.push({file:s[1],position:"".concat(s[2],":").concat(s[3]),type:s[4]==="error"?"error":"warning",message:s[5].trim()}):u.length?t.push({file:"commitlint",type:"error",message:u[1].trim(),rule:u[2].trim()}):r.push(e.trim())}}),t.length&&eF(t),r.length&&eR&&(ew.warning("Unmatched lines:"),r.forEach(function(e){return console.log(" ".concat(e))}))}function eq(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,o=e.line,a=e.column,i=e.ruleId,c=e.message;r.push({type:n===2?"error":"warning",file:t,position:"".concat(o,":").concat(a),rule:i,message:c})})}),r.length&&eF(r)}catch(t){eK(e)}}function eB(e){return eH.apply(this,arguments)}function eH(){eH=o(function(e){var t,r,n,o,a,i,c,s,u;var E=arguments;return S(this,function(l){switch(l.label){case 0:t=E.length>1&&E[1]!==void 0?E[1]:eq;r=new AbortController;h.on("SIGINT",function(){ew.warning("Process interrupted. Terminating..."),r.abort(),h.exit()});l.label=1;case 1:l.trys.push([1,3,,4]);return[4,eN(e,{maxBuffer:0x6400000,signal:r.signal})];case 2:n=l.sent(),o=n.stdout,a=n.stderr;[o,a].forEach(function(e){return e&&t(e)});return[3,4];case 3:i=l.sent();c=i.stdout,s=i.stderr,u=i.message;[c,s].forEach(function(e){return e&&t(e)}),!s&&!c&&ew.error("Command failed: ".concat(u));return[3,4];case 4:return[2]}})});return eH.apply(this,arguments)}function eJ(e){return{raw:!0,cmd:e}}function eV(e,t){return(t===null||t===void 0?void 0:t.isRemote)?"".concat(X," ").concat(y," ").concat(e):(t===null||t===void 0?void 0:t.isCurrentProject)?"".concat(X," ").concat(V," src/cli.ts ").concat(e):"".concat(X," ").concat(k," ").concat(e)}function eW(e,t){return typeof e=="function"?eV(e(t),t):(typeof e==="undefined"?"undefined":l(e))=="object"&&(e===null||e===void 0?void 0:e.raw)===!0?e.cmd:typeof e=="string"?eV(e,t):e}function e$(e){return eX.apply(this,arguments)}function eX(){eX=o(function(e){var t,r,n,o,a,i,c;var s=arguments;return S(this,function(E){switch(E.label){case 0:t=s.length>1&&s[1]!==void 0?s[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,ey(y)];case 2:c=E.sent().isCurrentProject;E.label=3;case 3:o=c,a={isRemote:n,isCurrentProject:o},i=typeof e=="function"?e(a):e;return[2,Object.fromEntries(Object.entries(i).map(function(e){var t=u(e,2),r=t[0],n=t[1];return[r,eW(n,a)]}))]}})});return eX.apply(this,arguments)}import{GraphQLError as ez}from"graphql";var eZ={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"}};function e0(e){var t=e.message,r=e.status,n=r===void 0?eZ.INTERNAL_SERVER_ERROR:r,o=e.type,a=o===void 0?"graphql":o;var i;var c=(i=t!==null&&t!==void 0?t:n.MESSAGE)!==null&&i!==void 0?i:"Internal server error";throw a==="graphql"?new ez(c,{extensions:{code:n.CODE}}):new Error(c)}export{ef as appendFileSync,ey as checkPackage,eY as clearAllErrorLists,ew as commandLog,eB as executeCommand,eu as existsSync,eW as formatCommand,eI as getLatestPackageVersion,ev as getPackageJson,eh as getStorageDir,ex as getStoredErrorLists,eA as initNodePersist,I as join,eJ as rawCommand,eE as readFileSync,v as resolve,e$ as resolveCommands,m as resolveWorkingPath,eS as rmSync,eg as storageServer,e0 as throwResponse,el as writeFileSync};