foliko 1.0.85 → 1.0.87

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (178) hide show
  1. package/.agent/agents/code-assistant.json +14 -0
  2. package/.agent/agents/email-assistant.json +14 -0
  3. package/.agent/agents/file-assistant.json +15 -0
  4. package/.agent/agents/system-assistant.json +15 -0
  5. package/.agent/agents/web-assistant.json +12 -0
  6. package/.agent/data/ambient/goals.json +50 -0
  7. package/.agent/data/ambient/memories.json +7 -0
  8. package/.agent/data/default.json +21 -311
  9. package/.agent/data/plugins-state.json +162 -174
  10. package/.agent/data/scheduler/tasks.json +1 -0
  11. package/.agent/data/weixin.json +6 -0
  12. package/.agent/mcp_config.json +1 -0
  13. package/.agent/package.json +8 -0
  14. package/.agent/plugins/__pycache__/test_plugin.cpython-312.pyc +0 -0
  15. package/.agent/plugins/daytona/README.md +89 -0
  16. package/.agent/plugins/daytona/index.js +377 -0
  17. package/.agent/plugins/daytona/package.json +12 -0
  18. package/.agent/plugins/marknative/README.md +134 -0
  19. package/.agent/plugins/marknative/index.js +228 -0
  20. package/.agent/plugins/marknative/package.json +12 -0
  21. package/.agent/plugins/marknative/update-readme.js +134 -0
  22. package/.agent/plugins/system-info/index.js +387 -0
  23. package/.agent/plugins/system-info/package.json +4 -0
  24. package/.agent/plugins/system-info/test.js +40 -0
  25. package/.agent/plugins/temp-repo/LICENSE +201 -0
  26. package/.agent/plugins/test_plugin.py +304 -0
  27. package/.agent/plugins.json +14 -5
  28. package/.agent/python-scripts/test_sample.py +24 -0
  29. package/.agent/skills/agent-browser/SKILL.md +311 -0
  30. package/.agent/skills/agent-browser/TEST_PLAN.md +200 -0
  31. package/.agent/skills/sysinfo/SKILL.md +38 -0
  32. package/.agent/skills/sysinfo/system-info.sh +130 -0
  33. package/.agent/skills/workflow/SKILL.md +324 -0
  34. package/.agent/workflows/email-digest.json +50 -0
  35. package/.agent/workflows/file-backup.json +21 -0
  36. package/.agent/workflows/get-ip-notify.json +32 -0
  37. package/.agent/workflows/news-aggregator.json +93 -0
  38. package/.agent/workflows/news-dashboard-v2.json +94 -0
  39. package/.agent/workflows/notification-batch.json +32 -0
  40. package/.claude/settings.local.json +8 -7
  41. package/.env.example +56 -56
  42. package/README.md +441 -441
  43. package/examples/test-chat-debug.js +102 -0
  44. package/examples/test-chat-result.js +76 -0
  45. package/examples/test-chat-stream-diff.js +63 -0
  46. package/examples/test-concurrent-chat.js +60 -0
  47. package/examples/test-long-chat.js +77 -0
  48. package/examples/test-session-chat.js +93 -0
  49. package/package.json +2 -2
  50. package/plugins/ambient-agent/EventWatcher.js +4 -4
  51. package/plugins/extension-executor-plugin.js +44 -1
  52. package/plugins/file-system-plugin.js +44 -5
  53. package/plugins/session-plugin.js +21 -0
  54. package/plugins/weixin-plugin.js +278 -29
  55. package/skills/find-skills/AGENTS.md +162 -162
  56. package/skills/find-skills/SKILL.md +133 -133
  57. package/skills/foliko-dev/SKILL.md +67 -0
  58. package/skills/python-plugin-dev/SKILL.md +238 -238
  59. package/src/core/agent-chat.js +106 -58
  60. package/src/core/agent.js +3 -61
  61. package/src/utils/index.js +1 -1
  62. package/.agent/.shared/ui-ux-pro-max/data/charts.csv +0 -26
  63. package/.agent/.shared/ui-ux-pro-max/data/colors.csv +0 -97
  64. package/.agent/.shared/ui-ux-pro-max/data/icons.csv +0 -101
  65. package/.agent/.shared/ui-ux-pro-max/data/landing.csv +0 -31
  66. package/.agent/.shared/ui-ux-pro-max/data/products.csv +0 -97
  67. package/.agent/.shared/ui-ux-pro-max/data/prompts.csv +0 -24
  68. package/.agent/.shared/ui-ux-pro-max/data/react-performance.csv +0 -45
  69. package/.agent/.shared/ui-ux-pro-max/data/stacks/flutter.csv +0 -53
  70. package/.agent/.shared/ui-ux-pro-max/data/stacks/html-tailwind.csv +0 -56
  71. package/.agent/.shared/ui-ux-pro-max/data/stacks/jetpack-compose.csv +0 -53
  72. package/.agent/.shared/ui-ux-pro-max/data/stacks/nextjs.csv +0 -53
  73. package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxt-ui.csv +0 -51
  74. package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxtjs.csv +0 -59
  75. package/.agent/.shared/ui-ux-pro-max/data/stacks/react-native.csv +0 -52
  76. package/.agent/.shared/ui-ux-pro-max/data/stacks/react.csv +0 -54
  77. package/.agent/.shared/ui-ux-pro-max/data/stacks/shadcn.csv +0 -61
  78. package/.agent/.shared/ui-ux-pro-max/data/stacks/svelte.csv +0 -54
  79. package/.agent/.shared/ui-ux-pro-max/data/stacks/swiftui.csv +0 -51
  80. package/.agent/.shared/ui-ux-pro-max/data/stacks/vue.csv +0 -50
  81. package/.agent/.shared/ui-ux-pro-max/data/styles.csv +0 -59
  82. package/.agent/.shared/ui-ux-pro-max/data/typography.csv +0 -58
  83. package/.agent/.shared/ui-ux-pro-max/data/ui-reasoning.csv +0 -101
  84. package/.agent/.shared/ui-ux-pro-max/data/ux-guidelines.csv +0 -100
  85. package/.agent/.shared/ui-ux-pro-max/data/web-interface.csv +0 -31
  86. package/.agent/.shared/ui-ux-pro-max/scripts/__pycache__/core.cpython-313.pyc +0 -0
  87. package/.agent/.shared/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-313.pyc +0 -0
  88. package/.agent/.shared/ui-ux-pro-max/scripts/core.py +0 -258
  89. package/.agent/.shared/ui-ux-pro-max/scripts/design_system.py +0 -1067
  90. package/.agent/.shared/ui-ux-pro-max/scripts/search.py +0 -106
  91. package/.agent/ARCHITECTURE.md +0 -288
  92. package/.agent/agents/ambient-agent.md +0 -57
  93. package/.agent/agents/debugger.md +0 -55
  94. package/.agent/agents/email-assistant.md +0 -49
  95. package/.agent/agents/file-manager.md +0 -42
  96. package/.agent/agents/python-developer.md +0 -60
  97. package/.agent/agents/scheduler.md +0 -59
  98. package/.agent/agents/web-developer.md +0 -45
  99. package/.agent/data/puppeteer-sessions/undefined.json +0 -6
  100. package/.agent/mcp_config_updated.json +0 -12
  101. package/.agent/rules/GEMINI.md +0 -273
  102. package/.agent/rules/allow-rule.md +0 -77
  103. package/.agent/rules/log-rule.md +0 -83
  104. package/.agent/rules/security-rule.md +0 -93
  105. package/.agent/scripts/auto_preview.py +0 -148
  106. package/.agent/scripts/checklist.py +0 -217
  107. package/.agent/scripts/session_manager.py +0 -120
  108. package/.agent/scripts/verify_all.py +0 -327
  109. package/.agent/skills/api-patterns/SKILL.md +0 -81
  110. package/.agent/skills/api-patterns/api-style.md +0 -42
  111. package/.agent/skills/api-patterns/auth.md +0 -24
  112. package/.agent/skills/api-patterns/documentation.md +0 -26
  113. package/.agent/skills/api-patterns/graphql.md +0 -41
  114. package/.agent/skills/api-patterns/rate-limiting.md +0 -31
  115. package/.agent/skills/api-patterns/response.md +0 -37
  116. package/.agent/skills/api-patterns/rest.md +0 -40
  117. package/.agent/skills/api-patterns/scripts/api_validator.py +0 -211
  118. package/.agent/skills/api-patterns/security-testing.md +0 -122
  119. package/.agent/skills/api-patterns/trpc.md +0 -41
  120. package/.agent/skills/api-patterns/versioning.md +0 -22
  121. package/.agent/skills/app-builder/SKILL.md +0 -75
  122. package/.agent/skills/app-builder/agent-coordination.md +0 -71
  123. package/.agent/skills/app-builder/feature-building.md +0 -53
  124. package/.agent/skills/app-builder/project-detection.md +0 -34
  125. package/.agent/skills/app-builder/scaffolding.md +0 -118
  126. package/.agent/skills/app-builder/tech-stack.md +0 -40
  127. package/.agent/skills/app-builder/templates/SKILL.md +0 -39
  128. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +0 -76
  129. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +0 -92
  130. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +0 -88
  131. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +0 -88
  132. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +0 -83
  133. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +0 -90
  134. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +0 -90
  135. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +0 -122
  136. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +0 -122
  137. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +0 -169
  138. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +0 -134
  139. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +0 -83
  140. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +0 -119
  141. package/.agent/skills/architecture/SKILL.md +0 -55
  142. package/.agent/skills/architecture/context-discovery.md +0 -43
  143. package/.agent/skills/architecture/examples.md +0 -94
  144. package/.agent/skills/architecture/pattern-selection.md +0 -68
  145. package/.agent/skills/architecture/patterns-reference.md +0 -50
  146. package/.agent/skills/architecture/trade-off-analysis.md +0 -77
  147. package/.agent/skills/clean-code/SKILL.md +0 -201
  148. package/.agent/skills/doc.md +0 -177
  149. package/.agent/skills/frontend-design/SKILL.md +0 -418
  150. package/.agent/skills/frontend-design/animation-guide.md +0 -331
  151. package/.agent/skills/frontend-design/color-system.md +0 -311
  152. package/.agent/skills/frontend-design/decision-trees.md +0 -418
  153. package/.agent/skills/frontend-design/motion-graphics.md +0 -306
  154. package/.agent/skills/frontend-design/scripts/accessibility_checker.py +0 -183
  155. package/.agent/skills/frontend-design/scripts/ux_audit.py +0 -722
  156. package/.agent/skills/frontend-design/typography-system.md +0 -345
  157. package/.agent/skills/frontend-design/ux-psychology.md +0 -1116
  158. package/.agent/skills/frontend-design/visual-effects.md +0 -383
  159. package/.agent/skills/i18n-localization/SKILL.md +0 -154
  160. package/.agent/skills/i18n-localization/scripts/i18n_checker.py +0 -241
  161. package/.agent/skills/mcp-builder/SKILL.md +0 -176
  162. package/.agent/skills/web-design-guidelines/SKILL.md +0 -57
  163. package/.agent/workflows/brainstorm.md +0 -113
  164. package/.agent/workflows/create.md +0 -59
  165. package/.agent/workflows/debug.md +0 -103
  166. package/.agent/workflows/deploy.md +0 -176
  167. package/.agent/workflows/enhance.md +0 -63
  168. package/.agent/workflows/orchestrate.md +0 -237
  169. package/.agent/workflows/plan.md +0 -89
  170. package/.agent/workflows/preview.md +0 -81
  171. package/.agent/workflows/simple-test.md +0 -42
  172. package/.agent/workflows/status.md +0 -86
  173. package/.agent/workflows/structured-orchestrate.md +0 -180
  174. package/.agent/workflows/test.md +0 -144
  175. package/.agent/workflows/ui-ux-pro-max.md +0 -296
  176. /package/.agent/plugins/{puppeteer-plugin → temp-repo/puppeteer-plugin}/README.md +0 -0
  177. /package/.agent/plugins/{puppeteer-plugin → temp-repo/puppeteer-plugin}/index.js +0 -0
  178. /package/.agent/plugins/{puppeteer-plugin → temp-repo/puppeteer-plugin}/package.json +0 -0
