@jackwener/opencli 1.6.1 → 1.6.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.
Files changed (384) hide show
  1. package/CONTRIBUTING.md +1 -1
  2. package/README.md +27 -45
  3. package/README.zh-CN.md +32 -34
  4. package/autoresearch/browse-tasks.json +18 -20
  5. package/autoresearch/commands/debug.ts +163 -0
  6. package/autoresearch/commands/fix.ts +145 -0
  7. package/autoresearch/commands/plan.ts +88 -0
  8. package/autoresearch/commands/run.ts +138 -0
  9. package/autoresearch/config.ts +82 -0
  10. package/autoresearch/engine.ts +359 -0
  11. package/autoresearch/eval-all.ts +127 -0
  12. package/autoresearch/eval-browse.ts +1 -1
  13. package/autoresearch/eval-publish.ts +238 -0
  14. package/autoresearch/eval-save.ts +249 -0
  15. package/autoresearch/eval-skill.ts +14 -8
  16. package/autoresearch/eval-v2ex.ts +220 -0
  17. package/autoresearch/eval-zhihu.ts +230 -0
  18. package/autoresearch/logger.ts +69 -0
  19. package/autoresearch/presets/combined-reliability.ts +27 -0
  20. package/autoresearch/presets/index.ts +23 -0
  21. package/autoresearch/presets/operate-reliability.ts +24 -0
  22. package/autoresearch/presets/save-reliability.ts +26 -0
  23. package/autoresearch/presets/skill-quality.ts +20 -0
  24. package/autoresearch/presets/v2ex-reliability.ts +24 -0
  25. package/autoresearch/presets/zhihu-reliability.ts +25 -0
  26. package/autoresearch/publish-tasks.json +345 -0
  27. package/autoresearch/run-save.sh +11 -0
  28. package/autoresearch/save-adapters/xhs-explore-deep.ts +64 -0
  29. package/autoresearch/save-adapters/xhs-note-comments.ts +61 -0
  30. package/autoresearch/save-adapters/xhs-search-full.ts +62 -0
  31. package/autoresearch/save-adapters/zhihu-hot-detail.ts +52 -0
  32. package/autoresearch/save-adapters/zhihu-question-full.ts +57 -0
  33. package/autoresearch/save-adapters/zhihu-search-detail.ts +53 -0
  34. package/autoresearch/save-tasks.json +281 -0
  35. package/autoresearch/v2ex-tasks.json +899 -0
  36. package/autoresearch/zhihu-tasks.json +848 -0
  37. package/dist/browser/base-page.d.ts +4 -2
  38. package/dist/browser/base-page.js +37 -4
  39. package/dist/browser/bridge.js +10 -8
  40. package/dist/browser/cdp.js +2 -6
  41. package/dist/browser/daemon-client.d.ts +11 -1
  42. package/dist/browser/daemon-client.js +3 -0
  43. package/dist/browser/dom-helpers.d.ts +4 -2
  44. package/dist/browser/dom-helpers.js +42 -31
  45. package/dist/browser/dom-snapshot.js +23 -1
  46. package/dist/browser/page.d.ts +7 -2
  47. package/dist/browser/page.js +112 -30
  48. package/dist/browser.test.js +1 -1
  49. package/dist/build-manifest.d.ts +1 -0
  50. package/dist/build-manifest.js +1 -0
  51. package/dist/cli-manifest.json +1135 -184
  52. package/dist/cli.d.ts +2 -0
  53. package/dist/cli.js +48 -7
  54. package/dist/cli.test.d.ts +1 -0
  55. package/dist/cli.test.js +88 -0
  56. package/dist/clis/1688/item.d.ts +70 -0
  57. package/dist/clis/1688/item.js +187 -0
  58. package/dist/clis/1688/item.test.d.ts +1 -0
  59. package/dist/clis/1688/item.test.js +67 -0
  60. package/dist/clis/1688/search.d.ts +56 -0
  61. package/dist/clis/1688/search.js +309 -0
  62. package/dist/clis/1688/search.test.d.ts +1 -0
  63. package/dist/clis/1688/search.test.js +75 -0
  64. package/dist/clis/1688/shared.d.ts +112 -0
  65. package/dist/clis/1688/shared.js +514 -0
  66. package/dist/clis/1688/shared.test.d.ts +1 -0
  67. package/dist/clis/1688/shared.test.js +57 -0
  68. package/dist/clis/1688/store.d.ts +45 -0
  69. package/dist/clis/1688/store.js +226 -0
  70. package/dist/clis/1688/store.test.d.ts +1 -0
  71. package/dist/clis/1688/store.test.js +62 -0
  72. package/dist/clis/amazon/bestsellers.d.ts +0 -20
  73. package/dist/clis/amazon/bestsellers.js +6 -129
  74. package/dist/clis/amazon/bestsellers.test.js +12 -3
  75. package/dist/clis/amazon/movers-shakers.d.ts +1 -0
  76. package/dist/clis/amazon/movers-shakers.js +7 -0
  77. package/dist/clis/amazon/new-releases.d.ts +1 -0
  78. package/dist/clis/amazon/new-releases.js +7 -0
  79. package/dist/clis/amazon/rankings.d.ts +59 -0
  80. package/dist/clis/amazon/rankings.js +226 -0
  81. package/dist/clis/amazon/rankings.test.d.ts +1 -0
  82. package/dist/clis/amazon/rankings.test.js +41 -0
  83. package/dist/clis/amazon/shared.d.ts +11 -0
  84. package/dist/clis/amazon/shared.js +121 -11
  85. package/dist/clis/amazon/shared.test.js +11 -0
  86. package/dist/clis/bilibili/comments.js +2 -2
  87. package/dist/clis/bilibili/comments.test.js +3 -2
  88. package/dist/clis/bilibili/download.js +2 -1
  89. package/dist/clis/bilibili/subtitle.js +4 -3
  90. package/dist/clis/bilibili/subtitle.test.js +2 -1
  91. package/dist/clis/bilibili/utils.d.ts +5 -0
  92. package/dist/clis/bilibili/utils.js +30 -0
  93. package/dist/clis/bilibili/utils.test.d.ts +1 -0
  94. package/dist/clis/bilibili/utils.test.js +17 -0
  95. package/dist/clis/douban/marks.js +1 -1
  96. package/dist/clis/douban/subject.yaml +50 -19
  97. package/dist/clis/doubao/utils.js +32 -12
  98. package/dist/clis/douyin/_shared/browser-fetch.test.js +0 -1
  99. package/dist/clis/douyin/_shared/transcode.test.js +0 -2
  100. package/dist/clis/douyin/draft.test.js +0 -2
  101. package/dist/clis/facebook/search.test.js +0 -2
  102. package/dist/clis/gemini/ask.js +9 -3
  103. package/dist/clis/gemini/ask.test.d.ts +1 -0
  104. package/dist/clis/gemini/ask.test.js +100 -0
  105. package/dist/clis/gemini/reply-state.test.d.ts +1 -0
  106. package/dist/clis/gemini/reply-state.test.js +641 -0
  107. package/dist/clis/gemini/utils.d.ts +44 -1
  108. package/dist/clis/gemini/utils.js +528 -61
  109. package/dist/clis/gemini/utils.test.js +149 -2
  110. package/dist/clis/hupu/detail.d.ts +1 -0
  111. package/dist/clis/hupu/detail.js +72 -0
  112. package/dist/clis/hupu/hot.yaml +43 -0
  113. package/dist/clis/hupu/like.d.ts +1 -0
  114. package/dist/clis/hupu/like.js +75 -0
  115. package/dist/clis/hupu/reply.d.ts +1 -0
  116. package/dist/clis/hupu/reply.js +71 -0
  117. package/dist/clis/hupu/search.d.ts +1 -0
  118. package/dist/clis/hupu/search.js +59 -0
  119. package/dist/clis/hupu/unlike.d.ts +1 -0
  120. package/dist/clis/hupu/unlike.js +75 -0
  121. package/dist/clis/hupu/utils.d.ts +20 -0
  122. package/dist/clis/hupu/utils.js +319 -0
  123. package/dist/clis/instagram/_shared/private-publish.d.ts +138 -0
  124. package/dist/clis/instagram/_shared/private-publish.js +1030 -0
  125. package/dist/clis/instagram/_shared/private-publish.test.d.ts +1 -0
  126. package/dist/clis/instagram/_shared/private-publish.test.js +705 -0
  127. package/dist/clis/instagram/_shared/protocol-capture.d.ts +26 -0
  128. package/dist/clis/instagram/_shared/protocol-capture.js +282 -0
  129. package/dist/clis/instagram/_shared/protocol-capture.test.d.ts +1 -0
  130. package/dist/clis/instagram/_shared/protocol-capture.test.js +114 -0
  131. package/dist/clis/instagram/_shared/runtime-info.d.ts +9 -0
  132. package/dist/clis/instagram/_shared/runtime-info.js +81 -0
  133. package/dist/clis/instagram/note.d.ts +1 -0
  134. package/dist/clis/instagram/note.js +222 -0
  135. package/dist/clis/instagram/note.test.d.ts +1 -0
  136. package/dist/clis/instagram/note.test.js +81 -0
  137. package/dist/clis/instagram/post.d.ts +4 -0
  138. package/dist/clis/instagram/post.js +1496 -0
  139. package/dist/clis/instagram/post.test.d.ts +1 -0
  140. package/dist/clis/instagram/post.test.js +1647 -0
  141. package/dist/clis/instagram/reel.d.ts +1 -0
  142. package/dist/clis/instagram/reel.js +826 -0
  143. package/dist/clis/instagram/reel.test.d.ts +1 -0
  144. package/dist/clis/instagram/reel.test.js +167 -0
  145. package/dist/clis/instagram/story.d.ts +1 -0
  146. package/dist/clis/instagram/story.js +115 -0
  147. package/dist/clis/instagram/story.test.d.ts +1 -0
  148. package/dist/clis/instagram/story.test.js +167 -0
  149. package/dist/clis/sinafinance/stock-rank.d.ts +4 -0
  150. package/dist/clis/sinafinance/stock-rank.js +65 -0
  151. package/dist/clis/substack/utils.test.js +0 -2
  152. package/dist/clis/twitter/post.js +72 -45
  153. package/dist/clis/twitter/post.test.d.ts +1 -0
  154. package/dist/clis/twitter/post.test.js +116 -0
  155. package/dist/clis/twitter/reply.d.ts +12 -0
  156. package/dist/clis/twitter/reply.js +257 -35
  157. package/dist/clis/twitter/reply.test.d.ts +1 -0
  158. package/dist/clis/twitter/reply.test.js +151 -0
  159. package/dist/clis/xianyu/chat.d.ts +7 -0
  160. package/dist/clis/xianyu/chat.js +146 -0
  161. package/dist/clis/xianyu/chat.test.d.ts +1 -0
  162. package/dist/clis/xianyu/chat.test.js +15 -0
  163. package/dist/clis/xianyu/item.d.ts +7 -0
  164. package/dist/clis/xianyu/item.js +152 -0
  165. package/dist/clis/xianyu/item.test.d.ts +1 -0
  166. package/dist/clis/xianyu/item.test.js +56 -0
  167. package/dist/clis/xianyu/search.d.ts +10 -0
  168. package/dist/clis/xianyu/search.js +134 -0
  169. package/dist/clis/xianyu/search.test.d.ts +1 -0
  170. package/dist/clis/xianyu/search.test.js +17 -0
  171. package/dist/clis/xianyu/utils.d.ts +1 -0
  172. package/dist/clis/xianyu/utils.js +8 -0
  173. package/dist/clis/xiaoe/catalog.yaml +129 -0
  174. package/dist/clis/xiaoe/content.yaml +43 -0
  175. package/dist/clis/xiaoe/courses.yaml +73 -0
  176. package/dist/clis/xiaoe/detail.yaml +39 -0
  177. package/dist/clis/xiaoe/play-url.yaml +124 -0
  178. package/dist/clis/xiaohongshu/comments.test.js +0 -2
  179. package/dist/clis/xiaohongshu/creator-note-detail.test.js +0 -2
  180. package/dist/clis/xiaohongshu/creator-notes.test.js +0 -2
  181. package/dist/clis/xiaohongshu/download.test.js +0 -2
  182. package/dist/clis/xiaohongshu/note.test.js +0 -2
  183. package/dist/clis/xiaohongshu/publish.test.js +0 -2
  184. package/dist/clis/xiaohongshu/search.js +29 -20
  185. package/dist/clis/xiaohongshu/search.test.js +56 -48
  186. package/dist/clis/yuanbao/ask.d.ts +21 -0
  187. package/dist/clis/yuanbao/ask.js +427 -0
  188. package/dist/clis/yuanbao/ask.test.d.ts +1 -0
  189. package/dist/clis/yuanbao/ask.test.js +124 -0
  190. package/dist/clis/yuanbao/new.d.ts +1 -0
  191. package/dist/clis/yuanbao/new.js +70 -0
  192. package/dist/clis/yuanbao/new.test.d.ts +1 -0
  193. package/dist/clis/yuanbao/new.test.js +30 -0
  194. package/dist/clis/yuanbao/shared.d.ts +13 -0
  195. package/dist/clis/yuanbao/shared.js +49 -0
  196. package/dist/clis/zhihu/question.js +30 -19
  197. package/dist/clis/zhihu/question.test.js +34 -16
  198. package/dist/commanderAdapter.js +8 -4
  199. package/dist/commanderAdapter.test.js +42 -0
  200. package/dist/completion.js +3 -1
  201. package/dist/completion.test.d.ts +1 -0
  202. package/dist/completion.test.js +23 -0
  203. package/dist/doctor.js +1 -1
  204. package/dist/electron-apps.d.ts +2 -0
  205. package/dist/electron-apps.js +7 -1
  206. package/dist/errors.js +1 -1
  207. package/dist/execution.js +25 -35
  208. package/dist/explore.js +1 -1
  209. package/dist/launcher.d.ts +4 -0
  210. package/dist/launcher.js +64 -8
  211. package/dist/launcher.test.js +88 -7
  212. package/dist/output.d.ts +2 -0
  213. package/dist/output.js +10 -1
  214. package/dist/output.test.d.ts +0 -3
  215. package/dist/output.test.js +59 -92
  216. package/dist/pipeline/executor.test.js +0 -2
  217. package/dist/pipeline/steps/download.test.js +0 -2
  218. package/dist/registry.d.ts +2 -0
  219. package/dist/serialization.d.ts +1 -0
  220. package/dist/serialization.js +1 -0
  221. package/dist/types.d.ts +9 -2
  222. package/docs/.vitepress/config.mts +4 -0
  223. package/docs/adapters/browser/1688.md +52 -0
  224. package/docs/adapters/browser/36kr.md +2 -1
  225. package/docs/adapters/browser/doubao.md +5 -1
  226. package/docs/adapters/browser/hupu.md +53 -0
  227. package/docs/adapters/browser/sinafinance.md +32 -2
  228. package/docs/adapters/browser/weibo.md +6 -1
  229. package/docs/adapters/browser/wikipedia.md +2 -0
  230. package/docs/adapters/browser/xianyu.md +42 -0
  231. package/docs/adapters/browser/xiaoe.md +44 -0
  232. package/docs/adapters/browser/yuanbao.md +64 -0
  233. package/docs/adapters/index.md +14 -5
  234. package/docs/comparison.md +1 -1
  235. package/docs/developer/ai-workflow.md +2 -2
  236. package/docs/developer/contributing.md +1 -1
  237. package/docs/developer/testing.md +2 -0
  238. package/docs/guide/plugins.md +1 -0
  239. package/docs/guide/troubleshooting.md +11 -0
  240. package/docs/superpowers/specs/2026-04-03-v2ex-autoresearch-design.md +41 -0
  241. package/docs/zh/guide/plugins.md +1 -0
  242. package/extension/dist/background.js +1127 -0
  243. package/extension/src/background.test.ts +39 -0
  244. package/extension/src/background.ts +223 -34
  245. package/extension/src/cdp.ts +194 -4
  246. package/extension/src/protocol.ts +22 -1
  247. package/package.json +3 -2
  248. package/scripts/postinstall.js +1 -1
  249. package/skills/opencli-explorer/SKILL.md +1 -1
  250. package/skills/opencli-oneshot/SKILL.md +2 -2
  251. package/skills/opencli-operate/SKILL.md +120 -27
  252. package/skills/opencli-usage/SKILL.md +31 -20
  253. package/skills/opencli-usage/browser.md +114 -16
  254. package/skills/opencli-usage/public-api.md +32 -3
  255. package/skills/smart-search/SKILL.md +156 -0
  256. package/skills/smart-search/references/sources-ai.md +74 -0
  257. package/skills/smart-search/references/sources-info.md +43 -0
  258. package/skills/smart-search/references/sources-media.md +50 -0
  259. package/skills/smart-search/references/sources-other.md +42 -0
  260. package/skills/smart-search/references/sources-shopping.md +31 -0
  261. package/skills/smart-search/references/sources-social.md +51 -0
  262. package/skills/smart-search/references/sources-tech.md +42 -0
  263. package/skills/smart-search/references/sources-travel.md +20 -0
  264. package/src/browser/base-page.ts +41 -6
  265. package/src/browser/bridge.ts +11 -8
  266. package/src/browser/cdp.ts +1 -8
  267. package/src/browser/daemon-client.ts +11 -1
  268. package/src/browser/dom-helpers.ts +43 -31
  269. package/src/browser/dom-snapshot.ts +23 -1
  270. package/src/browser/page.ts +115 -31
  271. package/src/browser.test.ts +1 -1
  272. package/src/build-manifest.ts +2 -0
  273. package/src/cli.test.ts +133 -0
  274. package/src/cli.ts +73 -11
  275. package/src/clis/1688/item.test.ts +69 -0
  276. package/src/clis/1688/item.ts +282 -0
  277. package/src/clis/1688/search.test.ts +81 -0
  278. package/src/clis/1688/search.ts +402 -0
  279. package/src/clis/1688/shared.test.ts +75 -0
  280. package/src/clis/1688/shared.ts +623 -0
  281. package/src/clis/1688/store.test.ts +69 -0
  282. package/src/clis/1688/store.ts +300 -0
  283. package/src/clis/amazon/bestsellers.test.ts +12 -3
  284. package/src/clis/amazon/bestsellers.ts +6 -178
  285. package/src/clis/amazon/movers-shakers.ts +8 -0
  286. package/src/clis/amazon/new-releases.ts +8 -0
  287. package/src/clis/amazon/rankings.test.ts +47 -0
  288. package/src/clis/amazon/rankings.ts +312 -0
  289. package/src/clis/amazon/shared.test.ts +16 -0
  290. package/src/clis/amazon/shared.ts +134 -12
  291. package/src/clis/bilibili/comments.test.ts +4 -3
  292. package/src/clis/bilibili/comments.ts +2 -2
  293. package/src/clis/bilibili/download.ts +2 -1
  294. package/src/clis/bilibili/subtitle.test.ts +2 -1
  295. package/src/clis/bilibili/subtitle.ts +4 -3
  296. package/src/clis/bilibili/utils.test.ts +21 -0
  297. package/src/clis/bilibili/utils.ts +27 -0
  298. package/src/clis/douban/marks.ts +1 -1
  299. package/src/clis/douban/subject.yaml +50 -19
  300. package/src/clis/doubao/utils.ts +32 -12
  301. package/src/clis/douyin/_shared/browser-fetch.test.ts +0 -1
  302. package/src/clis/douyin/_shared/transcode.test.ts +0 -2
  303. package/src/clis/douyin/draft.test.ts +0 -2
  304. package/src/clis/facebook/search.test.ts +0 -2
  305. package/src/clis/gemini/ask.test.ts +116 -0
  306. package/src/clis/gemini/ask.ts +10 -3
  307. package/src/clis/gemini/reply-state.test.ts +708 -0
  308. package/src/clis/gemini/utils.test.ts +184 -2
  309. package/src/clis/gemini/utils.ts +588 -60
  310. package/src/clis/hupu/detail.ts +126 -0
  311. package/src/clis/hupu/hot.yaml +43 -0
  312. package/src/clis/hupu/like.ts +76 -0
  313. package/src/clis/hupu/reply.ts +76 -0
  314. package/src/clis/hupu/search.ts +95 -0
  315. package/src/clis/hupu/unlike.ts +76 -0
  316. package/src/clis/hupu/utils.ts +381 -0
  317. package/src/clis/instagram/_shared/private-publish.test.ts +827 -0
  318. package/src/clis/instagram/_shared/private-publish.ts +1303 -0
  319. package/src/clis/instagram/_shared/protocol-capture.test.ts +148 -0
  320. package/src/clis/instagram/_shared/protocol-capture.ts +321 -0
  321. package/src/clis/instagram/_shared/runtime-info.ts +91 -0
  322. package/src/clis/instagram/note.test.ts +96 -0
  323. package/src/clis/instagram/note.ts +254 -0
  324. package/src/clis/instagram/post.test.ts +1716 -0
  325. package/src/clis/instagram/post.ts +1620 -0
  326. package/src/clis/instagram/reel.test.ts +191 -0
  327. package/src/clis/instagram/reel.ts +886 -0
  328. package/src/clis/instagram/story.test.ts +191 -0
  329. package/src/clis/instagram/story.ts +151 -0
  330. package/src/clis/sinafinance/stock-rank.ts +68 -0
  331. package/src/clis/substack/utils.test.ts +0 -2
  332. package/src/clis/twitter/post.test.ts +157 -0
  333. package/src/clis/twitter/post.ts +82 -48
  334. package/src/clis/twitter/reply.test.ts +177 -0
  335. package/src/clis/twitter/reply.ts +285 -39
  336. package/src/clis/xianyu/chat.test.ts +20 -0
  337. package/src/clis/xianyu/chat.ts +175 -0
  338. package/src/clis/xianyu/item.test.ts +67 -0
  339. package/src/clis/xianyu/item.ts +172 -0
  340. package/src/clis/xianyu/search.test.ts +22 -0
  341. package/src/clis/xianyu/search.ts +151 -0
  342. package/src/clis/xianyu/utils.ts +9 -0
  343. package/src/clis/xiaoe/catalog.yaml +129 -0
  344. package/src/clis/xiaoe/content.yaml +43 -0
  345. package/src/clis/xiaoe/courses.yaml +73 -0
  346. package/src/clis/xiaoe/detail.yaml +39 -0
  347. package/src/clis/xiaoe/play-url.yaml +124 -0
  348. package/src/clis/xiaohongshu/comments.test.ts +0 -2
  349. package/src/clis/xiaohongshu/creator-note-detail.test.ts +0 -2
  350. package/src/clis/xiaohongshu/creator-notes.test.ts +0 -2
  351. package/src/clis/xiaohongshu/download.test.ts +0 -2
  352. package/src/clis/xiaohongshu/note.test.ts +0 -2
  353. package/src/clis/xiaohongshu/publish.test.ts +0 -2
  354. package/src/clis/xiaohongshu/search.test.ts +59 -48
  355. package/src/clis/xiaohongshu/search.ts +31 -21
  356. package/src/clis/yuanbao/ask.test.ts +156 -0
  357. package/src/clis/yuanbao/ask.ts +522 -0
  358. package/src/clis/yuanbao/new.test.ts +36 -0
  359. package/src/clis/yuanbao/new.ts +81 -0
  360. package/src/clis/yuanbao/shared.ts +57 -0
  361. package/src/clis/zhihu/question.test.ts +42 -17
  362. package/src/clis/zhihu/question.ts +31 -26
  363. package/src/commanderAdapter.test.ts +51 -0
  364. package/src/commanderAdapter.ts +8 -4
  365. package/src/completion.test.ts +30 -0
  366. package/src/completion.ts +3 -1
  367. package/src/doctor.ts +1 -1
  368. package/src/electron-apps.ts +9 -1
  369. package/src/errors.ts +1 -1
  370. package/src/execution.ts +26 -30
  371. package/src/explore.ts +1 -1
  372. package/src/launcher.test.ts +121 -7
  373. package/src/launcher.ts +87 -9
  374. package/src/output.test.ts +50 -90
  375. package/src/output.ts +10 -1
  376. package/src/pipeline/executor.test.ts +0 -2
  377. package/src/pipeline/steps/download.test.ts +0 -2
  378. package/src/registry.ts +2 -0
  379. package/src/serialization.ts +2 -0
  380. package/src/types.ts +9 -2
  381. package/tests/e2e/browser-auth.test.ts +9 -0
  382. package/CLI-EXPLORER.md +0 -724
  383. package/CLI-ONESHOT.md +0 -216
  384. package/SKILL.md +0 -59
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  name: opencli-usage
3
- description: "Use when running OpenCLI commands to interact with websites (Bilibili, Twitter, Reddit, Xiaohongshu, etc.), desktop apps (Cursor, Notion), or public APIs (HackerNews, arXiv). Covers installation, command reference, and output formats for 60+ adapters."
4
- version: 1.6.0
3
+ description: "Use when running OpenCLI commands to interact with websites (Bilibili, Twitter, Reddit, Xiaohongshu, etc.), desktop apps (Cursor, Notion), or public APIs (HackerNews, arXiv). Covers installation, command reference, and output formats for 73+ adapters."
4
+ version: 1.6.1
5
5
  author: jackwener
