@daiyu-5577/buildsystem 1.0.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 (50) hide show
  1. package/README.md +485 -0
  2. package/dist/artifact.js +59 -0
  3. package/dist/artifact.js.map +1 -0
  4. package/dist/cli.js +25 -0
  5. package/dist/cli.js.map +1 -0
  6. package/dist/commands/build.js +39 -0
  7. package/dist/commands/build.js.map +1 -0
  8. package/dist/commands/server.js +28 -0
  9. package/dist/commands/server.js.map +1 -0
  10. package/dist/config.js +42 -0
  11. package/dist/config.js.map +1 -0
  12. package/dist/cron.js +163 -0
  13. package/dist/cron.js.map +1 -0
  14. package/dist/crypto.js +40 -0
  15. package/dist/crypto.js.map +1 -0
  16. package/dist/custError.js +10 -0
  17. package/dist/custError.js.map +1 -0
  18. package/dist/database/index.js +64 -0
  19. package/dist/database/index.js.map +1 -0
  20. package/dist/database/types.js +8 -0
  21. package/dist/database/types.js.map +1 -0
  22. package/dist/fsHelpers.js +93 -0
  23. package/dist/fsHelpers.js.map +1 -0
  24. package/dist/git.js +67 -0
  25. package/dist/git.js.map +1 -0
  26. package/dist/logger.js +80 -0
  27. package/dist/logger.js.map +1 -0
  28. package/dist/notifier.js +66 -0
  29. package/dist/notifier.js.map +1 -0
  30. package/dist/pm.js +21 -0
  31. package/dist/pm.js.map +1 -0
  32. package/dist/queue.js +273 -0
  33. package/dist/queue.js.map +1 -0
  34. package/dist/server/index.js +189 -0
  35. package/dist/server/index.js.map +1 -0
  36. package/dist/server/routes.js +395 -0
  37. package/dist/server/routes.js.map +1 -0
  38. package/dist/server/websocket.js +230 -0
  39. package/dist/server/websocket.js.map +1 -0
  40. package/dist/static/web/assets/index-BzSDdMyu.js +304 -0
  41. package/dist/static/web/assets/index-DptBjpyJ.css +1 -0
  42. package/dist/static/web/index.html +13 -0
  43. package/dist/types.js +33 -0
  44. package/dist/types.js.map +1 -0
  45. package/dist/utils.js +66 -0
  46. package/dist/utils.js.map +1 -0
  47. package/dist/web/assets/index-Ds-OtVY9.js +76 -0
  48. package/dist/web/assets/index-F5jE8yX9.css +1 -0
  49. package/dist/web/index.html +13 -0
  50. package/package.json +61 -0
