@optima-chat/optima-agent 0.8.0 → 0.8.2
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.
- package/.claude/settings.local.json +4 -1
- package/.claude/skills/instagram/SKILL.md +26 -0
- package/.claude/skills/merchant/SKILL.md +1 -0
- package/.claude/skills/order/SKILL.md +19 -15
- package/.claude/skills/scout/SKILL.md +22 -0
- package/.claude/skills/shipping/SKILL.md +3 -6
- package/.claude/skills/tiktok/SKILL.md +29 -0
- package/dist/src/system-prompt.d.ts.map +1 -1
- package/dist/src/system-prompt.js +18 -0
- package/dist/src/system-prompt.js.map +1 -1
- package/package.json +1 -1
|
@@ -110,7 +110,10 @@
|
|
|
110
110
|
"Bash(scout:*)",
|
|
111
111
|
"WebFetch(domain:docs.scrapecreators.com)",
|
|
112
112
|
"WebFetch(domain:scrapecreators.com)",
|
|
113
|
-
"Bash(gh auth status:*)"
|
|
113
|
+
"Bash(gh auth status:*)",
|
|
114
|
+
"Bash(optima-agent:*)",
|
|
115
|
+
"Bash(python3:*)",
|
|
116
|
+
"Bash(python3 -c \" import sys content = sys.stdin.read\\(\\) # Find flushMessageQueueSync idx = content.find\\(''flushMessageQueueSync''\\) # Get context around it lines = content.split\\(''\\\\n''\\) for i, line in enumerate\\(lines\\): if ''flushMessageQueueSync'' in line and ''private'' in line: for j in range\\(i, min\\(i+20, len\\(lines\\)\\)\\): print\\(f''{j+1}: {lines[j]}''\\) break \")"
|
|
114
117
|
],
|
|
115
118
|
"deny": [],
|
|
116
119
|
"ask": []
|
|
@@ -13,6 +13,32 @@ description: Instagram influencer marketing and content research. Use when user
|
|
|
13
13
|
- "搜索瑜伽相关的Reels" → `scout instagram reels "yoga" --limit 30`
|
|
14
14
|
- "这个Reel为什么火" + URL → `scout instagram reel-insights <url>`
|
|
15
15
|
- "看看XX发了什么内容" → `scout instagram creator-reels @username`
|
|
16
|
+
- 用户发 Instagram Reel/帖子链接 → `scout instagram reel-insights "<url>"`
|
|
17
|
+
- 用户发 Instagram 个人主页链接 → 提取 username → `scout instagram profile @username`
|
|
18
|
+
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
## URL 解析 - Instagram 链接处理
|
|
22
|
+
|
|
23
|
+
用户经常直接贴 Instagram 链接。**不要用 WebFetch**(需要登录),按以下规则解析:
|
|
24
|
+
|
|
25
|
+
| URL 特征 | 处理方式 | 调用命令 |
|
|
26
|
+
|----------|---------|---------|
|
|
27
|
+
| `instagram.com/reel/XXXX` | 完整 URL | `scout instagram reel-insights "<url>"` |
|
|
28
|
+
| `instagram.com/p/XXXX` | 完整 URL | `scout instagram reel-insights "<url>"` |
|
|
29
|
+
| `instagram.com/reels/XXXX` | 完整 URL | `scout instagram reel-insights "<url>"` |
|
|
30
|
+
| `instagram.com/username` (无 /reel/ /p/) | 提取 username | `scout instagram profile @username` |
|
|
31
|
+
|
|
32
|
+
**示例**:
|
|
33
|
+
```bash
|
|
34
|
+
# Reel / Post 链接 → 直接传入
|
|
35
|
+
scout instagram reel-insights "https://www.instagram.com/reel/ABC123DEF/"
|
|
36
|
+
|
|
37
|
+
# 个人主页 → 提取 username
|
|
38
|
+
scout instagram profile @beautyguru
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
---
|
|
16
42
|
|
|
17
43
|
### 场景决策表
|
|
18
44
|
|
|
@@ -12,7 +12,8 @@ description: Order fulfillment and shipping management. Process orders, ship pac
|
|
|
12
12
|
当用户说:
|
|
13
13
|
- "查看待发货订单" → `commerce order list --status paid`
|
|
14
14
|
- "订单XX发货" → 先查订单详情,根据 shipping_mode_used 决定发货方式(见下方流程)
|
|
15
|
-
- "查询订单物流" / "
|
|
15
|
+
- "查询订单物流" / "包裹到哪了" → `commerce order tracking --id XX`
|
|
16
|
+
- "运单标签好了吗" / "查标签" → `commerce order refresh-label --id XX`
|
|
16
17
|
- "取消订单XX" → `commerce order cancel --id XX --yes`
|
|
17
18
|
- "标记订单已送达" → `commerce order mark-delivered --id XX`
|
|
18
19
|
- "处理退款" → `commerce refund create --order-id XX --amount YY`
|
|
@@ -32,7 +33,7 @@ description: Order fulfillment and shipping management. Process orders, ship pac
|
|
|
32
33
|
2. **验证订单** - 检查库存、地址、特殊要求
|
|
33
34
|
3. **批量打包** - 准备商品、包装材料、打印面单
|
|
34
35
|
4. **标记发货** - 循环 `commerce order ship --id XX --tracking YY --carrier ZZ`
|
|
35
|
-
5. **物流跟踪** - 定期 `commerce order tracking`
|
|
36
|
+
5. **物流跟踪** - 定期 `commerce order tracking` 监控异常
|
|
36
37
|
6. **确认送达** - 签收后 `commerce order mark-delivered --id XX`
|
|
37
38
|
|
|
38
39
|
### 发货流程详解(重要)
|
|
@@ -101,9 +102,12 @@ commerce order ship --id <order-id> --easyship --courier-id <courier-id>
|
|
|
101
102
|
| `failed` / `technical_failed` | 生成失败 | 告知用户需要检查 EasyShip 后台或重新发货 |
|
|
102
103
|
|
|
103
104
|
**查询标签状态**:
|
|
105
|
+
|
|
106
|
+
如果发货时 label_state 为 pending/generating,稍后使用 `order refresh-label` 从 Easyship 同步最新状态:
|
|
104
107
|
```bash
|
|
105
|
-
commerce order
|
|
108
|
+
commerce order refresh-label --id <order-id>
|
|
106
109
|
```
|
|
110
|
+
返回最新的 `label_state` 和 `label_url`(如已生成)。
|
|
107
111
|
|
|
108
112
|
**查看可用快递**:
|
|
109
113
|
```bash
|
|
@@ -182,10 +186,16 @@ AskUserQuestion:
|
|
|
182
186
|
发货成功!运单号 ES123456789,快递公司 FedEx。
|
|
183
187
|
运单标签正在生成中,稍后可以让我帮你查询。
|
|
184
188
|
|
|
185
|
-
|
|
189
|
+
用户:标签好了吗
|
|
190
|
+
|
|
191
|
+
助手:[执行 Bash: commerce order refresh-label --id order_abc]
|
|
192
|
+
[检查返回结果中的 label_state 和 label_url]
|
|
186
193
|
|
|
187
|
-
|
|
194
|
+
[情况A:label_state = "generated",有 label_url]
|
|
188
195
|
运单标签已生成,请下载打印后贴在包裹上:https://...
|
|
196
|
+
|
|
197
|
+
[情况B:label_state 仍为 "pending" 或 "generating"]
|
|
198
|
+
运单标签仍在生成中,请稍后再试。
|
|
189
199
|
```
|
|
190
200
|
|
|
191
201
|
**场景2:固定运费订单**
|
|
@@ -282,7 +292,9 @@ commerce order ship --id order_789 --tracking DHL123458 --carrier DHL
|
|
|
282
292
|
- `commerce order list` - 查看订单列表
|
|
283
293
|
- `commerce order get` - 查看订单详情
|
|
284
294
|
- `commerce order ship` - 标记订单发货
|
|
285
|
-
- `commerce order tracking` -
|
|
295
|
+
- `commerce order tracking` - 查询物流跟踪(含轨迹、预计送达)
|
|
296
|
+
- `commerce order refresh-label` - 刷新 Easyship 运单标签状态
|
|
297
|
+
- `commerce order update-shipping-status` - 更新物流状态
|
|
286
298
|
- `commerce order cancel` - 取消订单
|
|
287
299
|
- `commerce order complete` - 完成订单
|
|
288
300
|
- `commerce order mark-delivered` - 标记已送达
|
|
@@ -294,15 +306,9 @@ commerce order ship --id order_789 --tracking DHL123458 --carrier DHL
|
|
|
294
306
|
- `commerce refund approve` - 批准退款
|
|
295
307
|
- `commerce refund reject` - 拒绝退款
|
|
296
308
|
|
|
297
|
-
### 物流状态
|
|
298
|
-
- `commerce order tracking` - 查询物流跟踪和标签状态
|
|
299
|
-
- `commerce order update-shipping-status` - 更新物流状态
|
|
300
|
-
- `commerce easyship track` - 查询 Easyship 详细物流轨迹
|
|
301
|
-
|
|
302
309
|
### Easyship 集成
|
|
303
310
|
- `commerce easyship couriers` - 查看可用快递公司
|
|
304
311
|
- `commerce easyship rates --order-id <id>` - 获取订单运费报价
|
|
305
|
-
- `commerce easyship track --order-id <id>` - 跟踪 Easyship 运单
|
|
306
312
|
|
|
307
313
|
## 详细示例
|
|
308
314
|
|
|
@@ -358,10 +364,8 @@ commerce refund approve --id refund_456
|
|
|
358
364
|
### 物流追踪
|
|
359
365
|
```bash
|
|
360
366
|
# 用户说:"查询订单order_123的物流信息"
|
|
367
|
+
# 返回物流轨迹(checkpoints)、预计送达时间、当前状态
|
|
361
368
|
commerce order tracking --id order_123
|
|
362
|
-
|
|
363
|
-
# 或查询 Easyship 详细轨迹
|
|
364
|
-
commerce easyship track --order-id order_123
|
|
365
369
|
```
|
|
366
370
|
|
|
367
371
|
## 重要提示
|
|
@@ -17,6 +17,7 @@ Use this skill when:
|
|
|
17
17
|
- User wants to source products from 1688/Alibaba China
|
|
18
18
|
- User asks about wholesale prices, bulk purchasing costs, or profit margins (e.g., "成本多少", "批发价", "利润空间")
|
|
19
19
|
- User wants to find suppliers by product image (e.g., "这个图片能找到货源吗", "帮我找同款", "看图找货", "Amazon这个能在1688找到吗")
|
|
20
|
+
- User shares an Amazon product link (e.g., amazon.com/dp/XXXX, amzn.to/XXXX)
|
|
20
21
|
|
|
21
22
|
## Interaction Style: Conversational → Report
|
|
22
23
|
|
|
@@ -36,6 +37,27 @@ Use this skill when:
|
|
|
36
37
|
- User explicitly requests: "给我一份XX市场分析报告"
|
|
37
38
|
- In this case, skip conversation and generate report directly
|
|
38
39
|
|
|
40
|
+
## URL 解析 - Amazon 链接处理
|
|
41
|
+
|
|
42
|
+
用户贴 Amazon 链接时,**不要用 WebFetch**(会被反爬拦截),提取 ASIN 后用 `scout product`:
|
|
43
|
+
|
|
44
|
+
| URL 格式 | ASIN 位置 |
|
|
45
|
+
|----------|----------|
|
|
46
|
+
| `amazon.com/dp/XXXXXXXXXX` | `/dp/` 后 10 位 |
|
|
47
|
+
| `amazon.com/gp/product/XXXXXXXXXX` | `/gp/product/` 后 10 位 |
|
|
48
|
+
| `amzn.to/XXXX` (短链) | 用 `curl -sI "https://amzn.to/XXXX"` 从 Location header 获取完整 URL → 提取 ASIN |
|
|
49
|
+
|
|
50
|
+
```bash
|
|
51
|
+
# 1. 提取 ASIN → 获取产品详情
|
|
52
|
+
scout product B08BHXG144
|
|
53
|
+
|
|
54
|
+
# 2. 如果用户想了解市场竞争
|
|
55
|
+
scout search "产品关键词" --limit 15
|
|
56
|
+
|
|
57
|
+
# 3. 如果用户想找供应商
|
|
58
|
+
scout supplier-search "中文关键词"
|
|
59
|
+
```
|
|
60
|
+
|
|
39
61
|
## Quick Start - First Step
|
|
40
62
|
|
|
41
63
|
When user asks about product opportunities or market research:
|
|
@@ -129,7 +129,7 @@ commerce shipping-zone delete --id <区域ID> --yes
|
|
|
129
129
|
|
|
130
130
|
## Easyship 集成
|
|
131
131
|
|
|
132
|
-
Easyship
|
|
132
|
+
Easyship 提供实时国际运费报价。
|
|
133
133
|
|
|
134
134
|
### 查看可用快递
|
|
135
135
|
```bash
|
|
@@ -162,10 +162,8 @@ commerce easyship validate-address \
|
|
|
162
162
|
```
|
|
163
163
|
|
|
164
164
|
### 物流追踪
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
commerce easyship track --order-id <订单ID>
|
|
168
|
-
```
|
|
165
|
+
|
|
166
|
+
物流追踪功能已统一到 `commerce order tracking` 命令(见 order skill)。
|
|
169
167
|
|
|
170
168
|
---
|
|
171
169
|
|
|
@@ -192,7 +190,6 @@ commerce easyship track --order-id <订单ID>
|
|
|
192
190
|
- `commerce easyship get-origin` - 查看发货地址
|
|
193
191
|
- `commerce easyship validate-origin` - 验证发货地址
|
|
194
192
|
- `commerce easyship validate-address` - 验证买家地址
|
|
195
|
-
- `commerce easyship track` - 物流追踪
|
|
196
193
|
|
|
197
194
|
**更新发货地址**用 `commerce merchant update --origin-*`(见 merchant skill)
|
|
198
195
|
|
|
@@ -70,6 +70,35 @@ scout tiktok trending --region UK --time-period 7d --limit 20
|
|
|
70
70
|
- "这个视频数据怎么样" + URL → `scout tiktok video-insights <url>`
|
|
71
71
|
- "TikTok热门话题" → `scout tiktok hashtags`
|
|
72
72
|
- "看看XX网红推广什么产品" → `scout tiktok creator-products @username`
|
|
73
|
+
- 用户发 TikTok Shop 产品链接 → 提取 productId → `scout tiktok shop-product <productId>`
|
|
74
|
+
- 用户发 TikTok 视频链接 → `scout tiktok video-insights "<url>"`
|
|
75
|
+
- 用户发 TikTok 达人主页链接 → 提取 username → `scout tiktok creator-products @username`
|
|
76
|
+
|
|
77
|
+
---
|
|
78
|
+
|
|
79
|
+
## URL 解析 - TikTok 链接处理
|
|
80
|
+
|
|
81
|
+
用户经常直接贴 TikTok 链接。**不要用 WebFetch**(会被登录墙拦截),按以下规则解析:
|
|
82
|
+
|
|
83
|
+
| URL 特征 | 提取内容 | 调用命令 |
|
|
84
|
+
|----------|---------|---------|
|
|
85
|
+
| 含 `/product/` 或 `productId=` | productId (数字) | `scout tiktok shop-product <productId>` |
|
|
86
|
+
| 含 `/@user/video/` | 完整 URL | `scout tiktok video-insights "<url>"` |
|
|
87
|
+
| `vm.tiktok.com/XXXX` 或 `tiktok.com/t/XXXX` | 完整 URL | `scout tiktok video-insights "<url>"` |
|
|
88
|
+
| `tiktok.com/@username` (无 /video/) | username | `scout tiktok creator-products @username` |
|
|
89
|
+
|
|
90
|
+
**示例**:
|
|
91
|
+
```bash
|
|
92
|
+
# 产品链接 → 提取 productId
|
|
93
|
+
# https://www.tiktok.com/view/product/1729991116834247323
|
|
94
|
+
scout tiktok shop-product 1729991116834247323
|
|
95
|
+
|
|
96
|
+
# 视频链接 → 直接传入(支持各种格式,API 自动解析)
|
|
97
|
+
scout tiktok video-insights "https://www.tiktok.com/@user/video/7456789012345"
|
|
98
|
+
|
|
99
|
+
# 达人主页 → 提取 username
|
|
100
|
+
scout tiktok creator-products @username --sort popular --limit 30
|
|
101
|
+
```
|
|
73
102
|
|
|
74
103
|
---
|
|
75
104
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"system-prompt.d.ts","sourceRoot":"","sources":["../../src/system-prompt.ts"],"names":[],"mappings":"AAAA,wBAAgB,eAAe,IAAI,MAAM,
|
|
1
|
+
{"version":3,"file":"system-prompt.d.ts","sourceRoot":"","sources":["../../src/system-prompt.ts"],"names":[],"mappings":"AAAA,wBAAgB,eAAe,IAAI,MAAM,CA+HxC"}
|
|
@@ -58,6 +58,24 @@ export function getSystemPrompt() {
|
|
|
58
58
|
4. **提供上下文** - 执行结果后给出简要说明和后续建议
|
|
59
59
|
5. **错误时诊断** - 遇到错误时分析原因并给出解决方案
|
|
60
60
|
|
|
61
|
+
## 链接处理规则
|
|
62
|
+
|
|
63
|
+
当用户发送电商平台链接时,**不要用 WebFetch 访问**(会被反爬拦截),提取标识符后调用对应的 scout CLI 命令:
|
|
64
|
+
|
|
65
|
+
| URL 特征 | 提取内容 | 调用命令 |
|
|
66
|
+
|----------|---------|---------|
|
|
67
|
+
| \`amazon.com/dp/XXXX\` 或 \`/gp/product/XXXX\` | ASIN (10位字母数字) | \`scout product <ASIN>\` |
|
|
68
|
+
| \`amzn.to/XXXX\` (短链) | 用 \`curl -sI\` 获取重定向 URL → 提取 ASIN | \`scout product <ASIN>\` |
|
|
69
|
+
| \`tiktok.com\` 含 \`/product/XXXX\` | productId (数字) | \`scout tiktok shop-product <productId>\` |
|
|
70
|
+
| \`tiktok.com/@user/video/XXXX\` | 完整 URL | \`scout tiktok video-insights "<url>"\` |
|
|
71
|
+
| \`vm.tiktok.com/XXXX\` 或 \`tiktok.com/t/XXXX\` | 完整 URL | \`scout tiktok video-insights "<url>"\` |
|
|
72
|
+
| \`tiktok.com/@username\` (无 /video/) | username | \`scout tiktok creator-products @username\` |
|
|
73
|
+
| \`instagram.com/reel/XXXX\` 或 \`/p/XXXX\` | 完整 URL | \`scout instagram reel-insights "<url>"\` |
|
|
74
|
+
| \`instagram.com/username\` (无 /reel/ /p/) | username | \`scout instagram profile @username\` |
|
|
75
|
+
| \`1688.com/offer/XXXX\` | 请用户描述产品或从 URL 路径提取关键词 | \`scout supplier-search "关键词"\` |
|
|
76
|
+
|
|
77
|
+
**重要**:这些平台有反爬机制,WebFetch 必然失败。始终使用 scout CLI 获取数据。
|
|
78
|
+
|
|
61
79
|
## 输出风格
|
|
62
80
|
|
|
63
81
|
- 简洁明了,不废话
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"system-prompt.js","sourceRoot":"","sources":["../../src/system-prompt.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,eAAe;IAC7B,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,OAAO,GAAG,GAAG,CAAC,kBAAkB,CAAC,OAAO,EAAE;QAC9C,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,MAAM;QACb,GAAG,EAAE,SAAS;QACd,OAAO,EAAE,MAAM;KAChB,CAAC,CAAC;IACH,MAAM,OAAO,GAAG,GAAG,CAAC,kBAAkB,CAAC,OAAO,EAAE;QAC9C,IAAI,EAAE,SAAS;QACf,MAAM,EAAE,SAAS;KAClB,CAAC,CAAC;IAEH,OAAO;;;;;;;;;aASI,OAAO,IAAI,OAAO
|
|
1
|
+
{"version":3,"file":"system-prompt.js","sourceRoot":"","sources":["../../src/system-prompt.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,eAAe;IAC7B,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,OAAO,GAAG,GAAG,CAAC,kBAAkB,CAAC,OAAO,EAAE;QAC9C,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,MAAM;QACb,GAAG,EAAE,SAAS;QACd,OAAO,EAAE,MAAM;KAChB,CAAC,CAAC;IACH,MAAM,OAAO,GAAG,GAAG,CAAC,kBAAkB,CAAC,OAAO,EAAE;QAC9C,IAAI,EAAE,SAAS;QACf,MAAM,EAAE,SAAS;KAClB,CAAC,CAAC;IAEH,OAAO;;;;;;;;;aASI,OAAO,IAAI,OAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwG9B,CAAC;AACF,CAAC"}
|