6
6
  tags: [opencli, cli, browser, web, chrome-extension, cdp, bilibili, twitter, reddit, xiaohongshu, github, youtube, AI, agent, automation]
7
7
  ---
@@ -44,8 +44,8 @@ Public API commands (`hackernews`, `v2ex`) need no browser.
44
44
  | **hot/trending** | Bilibili, Twitter, Weibo, HackerNews, Reddit, V2EX, Xueqiu, Lobsters, Douban | browser.md / public-api.md |
45
45
  | **feed/timeline** | Twitter, Reddit, Xiaohongshu, Xueqiu, Jike, Facebook, Instagram, Medium | browser.md |
46
46
  | **user/profile** | Twitter, Reddit, Instagram, TikTok, Facebook, Bilibili, Pixiv | browser.md |
47
- | **post/create** | Twitter, Jike | browser.md |
48
- | **AI chat** | Grok, Doubao, Kimi, DeepSeek, Qwen, ChatGPT, Cursor, Codex | browser.md / desktop.md |
47
+ | **post/create** | Twitter, Jike, Douyin, Weibo | browser.md |
48
+ | **AI chat** | Grok, Doubao, ChatGPT, Gemini, Cursor, Codex, NotebookLM | browser.md / desktop.md |
49
49
  | **finance/stock** | Xueqiu, Yahoo Finance, Barchart, Sina Finance, Bloomberg | browser.md / public-api.md |