@@ -0,0 +1,66 @@
1
+ /**
2
+ * 通知系统 – 统一 webhook 通知与 Socket.IO 实时推送
3
+ */
4
+ import axios from 'axios';
5
+ import dayjs from 'dayjs';
6
+ import { generateUid } from './database/index.js';
7
+ import { formatMsg, IdType } from './types.js';
8
+ import { getFormatTime } from './utils.js';
9
+ /** Notifier 单例,持有 Socket.IO 引用 */
10
+ export class Notifier {
11
+ constructor() {
12
+ this.buildServer = null;
13
+ }
14
+ /** 绑定 Socket.IO 实例(在 BuildServer 启动时调用) */
15
+ inject(buildServer) {
16
+ this.buildServer = buildServer;
17
+ return this;
18
+ }
19
+ /** 发送构建聊天消息(通过 notify webhook) */
20
+ sendChatMsgByTask(curTask, msg) {
21
+ if (curTask.notify) {
22
+ axios.post(curTask.notify, formatMsg('on:msg-chat', {
23
+ id: generateUid(IdType.M),
24
+ socketId: '',
25
+ name: '系统消息',
26
+ msg: `branch: ${curTask.branch}\ntaskId: ${curTask.taskId}\npackagePath: ${curTask.packagePath}\ncwd: ${curTask.cwd}\ntime: ${getFormatTime()}\n${msg}`,
27
+ ctxType: 'ctx:txt',
28
+ time: getFormatTime(),
29
+ timestamp: +dayjs(),
30
+ }), {
31
+ maxContentLength: Infinity,
32
+ maxBodyLength: Infinity,
33
+ }).catch(() => { });
34
+ }
35
+ return msg;
36
+ }
37
+ /** 发送构建状态消息(通过 notify webhook + Socket.IO) */
38
+ sendBuildMsg(curTask, msg) {
39
+ if (curTask.notify) {
40
+ axios.post(curTask.notify, formatMsg('on:msg-build', {
41
+ id: generateUid(IdType.TM),
42
+ name: '构建消息',
43
+ taskId: curTask.taskId,
44
+ msg: msg + '\n',
45
+ task: curTask,
46
+ time: getFormatTime(),
47
+ timestamp: +dayjs(),
48
+ }), {
49
+ maxContentLength: Infinity,
50
+ maxBodyLength: Infinity,
51
+ }).catch(() => { });
52
+ }
53
+ return msg;
54
+ }
55
+ /** 通过 axios POST 推送消息(服务端/无服务通用) */
56
+ emitAxiosMsg(type, data, notifyUrl) {
57
+ var _a;
58
+ const url = notifyUrl || `http://127.0.0.1:${(_a = this.buildServer) === null || _a === void 0 ? void 0 : _a.port}/api/notify`;
59
+ axios.post(url, formatMsg(type, data), {
60
+ maxContentLength: Infinity,
61
+ maxBodyLength: Infinity,
62
+ }).catch(() => { });
63
+ }
64
+ }
65
+ export const notifier = new Notifier();
66
+ //# sourceMappingURL=notifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"notifier.js","sourceRoot":"","sources":["../src/notifier.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAI1C,kCAAkC;AAClC,MAAM,OAAO,QAAQ;IAArB;QAEU,gBAAW,GAAuB,IAAI,CAAA;IAsDhD,CAAC;IApDC,2CAA2C;IAC3C,MAAM,CAAC,WAAwB;QAC7B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAA;QAC9B,OAAO,IAAI,CAAA;IACb,CAAC;IAED,kCAAkC;IAClC,iBAAiB,CAAC,OAAkB,EAAE,GAAW;QAC/C,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,aAAa,EAAE;gBAClD,EAAE,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC;gBACzB,QAAQ,EAAE,EAAE;gBACZ,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,WAAW,OAAO,CAAC,MAAM,aAAa,OAAO,CAAC,MAAM,kBAAkB,OAAO,CAAC,WAAW,UAAU,OAAO,CAAC,GAAG,WAAW,aAAa,EAAE,KAAK,GAAG,EAAE;gBACvJ,OAAO,EAAE,SAAS;gBAClB,IAAI,EAAE,aAAa,EAAE;gBACrB,SAAS,EAAE,CAAC,KAAK,EAAE;aACpB,CAAC,EAAE;gBACF,gBAAgB,EAAE,QAAQ;gBAC1B,aAAa,EAAE,QAAQ;aACxB,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QACrB,CAAC;QACD,OAAO,GAAG,CAAA;IACZ,CAAC;IAED,8CAA8C;IAC9C,YAAY,CAAC,OAAkB,EAAE,GAAW;QAC1C,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,cAAc,EAAE;gBACnD,EAAE,EAAE,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC1B,IAAI,EAAE,MAAM;gBACZ,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,GAAG,EAAE,GAAG,GAAG,IAAI;gBACf,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE,aAAa,EAAE;gBACrB,SAAS,EAAE,CAAC,KAAK,EAAE;aACpB,CAAC,EAAE;gBACF,gBAAgB,EAAE,QAAQ;gBAC1B,aAAa,EAAE,QAAQ;aACxB,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QACrB,CAAC;QACD,OAAO,GAAG,CAAA;IACZ,CAAC;IAED,oCAAoC;IACpC,YAAY,CAAsB,IAAO,EAAE,IAAY,EAAE,SAAkB;;QACzE,MAAM,GAAG,GAAG,SAAS,IAAI,oBAAoB,MAAA,IAAI,CAAC,WAAW,0CAAE,IAAI,aAAa,CAAA;QAChF,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE;YACrC,gBAAgB,EAAE,QAAQ;YAC1B,aAAa,EAAE,QAAQ;SACxB,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;IACrB,CAAC;CACF;AAED,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAA"}
package/dist/pm.js ADDED
@@ -0,0 +1,21 @@
1
+ /**
2
+ * 包管理器检测
3
+ */
4
+ import fse from 'fs-extra';
5
+ import path from 'node:path';
6
+ /** 支持的包管理器列表(集中定义) */
7
+ export const npmTypes = [
8
+ { name: 'npm', lockFile: 'package-lock.json', installScript: 'npm ci' },
9
+ { name: 'yarn', lockFile: 'yarn.lock', installScript: 'yarn install --frozen-lockfile' },
10
+ { name: 'pnpm', lockFile: 'pnpm-lock.yaml', installScript: 'pnpm install --frozen-lockfile' },
11
+ ];
12
+ /** 检测项目使用的包管理器,返回完整 NpmType 对象 */
13
+ export function detectPackageManager(dir) {
14
+ for (const item of npmTypes) {
15
+ if (fse.existsSync(path.join(dir, item.lockFile))) {
16
+ return item;
17
+ }
18
+ }
19
+ return npmTypes[0];
20
+ }
21
+ //# sourceMappingURL=pm.js.map
package/dist/pm.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pm.js","sourceRoot":"","sources":["../src/pm.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,GAAG,MAAM,UAAU,CAAA;AAC1B,OAAO,IAAI,MAAM,WAAW,CAAA;AAG5B,sBAAsB;AACtB,MAAM,CAAC,MAAM,QAAQ,GAAc;IACjC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,mBAAmB,EAAE,aAAa,EAAE,QAAQ,EAAE;IACvE,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE,gCAAgC,EAAE;IACxF,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,EAAE,aAAa,EAAE,gCAAgC,EAAE;CAC9F,CAAA;AAED,kCAAkC;AAClC,MAAM,UAAU,oBAAoB,CAAC,GAAW;IAC9C,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;QAC5B,IAAI,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC;YAClD,OAAO,IAAI,CAAA;QACb,CAAC;IACH,CAAC;IACD,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAA;AACpB,CAAC"}
package/dist/queue.js ADDED
@@ -0,0 +1,273 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ /**
11
+ * BuildTaskQueue – 构建任务队列,支持并发控制、AbortController、增量构建
12
+ */
13
+ import { globSync } from 'glob';
14
+ import path from 'node:path';
15
+ import dayjs from 'dayjs';
16
+ import chalk from 'chalk';
17
+ import fse from 'fs-extra';
18
+ import { spawnPms, getFormatTime } from './utils.js';
19
+ import { logger } from './logger.js';
20
+ import { notifier } from './notifier.js';
21
+ import { copyDist, backupDist } from './artifact.js';
22
+ import { checkBranch, gitClean, getChangedFiles, pullBranch } from './git.js';
23
+ import { detectPackageManager } from './pm.js';
24
+ import { getWriteStream } from './fsHelpers.js';
25
+ import { generateUid } from './database/index.js';
26
+ import { webDistPath, catchBuildLogPath, maxConcurrency, baseRoute, catchWebDistPath } from './config.js';
27
+ import CustError from './custError.js';
28
+ import { BuildStatus as BuildStatusEnum, formatMsg, IdType as IdTypeEnum, sanitizePath } from './types.js';
29
+ const cwd = process.cwd();
30
+ export class BuildTaskQueue {
31
+ constructor() {
32
+ this.pending = [];
33
+ this.runningTasks = [];
34
+ this.packages = [];
35
+ this.packages = this.getAllPackage();
36
+ if (!this.packages.length) {
37
+ console.error(chalk.red(new CustError(`${cwd} 当前路径不存在package.json文件`).custMsg));
38
+ }
39
+ }
40
+ get runningNum() {
41
+ return this.runningTasks.length;
42
+ }
43
+ /** 重新扫描并更新 packages 列表 */
44
+ refreshPackages() {
45
+ this.packages = this.getAllPackage();
46
+ }
47
+ /** 获取所有含 package.json 的目录 */
48
+ getAllPackage() {
49
+ const jsonPaths = globSync(['**/package.json'], {
50
+ cwd,
51
+ ignore: ['**/node_modules/**', '**/dist/**'],
52
+ });
53
+ return jsonPaths.map((item) => path.dirname(item)).sort((a, b) => b.length - a.length);
54
+ }
55
+ /** 添加任务到队列 */
56
+ addTask(params) {
57
+ return __awaiter(this, void 0, void 0, function* () {
58
+ const { packagePath, branch, commit, notify, buildSourceType } = params;
59
+ const absolutePackagePath = path.join(cwd, packagePath);
60
+ if (!this.packages.length) {
61
+ throw new CustError(`${cwd} 当前路径不存在可执行的项目`);
62
+ }
63
+ if (!fse.existsSync(absolutePackagePath)) {
64
+ throw new CustError(`${absolutePackagePath} 路径不存在`);
65
+ }
66
+ const checkAddTask = (absolutePackagePath) => __awaiter(this, void 0, void 0, function* () {
67
+ const packageJsonPath = path.join(absolutePackagePath, 'package.json');
68
+ const packageJson = fse.readJSONSync(packageJsonPath, { encoding: 'utf-8' });
69
+ const { scripts } = packageJson;
70
+ if (!scripts.build) {
71
+ throw new CustError(`${packageJsonPath} 没有找到当前项目的build脚本`);
72
+ }
73
+ const npmType = detectPackageManager(absolutePackagePath);
74
+ const abortController = new AbortController();
75
+ abortController.signal.addEventListener('abort', () => {
76
+ notifier.sendChatMsgByTask(task, `任务已终止,请等待退出`);
77
+ });
78
+ const task = Object.assign({ time: getFormatTime(+dayjs(), 'YYYY-MM-DD_HH:mm:ss'), timestamp: +dayjs(), taskId: generateUid(IdTypeEnum.T), npmType, cwd: absolutePackagePath, abortController, status: BuildStatusEnum.Pending, buildLogPath: '', absolutePackagePath }, params);
79
+ this.pending.push(task);
80
+ notifier.sendChatMsgByTask(task, `已加入任务队列`);
81
+ emitPendingTasksUpdate();
82
+ });
83
+ if (!commit) {
84
+ yield checkAddTask(absolutePackagePath);
85
+ setImmediate(() => this.runNext());
86
+ return;
87
+ }
88
+ // 增量构建:根据 commit diff 识别变更项目
89
+ const diffs = yield getChangedFiles(commit, absolutePackagePath);
90
+ if (!diffs.length)
91
+ throw new CustError(`${cwd} 当前路径 git diff 没有任何文件变更`);
92
+ const changePackages = new Set();
93
+ if (this.packages.length === 1 && this.packages[0] === '.') {
94
+ changePackages.add(this.packages[0]);
95
+ }
96
+ else {
97
+ for (const diff of diffs) {
98
+ const findPkg = this.packages.find((v) => diff.includes(v));
99
+ if (!findPkg && this.packages.includes('.')) {
100
+ changePackages.add('.');
101
+ }
102
+ if (findPkg) {
103
+ changePackages.add(findPkg);
104
+ }
105
+ }
106
+ }
107
+ if (changePackages.size === 0)
108
+ throw new CustError('git diff 没有找到可执行的匹配项目');
109
+ for (const pkg of changePackages) {
110
+ const absolutePkg = path.join(cwd, pkg);
111
+ yield checkAddTask(absolutePkg);
112
+ }
113
+ setImmediate(() => this.runNext());
114
+ });
115
+ }
116
+ /** 检查指定 packagePath 是否与任何运行中任务冲突(同项目或 monorepo 父子) */
117
+ hasConflictWithRunning(pkg) {
118
+ // 规范化:去掉 ./ 前缀
119
+ const a = pkg.replace(/^\.\//, '');
120
+ return this.runningTasks.map((t) => t.packagePath).some((runningPkg) => {
121
+ const b = runningPkg.replace(/^\.\//, '');
122
+ // 完全相同
123
+ if (a === b)
124
+ return true;
125
+ // . 代表根目录,与所有项目冲突
126
+ if (a === '' || b === '')
127
+ return true;
128
+ // monorepo 父子关系
129
+ return a.startsWith(b + '/') || b.startsWith(a + '/');
130
+ });
131
+ }
132
+ /** 触发下一个任务(支持并行,排除与运行中任务冲突的项目) */
133
+ runNext() {
134
+ return __awaiter(this, void 0, void 0, function* () {
135
+ if (this.runningNum >= maxConcurrency)
136
+ return;
137
+ let slotsLeft = maxConcurrency - this.runningNum;
138
+ for (const task of this.pending) {
139
+ if (slotsLeft <= 0)
140
+ return;
141
+ if (this.hasConflictWithRunning(task.packagePath))
142
+ continue;
143
+ this.runningTasks.push(task);
144
+ this.pending = this.pending.filter((v) => v.taskId !== task.taskId);
145
+ this.spawnTask(task);
146
+ slotsLeft--;
147
+ }
148
+ });
149
+ }
150
+ /** 非阻塞地启动单个任务 */
151
+ spawnTask(task) {
152
+ return __awaiter(this, void 0, void 0, function* () {
153
+ try {
154
+ yield this.execute(task);
155
+ logger.info(`Task ${task.taskId} succeeded`);
156
+ }
157
+ catch (err) {
158
+ logger.error(`Task ${task.taskId} failed: ${err.message}`);
159
+ }
160
+ finally {
161
+ this.runningTasks = this.runningTasks.filter((t) => t.taskId !== task.taskId);
162
+ emitPendingTasksUpdate();
163
+ setImmediate(() => this.runNext());
164
+ }
165
+ });
166
+ }
167
+ /** 执行单个任务的完整流程 */
168
+ execute(task) {
169
+ return __awaiter(this, void 0, void 0, function* () {
170
+ const fileName = `${task.time}_${task.branch}_${sanitizePath(task.packagePath)}_${task.taskId}.log`;
171
+ const { writeStream, localFileName } = yield getWriteStream(catchBuildLogPath, fileName);
172
+ writeStream.write(`\n${getFormatTime()}\n`);
173
+ const buildLogPath = `${baseRoute}/api/showLog?type=buildLog&name=${localFileName}`;
174
+ task.status = BuildStatusEnum.InProgress;
175
+ task.buildLogPath = buildLogPath;
176
+ // status: 1 进行中, 2 成功, 3 失败
177
+ const onSendBuildMsg = (msg, status = BuildStatusEnum.InProgress, isCustMsg = false) => {
178
+ task.status = status;
179
+ if ([2, 3].includes(status)) {
180
+ writeStream.writable && writeStream.end(msg + '\n');
181
+ }
182
+ else {
183
+ writeStream.writable && writeStream.write(msg + '\n');
184
+ }
185
+ if (task.notify && (/err|error/i.test(msg) || status !== 1 || isCustMsg)) {
186
+ notifier.sendBuildMsg(task, msg);
187
+ }
188
+ return msg;
189
+ };
190
+ try {
191
+ notifier.sendChatMsgByTask(task, `开始构建`);
192
+ console.log(chalk.green(onSendBuildMsg(`------ build time ${getFormatTime()} ------`, BuildStatusEnum.InProgress, true)));
193
+ console.log(chalk.green(onSendBuildMsg(`------ build taskId ${task.taskId} ------`, BuildStatusEnum.InProgress, true)));
194
+ console.log(chalk.green(onSendBuildMsg(`------ build packagePath ${task.packagePath} ------`, BuildStatusEnum.InProgress, true)));
195
+ console.log(chalk.green(onSendBuildMsg(`------ build by ${task.npmType.name} ------`, BuildStatusEnum.InProgress, true)));
196
+ // 切换分支
197
+ console.log(chalk.green(onSendBuildMsg(`------ check branch ${task.branch} by ${task.cwd} ------`, BuildStatusEnum.InProgress, true)));
198
+ yield checkBranch(task.branch, task.cwd, { signal: task.abortController.signal });
199
+ // pull 分支
200
+ console.log(chalk.green(onSendBuildMsg(`------ git pull origin ${task.branch} ------`, BuildStatusEnum.InProgress, true)));
201
+ yield pullBranch(task.branch, task.cwd, { signal: task.abortController.signal });
202
+ // 安装
203
+ console.log(chalk.green(onSendBuildMsg(`------ ${task.npmType.installScript} ------`, BuildStatusEnum.InProgress, true)));
204
+ const [runName, ...args] = task.npmType.installScript.split(' ');
205
+ yield spawnPms(runName, args, {
206
+ cwd: task.cwd,
207
+ onMessage: onSendBuildMsg,
208
+ signal: task.abortController.signal,
209
+ });
210
+ // 构建
211
+ console.log(chalk.green(onSendBuildMsg(`------ npm run build ------`, 1, true)));
212
+ yield spawnPms('npm', ['run', 'build'], {
213
+ cwd: task.cwd,
214
+ onMessage: onSendBuildMsg,
215
+ signal: task.abortController.signal,
216
+ });
217
+ // 复制构建输出到网站目录
218
+ const sourcePath = path.join(task.cwd, 'dist');
219
+ const targetPath = path.join(webDistPath, task.packagePath);
220
+ // 非 monorepo 项目且在项目根目录执行构建,不复制
221
+ if (sourcePath !== targetPath) {
222
+ console.log(chalk.green(onSendBuildMsg(`------ copy ${sourcePath} ${targetPath} ------`, BuildStatusEnum.InProgress, true)));
223
+ yield copyDist(sourcePath, targetPath);
224
+ }
225
+ // 备份
226
+ if (fse.existsSync(targetPath)) {
227
+ const backupPath = path.join(catchWebDistPath, `${task.branch}_${sanitizePath(task.packagePath)}_${dayjs().format('YYYY-MM-DD_HH:mm:ss')}`, task.packagePath);
228
+ console.log(chalk.green(onSendBuildMsg(`------ backup ${targetPath} --> ${backupPath} ------`, BuildStatusEnum.InProgress, true)));
229
+ yield backupDist(targetPath, backupPath);
230
+ }
231
+ // git clean
232
+ console.log(chalk.green(onSendBuildMsg(`------ git clean ------`, 1, true)));
233
+ yield gitClean(task.cwd);
234
+ console.log(chalk.green(onSendBuildMsg(`------ ${getFormatTime()} 构建成功 packagePath ${task.packagePath} build success ------\n`, BuildStatusEnum.Success, true)));
235
+ notifier.sendChatMsgByTask(task, `构建成功`);
236
+ }
237
+ catch (error) {
238
+ notifier.sendChatMsgByTask(task, `构建失败 ${error}`);
239
+ console.log(chalk.red(onSendBuildMsg(`------ ${getFormatTime()} 构建失败 packagePath ${task.packagePath} build error: ${error} ------\n`, BuildStatusEnum.Failed, true)));
240
+ throw error;
241
+ }
242
+ });
243
+ }
244
+ /** 取消任务(当前运行或待执行) */
245
+ cancelTask(taskId) {
246
+ const runningTask = this.runningTasks.find((t) => t.taskId === taskId);
247
+ if (runningTask) {
248
+ runningTask.abortController.abort();
249
+ this.runningTasks = this.runningTasks.filter((t) => t.taskId !== taskId);
250
+ emitPendingTasksUpdate();
251
+ return true;
252
+ }
253
+ // 从 pending 中移除
254
+ const idx = this.pending.findIndex((t) => t.taskId === taskId);
255
+ if (idx !== -1) {
256
+ this.pending.splice(idx, 1);
257
+ emitPendingTasksUpdate();
258
+ return true;
259
+ }
260
+ return false;
261
+ }
262
+ }
263
+ /** 广播排队任务列表变更(服务端 emit 信号 + 无服务 axios POST) */
264
+ function emitPendingTasksUpdate() {
265
+ notifier.emitAxiosMsg('on:pending-tasks-update', formatMsg('on:pending-tasks-update', {
266
+ id: generateUid(IdTypeEnum.M),
267
+ name: '系统消息',
268
+ time: getFormatTime(),
269
+ timestamp: +dayjs(),
270
+ }));
271
+ }
272
+ export const buildTaskQueue = new BuildTaskQueue();
273
+ //# sourceMappingURL=queue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"queue.js","sourceRoot":"","sources":["../src/queue.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,189 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ /**
11
+ * BuildServer – Express + Socket.IO 服务
12
+ */
13
+ import express from 'express';
14
+ import { createServer } from 'node:http';
15
+ import { Server } from 'socket.io';
16
+ import cors from 'cors';
17
+ import path from 'node:path';
18
+ import chalk from 'chalk';
19
+ import fse from 'fs-extra';
20
+ import swaggerUi from 'swagger-ui-express';
21
+ import swaggerJSDoc from 'swagger-jsdoc';
22
+ import { logger } from '../logger.js';
23
+ import { decrypt } from '../crypto.js';
24
+ import { loadDatabase } from '../database/index.js';
25
+ import { startCron } from '../cron.js';
26
+ import { findIndexHtml } from '../fsHelpers.js';
27
+ import { buildTaskQueue } from '../queue.js';
28
+ import { websocketHandler } from './websocket.js';
29
+ import { notifier } from '../notifier.js';
30
+ import { createRouter } from './routes.js';
31
+ const __dirname = new URL('.', import.meta.url).pathname;
32
+ export default class BuildServer {
33
+ constructor(props) {
34
+ this.app = express();
35
+ this.httpServer = createServer(this.app);
36
+ this.io = new Server(this.httpServer, {
37
+ path: '/ws/',
38
+ pingTimeout: 20000,
39
+ pingInterval: 6000,
40
+ maxHttpBufferSize: 1e8 * 60,
41
+ });
42
+ this.port = 3000;
43
+ this.websiteRoot = '';
44
+ this.websitePath = '';
45
+ this.database = new Map();
46
+ this.noticeJson = [];
47
+ this.port = props.port || this.port;
48
+ this.websiteRoot = props.websiteRoot || this.websiteRoot;
49
+ this.websitePath = props.websitePath || this.websitePath;
50
+ this.queue = buildTaskQueue;
51
+ this.wsHandler = websocketHandler;
52
+ this.notifier = notifier;
53
+ this.app
54
+ .set('queue', this.queue)
55
+ .set('io', this.io)
56
+ .set('port', this.port)
57
+ .set('websiteRoot', this.websiteRoot)
58
+ .set('websitePath', this.websitePath);
59
+ }
60
+ init() {
61
+ return __awaiter(this, void 0, void 0, function* () {
62
+ // database
63
+ this.database = yield loadDatabase();
64
+ this.app.set('database', this.database);
65
+ // noticeJson
66
+ yield this.loadNoticeJson();
67
+ // CORS(必须在认证中间件之前,否则跨域预检请求会被拦截)
68
+ this.app.use(cors({ origin: true, methods: ['GET', 'HEAD', 'PUT', 'PATCH', 'POST', 'DELETE'], allowedHeaders: ['Content-Type', 'Authorization', 'X-Debug', 'user-token'], credentials: true }));
69
+ // JSON parser
70
+ this.app.use(express.json({ limit: '50mb' }));
71
+ // 后台系统 static files
72
+ const webStaticDir = path.resolve(__dirname, '../web');
73
+ if (fse.existsSync(webStaticDir)) {
74
+ this.app.use('/buildsystem', (req, res, next) => {
75
+ const ext = path.extname(req.path);
76
+ const htmlPath = path.join(webStaticDir, `index.html`);
77
+ if (!fse.existsSync(htmlPath))
78
+ return next();
79
+ if (!ext) {
80
+ res.sendFile(htmlPath);
81
+ return;
82
+ }
83
+ next();
84
+ }, express.static(webStaticDir, {
85
+ extensions: ['html', 'js', 'css', 'webp', 'png', 'jpg', 'jpeg', 'gif', 'svg'],
86
+ index: ['index.html', 'index.htm'],
87
+ }));
88
+ }
89
+ // websiteRoot static files
90
+ if (this.websitePath && this.websiteRoot) {
91
+ this.app.use(this.websitePath, (req, res, next) => __awaiter(this, void 0, void 0, function* () {
92
+ const ext = path.extname(req.path);
93
+ if (!ext) {
94
+ try {
95
+ const html = yield findIndexHtml(req.path, path.resolve(process.cwd(), this.websiteRoot));
96
+ res.sendFile(html);
97
+ }
98
+ catch (_a) {
99
+ next();
100
+ }
101
+ return;
102
+ }
103
+ next();
104
+ }), express.static(path.resolve(process.cwd(), this.websiteRoot), {
105
+ extensions: ['html', 'js', 'css', 'webp', 'png', 'jpg', 'jpeg', 'gif', 'svg'],
106
+ index: ['index.html', 'index.htm'],
107
+ }));
108
+ }
109
+ // auth middleware
110
+ this.app.use((req, res, next) => __awaiter(this, void 0, void 0, function* () {
111
+ const excludePaths = ['/api/login', '/api/register', '/api/notice/aliyunxiao', '/api/github', '/api/notify', '/api/showLog'];
112
+ if (excludePaths.some((v) => req.path.startsWith(v)))
113
+ return next();
114
+ const token = req.headers['user-token'];
115
+ if (!token)
116
+ return res.send({ success: false, message: 'invalid token' });
117
+ try {
118
+ const userInfo = yield decrypt(token);
119
+ const userInfoObj = JSON.parse(userInfo);
120
+ req.userInfo = userInfoObj;
121
+ next();
122
+ }
123
+ catch (_a) {
124
+ next('invalid token');
125
+ return;
126
+ }
127
+ }));
128
+ // log middleware
129
+ this.app.use((req, res, next) => __awaiter(this, void 0, void 0, function* () {
130
+ var _a;
131
+ const excludePaths = ['/static', '/page', '/api/getAllTask', '/api/getAllPackage', '/api/getAllLog', '/api/getAllBackup', '/api/getAllCommand', '/api/getNoticeList', '/api/showLog'];
132
+ if (excludePaths.some((v) => req.path.startsWith(v)))
133
+ return next();
134
+ if (req.path.startsWith('/api/notify') && ((_a = req.body) === null || _a === void 0 ? void 0 : _a.type) === 'on:msg-build')
135
+ return next();
136
+ const userInfo = req.userInfo || {};
137
+ logger.log({ level: 'http', message: `Request: ${req.method} ${req.originalUrl}`, userInfo, headers: req.headers, body: req.body });
138
+ res.on('finish', () => {
139
+ logger.log({ level: 'http', message: `Response: ${req.method} ${req.originalUrl}`, code: res.statusCode });
140
+ });
141
+ next();
142
+ }));
143
+ // swagger
144
+ const swaggerSpec = swaggerJSDoc({
145
+ failOnErrors: true,
146
+ definition: { openapi: '3.0.0', info: { title: 'BuildSystem Api', version: '1.0.0' } },
147
+ apis: [path.join(__dirname, './routes*')],
148
+ });
149
+ this.app.use('/swagger', swaggerUi.serve, swaggerUi.setup(swaggerSpec));
150
+ // API routes
151
+ const router = createRouter(this.queue, this.io, this.database, this.wsHandler, this.noticeJson, this.port);
152
+ this.app.use('/api', router);
153
+ // websocket
154
+ this.wsHandler.inject(this).start();
155
+ // notifier bind
156
+ this.notifier.inject(this);
157
+ // error handler
158
+ this.app.use((err, req, res, next) => {
159
+ const errorMsg = err instanceof Error ? err.stack : typeof err === 'string' ? err : JSON.stringify(err);
160
+ if (res.headersSent) {
161
+ console.error('errorHandler: ' + errorMsg);
162
+ next(err);
163
+ return;
164
+ }
165
+ res.status(500).send({ message: errorMsg, success: false });
166
+ });
167
+ });
168
+ }
169
+ loadNoticeJson() {
170
+ return __awaiter(this, void 0, void 0, function* () {
171
+ const noticePath = path.resolve(process.cwd(), 'notice.json');
172
+ if (!fse.existsSync(noticePath))
173
+ return;
174
+ const noticeJson = fse.readJSONSync(noticePath);
175
+ this.app.set('noticeJson', noticeJson);
176
+ this.noticeJson = noticeJson;
177
+ });
178
+ }
179
+ start() {
180
+ return __awaiter(this, void 0, void 0, function* () {
181
+ yield this.init();
182
+ startCron();
183
+ this.httpServer.listen(this.port, () => {
184
+ console.log(chalk.green(`server start listening on port ${this.port}`));
185
+ });
186
+ });
187
+ }
188
+ }
189
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/server/index.ts"],"names":[],"mappings":";;;;;;;;;AAAA;;GAEG;AACH,OAAO,OAAO,MAAM,SAAS,CAAA;AAC7B,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAA;AAClC,OAAO,IAAI,MAAM,MAAM,CAAA;AACvB,OAAO,IAAI,MAAM,WAAW,CAAA;AAC5B,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,GAAG,MAAM,UAAU,CAAA;AAC1B,OAAO,SAAS,MAAM,oBAAoB,CAAA;AAC1C,OAAO,YAAY,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AACtC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAkB,cAAc,EAAE,MAAM,aAAa,CAAA;AAC5D,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACnE,OAAO,EAAY,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAI1C,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAA;AAQxD,MAAM,CAAC,OAAO,OAAO,WAAW;IAkB9B,YAAY,KAAuB;QAjBnC,QAAG,GAAG,OAAO,EAAE,CAAA;QACf,eAAU,GAAG,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QACnC,OAAE,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE;YAC/B,IAAI,EAAE,MAAM;YACZ,WAAW,EAAE,KAAK;YAClB,YAAY,EAAE,IAAI;YAClB,iBAAiB,EAAE,GAAG,GAAG,EAAE;SAC5B,CAAC,CAAA;QAEF,SAAI,GAAW,IAAI,CAAA;QACnB,gBAAW,GAAW,EAAE,CAAA;QACxB,gBAAW,GAAW,EAAE,CAAA;QACxB,aAAQ,GAAgB,IAAI,GAAG,EAAE,CAAA;QACjC,eAAU,GAAiB,EAAE,CAAA;QAK3B,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAA;QACnC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAA;QACxD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAA;QACxD,IAAI,CAAC,KAAK,GAAG,cAAc,CAAA;QAC3B,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAA;QACjC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;QAExB,IAAI,CAAC,GAAG;aACL,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC;aACxB,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC;aAClB,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC;aACtB,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC;aACpC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,CAAA;IACzC,CAAC;IAEK,IAAI;;YACR,WAAW;YACX,IAAI,CAAC,QAAQ,GAAG,MAAM,YAAY,EAAE,CAAA;YACpC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;YAEvC,aAAa;YACb,MAAM,IAAI,CAAC,cAAc,EAAE,CAAA;YAE3B,gCAAgC;YAChC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,cAAc,EAAE,CAAC,cAAc,EAAE,eAAe,EAAE,SAAS,EAAE,YAAY,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAA;YAE/L,cAAc;YACd,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAA;YAE7C,oBAAoB;YACpB,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;YACtD,IAAI,GAAG,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;gBACjC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,cAAc,EACzB,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;oBACjB,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;oBAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,CAAA;oBACtD,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,QAAQ,CAAC;wBAAE,OAAO,IAAI,EAAE,CAAA;oBAC5C,IAAI,CAAC,GAAG,EAAE,CAAC;wBACT,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAA;wBACtB,OAAM;oBACR,CAAC;oBACD,IAAI,EAAE,CAAA;gBACR,CAAC,EACD,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE;oBAC3B,UAAU,EAAE,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC;oBAC7E,KAAK,EAAE,CAAC,YAAY,EAAE,WAAW,CAAC;iBACnC,CAAC,CAAC,CAAA;YACP,CAAC;YAED,2BAA2B;YAC3B,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACzC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,CAAO,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;oBACtD,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;oBAClC,IAAI,CAAC,GAAG,EAAE,CAAC;wBACT,IAAI,CAAC;4BACH,MAAM,IAAI,GAAG,MAAM,aAAa,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAA;4BACzF,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;wBACpB,CAAC;wBAAC,WAAM,CAAC;4BACP,IAAI,EAAE,CAAA;wBACR,CAAC;wBACD,OAAM;oBACR,CAAC;oBACD,IAAI,EAAE,CAAA;gBACR,CAAC,CAAA,EAAE,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE;oBAC/D,UAAU,EAAE,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC;oBAC7E,KAAK,EAAE,CAAC,YAAY,EAAE,WAAW,CAAC;iBACnC,CAAC,CAAC,CAAA;YACL,CAAC;YAED,kBAAkB;YAClB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAO,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;gBACpC,MAAM,YAAY,GAAG,CAAC,YAAY,EAAE,eAAe,EAAE,wBAAwB,EAAE,aAAa,EAAE,aAAa,EAAE,cAAc,CAAC,CAAA;gBAC5H,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;oBAAE,OAAO,IAAI,EAAE,CAAA;gBACnE,MAAM,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC,YAAY,CAAuB,CAAA;gBAC7D,IAAI,CAAC,KAAK;oBAAE,OAAO,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,CAAC,CAAA;gBACzE,IAAI,CAAC;oBACH,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,KAAe,CAAC,CAAA;oBAC/C,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;oBACxC,GAAG,CAAC,QAAQ,GAAG,WAAW,CAAA;oBAC1B,IAAI,EAAE,CAAA;gBACR,CAAC;gBAAC,WAAM,CAAC;oBACP,IAAI,CAAC,eAAe,CAAC,CAAA;oBACrB,OAAM;gBACR,CAAC;YACH,CAAC,CAAA,CAAC,CAAA;YAEF,iBAAiB;YACjB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAO,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;;gBACpC,MAAM,YAAY,GAAG,CAAC,SAAS,EAAE,OAAO,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,cAAc,CAAC,CAAA;gBACrL,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;oBAAE,OAAO,IAAI,EAAE,CAAA;gBACnE,IAAI,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAA,MAAA,GAAG,CAAC,IAAI,0CAAE,IAAI,MAAK,cAAc;oBAAE,OAAO,IAAI,EAAE,CAAA;gBAC1F,MAAM,QAAQ,GAAG,GAAG,CAAC,QAAQ,IAAI,EAAE,CAAA;gBACnC,MAAM,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,WAAW,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,CAAC,CAAA;gBACnI,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;oBACpB,MAAM,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,aAAa,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,GAAG,CAAC,UAAU,EAAE,CAAC,CAAA;gBAC5G,CAAC,CAAC,CAAA;gBACF,IAAI,EAAE,CAAA;YACR,CAAC,CAAA,CAAC,CAAA;YAEF,UAAU;YACV,MAAM,WAAW,GAAG,YAAY,CAAC;gBAC/B,YAAY,EAAE,IAAI;gBAClB,UAAU,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE,KAAK,EAAE,iBAAiB,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE;gBACtF,IAAI,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;aAC1C,CAAC,CAAA;YACF,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,UAAU,EAAE,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAA;YAEvE,aAAa;YACb,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;YAC3G,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;YAE5B,YAAY;YACZ,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,CAAA;YAEnC,gBAAgB;YAChB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;YAE1B,gBAAgB;YAChB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,GAAoB,EAAE,GAAqB,EAAE,IAA0B,EAAE,EAAE;gBACjG,MAAM,QAAQ,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;gBACvG,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;oBACpB,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,QAAQ,CAAC,CAAA;oBAC1C,IAAI,CAAC,GAAG,CAAC,CAAA;oBACT,OAAM;gBACR,CAAC;gBACD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAA;YAC7D,CAAC,CAAC,CAAA;QACJ,CAAC;KAAA;IAEK,cAAc;;YAClB,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,aAAa,CAAC,CAAA;YAC7D,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC;gBAAE,OAAM;YACvC,MAAM,UAAU,GAAG,GAAG,CAAC,YAAY,CAAC,UAAU,CAAC,CAAA;YAC/C,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,YAAY,EAAE,UAAU,CAAC,CAAA;YACtC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC9B,CAAC;KAAA;IAEK,KAAK;;YACT,MAAM,IAAI,CAAC,IAAI,EAAE,CAAA;YACjB,SAAS,EAAE,CAAA;YACX,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE;gBACrC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,kCAAkC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAA;YACzE,CAAC,CAAC,CAAA;QACJ,CAAC;KAAA;CACF"}