auto_agent/backend/app/services/metadata_service.py
2521690 a0f7152e80 feat(mvp): 接入真实样板应用桥接并推进演示主线
- 新增 `sample-apps/order-service` Java 样板应用及 Win/Linux 构建、启停、状态脚本
- 新增 `LocalSampleAppService`,在 `software-a` 中支持 `order-service test` 本地桥接部署
- 增加桥接开关配置:`ENABLE_SAMPLE_APP_BRIDGE`、`SAMPLE_APP_ROOT`
- 修正后端配置读取方式,环境变量可在运行时生效(`Settings` 改为 `default_factory`)
- 更新应用元数据默认验证目标:`127.0.0.1:18080`、本地日志路径
- 新增桥接测试 `test_sample_app_bridge.py`,后端基线更新至 `24 passed`
- 更新 `.gitignore`,忽略样板应用 `build/runtime` 产物
- 更新 README 与《当前进度总结》:记录本轮“真实样板应用 + 桥接能力”进展,MVP 进度约 `97%`
2026-04-09 15:45:03 +08:00

77 lines
2.8 KiB
Python

from __future__ import annotations
from uuid import uuid4
from sqlalchemy.orm import Session
from app.core.time import format_now
from app.models.app_metadata import AppMetadata
from app.repositories.metadata_repository import AppMetadataRepository
class MetadataService:
DEMO_ITEMS = [
{
"app_code": "order-service",
"env": "test",
"process_name": "java",
"command_contains": "order-service",
"health_check_url": "http://127.0.0.1:18080/actuator/health",
"log_path": "sample-apps/order-service/runtime/logs/order-service.log",
"listen_port": 18080,
"startup_keyword": "Started order-service",
},
{
"app_code": "order-service",
"env": "prod",
"process_name": "java",
"command_contains": "order-service",
"health_check_url": "http://order-service.prod.demo/actuator/health",
"log_path": "logs/order-service.log",
"listen_port": 8080,
"startup_keyword": "Started order-service",
},
{
"app_code": "payment-service",
"env": "test",
"process_name": "java",
"command_contains": "payment-service",
"health_check_url": "http://payment-service.test.demo/actuator/health",
"log_path": "logs/payment-service.log",
"listen_port": 8081,
"startup_keyword": "Started payment-service",
},
]
def __init__(self, db: Session, timezone_name: str) -> None:
self.db = db
self.timezone_name = timezone_name
self.repository = AppMetadataRepository(db)
def ensure_demo_metadata(self) -> None:
for item in self.DEMO_ITEMS:
existing = self.repository.get_by_app_env(item["app_code"], item["env"])
if existing:
continue
current_time = format_now(self.timezone_name)
self.repository.add(
AppMetadata(
app_metadata_id=f"app-meta-{uuid4().hex[:12]}",
app_code=item["app_code"],
env=item["env"],
process_name=item["process_name"],
command_contains=item["command_contains"],
health_check_url=item["health_check_url"],
log_path=item["log_path"],
listen_port=item["listen_port"],
startup_keyword=item["startup_keyword"],
created_at=current_time,
updated_at=current_time,
)
)
def get_app_metadata(self, app_code: str | None, env: str | None) -> AppMetadata | None:
if not app_code or not env:
return None
return self.repository.get_by_app_env(app_code, env)