feat: 实现环境变量预设功能 & 移除稀疏检出

## 后端改动
- 添加 Project.envPresets 字段(JSON 格式)
- 移除 Deployment.env 字段,统一使用 envVars
- 更新部署 DTO,支持 envVars (Record<string, string>)
- pipeline-runner 支持解析并注入 envVars 到环境
- 移除稀疏检出模板和相关环境变量
- 优化代码格式(Biome lint & format)

## 前端改动
- 新增 EnvPresetsEditor 组件(支持单选/多选/输入框类型)
- 项目创建/编辑界面集成环境预设编辑器
- 部署界面基于预设动态生成环境变量表单
- 移除稀疏检出表单项
- 项目详情页添加环境变量预设配置 tab
- 优化部署界面布局(基本参数 & 环境变量分区)

## 文档
- 添加完整文档目录结构(docs/)
- 创建设计文档 design-0005(部署流程重构)
- 添加 API 文档、架构设计文档等

## 数据库
- 执行 prisma db push 同步 schema 变更
This commit is contained in:
2026-01-03 22:59:20 +08:00
parent c40532c757
commit d22fdc9618
71 changed files with 9611 additions and 5849 deletions

View File

@@ -1,15 +1,17 @@
import type { Context } from 'koa';
import { Controller, Get, Post } from '../../decorators/route.ts';
import type { Prisma } from '../../generated/client.ts';
import { prisma } from '../../libs/prisma.ts';
import type { Context } from 'koa';
import { listDeploymentsQuerySchema, createDeploymentSchema } from './dto.ts';
import { ExecutionQueue } from '../../libs/execution-queue.ts';
import { prisma } from '../../libs/prisma.ts';
import { createDeploymentSchema, listDeploymentsQuerySchema } from './dto.ts';
@Controller('/deployments')
export class DeploymentController {
@Get('')
async list(ctx: Context) {
const { page, pageSize, projectId } = listDeploymentsQuerySchema.parse(ctx.query);
const { page, pageSize, projectId } = listDeploymentsQuerySchema.parse(
ctx.query,
);
const where: Prisma.DeploymentWhereInput = {
valid: 1,
};
@@ -50,8 +52,7 @@ export class DeploymentController {
connect: { id: body.projectId },
},
pipelineId: body.pipelineId,
env: body.env || 'dev',
sparseCheckoutPaths: body.sparseCheckoutPaths || '', // 添加稀疏检出路径
envVars: body.envVars ? JSON.stringify(body.envVars) : null,
buildLog: '',
createdBy: 'system', // TODO: get from user
updatedBy: 'system',
@@ -73,7 +74,7 @@ export class DeploymentController {
// 获取原始部署记录
const originalDeployment = await prisma.deployment.findUnique({
where: { id: Number(id) }
where: { id: Number(id) },
});
if (!originalDeployment) {
@@ -82,7 +83,7 @@ export class DeploymentController {
code: 404,
message: '部署记录不存在',
data: null,
timestamp: Date.now()
timestamp: Date.now(),
};
return;
}
@@ -96,8 +97,7 @@ export class DeploymentController {
status: 'pending',
projectId: originalDeployment.projectId,
pipelineId: originalDeployment.pipelineId,
env: originalDeployment.env,
sparseCheckoutPaths: originalDeployment.sparseCheckoutPaths,
envVars: originalDeployment.envVars,
buildLog: '',
createdBy: 'system',
updatedBy: 'system',
@@ -113,7 +113,7 @@ export class DeploymentController {
code: 0,
message: '重新执行任务已创建',
data: newDeployment,
timestamp: Date.now()
timestamp: Date.now(),
};
}
}