feat(engine): 添加技能查看工具并优化异步任务管理

- 添加SkillViewTool到引擎加载器中,增强技能管理功能
- 在AgentLoop中引入_active_direct_task来跟踪活跃任务
- 实现直接任务执行时的同步处理逻辑
- 更新工具实例化方式以支持依赖注入

feat(config): 增加智能体运行时参数配置支持

- 扩展AgentDefaultsConfig添加max_tokens和temperature字段
- 实现配置解析函数_first_config_value处理多个配置源
- 支持通过Web API动态更新智能体运行时参数
- 添加前端页面配置表单和验证逻辑

refactor(provider): 统一最大令牌数参数类型为可选整型

- 将所有LLM提供者的max_tokens参数改为int | None类型
- 为AnthropicProvider实现模型特定的最大令牌数默认值
- 调整参数传递逻辑,优先级:调用参数 > 配置文件 > 模型默认值
- 移除硬编码的默认值,改用条件判断

feat(process): 增强事件投影功能

- 添加工具调用开始/结束事件的映射逻辑
- 实现技能激活事件的识别和展示
- 添加辅助函数处理工具调用名称和参数提取
- 优化运行记录关联逻辑,提升事件匹配准确性

fix(web): 更新网络请求客户端信任环境设置

- 将WebFetchTool和WebSearchTool的trust_env参数设为True
- 确保HTTP客户端能够正确使用系统代理配置
- 修复可能的网络连接问题

test: 添加配置加载和事件投影相关测试

- 新增智能体默认参数配置测试用例
- 实现API配置持久化和重载测试
- 添加技能卡片和工具事件的投影测试
```
This commit is contained in:
2026-05-27 13:37:06 +08:00
parent 55b39563a0
commit 33a9845566
75 changed files with 2599 additions and 114 deletions

View File

@ -0,0 +1,61 @@
#!/bin/bash
# Deploy initial skills to all runtime instances via docker cp
# Usage: ./scripts/deploy-initial-skills.sh
set -euo pipefail
SKILL_SOURCE="/home/ivan/xuan/beaver_project/skills"
DOCKER_NAMES=("app-instance-steven" "app-instance-benson" "app-instance-jayc" "app-instance-officebench")
SKILLS=(
"outlook-mail"
"filesystem-operation"
"terminal-operation"
"web-operation"
"utility-tools"
"skills-admin"
"cron-scheduler"
"memory-management"
)
for container in "${DOCKER_NAMES[@]}"; do
echo "==> Deploying to $container..."
docker exec "$container" mkdir -p /root/.beaver/workspace/skills/_index
for skill in "${SKILLS[@]}"; do
if [ -d "$SKILL_SOURCE/$skill" ]; then
docker cp "$SKILL_SOURCE/$skill" "$container":/root/.beaver/workspace/skills/
echo " + $skill"
fi
done
# Merge index: keep existing entries + add new skills, no duplicates
docker exec "$container" python3 -c "
import json
from pathlib import Path
idx = Path('/root/.beaver/workspace/skills/_index/published.json')
existing = json.loads(idx.read_text()) if idx.exists() else {'items': []}
new_skills = $(printf '["%s"]' "$(IFS=,; echo "${SKILLS[*]}")" | sed 's/,/", "/g')
seen = set(existing['items'])
for s in new_skills:
if s not in seen:
existing['items'].append(s)
seen.add(s)
idx.write_text(json.dumps(existing, ensure_ascii=False, indent=2) + '\n')
print(f\"Index updated: {len(existing['items'])} skills\")
"
docker cp "$SKILL_SOURCE/_index/disabled.json" "$container":/root/.beaver/workspace/skills/_index/disabled.json
echo " [done]"
done
echo ""
echo "Done! All skills deployed to all instances."
echo "Containers: ${DOCKER_NAMES[*]}"
echo "Skills: ${SKILLS[*]}"