@@ -1,238 +1,238 @@
1
- ---
2
- name: python-plugin-dev
3
- description: Python 插件开发指南。当用户说"创建 Python 插件"、"用 Python 写插件"时立即调用此 skill。
4
- allowed-tools: Read, Write, Edit, Glob, Grep, Bash
5
- ---
6
-
7
- # Python 插件开发
8
-
9
- ## 概述
10
-
11
- Python 插件允许用 Python 语言开发工具,插件代码运行在 Python 环境中,可以调用所有 Python 库。
12
-
13
- ## 插件存放位置
14
-
15
- `.agent/plugins/*.py`
16
-
17
- ## 插件结构
18
-
19
- ```python
20
- # .agent/plugins/my-plugin.py
21
-
22
- PLUGIN = {
23
- "name": "my-plugin",
24
- "version": "1.0.0",
25
- "description": "我的 Python 插件"
26
- }
27
-
28
- TOOLS = [
29
- {
30
- "name": "hello",
31
- "description": "问候工具",
32
- "params": {"name": "string"}
33
- },
34
- {
35
- "name": "calc",
36
- "description": "计算器工具",
37
- "params": {"a": "number", "b": "number", "op": "string"}
38
- }
39
- ]
40
-
41
- # === 工具实现 ===
42
-
43
- def hello(params):
44
- """问候工具"""
45
- name = params.get("name", "World")
46
- return {"success": True, "result": f"Hello, {name}!"}
47
-
48
- def calc(params):
49
- """计算器工具"""
50
- a = params.get("a", 0)
51
- b = params.get("b", 0)
52
- op = params.get("op", "add")
53
-
54
- if op == "add":
55
- result = a + b
56
- elif op == "sub":
57
- result = a - b
58
- elif op == "mul":
59
- result = a * b
60
- elif op == "div":
61
- if b == 0:
62
- return {"success": False, "error": "Division by zero"}
63
- result = a / b
64
- else:
65
- return {"success": False, "error": f"Unknown operation: {op}"}
66
-
67
- return {"success": True, "result": result}
68
- ```
69
-
70
- **重要**:`tools` 字段定义了插件提供的所有工具。框架会自动:
71
-
72
- 1. 将这些工具注册到 ExtensionExecutor
73
- 2. 附加到系统提示词【Extensions 扩展工具】部分
74
- 3. 可通过 `ext_call` 调用
75
-
76
- ## 工具函数规范
77
-
78
- | 规范 | 说明 |
79
- | ------------ | -------------------- |
80
- | 返回 dict | 必须是 Python 字典 |
81
- | success 字段 | `true` 或 `false` |
82
- | result 字段 | 成功时返回的结果 |
83
- | error 字段 | 失败时返回的错误信息 |
84
-
85
- ## 返回值格式
86
-
87
- ```python
88
- # 成功
89
- {"success": True, "result": "返回值"}
90
-
91
- # 失败
92
- {"success": False, "error": "错误信息"}
93
-
94
- # 返回复杂数据
95
- {"success": True, "result": {"key": "value", "list": [1, 2, 3]}}
96
- ```
97
-
98
- ## 使用方式
99
-
100
- 通过 `ext_call` 调用:
101
-
102
- ```javascript
103
- ext_call({
104
- plugin: 'my-plugin', // 插件名称
105
- tool: 'hello', // 工具名称
106
- args: { name: 'Foliko' }, // 工具参数
107
- });
108
- ```
109
-
110
- 工具会自动出现在系统提示词的【Extensions 扩展工具】部分。
111
-
112
- ## 示例:天气查询插件
113
-
114
- ```python
115
- # .agent/plugins/weather.py
116
-
117
- PLUGIN = {
118
- "name": "weather",
119
- "version": "1.0.0",
120
- "description": "天气查询插件"
121
- }
122
-
123
- TOOLS = [
124
- {
125
- "name": "get_weather",
126
- "description": "查询天气",
127
- "params": {"city": "string"}
128
- }
129
- ]
130
-
131
- def get_weather(params):
132
- import requests
133
-
134
- city = params.get("city", "北京")
135
-
136
- try:
137
- response = requests.get(
138
- f"https://wttr.in/{city}?format=j1",
139
- timeout=5
140
- )
141
- data = response.json()
142
-
143
- return {
144
- "success": True,
145
- "result": {
146
- "city": city,
147
- "temperature": data["current_condition"][0]["temp_C"],
148
- "weather": data["current_condition"][0]["weatherDesc"][0]["value"]
149
- }
150
- }
151
- except Exception as e:
152
- return {"success": False, "error": str(e)}
153
- ```
154
-
155
- ## 示例:文件处理插件
156
-
157
- ```python
158
- # .agent/plugins/file_processor.py
159
-
160
- PLUGIN = {
161
- "name": "file_processor",
162
- "version": "1.0.0",
163
- "description": "文件处理插件"
164
- }
165
-
166
- TOOLS = [
167
- {
168
- "name": "read_file",
169
- "description": "读取文件",
170
- "params": {"path": "string"}
171
- },
172
- {
173
- "name": "write_file",
174
- "description": "写入文件",
175
- "params": {"path": "string", "content": "string"}
176
- }
177
- ]
178
-
179
- def read_file(params):
180
- import os
181
-
182
- filepath = params.get("path")
183
- if not filepath:
184
- return {"success": False, "error": "path is required"}
185
-
186
- try:
187
- with open(filepath, "r", encoding="utf-8") as f:
188
- content = f.read()
189
- return {"success": True, "result": content}
190
- except Exception as e:
191
- return {"success": False, "error": str(e)}
192
-
193
- def write_file(params):
194
- import os
195
-
196
- filepath = params.get("path")
197
- content = params.get("content", "")
198
-
199
- if not filepath:
200
- return {"success": False, "error": "path is required"}
201
-
202
- try:
203
- os.makedirs(os.path.dirname(filepath), exist_ok=True)
204
- with open(filepath, "w", encoding="utf-8") as f:
205
- f.write(content)
206
- return {"success": True, "result": f"Written to {filepath}"}
207
- except Exception as e:
208
- return {"success": False, "error": str(e)}
209
- ```
210
-
211
- ## 注意事项
212
-
213
- 1. **文件格式** - 必须是单个 `.py` 文件
214
- 2. **必须定义 `PLUGIN`** - 插件元信息
215
- 3. **必须定义 `TOOLS`** - 工具列表
216
- 4. **工具函数名** - 必须与 TOOLS 中定义的 name 一致
217
- 5. **异常处理** - 所有可能出错的地方都要 try-except
218
- 6. **编码** - 文件使用 UTF-8 编码
219
-
220
- ## 开发流程
221
-
222
- 1. **编写插件代码** - 在 `.agent/plugins/` 下创建 `.py` 文件
223
- 2. **自动加载** - 框架启动时自动注册工具
224
- 3. **调试** - 查看返回的 `success` 和 `error` 信息
225
-
226
- ## 常用 Python 库
227
-
228
- 插件中可以使用的常用库:
229
-
230
- | 库 | 用途 | 导入方式 |
231
- | -------- | ---------- | ------------------------------- |
232
- | requests | HTTP 请求 | `import requests` |
233
- | json | JSON 处理 | `import json` |
234
- | os | 系统操作 | `import os` |
235
- | pathlib | 路径处理 | `from pathlib import Path` |
236
- | datetime | 日期时间 | `from datetime import datetime` |
237
- | re | 正则表达式 | `import re` |
238
- | csv | CSV 处理 | `import csv` |
1
+ ---
2
+ name: python-plugin-dev
3
+ description: Python 插件开发指南。当用户说"创建 Python 插件"、"用 Python 写插件"时立即调用此 skill。
4
+ allowed-tools: Read, Write, Edit, Glob, Grep, Bash
5
+ ---
6
+
7
+ # Python 插件开发
8
+
9
+ ## 概述
10
+
11
+ Python 插件允许用 Python 语言开发工具,插件代码运行在 Python 环境中,可以调用所有 Python 库。
12
+
13
+ ## 插件存放位置
14
+
15
+ `.agent/plugins/*.py`
16
+
17
+ ## 插件结构
18
+
19
+ ```python
20
+ # .agent/plugins/my-plugin.py
21
+
22
+ PLUGIN = {
23
+ "name": "my-plugin",
24
+ "version": "1.0.0",
25
+ "description": "我的 Python 插件"
26
+ }
27
+
28
+ TOOLS = [
29
+ {
30
+ "name": "hello",
31
+ "description": "问候工具",
32
+ "params": {"name": "string"}
33
+ },
34
+ {
35
+ "name": "calc",
36
+ "description": "计算器工具",
37
+ "params": {"a": "number", "b": "number", "op": "string"}
38
+ }
39
+ ]
40
+
41
+ # === 工具实现 ===
42
+
43
+ def hello(params):
44
+ """问候工具"""
45
+ name = params.get("name", "World")
46
+ return {"success": True, "result": f"Hello, {name}!"}
47
+
48
+ def calc(params):
49
+ """计算器工具"""
50
+ a = params.get("a", 0)
51
+ b = params.get("b", 0)
52
+ op = params.get("op", "add")
53
+
54
+ if op == "add":
55
+ result = a + b
56
+ elif op == "sub":
57
+ result = a - b
58
+ elif op == "mul":
59
+ result = a * b
60
+ elif op == "div":
61
+ if b == 0:
62
+ return {"success": False, "error": "Division by zero"}
63
+ result = a / b
64
+ else:
65
+ return {"success": False, "error": f"Unknown operation: {op}"}
66
+
67
+ return {"success": True, "result": result}
68
+ ```
69
+
70
+ **重要**:`tools` 字段定义了插件提供的所有工具。框架会自动:
71
+
72
+ 1. 将这些工具注册到 ExtensionExecutor
73
+ 2. 附加到系统提示词【Extensions 扩展工具】部分
74
+ 3. 可通过 `ext_call` 调用
75
+
76
+ ## 工具函数规范
77
+
78
+ | 规范 | 说明 |
79
+ | ------------ | -------------------- |
80
+ | 返回 dict | 必须是 Python 字典 |
81
+ | success 字段 | `true` 或 `false` |
82
+ | result 字段 | 成功时返回的结果 |
83
+ | error 字段 | 失败时返回的错误信息 |
84
+
85
+ ## 返回值格式
86
+
87
+ ```python
88
+ # 成功
89
+ {"success": True, "result": "返回值"}
90
+
91
+ # 失败
92
+ {"success": False, "error": "错误信息"}
93
+
94
+ # 返回复杂数据
95
+ {"success": True, "result": {"key": "value", "list": [1, 2, 3]}}
96
+ ```
97
+
98
+ ## 使用方式
99
+
100
+ 通过 `ext_call` 调用:
101
+
102
+ ```javascript
103
+ ext_call({
104
+ plugin: 'my-plugin', // 插件名称
105
+ tool: 'hello', // 工具名称
106
+ args: { name: 'Foliko' }, // 工具参数
107
+ });
108
+ ```
109
+
110
+ 工具会自动出现在系统提示词的【Extensions 扩展工具】部分。
111
+
112
+ ## 示例:天气查询插件
113
+
114
+ ```python
115
+ # .agent/plugins/weather.py
116
+
117
+ PLUGIN = {
118
+ "name": "weather",
119
+ "version": "1.0.0",
120
+ "description": "天气查询插件"
121
+ }
122
+
123
+ TOOLS = [
124
+ {
125
+ "name": "get_weather",
126
+ "description": "查询天气",
127
+ "params": {"city": "string"}
128
+ }
129
+ ]
130
+
131
+ def get_weather(params):
132
+ import requests
133
+
134
+ city = params.get("city", "北京")
135
+
136
+ try:
137
+ response = requests.get(
138
+ f"https://wttr.in/{city}?format=j1",
139
+ timeout=5
140
+ )
141
+ data = response.json()
142
+
143
+ return {
144
+ "success": True,
145
+ "result": {
146
+ "city": city,
147
+ "temperature": data["current_condition"][0]["temp_C"],
148
+ "weather": data["current_condition"][0]["weatherDesc"][0]["value"]
149
+ }
150
+ }
151
+ except Exception as e:
152
+ return {"success": False, "error": str(e)}
153
+ ```
154
+
155
+ ## 示例:文件处理插件
156
+
157
+ ```python
158
+ # .agent/plugins/file_processor.py
159
+
160
+ PLUGIN = {
161
+ "name": "file_processor",
162
+ "version": "1.0.0",
163
+ "description": "文件处理插件"
164
+ }
165
+
166
+ TOOLS = [
167
+ {
168
+ "name": "read_file",
169
+ "description": "读取文件",
170
+ "params": {"path": "string"}
171
+ },
172
+ {
173
+ "name": "write_file",
174
+ "description": "写入文件",
175
+ "params": {"path": "string", "content": "string"}
176
+ }
177
+ ]
178
+
179
+ def read_file(params):
180
+ import os
181
+
182
+ filepath = params.get("path")
183
+ if not filepath:
184
+ return {"success": False, "error": "path is required"}
185
+
186
+ try:
187
+ with open(filepath, "r", encoding="utf-8") as f:
188
+ content = f.read()
189
+ return {"success": True, "result": content}
190
+ except Exception as e:
191
+ return {"success": False, "error": str(e)}
192
+
193
+ def write_file(params):
194
+ import os
195
+
196
+ filepath = params.get("path")
197
+ content = params.get("content", "")
198
+
199
+ if not filepath:
200
+ return {"success": False, "error": "path is required"}
201
+
202
+ try:
203
+ os.makedirs(os.path.dirname(filepath), exist_ok=True)
204
+ with open(filepath, "w", encoding="utf-8") as f:
205
+ f.write(content)
206
+ return {"success": True, "result": f"Written to {filepath}"}
207
+ except Exception as e:
208
+ return {"success": False, "error": str(e)}
209
+ ```
210
+
211
+ ## 注意事项
212
+
213
+ 1. **文件格式** - 必须是单个 `.py` 文件
214
+ 2. **必须定义 `PLUGIN`** - 插件元信息
215
+ 3. **必须定义 `TOOLS`** - 工具列表
216
+ 4. **工具函数名** - 必须与 TOOLS 中定义的 name 一致
217
+ 5. **异常处理** - 所有可能出错的地方都要 try-except
218
+ 6. **编码** - 文件使用 UTF-8 编码
219
+
220
+ ## 开发流程
221
+
222
+ 1. **编写插件代码** - 在 `.agent/plugins/` 下创建 `.py` 文件
223
+ 2. **自动加载** - 框架启动时自动注册工具
224
+ 3. **调试** - 查看返回的 `success` 和 `error` 信息
225
+
226
+ ## 常用 Python 库
227
+
228
+ 插件中可以使用的常用库:
229
+
230
+ | 库 | 用途 | 导入方式 |
231
+ | -------- | ---------- | ------------------------------- |
232
+ | requests | HTTP 请求 | `import requests` |
233
+ | json | JSON 处理 | `import json` |
234
+ | os | 系统操作 | `import os` |
235
+ | pathlib | 路径处理 | `from pathlib import Path` |
236
+ | datetime | 日期时间 | `from datetime import datetime` |
237
+ | re | 正则表达式 | `import re` |
238
+ | csv | CSV 处理 | `import csv` |