50
50
  | **web scraping** | `opencli web read --url <url>` — any URL to Markdown | browser.md |
51
51
 
@@ -59,9 +59,9 @@ Usage: `opencli <site> <command> [args] [--limit N] [-f json|yaml|md|csv|table]`
59
59
  |------|----------|
60
60
  | **bilibili** | `hot` `search` `me` `favorite` `history` `feed` `user-videos` `subtitle` `dynamic` `ranking` `following` |
61
61
  | **zhihu** | `hot` `search` `question` |
62
- | **xiaohongshu** | `search` `notifications` `feed` `user` `creator-notes` `creator-note-detail` `creator-notes-summary` `creator-profile` `creator-stats` |
63
- | **xueqiu** | `hot-stock` `stock` `watchlist` `feed` `hot` `search` `earnings-date` `fund-holdings` `fund-snapshot` |
64
- | **twitter** | `trending` `bookmarks` `search` `profile` `timeline` `thread` `article` `follow` `unfollow` `bookmark` `unbookmark` `post` `like` `reply` `delete` `block` `unblock` `followers` `following` `notifications` `hide-reply` `download` `accept` `reply-dm` |
62
+ | **xiaohongshu** | `search` `notifications` `feed` `user` `note` `comments` `download` `publish` `creator-notes` `creator-note-detail` `creator-notes-summary` `creator-profile` `creator-stats` |
63
+ | **xueqiu** | `hot-stock` `stock` `watchlist` `feed` `hot` `search` `comments` `earnings-date` `fund-holdings` `fund-snapshot` |
64
+ | **twitter** | `trending` `bookmarks` `search` `profile` `timeline` `thread` `article` `follow` `unfollow` `bookmark` `unbookmark` `post` `like` `likes` `reply` `delete` `block` `unblock` `followers` `following` `notifications` `hide-reply` `download` `accept` `reply-dm` |
65
65
  | **reddit** | `hot` `frontpage` `popular` `search` `subreddit` `read` `user` `user-posts` `user-comments` `upvote` `save` `comment` `subscribe` `saved` `upvoted` |
