Summary: - Implement Prompt management infrastructure and core services - Build admin portal frontend with light theme - Integrate CodeMirror 6 editor for non-technical users Phase 3.5.1: Infrastructure Setup - Create capability_schema for Prompt storage - Add prompt_templates and prompt_versions tables - Add prompt:view/edit/debug/publish permissions - Migrate RVW prompts to database (RVW_EDITORIAL, RVW_METHODOLOGY) Phase 3.5.2: PromptService Core - Implement gray preview logic (DRAFT for debuggers, ACTIVE for users) - Module-level debug control (setDebugMode) - Handlebars template rendering - Variable extraction and validation (extractVariables, validateVariables) - Three-level disaster recovery (database -> cache -> hardcoded fallback) Phase 3.5.3: Management API - 8 RESTful endpoints (/api/admin/prompts/*) - Permission control (PROMPT_ENGINEER can edit, SUPER_ADMIN can publish) Phase 3.5.4: Frontend Management UI - Build admin portal architecture (AdminLayout, OrgLayout) - Add route system (/admin/*, /org/*) - Implement PromptListPage (filter, search, debug switch) - Implement PromptEditor (CodeMirror 6 simplified for clinical users) - Implement PromptEditorPage (edit, save, publish, test, version history) Technical Details: - Backend: 6 files, ~2044 lines (prompt.service.ts 596 lines) - Frontend: 9 files, ~1735 lines (PromptEditorPage.tsx 399 lines) - CodeMirror 6: Line numbers, auto-wrap, variable highlight, search, undo/redo - Chinese-friendly: 15px font, 1.8 line-height, system fonts Next Step: Phase 3.5.5 - Integrate RVW module with PromptService Tested: Backend API tests passed (8/8), Frontend pending user testing Status: Ready for Phase 3.5.5 RVW integration
122 lines
3.7 KiB
PowerShell
122 lines
3.7 KiB
PowerShell
# Node.js后端 - 重新构建并推送镜像到ACR
|
||
# 创建时间: 2025-12-24
|
||
# 原因: 修复缺少config目录的问题
|
||
|
||
Write-Host "============================================" -ForegroundColor Cyan
|
||
Write-Host "🚀 Node.js后端 - 重新构建镜像" -ForegroundColor Cyan
|
||
Write-Host "============================================" -ForegroundColor Cyan
|
||
Write-Host ""
|
||
|
||
# 1. 确认当前目录
|
||
$currentDir = Get-Location
|
||
Write-Host "📁 当前目录: $currentDir" -ForegroundColor Yellow
|
||
if ($currentDir.Path -notlike "*\backend") {
|
||
Write-Host "❌ 错误: 请在 backend 目录下运行此脚本!" -ForegroundColor Red
|
||
exit 1
|
||
}
|
||
|
||
# 2. 检查必需文件
|
||
Write-Host ""
|
||
Write-Host "🔍 检查必需文件..." -ForegroundColor Yellow
|
||
$requiredFiles = @("Dockerfile", "dist", "config", "package.json", "prisma")
|
||
foreach ($file in $requiredFiles) {
|
||
if (Test-Path $file) {
|
||
Write-Host " ✅ $file" -ForegroundColor Green
|
||
} else {
|
||
Write-Host " ❌ $file 不存在!" -ForegroundColor Red
|
||
exit 1
|
||
}
|
||
}
|
||
|
||
# 3. 登录ACR
|
||
Write-Host ""
|
||
Write-Host "🔐 登录阿里云容器镜像服务 (ACR)..." -ForegroundColor Yellow
|
||
docker login `
|
||
--username=gofeng117@163.com `
|
||
--password=fengzhibo117 `
|
||
crpi-cd5ij4pjt65mweeo.cn-beijing.personal.cr.aliyuncs.com
|
||
|
||
if ($LASTEXITCODE -ne 0) {
|
||
Write-Host "❌ ACR登录失败!" -ForegroundColor Red
|
||
exit 1
|
||
}
|
||
Write-Host "✅ ACR登录成功" -ForegroundColor Green
|
||
|
||
# 4. 构建镜像
|
||
Write-Host ""
|
||
Write-Host "🏗️ 开始构建Docker镜像..." -ForegroundColor Yellow
|
||
Write-Host " 镜像名称: backend-service:v1.1" -ForegroundColor Cyan
|
||
Write-Host " 修复内容: 添加config目录(agents.yaml等配置文件)" -ForegroundColor Cyan
|
||
Write-Host ""
|
||
|
||
$imageName = "crpi-cd5ij4pjt65mweeo.cn-beijing.personal.cr.aliyuncs.com/ai-clinical/backend-service"
|
||
$imageTag = "v1.1"
|
||
|
||
docker build -t "${imageName}:${imageTag}" .
|
||
|
||
if ($LASTEXITCODE -ne 0) {
|
||
Write-Host "❌ 镜像构建失败!" -ForegroundColor Red
|
||
exit 1
|
||
}
|
||
Write-Host "✅ 镜像构建成功: ${imageName}:${imageTag}" -ForegroundColor Green
|
||
|
||
# 5. 推送镜像到ACR
|
||
Write-Host ""
|
||
Write-Host "📤 推送镜像到ACR..." -ForegroundColor Yellow
|
||
docker push "${imageName}:${imageTag}"
|
||
|
||
if ($LASTEXITCODE -ne 0) {
|
||
Write-Host "❌ 镜像推送失败!" -ForegroundColor Red
|
||
exit 1
|
||
}
|
||
Write-Host "✅ 镜像推送成功" -ForegroundColor Green
|
||
|
||
# 6. 同时打上latest标签(可选)
|
||
Write-Host ""
|
||
Write-Host "🏷️ 打上latest标签..." -ForegroundColor Yellow
|
||
docker tag "${imageName}:${imageTag}" "${imageName}:latest"
|
||
docker push "${imageName}:latest"
|
||
Write-Host "✅ latest标签已推送" -ForegroundColor Green
|
||
|
||
# 7. 完成
|
||
Write-Host ""
|
||
Write-Host "============================================" -ForegroundColor Cyan
|
||
Write-Host "🎉 镜像构建和推送完成!" -ForegroundColor Green
|
||
Write-Host "============================================" -ForegroundColor Cyan
|
||
Write-Host ""
|
||
Write-Host "📋 镜像信息:" -ForegroundColor Yellow
|
||
Write-Host " 公网地址: ${imageName}:${imageTag}" -ForegroundColor Cyan
|
||
Write-Host " VPC地址: crpi-cd5ij4pjt65mweeo-vpc.cn-beijing.personal.cr.aliyuncs.com/ai-clinical/backend-service:${imageTag}" -ForegroundColor Cyan
|
||
Write-Host ""
|
||
Write-Host "📝 下一步操作:" -ForegroundColor Yellow
|
||
Write-Host " 1. 登录SAE控制台: https://sae.console.aliyun.com/" -ForegroundColor White
|
||
Write-Host " 2. 找到应用: nodejs-backend-test" -ForegroundColor White
|
||
Write-Host " 3. 配置管理 → 部署配置 → 镜像设置" -ForegroundColor White
|
||
Write-Host " 4. 修改镜像版本为: v1.1" -ForegroundColor White
|
||
Write-Host " 5. 保存并重新部署" -ForegroundColor White
|
||
Write-Host ""
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|