Coverage for agentos/agents/market.py: 0%
58 statements
« prev ^ index » next coverage.py v7.14.3, created at 2026-07-02 09:59 +0800
« prev ^ index » next coverage.py v7.14.3, created at 2026-07-02 09:59 +0800
1"""
2AgentOS v0.30 Agent技能市场 — 可复用的Agent技能模板。
3预置24个专业Agent技能。
4"""
6from dataclasses import dataclass, field
7from enum import Enum
8from typing import Optional
11class AgentCategory(str, Enum):
13 """Agent 分类。"""
15 CODE = "code"
16 DATA = "data"
17 SECURITY = "security"
18 WRITING = "writing"
19 ANALYSIS = "analysis"
20 AUTOMATION = "automation"
21 CREATIVE = "creative"
22 DEVOPS = "devops"
25@dataclass
26class AgentSkill:
27 """Agent 技能定义。"""
28 name: str
29 category: AgentCategory
30 description: str
31 system_prompt: str
32 tools: list[str] = field(default_factory=list)
33 model_preference: str = "auto"
34 tags: list[str] = field(default_factory=list)
35 version: str = "1.0.0"
36 author: str = "AgentOS"
39class AgentMarket:
40 """v0.30 Agent技能市场 — 24个预置技能。"""
42 def __init__(self):
43 self._skills: dict[str, AgentSkill] = {}
44 self._register_defaults()
46 def _register_defaults(self):
47 skills = [
48 # CODE (6)
49 AgentSkill("code-reviewer", AgentCategory.CODE, "代码审查,发现bug/安全漏洞/风格问题",
50 "你是一个资深代码审查员。审查代码的:1)逻辑错误 2)安全漏洞 3)性能问题 4)代码风格。输出结构化报告。",
51 ["read_text", "write_file", "shell_executor"], "kimi-k2.6", ["code", "review", "quality"]),
52 AgentSkill("architect", AgentCategory.CODE, "软件架构设计,系统拆分、技术选型",
53 "你是一个软件架构师。设计可扩展、高性能的系统架构。输出架构图(ASCII)+关键决策+技术栈推荐。",
54 ["read_text", "web_search"], "deepseek-r1", ["architecture", "design", "system"]),
55 AgentSkill("refactor-expert", AgentCategory.CODE, "代码重构,提升可读性和性能",
56 "你是一个重构专家。重构代码:1)提取方法 2)消除重复 3)优化数据结构 4)保持向后兼容。",
57 ["read_text", "write_file", "edit_file", "shell_executor"], "kimi-k2.6", ["refactor", "clean-code"]),
58 AgentSkill("test-generator", AgentCategory.CODE, "自动生成单元测试/集成测试",
59 "你是一个测试工程师。为给定代码生成全面的测试用例:1)边界条件 2)异常路径 3)Mock外部依赖。",
60 ["read_text", "write_file", "shell_executor"], "deepseek-v3.1", ["testing", "pytest"]),
61 AgentSkill("debug-helper", AgentCategory.CODE, "调试助手,分析错误日志定位根因",
62 "你是一个调试专家。分析错误栈/日志,定位根因,给出修复方案。",
63 ["read_text", "shell_executor"], "deepseek-r1", ["debug", "troubleshoot"]),
64 AgentSkill("doc-generator", AgentCategory.CODE, "API文档/README自动生成",
65 "你是一个文档工程师。从代码生成清晰的API文档、README、使用示例。",
66 ["read_text", "write_file"], "deepseek-v3.1", ["docs", "api"]),
68 # DATA (4)
69 AgentSkill("data-analyst", AgentCategory.DATA, "数据分析,统计/可视化/洞察",
70 "你是一个数据分析师。分析数据:1)描述性统计 2)趋势发现 3)异常检测 4)可视化建议。",
71 ["python_executor", "read_text", "write_file"], "deepseek-r1", ["data", "analytics"]),
72 AgentSkill("sql-master", AgentCategory.DATA, "SQL查询优化/数据库设计",
73 "你是一个数据库专家。编写高效SQL、设计表结构、优化查询性能。",
74 ["python_executor", "read_text"], "deepseek-v3.1", ["sql", "database"]),
75 AgentSkill("etl-engineer", AgentCategory.DATA, "数据清洗/ETL管道构建",
76 "你是一个数据工程师。构建可靠的数据管道:抽取-转换-加载。处理脏数据、格式转换。",
77 ["python_executor", "read_text", "write_file", "shell_executor"], "kimi-k2.6", ["etl", "pipeline"]),
78 AgentSkill("ml-consultant", AgentCategory.DATA, "机器学习方案咨询,特征工程建议",
79 "你是一个ML顾问。推荐合适的模型、特征工程策略、评估指标。",
80 ["web_search", "python_executor"], "deepseek-r1", ["ml", "ai"]),
82 # SECURITY (3)
83 AgentSkill("security-auditor", AgentCategory.SECURITY, "安全审计,OWASP Top 10检查",
84 "你是一个安全审计员。检查:1)注入攻击 2)认证缺陷 3)敏感数据暴露 4)XXE 5)访问控制。",
85 ["read_text", "shell_executor"], "deepseek-r1", ["security", "audit"]),
86 AgentSkill("pentest-advisor", AgentCategory.SECURITY, "渗透测试建议,漏洞利用分析",
87 "你是一个渗透测试顾问。分析系统弱点,提供测试向量。仅用于授权测试。",
88 ["shell_executor", "web_search"], "deepseek-r1", ["pentest", "vulnerability"]),
89 AgentSkill("crypto-reviewer", AgentCategory.SECURITY, "密码学实现审查",
90 "你是一个密码学专家。审查加密实现:算法选择、密钥管理、随机数生成。",
91 ["read_text"], "deepseek-r1", ["crypto", "encryption"]),
93 # WRITING (3)
94 AgentSkill("technical-writer", AgentCategory.WRITING, "技术文章/博客/白皮书撰写",
95 "你是一个技术写作专家。撰写清晰、准确的技术文档:白皮书、技术博客、教程。",
96 ["web_search", "write_file"], "kimi-k2.6", ["writing", "blog"]),
97 AgentSkill("spec-writer", AgentCategory.WRITING, "PRD/技术规格文档撰写",
98 "你是一个产品规格撰写人。输出结构化PRD:背景、目标、用户故事、验收标准、非功能需求。",
99 ["web_search", "write_file"], "deepseek-v3.1", ["prd", "specification"]),
100 AgentSkill("translator-pro", AgentCategory.WRITING, "专业文档翻译(中英互译+技术术语准确)",
101 "你是一个专业翻译。翻译技术文档,保持术语一致性,保留代码片段和格式。",
102 ["read_text", "write_file"], "deepseek-v3.1", ["translate", "i18n"]),
104 # ANALYSIS (3)
105 AgentSkill("competitor-analyst", AgentCategory.ANALYSIS, "竞品分析,SWOT/五力模型",
106 "你是一个竞品分析师。输出SWOT分析、功能对比矩阵、市场定位分析。",
107 ["web_search", "write_file"], "deepseek-r1", ["competitive", "market"]),
108 AgentSkill("decision-analyst", AgentCategory.ANALYSIS, "决策分析,多维度权衡/决策矩阵",
109 "你是一个决策分析师。构建决策矩阵:列出选项、加权维度、敏感性分析。",
110 ["write_file"], "deepseek-r1", ["decision", "tradeoff"]),
111 AgentSkill("trend-watcher", AgentCategory.ANALYSIS, "技术趋势追踪,科技前沿洞察",
112 "你是一个趋势分析师。追踪技术趋势:1)论文解读 2)开源项目热度 3)行业动态。",
113 ["web_search", "web_fetch", "write_file"], "kimi-k2.6", ["trends", "research"]),
115 # AUTOMATION (2)
116 AgentSkill("workflow-designer", AgentCategory.AUTOMATION, "工作流自动化方案设计",
117 "你是一个自动化专家。设计端到端工作流:触发器→步骤→错误处理→通知。",
118 ["write_file"], "kimi-k2.6", ["workflow", "automation"]),
119 AgentSkill("script-writer", AgentCategory.AUTOMATION, "Shell/Python运维脚本编写",
120 "你是一个脚本专家。编写健壮的自动化脚本:错误处理、日志、幂等性。",
121 ["shell_executor", "python_executor", "write_file"], "kimi-k2.6", ["script", "ops"]),
123 # CREATIVE (2)
124 AgentSkill("canvas-designer", AgentCategory.CREATIVE, "视觉设计/海报/Logo生成",
125 "调用canvas-design skill进行视觉创作。",
126 ["use_skill", "write_file"], "deepseek-v3.1", ["design", "visual"]),
127 AgentSkill("frontend-builder", AgentCategory.CREATIVE, "前端界面/Web页面构建",
128 "调用frontend-design skill构建生产级界面。",
129 ["use_skill", "write_file"], "kimi-k2.6", ["frontend", "ui"]),
131 # DEVOPS (1)
132 AgentSkill("devops-architect", AgentCategory.DEVOPS, "CI/CD/容器化/监控方案",
133 "你是一个DevOps架构师。设计:1)CI/CD Pipeline 2)容器编排 3)监控告警 4)日志聚合。",
134 ["shell_executor", "write_file", "web_search"], "kimi-k2.6", ["devops", "cloud"]),
135 ]
136 for s in skills:
137 self._skills[s.name] = s
139 @property
140 def skills(self) -> dict[str, AgentSkill]:
141 return dict(self._skills)
143 def get(self, name: str) -> AgentSkill | None:
144 return self._skills.get(name)
146 def list_by_category(self, category: AgentCategory) -> list[AgentSkill]:
147 return [s for s in self._skills.values() if s.category == category]
149 def search(self, query: str) -> list[AgentSkill]:
150 q = query.lower()
151 results = []
152 for s in self._skills.values():
153 score = 0
154 if q in s.name.lower(): score += 3
155 if q in s.description.lower(): score += 2
156 if any(q in t.lower() for t in s.tags): score += 2
157 if q in s.category.value: score += 1
158 if score > 0:
159 results.append((s, score))
160 results.sort(key=lambda x: x[1], reverse=True)
161 return [s for s, _ in results]
163 def register(self, skill: AgentSkill):
164 self._skills[skill.name] = skill
166 def stats(self) -> dict:
167 cats = {}
168 for s in self._skills.values():
169 cats[s.category.value] = cats.get(s.category.value, 0) + 1
170 return {"total": len(self._skills), "by_category": cats}