66
66
  | **youtube** | `search` `video` `transcript` |
67
67
  | **facebook** | `feed` `profile` `search` `friends` `groups` `events` `notifications` `memories` `add-friend` `join-group` |
@@ -71,33 +71,40 @@ Usage: `opencli <site> <command> [args] [--limit N] [-f json|yaml|md|csv|table]`
71
71
  | **medium** | `feed` `search` `user` |
72
72
  | **substack** | `feed` `search` `publication` |
73
73
  | **sinablog** | `hot` `search` `article` `user` |
74
- | **weibo** | `hot` |
74
+ | **weibo** | `hot` `search` `feed` `user` `me` `post` `comments` |
75
+ | **douyin** | `profile` `videos` `user-videos` `activities` `collections` `hashtag` `location` `stats` `publish` `draft` `drafts` `delete` `update` |
76
+ | **bluesky** | `search` `profile` `user` `feeds` `followers` `following` `thread` `trending` `starter-packs` |
75
77
  | **boss** | `search` `detail` `recommend` `joblist` `greet` `batchgreet` `send` `chatlist` `chatmsg` `invite` `mark` `exchange` `resume` `stats` |
76
- | **douban** | `search` `top250` `subject` `photos` `download` `marks` `reviews` |
78
+ | **douban** | `search` `top250` `subject` `photos` `download` `marks` `reviews` `movie-hot` `book-hot` |
77
79
  | **pixiv** | `ranking` `search` `user` `illusts` `detail` `download` |
78
- | **jike** | `feed` `search` `create` `like` `comment` `repost` `notifications` |
80
+ | **jike** | `feed` `search` `create` `like` `comment` `repost` `notifications` `post` `topic` `user` |
81
+ | **band** | `bands` `posts` `post` `mentions` |
82
+ | **zsxq** | `groups` `dynamics` `topics` `topic` `search` |
83
+ | **tieba** | `hot` `search` `posts` `read` |
79
84
  | **yahoo-finance** | `quote` |
80
85
  | **barchart** | `quote` `options` `greeks` `flow` |
81
86
  | **sinafinance** | `news` |
82
87
  | **reuters** | `search` |
88
+ | **amazon** | `bestsellers` `search` `product` `offer` `discussion` |
83
89
  | **coupang** | `search` `add-to-cart` |
84
90
  | **jd** | `item` |
85
91
  | **smzdm** | `search` |
86
92
  | **ctrip** | `search` |
87
- | **weread** | `shelf` `search` `book` `highlights` `notes` `ranking` |
93
+ | **36kr** | `hot` `news` `search` `article` |
94
+ | **weread** | `shelf` `search` `book` `highlights` `notes` `notebooks` `ranking` |
88
95
  | **chaoxing** | `assignments` `exams` |
89
96
  | **jimeng** | `generate` `history` |
90
97
  | **yollomi** | `models` `generate` `video` `upload` `remove-bg` `edit` `background` `face-swap` `object-remover` `restore` `try-on` `upscale` |
98
+ | **ones** | `login` `logout` `me` `tasks` `task` `my-tasks` `worklog` `token-info` |
91
99
  | **web** | `read` — any URL to Markdown |
92
100
  | **weixin** | `download` — 公众号 article to Markdown |
93
101
  | **v2ex** (browser) | `daily` `me` `notifications` |
94
- | **linux-do** (browser) | `categories` `category` |
102
+ | **linux-do** (browser) | `hot` `latest` `feed` `search` `categories` `category` `tags` `topic` `user-posts` `user-topics` |
95
103
  | **bloomberg** (browser) | `news` — full article reader |
96
104
  | **grok** | `ask` |
97
- | **doubao** | `status` `new` `send` `read` `ask` |
98
- | **kimi** | `status` `new` `ask` |
99
- | **deepseek** | `status` `new` `ask` |
100
- | **qwen** | `status` `new` `ask` |
105
+ | **doubao** | `status` `new` `send` `read` `ask` `detail` `history` `meeting-summary` `meeting-transcript` |
106
+ | **gemini** | `ask` `new` `image` |
107
+ | **notebooklm** | `status` `list` `open` `get` `current` `history` `summary` `note-list` `notes-get` `source-list` `source-get` `source-fulltext` `source-guide` |
101
108
 
102
109
  ### Desktop (CDP/Electron)
103
110
 
@@ -106,7 +113,7 @@ Usage: `opencli <site> <command> [args] [--limit N] [-f json|yaml|md|csv|table]`
106
113
  | **gh** | `repo` `pr` `issue` — passthrough to gh CLI |
107
114
  | **cursor** | `status` `send` `read` `new` `dump` `composer` `model` `extract-code` `ask` `screenshot` `history` `export` |
108
115
  | **codex** | `status` `send` `read` `new` `dump` `extract-diff` `model` `ask` `screenshot` `history` `export` |
109
- | **chatgpt** | `status` `new` `send` `read` `ask` |
116
+ | **chatgpt** | `status` `new` `send` `read` `ask` `model` |
110
117
  | **chatwise** | `status` `new` `send` `read` `ask` `model` `history` `export` `screenshot` |
111
118
  | **notion** | `status` `search` `read` `new` `write` `sidebar` `favorites` `export` |
112
119
  | **discord-app** | `status` `send` `read` `channels` `servers` `search` `members` |
@@ -129,10 +136,13 @@ Usage: `opencli <site> <command> [args] [--limit N] [-f json|yaml|md|csv|table]`
129
136
  | **bloomberg** (RSS) | `main` `markets` `tech` `politics` `economics` `opinions` `industries` `businessweek` `feeds` |
130
137
  | **dictionary** | `search` `synonyms` `examples` |
131
138
  | **hf** | `top` |
132
- | **stackoverflow** | `hot` `search` `bounties` |
139
+ | **stackoverflow** | `hot` `search` `bounties` `unanswered` |
133
140
  | **xiaoyuzhou** | `podcast` `podcast-episodes` `episode` |
134
- | **wikipedia** | `search` `summary` |
135
- | **producthunt** | `today` `week` `month` `search` |
141
+ | **wikipedia** | `search` `summary` `random` `trending` |
142
+ | **producthunt** | `today` `hot` `browse` `posts` |
143
+ | **imdb** | `top` `trending` `search` `title` `person` `reviews` |
144
+ | **spotify** | `auth` `status` `play` |
145
+ | **paperreview** | `submit` `review` `feedback` |
136
146
 
137
147
  ### Management
138
148
 
@@ -148,5 +158,6 @@ All commands support: `--format` / `-f` with `table` `json` `yaml` `md` `csv`
148
158
 
149
159
  ## Related Skills
150
160
 
161
+ - **opencli-operate** — Browser automation for AI agents (navigate, click, type, extract via Chrome)
151
162
  - **opencli-explorer** — Full guide for creating new adapters (API discovery, auth strategy, YAML/TS writing)
152
163
  - **opencli-oneshot** — Quick 4-step template for adding a single command from a URL
@@ -29,10 +29,14 @@ opencli zhihu question 34816524 # 问题详情和回答 (id positiona
29
29
  ## Xiaohongshu (小红书)
30
30
 
31
31
  ```bash
32
- opencli xiaohongshu search "美食" # 搜索笔记 (query positional)
33
- opencli xiaohongshu notifications # 通知(mentions/likes/connections)
34
- opencli xiaohongshu feed --limit 10 # 推荐 Feed
35
- opencli xiaohongshu user xxx # 用户主页 (id positional)
32
+ opencli xiaohongshu search "美食" # 搜索笔记 (query positional)
33
+ opencli xiaohongshu note <note-id-or-url> # 读取笔记正文和互动数据
34
+ opencli xiaohongshu comments <note-id> # 笔记评论
35
+ opencli xiaohongshu notifications # 通知(mentions/likes/connections)
36
+ opencli xiaohongshu feed --limit 10 # 推荐 Feed
37
+ opencli xiaohongshu user xxx # 用户主页 (id positional)
38
+ opencli xiaohongshu download <note-id> # 下载笔记图片/视频
39
+ opencli xiaohongshu publish # 发布笔记
36
40
  opencli xiaohongshu creator-notes --limit 10 # 创作者笔记列表
37
41
  opencli xiaohongshu creator-note-detail --note-id xxx # 笔记详情
38
42
  opencli xiaohongshu creator-notes-summary # 笔记数据概览
@@ -116,6 +120,12 @@ opencli v2ex notifications --limit 10 # 通知
116
120
 
117
121
  ```bash
118
122
  opencli weibo hot --limit 10 # 微博热搜
123
+ opencli weibo search "关键词" # 搜索微博
124
+ opencli weibo feed --limit 20 # 首页时间线
125
+ opencli weibo user <uid> # 用户信息
126
+ opencli weibo me # 我的信息
127
+ opencli weibo post "内容" # 发微博
128
+ opencli weibo comments <mid> # 微博评论
119
129
  ```
120
130
 
121
131
  ## BOSS直聘
@@ -353,6 +363,10 @@ opencli doubao new # 新建对话
353
363
  opencli doubao send "你好" # 发送消息 (text positional)
354
364
  opencli doubao read # 读取对话记录
355
365
  opencli doubao ask "问题" # 一键提问并等回复 (text positional)
366
+ opencli doubao detail <id> # 对话详情
367
+ opencli doubao history # 历史对话列表
368
+ opencli doubao meeting-summary <id> # 会议总结
369
+ opencli doubao meeting-transcript <id> # 会议记录
356
370
  ```
357
371
 
358
372
  ## Grok
@@ -404,26 +418,110 @@ opencli linkedin timeline --limit 20 # 首页动态流
404
418
  opencli bloomberg news "https://..." # 阅读 Bloomberg 文章全文 (link positional, browser)
405
419
  ```
406
420
 
407
- ## Kimi
421
+ ## Gemini
408
422
 
409
423
  ```bash
410
- opencli kimi status # 检查 Kimi 页面状态
411
- opencli kimi new # 新建对话
412
- opencli kimi ask "问题" # 提问 (prompt positional)
424
+ opencli gemini ask "问题" # 提问 (prompt positional)
425
+ opencli gemini new # 新建对话
426
+ opencli gemini image "描述" # 生成图片
413
427
  ```
414
428
 
415
- ## DeepSeek
429
+ ## NotebookLM
416
430
 
417
431
  ```bash
418
- opencli deepseek status # 检查 DeepSeek 页面状态
419
- opencli deepseek new # 新建对话
420
- opencli deepseek ask "问题" # 提问 (prompt positional)
432
+ opencli notebooklm status # 检查页面状态
433
+ opencli notebooklm list # 列出所有笔记本
434
+ opencli notebooklm open <notebook> # 打开笔记本
435
+ opencli notebooklm current # 当前笔记本信息
436
+ opencli notebooklm get # 获取笔记本详情
437
+ opencli notebooklm history # 对话历史
438
+ opencli notebooklm summary # 笔记本摘要
439
+ opencli notebooklm source-list # 列出来源
440
+ opencli notebooklm source-get <source> # 获取来源详情
441
+ opencli notebooklm source-fulltext <src> # 来源全文
442
+ opencli notebooklm source-guide <src> # 来源指南
443
+ opencli notebooklm note-list # 笔记列表
444
+ opencli notebooklm notes-get <note> # 获取笔记内容
421
445
  ```
422
446
 
423
- ## Qwen (通义千问)
447
+ ## Bluesky
424
448
 
425
449
  ```bash
426
- opencli qwen status # 检查 Qwen 页面状态
427
- opencli qwen new # 新建对话
428
- opencli qwen ask "问题" # 提问 (prompt positional)
450
+ opencli bluesky search "关键词" # 搜索帖子 (query positional)
451
+ opencli bluesky profile <handle> # 用户资料
452
+ opencli bluesky user <handle> # 用户详情
453
+ opencli bluesky feeds <handle> # 用户 feeds
454
+ opencli bluesky followers <handle> # 粉丝列表
455
+ opencli bluesky following <handle> # 关注列表
456
+ opencli bluesky thread <uri> # 帖子线程
457
+ opencli bluesky trending # 热门话题
458
+ opencli bluesky starter-packs # Starter packs
459
+ ```
460
+
461
+ ## Douyin (抖音)
462
+
463
+ ```bash
464
+ opencli douyin profile # 创作者资料
465
+ opencli douyin videos --limit 10 # 浏览视频
466
+ opencli douyin user-videos # 我的作品列表
467
+ opencli douyin activities # 动态
468
+ opencli douyin collections # 收藏夹
469
+ opencli douyin hashtag <tag> # 话题页
470
+ opencli douyin location <poi> # 地点页
471
+ opencli douyin stats # 数据统计
472
+ opencli douyin publish # 发布视频
473
+ opencli douyin draft # 编辑草稿
474
+ opencli douyin drafts # 草稿列表
475
+ opencli douyin delete <id> # 删除作品
476
+ opencli douyin update <id> # 更新作品信息
477
+ ```
478
+
479
+ ## Band
480
+
481
+ ```bash
482
+ opencli band bands # 列出已加入的 bands
483
+ opencli band posts <band-id> # Band 帖子列表
484
+ opencli band post <post-key> # 帖子详情
485
+ opencli band mentions # 提到我的消息
486
+ ```
487
+
488
+ ## ZSXQ (知识星球)
489
+
490
+ ```bash
491
+ opencli zsxq groups # 我加入的星球
492
+ opencli zsxq dynamics <group-id> # 星球动态
493
+ opencli zsxq topics <group-id> # 主题列表
494
+ opencli zsxq topic <topic-id> # 主题详情
495
+ opencli zsxq search "关键词" # 搜索
496
+ ```
497
+
498
+ ## Tieba (百度贴吧)
499
+
500
+ ```bash
501
+ opencli tieba hot # 热门贴吧
502
+ opencli tieba search "关键词" # 搜索
503
+ opencli tieba posts <forum> # 帖子列表
504
+ opencli tieba read <thread-id> # 阅读帖子
505
+ ```
506
+
507
+ ## 36kr
508
+
509
+ ```bash
510
+ opencli 36kr hot # 热门文章
511
+ opencli 36kr news # 最新资讯
512
+ opencli 36kr search "关键词" # 搜索文章
513
+ opencli 36kr article <id> # 文章全文
514
+ ```
515
+
516
+ ## ONES
517
+
518
+ ```bash
519
+ opencli ones login # 登录
520
+ opencli ones me # 我的信息
521
+ opencli ones tasks --team <id> # 项目任务列表
522
+ opencli ones my-tasks # 我的任务
523
+ opencli ones task <id> # 任务详情
524
+ opencli ones worklog --task <id> # 工时日志
525
+ opencli ones token-info # Token 信息
526
+ opencli ones logout # 登出
429
527
  ```
@@ -109,6 +109,8 @@ opencli xiaoyuzhou episode 12345 # 单集详情 (id positional)
109
109
  ```bash
110
110
  opencli wikipedia search "AI" # 搜索 (query positional)
111
111
  opencli wikipedia summary "Python" # 摘要 (title positional)
112
+ opencli wikipedia random # 随机条目
113
+ opencli wikipedia trending # 热门条目
112
114
  ```
113
115
 
114
116
  ## Bloomberg (RSS)
@@ -143,7 +145,34 @@ opencli hf top --limit 10 # 热门模型
143
145
 
144
146
  ```bash
145
147
  opencli producthunt today --limit 10 # 今日产品
146
- opencli producthunt week --limit 10 # 本周产品
147
- opencli producthunt month --limit 10 # 本月产品
148
- opencli producthunt search "AI" # 搜索产品 (query positional)
148
+ opencli producthunt hot --limit 10 # 热门产品
149
+ opencli producthunt browse --limit 10 # 浏览产品
150
+ opencli producthunt posts --limit 10 # 最新产品
151
+ ```
152
+
153
+ ## IMDB
154
+
155
+ ```bash
156
+ opencli imdb top --limit 10 # Top 250
157
+ opencli imdb trending --limit 10 # 热门影视
158
+ opencli imdb search "关键词" # 搜索 (query positional)
159
+ opencli imdb title <id> # 影视详情
160
+ opencli imdb person <id> # 演员详情
161
+ opencli imdb reviews <id> # 评论
162
+ ```
163
+
164
+ ## Spotify
165
+
166
+ ```bash
167
+ opencli spotify auth # OAuth 授权
168
+ opencli spotify status # 播放状态
169
+ opencli spotify play "歌曲" # 播放 (query positional)
170
+ ```
171
+
172
+ ## Paper Review
173
+
174
+ ```bash
175
+ opencli paperreview submit # 提交论文
176
+ opencli paperreview review # 审阅
177
+ opencli paperreview feedback # 反馈
149
178
  ```
@@ -0,0 +1,156 @@
1
+ ---
2
+ name: smart-search
3
+ description: 基于 opencli 命令的智能搜索路由器。当用户想要搜索、查询、查找或研究信息时,尤其是涉及指定网站、社交媒体、技术资料、新闻、购物、旅游、求职、金融或中文内容时,务必使用此 skill
4
+ ---
5
+
6
+ # 智能搜索路由器
7
+
8
+ 根据话题和场景,将查询路由到最佳的 opencli 搜索源。此 skill 的核心目标不是记忆命令,而是先定位数据源,再让 Agent 通过 `opencli` 自己读取实时帮助,避免文档漂移。
9
+
10
+ ## 强制预检
11
+
12
+ 每次使用前,必须先做下面两步:
13
+
14
+ - 运行 `opencli list -f yaml`
15
+ - 用 live registry 确认候选站点是否存在,并检查 `strategy`、`browser`、`domain`
16
+
17
+ 选定站点后,必须再做下面两步:
18
+
19
+ - 运行 `opencli <site> -h` 查看该站点有哪些子命令
20
+ - 若已锁定某个子命令,再运行 `opencli <site> <command> -h` 查看参数、输出列、策略
21
+
22
+ 不要在 skill 文档里硬编码参数或假设命令签名;以 `opencli ... -h` 的实时输出为准。
23
+
24
+ ## 主路由规则
25
+
26
+ 只使用这一条规则,不再维护多套优先级:
27
+
28
+ 1. 当用户明确指定网站、平台或数据源时,直接使用对应网站。
29
+ 2. 当用户没有指定网站时,优先只选择一个 AI 源:`grok`、`doubao`、`gemini` 三选一。
30
+ 3. 当 AI 返回内容不足、缺少原始数据、需要权威佐证或需要垂直结果时,再补充 1-2 个专用源。
31
+
32
+ ## 单题预算与频率限制
33
+
34
+ 把“单个用户问题”理解为同一意图链路下的一次问题求解;同一轮追问、澄清、补充条件,若核心问题未变,仍算同一题。
35
+
36
+ 先建立一份站点调用台账。每次真正执行搜索命令后,立刻更新:
37
+
38
+ - `site`
39
+ - `query`
40
+ - `count`
41
+ - `status`
42
+
43
+ 计数规则:
44
+
45
+ - `opencli list -f yaml`、`opencli <site> -h`、`opencli <site> <command> -h` 属于预检与帮助,不计入搜索次数
46
+ - 一次真正的 `opencli <site> ...` 搜索/查询执行,计为该站点 1 次调用
47
+ - 同站点因为报错、超时、验证码、反爬、登录态异常而失败,也算 1 次调用,不要无限重试
48
+
49
+ 频率上限:
50
+
51
+ - AI 站点硬限制:同一题内,每个 AI 站点最多调用 1 次
52
+ - 默认策略仍然是只选 1 个 AI 站点,不要把多个 AI 站点串成常规流程
53
+ - 只有当用户明确要求比较多个 AI 站点时,才可以额外调用其他 AI 站点;但每个被点名的 AI 站点仍然最多 1 次
54
+ - 非 AI 站点默认最多调用 2 次
55
+ - 非 AI 站点第 2 次调用必须有明确理由,例如第一次结果过宽,需要加时间、地区、类别、排序或关键词限定
56
+ - 非 AI 站点不要进行第 3 次调用;若信息仍不足,停止扩搜并明确说明缺口
57
+
58
+ 触发限频后的处理:
59
+
60
+ - 记录:「已跳过:<site> 达到频率上限」
61
+ - 优先改用其他同类站点
62
+ - 若没有合适替代源,则直接基于已收集信息回答,并说明覆盖范围与缺口
63
+
64
+ ## 查询结束汇报
65
+
66
+ 每次查询结束后,回答末尾必须追加一段简短的“搜索摘要”,至少包含下面三项:
67
+
68
+ - 使用了什么网站搜索
69
+ - 每个网站搜了什么词
70
+ - 每个网站搜了几次
71
+
72
+ 如果有被限频跳过的站点,也要明确写出。
73
+
74
+ 建议使用下面的固定格式:
75
+
76
+ ```md
77
+ 搜索摘要
78
+ - 网站:<site1> | 查询词:<term1> | 次数:<n>
79
+ - 网站:<site2> | 查询词:<term2>;<term3> | 次数:<n>
80
+ - 已跳过:<site3>,原因:达到频率上限
81
+ ```
82
+
83
+ ## AI 源选择
84
+
85
+ - `grok`
86
+ 适合实时讨论、英文互联网舆论、Twitter/X 语境、热点追踪。
87
+ - `doubao`
88
+ 适合中文语境、字节抖音生态、生活方式内容、中文热点与泛中文问答。
89
+ - `gemini`
90
+ 适合全球网页、英文资料、通用信息检索、背景综述。
91
+
92
+ 如果用户没有指定网站,默认先判断语言和语境,再从这三个里只选一个。
93
+
94
+ 一旦某个 AI 站点已经执行过一次真实查询,就不要在同一题里改写关键词后再次调用该 AI 站点。若答案不足,优先补专用源,不要反复追打同一个 AI 站点。
95
+
96
+ ## AI 查询词建议
97
+
98
+ 当使用 AI 源时,不要只丢一个过短关键词。优先构造成“主题 + 目标 + 限定条件”的查询。
99
+
100
+ - 主题
101
+ 用户真正要查的对象、事件、产品、人物、公司、技术名词。
102
+ - 目标
103
+ 想要什么结果,例如总结、对比、原因、趋势、推荐、原始线索。
104
+ - 限定条件
105
+ 语言、地区、时间范围、平台范围、受众、价格带、岗位地点、是否要引用原始来源。
106
+
107
+ 优先使用下面这种表达方式:
108
+
109
+ - `<主题> + <你要回答的问题>`
110
+ - `<主题> + <时间范围/地区/语言>`
111
+ - `<主题> + <平台或来源范围>`
112
+ - `<主题> + <输出要求>`
113
+
114
+ 避免只输入:
115
+
116
+ - 单个名词
117
+ - 没有时间范围的热点问题
118
+ - 没有地区限制的购物、求职、旅游问题
119
+ - 没有平台限制的社交媒体问题
120
+
121
+ ## 专用源补充时机
122
+
123
+ 当出现以下任一情况时,再补充专用源:
124
+
125
+ - AI 给出的是摘要,但你需要原始帖子、原始视频、原始商品或原始职位结果
126
+ - AI 覆盖面不足,漏掉垂直站点信息
127
+ - 需要更高权威性或更强领域相关性
128
+ - 用户明确要求“从某个平台找”
129
+
130
+ 单次查询通常控制在 1 个 AI 源 + 1 到 2 个专用源,避免结果过载。
131
+
132
+ ## 处理不可用的源
133
+
134
+ 当站点不可用时:
135
+
136
+ - 不要因为单个源失败而中止整个搜索
137
+ - 记录:「已跳过:<site> 不可用」
138
+ - 回退到同类其他站点,或回退到一个 AI 源
139
+ - 始终以 `opencli list -f yaml` 与 `opencli <site> -h` 的实际结果为准
140
+
141
+ 不要假设任何站点“绝对可用”。即使是公开站点,也以当前环境中的 live help 和执行结果为准。
142
+
143
+ ## 参考文件
144
+
145
+ 根据需要读取对应文件:
146
+
147
+ - **`references/sources-ai.md`** — AI 默认源
148
+ - **`references/sources-tech.md`** — 技术 / 学术
149
+ - **`references/sources-social.md`** — 社交媒体
150
+ - **`references/sources-media.md`** — 媒体 / 娱乐
151
+ - **`references/sources-info.md`** — 资讯 / 知识
152
+ - **`references/sources-shopping.md`** — 购物
153
+ - **`references/sources-travel.md`** — 旅游
154
+ - **`references/sources-other.md`** — 其他垂直源
155
+
156
+ 只读与当前查询相关的文件,无需全部加载。
@@ -0,0 +1,74 @@
1
+ # AI 默认源
2
+
3
+ 当用户没有明确指定网站时,先在 `grok`、`doubao`、`gemini` 中选择一个,不要一开始并行跑多个 AI 源。
4
+
5
+ ## 使用规则
6
+
7
+ 1. 先运行 `opencli list -f yaml`
8
+ 2. 确认 `grok`、`doubao`、`gemini` 哪些在当前 registry 中可用
9
+ 3. 运行 `opencli <site> -h`
10
+ 4. 锁定具体子命令后,再运行 `opencli <site> <command> -h`
11
+
12
+ ## 路由建议
13
+
14
+ ### grok
15
+
16
+ - 适用:实时热点、Twitter/X 语境、英文互联网讨论、舆论与趋势
17
+ - 补充源常见去向:`twitter`、`reddit`、`reuters`、`google`
18
+ - 搜索词建议:
19
+ - 加上时间范围,例如“today / this week”
20
+ - 加上平台范围,例如“on X”, “from social posts”
21
+ - 加上目标,例如“latest reactions”, “main viewpoints”, “key claims”
22
+ - 示例:
23
+ - `OpenAI latest reactions on X this week`
24
+ - `TSLA earnings main viewpoints on social media April 2026`
25
+ - `Nintendo Switch 2 rumors latest discussion on X`
26
+
27
+ ### doubao
28
+
29
+ - 适用:中文语境、国内热点、生活方式、字节生态、中文泛问答
30
+ - 补充源常见去向:`xiaohongshu`、`weibo`、`zhihu`、`bilibili`、`36kr`
31
+ - 搜索词建议:
32
+ - 加上中文场景限定,例如“中文讨论”“国内用户”“小红书/微博语境”
33
+ - 加上需求目标,例如“帮我总结”“给我对比”“提取推荐理由”
34
+ - 加上人群或用途,例如“适合新手”“预算 500 元内”“上海求职”
35
+ - 示例:
36
+ - `2026年MacBook Air值得买吗 中文讨论里主要观点是什么`
37
+ - `上海 AI 产品经理招聘趋势 近一个月中文信息总结`
38
+ - `敏感肌防晒推荐 中文用户常提到的优缺点`
39
+
40
+ ### gemini
41
+
42
+ - 适用:全球网页、英文资料、背景综述、通用检索
43
+ - 补充源常见去向:`google`、`wikipedia`、`arxiv`、`stackoverflow`
44
+ - 搜索词建议:
45
+ - 加上主题类型,例如“overview”, “comparison”, “background”, “best sources”
46
+ - 加上范围限定,例如地区、时间、语言、行业
47
+ - 加上结果形式,例如“with sources”, “compare pros and cons”, “official guidance”
48
+ - 示例:
49
+ - `MCP overview and official guidance with sources`
50
+ - `best budget travel destinations in Japan April 2026 compare pros and cons`
51
+ - `TypeScript decorators current status official sources`
52
+
53
+ ## 补充原则
54
+
55
+ - 先用一个 AI 源拿到初步答案
56
+ - 若答案缺少原始数据、垂直结果或权威来源,再补 1-2 个专用源
57
+ - 不要把 AI 默认源当成命令签名的事实来源;命令细节始终以 `opencli ... -h` 为准
58
+
59
+ ## 通用写法模板
60
+
61
+ 可直接按下面模板构造 AI 查询:
62
+
63
+ - 热点/新闻:
64
+ `<事件> + 最新进展 + <时间范围> + <地区/平台>`
65
+ - 对比/推荐:
66
+ `<对象A> vs <对象B> + <关注维度> + <人群/预算/用途>`
67
+ - 中文社区:
68
+ `<主题> + 中文讨论里主要观点 + <时间范围>`
69
+ - 全球资料:
70
+ `<主题> + overview/background + with sources`
71
+ - 求职:
72
+ `<岗位> + <城市/国家> + market trends/hiring + <时间范围>`
73
+ - 购物:
74
+ `<商品> + reviews/price/value + <地区/预算>`
@@ -0,0 +1,43 @@
1
+ # 资讯 / 知识
2
+
3
+ 用于新闻、百科、通用知识、中文科技资讯。
4
+
5
+ ## 站点
6
+
7
+ ### google
8
+
9
+ - 适用:通用网页搜索、跨站点兜底
10
+ - 使用前先运行:`opencli google -h`
11
+
12
+ ### wikipedia
13
+
14
+ - 适用:名词解释、背景知识、历史事实
15
+ - 使用前先运行:`opencli wikipedia -h`
16
+
17
+ ### reuters
18
+
19
+ - 适用:国际新闻、事实性报道
20
+ - 使用前先运行:`opencli reuters -h`
21
+
22
+ ### weibo
23
+
24
+ - 适用:微博热点、话题、中文舆论
25
+ - 使用前先运行:`opencli weibo -h`
26
+
27
+ ### 36kr
28
+
29
+ - 适用:中文科技、创业、融资资讯
30
+ - 使用前先运行:`opencli 36kr -h`
31
+
32
+ ### substack
33
+
34
+ - 适用:newsletter、作者订阅内容、长文
35
+ - 使用前先运行:`opencli substack -h`
36
+
37
+ ## 路由提示
38
+
39
+ - 背景知识与定义,优先 `wikipedia`
40
+ - 通用网页与跨站信息,优先 `google`
41
+ - 国际新闻优先 `reuters`
42
+ - 中文科技资讯优先 `36kr`
43
+ - 当 AI 回答过于泛化时,用这些源补充事实和链接
@@ -0,0 +1,50 @@
1
+ # 媒体 / 娱乐
2
+
3
+ 用于视频、电影、剧集、音乐、播客、内容平台搜索。
4
+
5
+ ## 站点
6
+
7
+ ### bilibili
8
+
9
+ - 适用:中文视频、教程、评测、UP 主内容
10
+ - 使用前先运行:`opencli bilibili -h`
11
+
12
+ ### youtube
13
+
14
+ - 适用:英文视频、教程、评测、访谈
15
+ - 使用前先运行:`opencli youtube -h`
16
+
17
+ ### tiktok
18
+
19
+ - 适用:短视频、热点、娱乐内容
20
+ - 使用前先运行:`opencli tiktok -h`
21
+
22
+ ### imdb
23
+
24
+ - 适用:电影、剧集、演员、评分
25
+ - 使用前先运行:`opencli imdb -h`
26
+
27
+ ### douban
28
+
29
+ - 适用:中文电影、书籍、音乐口碑与评分
30
+ - 使用前先运行:`opencli douban -h`
31
+
32
+ ### spotify
33
+
34
+ - 适用:歌曲、歌手、专辑
35
+ - 使用前先运行:`opencli spotify -h`
36
+
37
+ ### apple-podcasts
38
+
39
+ - 适用:播客节目、播客搜索
40
+ - 使用前先运行:`opencli apple-podcasts -h`
41
+
42
+ ### medium
43
+
44
+ - 适用:长文、技术博客、设计与产品文章
45
+ - 使用前先运行:`opencli medium -h`
46
+
47
+ ## 路由提示
48
+
49
+ - 用户只说“找视频/影评/播客/文章”,先按内容形态选站点
50
+ - 用户没有指定站点时,可先用 `doubao`、`grok` 或 `gemini` 做一轮粗检索,再补媒体站点拿原始结果