@jackwener/opencli 1.6.2 → 1.6.4
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/README.md +7 -7
- package/README.zh-CN.md +9 -9
- package/dist/browser/cdp.d.ts +1 -40
- package/dist/browser/cdp.js +2 -310
- package/dist/browser/page.d.ts +1 -62
- package/dist/browser/page.js +2 -304
- package/dist/browser/utils.d.ts +1 -10
- package/dist/browser/utils.js +2 -27
- package/dist/cli-manifest.json +546 -2
- package/dist/clis/1688/item.js +3 -3
- package/dist/clis/1688/search.js +2 -2
- package/dist/clis/1688/shared.d.ts +1 -1
- package/dist/clis/1688/shared.js +1 -1
- package/dist/clis/1688/store.js +2 -2
- package/dist/clis/36kr/article.js +2 -2
- package/dist/clis/36kr/hot.js +12 -6
- package/dist/clis/36kr/news.js +1 -1
- package/dist/clis/36kr/search.js +12 -6
- package/dist/clis/_shared/desktop-commands.d.ts +5 -5
- package/dist/clis/_shared/desktop-commands.js +1 -1
- package/dist/clis/amazon/bestsellers.js +1 -1
- package/dist/clis/amazon/discussion.js +2 -2
- package/dist/clis/amazon/movers-shakers.js +1 -1
- package/dist/clis/amazon/new-releases.js +1 -1
- package/dist/clis/amazon/offer.js +2 -2
- package/dist/clis/amazon/product.js +2 -2
- package/dist/clis/amazon/rankings.d.ts +1 -1
- package/dist/clis/amazon/rankings.js +2 -2
- package/dist/clis/amazon/search.js +2 -2
- package/dist/clis/amazon/shared.d.ts +1 -1
- package/dist/clis/amazon/shared.js +1 -1
- package/dist/clis/antigravity/dump.d.ts +1 -1
- package/dist/clis/antigravity/dump.js +1 -1
- package/dist/clis/antigravity/extract-code.d.ts +1 -1
- package/dist/clis/antigravity/extract-code.js +1 -1
- package/dist/clis/antigravity/model.d.ts +1 -1
- package/dist/clis/antigravity/model.js +1 -1
- package/dist/clis/antigravity/new.d.ts +1 -1
- package/dist/clis/antigravity/new.js +1 -1
- package/dist/clis/antigravity/read.d.ts +1 -1
- package/dist/clis/antigravity/read.js +1 -1
- package/dist/clis/antigravity/send.d.ts +1 -1
- package/dist/clis/antigravity/send.js +1 -1
- package/dist/clis/antigravity/serve.js +2 -2
- package/dist/clis/antigravity/status.d.ts +1 -1
- package/dist/clis/antigravity/status.js +1 -1
- package/dist/clis/antigravity/watch.d.ts +1 -1
- package/dist/clis/antigravity/watch.js +1 -1
- package/dist/clis/apple-podcasts/commands.test.js +1 -1
- package/dist/clis/apple-podcasts/episodes.js +2 -2
- package/dist/clis/apple-podcasts/search.js +2 -2
- package/dist/clis/apple-podcasts/top.js +2 -2
- package/dist/clis/apple-podcasts/utils.js +1 -1
- package/dist/clis/arxiv/paper.js +2 -2
- package/dist/clis/arxiv/search.js +2 -2
- package/dist/clis/arxiv/utils.js +1 -1
- package/dist/clis/band/bands.js +2 -2
- package/dist/clis/band/mentions.js +2 -2
- package/dist/clis/band/post.js +2 -2
- package/dist/clis/band/posts.js +2 -2
- package/dist/clis/barchart/flow.js +1 -1
- package/dist/clis/barchart/greeks.js +1 -1
- package/dist/clis/barchart/options.js +1 -1
- package/dist/clis/barchart/quote.js +1 -1
- package/dist/clis/bbc/news.js +1 -1
- package/dist/clis/bilibili/comments.js +1 -1
- package/dist/clis/bilibili/comments.test.js +1 -1
- package/dist/clis/bilibili/download.js +1 -1
- package/dist/clis/bilibili/dynamic.js +1 -1
- package/dist/clis/bilibili/dynamic.test.js +1 -1
- package/dist/clis/bilibili/favorite.js +1 -1
- package/dist/clis/bilibili/feed.js +1 -1
- package/dist/clis/bilibili/following.js +2 -2
- package/dist/clis/bilibili/history.js +1 -1
- package/dist/clis/bilibili/me.js +1 -1
- package/dist/clis/bilibili/ranking.js +1 -1
- package/dist/clis/bilibili/search.js +1 -1
- package/dist/clis/bilibili/subtitle.js +2 -2
- package/dist/clis/bilibili/subtitle.test.js +2 -2
- package/dist/clis/bilibili/user-videos.js +1 -1
- package/dist/clis/bilibili/utils.d.ts +1 -1
- package/dist/clis/bilibili/utils.js +1 -1
- package/dist/clis/bloomberg/businessweek.js +1 -1
- package/dist/clis/bloomberg/economics.js +1 -1
- package/dist/clis/bloomberg/feeds.js +1 -1
- package/dist/clis/bloomberg/industries.js +1 -1
- package/dist/clis/bloomberg/main.js +1 -1
- package/dist/clis/bloomberg/markets.js +1 -1
- package/dist/clis/bloomberg/news.js +2 -2
- package/dist/clis/bloomberg/opinions.js +1 -1
- package/dist/clis/bloomberg/politics.js +1 -1
- package/dist/clis/bloomberg/tech.js +1 -1
- package/dist/clis/bloomberg/utils.js +1 -1
- package/dist/clis/boss/batchgreet.js +1 -1
- package/dist/clis/boss/chatlist.js +1 -1
- package/dist/clis/boss/chatmsg.js +1 -1
- package/dist/clis/boss/detail.js +1 -1
- package/dist/clis/boss/exchange.js +1 -1
- package/dist/clis/boss/greet.js +1 -1
- package/dist/clis/boss/invite.js +1 -1
- package/dist/clis/boss/joblist.js +1 -1
- package/dist/clis/boss/mark.js +2 -2
- package/dist/clis/boss/recommend.js +1 -1
- package/dist/clis/boss/resume.js +1 -1
- package/dist/clis/boss/search.js +1 -1
- package/dist/clis/boss/send.js +2 -2
- package/dist/clis/boss/stats.js +1 -1
- package/dist/clis/boss/utils.d.ts +1 -1
- package/dist/clis/chaoxing/assignments.js +2 -2
- package/dist/clis/chaoxing/exams.js +1 -1
- package/dist/clis/chaoxing/utils.d.ts +1 -1
- package/dist/clis/chatgpt/ask.d.ts +1 -1
- package/dist/clis/chatgpt/ask.js +2 -2
- package/dist/clis/chatgpt/model.d.ts +1 -1
- package/dist/clis/chatgpt/model.js +2 -2
- package/dist/clis/chatgpt/new.d.ts +1 -1
- package/dist/clis/chatgpt/new.js +2 -2
- package/dist/clis/chatgpt/read.d.ts +1 -1
- package/dist/clis/chatgpt/read.js +2 -2
- package/dist/clis/chatgpt/send.d.ts +1 -1
- package/dist/clis/chatgpt/send.js +2 -2
- package/dist/clis/chatgpt/status.d.ts +1 -1
- package/dist/clis/chatgpt/status.js +2 -2
- package/dist/clis/chatwise/ask.d.ts +1 -1
- package/dist/clis/chatwise/ask.js +2 -2
- package/dist/clis/chatwise/export.d.ts +1 -1
- package/dist/clis/chatwise/export.js +1 -1
- package/dist/clis/chatwise/history.d.ts +1 -1
- package/dist/clis/chatwise/history.js +1 -1
- package/dist/clis/chatwise/model.d.ts +1 -1
- package/dist/clis/chatwise/model.js +2 -2
- package/dist/clis/chatwise/new.d.ts +1 -1
- package/dist/clis/chatwise/read.d.ts +1 -1
- package/dist/clis/chatwise/read.js +1 -1
- package/dist/clis/chatwise/screenshot.d.ts +1 -1
- package/dist/clis/chatwise/send.d.ts +1 -1
- package/dist/clis/chatwise/send.js +2 -2
- package/dist/clis/chatwise/status.d.ts +1 -1
- package/dist/clis/codex/ask.d.ts +1 -1
- package/dist/clis/codex/ask.js +2 -2
- package/dist/clis/codex/dump.d.ts +1 -1
- package/dist/clis/codex/export.d.ts +1 -1
- package/dist/clis/codex/export.js +1 -1
- package/dist/clis/codex/extract-diff.d.ts +1 -1
- package/dist/clis/codex/extract-diff.js +1 -1
- package/dist/clis/codex/history.d.ts +1 -1
- package/dist/clis/codex/history.js +1 -1
- package/dist/clis/codex/model.d.ts +1 -1
- package/dist/clis/codex/model.js +1 -1
- package/dist/clis/codex/new.d.ts +1 -1
- package/dist/clis/codex/read.d.ts +1 -1
- package/dist/clis/codex/read.js +1 -1
- package/dist/clis/codex/screenshot.d.ts +1 -1
- package/dist/clis/codex/send.d.ts +1 -1
- package/dist/clis/codex/send.js +2 -2
- package/dist/clis/codex/status.d.ts +1 -1
- package/dist/clis/coupang/add-to-cart.js +1 -1
- package/dist/clis/coupang/search.js +1 -1
- package/dist/clis/ctrip/search.js +2 -2
- package/dist/clis/ctrip/search.test.js +1 -1
- package/dist/clis/cursor/ask.d.ts +1 -1
- package/dist/clis/cursor/ask.js +2 -2
- package/dist/clis/cursor/composer.d.ts +1 -1
- package/dist/clis/cursor/composer.js +2 -2
- package/dist/clis/cursor/dump.d.ts +1 -1
- package/dist/clis/cursor/export.d.ts +1 -1
- package/dist/clis/cursor/export.js +1 -1
- package/dist/clis/cursor/extract-code.d.ts +1 -1
- package/dist/clis/cursor/extract-code.js +1 -1
- package/dist/clis/cursor/history.d.ts +1 -1
- package/dist/clis/cursor/history.js +1 -1
- package/dist/clis/cursor/model.d.ts +1 -1
- package/dist/clis/cursor/model.js +1 -1
- package/dist/clis/cursor/new.d.ts +1 -1
- package/dist/clis/cursor/read.d.ts +1 -1
- package/dist/clis/cursor/read.js +2 -2
- package/dist/clis/cursor/screenshot.d.ts +1 -1
- package/dist/clis/cursor/send.d.ts +1 -1
- package/dist/clis/cursor/send.js +2 -2
- package/dist/clis/cursor/status.d.ts +1 -1
- package/dist/clis/discord-app/channels.d.ts +1 -1
- package/dist/clis/discord-app/channels.js +1 -1
- package/dist/clis/discord-app/members.d.ts +1 -1
- package/dist/clis/discord-app/members.js +1 -1
- package/dist/clis/discord-app/read.d.ts +1 -1
- package/dist/clis/discord-app/read.js +1 -1
- package/dist/clis/discord-app/search.d.ts +1 -1
- package/dist/clis/discord-app/search.js +1 -1
- package/dist/clis/discord-app/send.d.ts +1 -1
- package/dist/clis/discord-app/send.js +1 -1
- package/dist/clis/discord-app/servers.d.ts +1 -1
- package/dist/clis/discord-app/servers.js +1 -1
- package/dist/clis/discord-app/status.d.ts +1 -1
- package/dist/clis/discord-app/status.js +1 -1
- package/dist/clis/douban/book-hot.js +1 -1
- package/dist/clis/douban/download.js +2 -2
- package/dist/clis/douban/download.test.js +1 -1
- package/dist/clis/douban/marks.js +1 -1
- package/dist/clis/douban/movie-hot.js +1 -1
- package/dist/clis/douban/photos.js +1 -1
- package/dist/clis/douban/reviews.js +1 -1
- package/dist/clis/douban/search.js +1 -1
- package/dist/clis/douban/utils.d.ts +1 -1
- package/dist/clis/douban/utils.js +1 -1
- package/dist/clis/doubao/ask.d.ts +1 -1
- package/dist/clis/doubao/ask.js +1 -1
- package/dist/clis/doubao/detail.d.ts +1 -1
- package/dist/clis/doubao/detail.js +1 -1
- package/dist/clis/doubao/detail.test.js +1 -1
- package/dist/clis/doubao/history.d.ts +1 -1
- package/dist/clis/doubao/history.js +1 -1
- package/dist/clis/doubao/history.test.js +1 -1
- package/dist/clis/doubao/meeting-summary.d.ts +1 -1
- package/dist/clis/doubao/meeting-summary.js +1 -1
- package/dist/clis/doubao/meeting-transcript.d.ts +1 -1
- package/dist/clis/doubao/meeting-transcript.js +1 -1
- package/dist/clis/doubao/new.d.ts +1 -1
- package/dist/clis/doubao/new.js +1 -1
- package/dist/clis/doubao/read.d.ts +1 -1
- package/dist/clis/doubao/read.js +1 -1
- package/dist/clis/doubao/send.d.ts +1 -1
- package/dist/clis/doubao/send.js +1 -1
- package/dist/clis/doubao/status.d.ts +1 -1
- package/dist/clis/doubao/status.js +1 -1
- package/dist/clis/doubao/utils.d.ts +1 -1
- package/dist/clis/doubao-app/ask.d.ts +1 -1
- package/dist/clis/doubao-app/ask.js +1 -1
- package/dist/clis/doubao-app/dump.d.ts +1 -1
- package/dist/clis/doubao-app/dump.js +1 -1
- package/dist/clis/doubao-app/new.d.ts +1 -1
- package/dist/clis/doubao-app/new.js +1 -1
- package/dist/clis/doubao-app/read.d.ts +1 -1
- package/dist/clis/doubao-app/read.js +1 -1
- package/dist/clis/doubao-app/screenshot.d.ts +1 -1
- package/dist/clis/doubao-app/screenshot.js +1 -1
- package/dist/clis/doubao-app/send.d.ts +1 -1
- package/dist/clis/doubao-app/send.js +1 -1
- package/dist/clis/doubao-app/status.d.ts +1 -1
- package/dist/clis/doubao-app/status.js +1 -1
- package/dist/clis/douyin/_shared/browser-fetch.d.ts +1 -1
- package/dist/clis/douyin/_shared/browser-fetch.js +1 -1
- package/dist/clis/douyin/_shared/imagex-upload.js +1 -1
- package/dist/clis/douyin/_shared/imagex-upload.test.js +1 -1
- package/dist/clis/douyin/_shared/public-api.d.ts +1 -1
- package/dist/clis/douyin/_shared/sts2.d.ts +1 -1
- package/dist/clis/douyin/_shared/sts2.js +1 -1
- package/dist/clis/douyin/_shared/sts2.test.js +1 -1
- package/dist/clis/douyin/_shared/tos-upload-short-read.test.js +1 -1
- package/dist/clis/douyin/_shared/tos-upload.js +1 -1
- package/dist/clis/douyin/_shared/transcode.d.ts +1 -1
- package/dist/clis/douyin/_shared/transcode.js +1 -1
- package/dist/clis/douyin/_shared/transcode.test.js +1 -1
- package/dist/clis/douyin/activities.js +1 -1
- package/dist/clis/douyin/activities.test.js +1 -1
- package/dist/clis/douyin/collections.js +1 -1
- package/dist/clis/douyin/collections.test.js +1 -1
- package/dist/clis/douyin/delete.js +1 -1
- package/dist/clis/douyin/delete.test.js +1 -1
- package/dist/clis/douyin/draft.js +2 -2
- package/dist/clis/douyin/draft.test.js +1 -1
- package/dist/clis/douyin/drafts.js +1 -1
- package/dist/clis/douyin/drafts.test.js +1 -1
- package/dist/clis/douyin/hashtag.js +2 -2
- package/dist/clis/douyin/hashtag.test.js +1 -1
- package/dist/clis/douyin/location.js +1 -1
- package/dist/clis/douyin/location.test.js +1 -1
- package/dist/clis/douyin/profile.js +2 -2
- package/dist/clis/douyin/profile.test.js +1 -1
- package/dist/clis/douyin/publish.js +2 -2
- package/dist/clis/douyin/publish.test.js +1 -1
- package/dist/clis/douyin/stats.js +1 -1
- package/dist/clis/douyin/stats.test.js +1 -1
- package/dist/clis/douyin/update.js +2 -2
- package/dist/clis/douyin/update.test.js +1 -1
- package/dist/clis/douyin/user-videos.js +1 -1
- package/dist/clis/douyin/user-videos.test.js +1 -1
- package/dist/clis/douyin/videos.js +1 -1
- package/dist/clis/douyin/videos.test.js +1 -1
- package/dist/clis/gemini/ask.d.ts +1 -1
- package/dist/clis/gemini/ask.js +1 -1
- package/dist/clis/gemini/deep-research-result.d.ts +1 -0
- package/dist/clis/gemini/deep-research-result.js +91 -0
- package/dist/clis/gemini/deep-research-result.test.js +154 -0
- package/dist/clis/gemini/deep-research.d.ts +1 -0
- package/dist/clis/gemini/deep-research.js +98 -0
- package/dist/clis/gemini/deep-research.test.js +184 -0
- package/dist/clis/gemini/image.d.ts +1 -1
- package/dist/clis/gemini/image.js +2 -2
- package/dist/clis/gemini/new.d.ts +1 -1
- package/dist/clis/gemini/new.js +1 -1
- package/dist/clis/gemini/reply-state.test.js +30 -0
- package/dist/clis/gemini/utils.d.ts +30 -1
- package/dist/clis/gemini/utils.js +1014 -2
- package/dist/clis/gemini/utils.test.js +21 -1
- package/dist/clis/google/news.js +2 -2
- package/dist/clis/google/search.js +2 -2
- package/dist/clis/google/suggest.js +2 -2
- package/dist/clis/google/trends.js +2 -2
- package/dist/clis/grok/ask.d.ts +2 -2
- package/dist/clis/grok/ask.js +1 -1
- package/dist/clis/hf/top.js +2 -2
- package/dist/clis/hupu/detail.js +1 -1
- package/dist/clis/hupu/like.js +2 -2
- package/dist/clis/hupu/mentions.js +159 -0
- package/dist/clis/hupu/reply.js +2 -2
- package/dist/clis/hupu/search.js +1 -1
- package/dist/clis/hupu/unlike.js +2 -2
- package/dist/clis/hupu/utils.d.ts +1 -1
- package/dist/clis/hupu/utils.js +1 -1
- package/dist/clis/imdb/person.js +2 -2
- package/dist/clis/imdb/reviews.js +2 -2
- package/dist/clis/imdb/search.js +2 -2
- package/dist/clis/imdb/title.js +2 -2
- package/dist/clis/imdb/top.js +2 -2
- package/dist/clis/imdb/trending.js +2 -2
- package/dist/clis/imdb/utils.d.ts +1 -1
- package/dist/clis/imdb/utils.js +1 -1
- package/dist/clis/instagram/_shared/private-publish.d.ts +1 -1
- package/dist/clis/instagram/_shared/private-publish.js +1 -1
- package/dist/clis/instagram/_shared/protocol-capture.d.ts +1 -1
- package/dist/clis/instagram/_shared/runtime-info.d.ts +1 -1
- package/dist/clis/instagram/download.js +2 -2
- package/dist/clis/instagram/download.test.js +2 -2
- package/dist/clis/instagram/note.js +2 -2
- package/dist/clis/instagram/note.test.js +2 -2
- package/dist/clis/instagram/post.js +2 -2
- package/dist/clis/instagram/post.test.js +2 -2
- package/dist/clis/instagram/reel.js +2 -2
- package/dist/clis/instagram/reel.test.js +2 -2
- package/dist/clis/instagram/story.js +2 -2
- package/dist/clis/instagram/story.test.js +2 -2
- package/dist/clis/jd/item.js +1 -1
- package/dist/clis/jd/item.test.js +1 -1
- package/dist/clis/jike/comment.js +1 -1
- package/dist/clis/jike/create.js +1 -1
- package/dist/clis/jike/feed.js +1 -1
- package/dist/clis/jike/like.js +1 -1
- package/dist/clis/jike/notifications.js +1 -1
- package/dist/clis/jike/repost.js +1 -1
- package/dist/clis/jike/search.js +1 -1
- package/dist/clis/lesswrong/_helpers.d.ts +15 -0
- package/dist/clis/lesswrong/_helpers.js +75 -0
- package/dist/clis/lesswrong/comments.js +64 -0
- package/dist/clis/lesswrong/curated.js +30 -0
- package/dist/clis/lesswrong/frontpage.js +30 -0
- package/dist/clis/lesswrong/new.js +30 -0
- package/dist/clis/lesswrong/read.js +45 -0
- package/dist/clis/lesswrong/sequences.js +27 -0
- package/dist/clis/lesswrong/shortform.js +30 -0
- package/dist/clis/lesswrong/tag.js +45 -0
- package/dist/clis/lesswrong/tags.js +27 -0
- package/dist/clis/lesswrong/top-month.js +30 -0
- package/dist/clis/lesswrong/top-week.js +30 -0
- package/dist/clis/lesswrong/top-year.js +30 -0
- package/dist/clis/lesswrong/top.js +30 -0
- package/dist/clis/lesswrong/user-posts.js +41 -0
- package/dist/clis/lesswrong/user.js +44 -0
- package/dist/clis/linkedin/search.js +2 -2
- package/dist/clis/linkedin/timeline.js +2 -2
- package/dist/clis/linkedin/timeline.test.js +1 -1
- package/dist/clis/linux-do/category.js +1 -1
- package/dist/clis/linux-do/feed.d.ts +2 -2
- package/dist/clis/linux-do/feed.js +2 -2
- package/dist/clis/linux-do/hot.js +1 -1
- package/dist/clis/linux-do/latest.js +1 -1
- package/dist/clis/medium/feed.js +1 -1
- package/dist/clis/medium/search.js +1 -1
- package/dist/clis/medium/user.js +1 -1
- package/dist/clis/medium/utils.d.ts +1 -1
- package/dist/clis/medium/utils.js +1 -1
- package/dist/clis/notebooklm/compat.test.js +1 -1
- package/dist/clis/notebooklm/current.js +2 -2
- package/dist/clis/notebooklm/get.js +2 -2
- package/dist/clis/notebooklm/history.js +2 -2
- package/dist/clis/notebooklm/history.test.js +1 -1
- package/dist/clis/notebooklm/list.js +2 -2
- package/dist/clis/notebooklm/note-list.js +2 -2
- package/dist/clis/notebooklm/note-list.test.js +1 -1
- package/dist/clis/notebooklm/notes-get.js +2 -2
- package/dist/clis/notebooklm/notes-get.test.js +1 -1
- package/dist/clis/notebooklm/open.js +2 -2
- package/dist/clis/notebooklm/open.test.js +1 -1
- package/dist/clis/notebooklm/rpc.d.ts +1 -1
- package/dist/clis/notebooklm/rpc.js +1 -1
- package/dist/clis/notebooklm/rpc.test.js +1 -1
- package/dist/clis/notebooklm/source-fulltext.js +2 -2
- package/dist/clis/notebooklm/source-fulltext.test.js +1 -1
- package/dist/clis/notebooklm/source-get.js +2 -2
- package/dist/clis/notebooklm/source-get.test.js +1 -1
- package/dist/clis/notebooklm/source-guide.js +2 -2
- package/dist/clis/notebooklm/source-guide.test.js +1 -1
- package/dist/clis/notebooklm/source-list.js +2 -2
- package/dist/clis/notebooklm/status.js +1 -1
- package/dist/clis/notebooklm/summary.js +2 -2
- package/dist/clis/notebooklm/summary.test.js +1 -1
- package/dist/clis/notebooklm/utils.d.ts +1 -1
- package/dist/clis/notebooklm/utils.js +1 -1
- package/dist/clis/notion/export.d.ts +1 -1
- package/dist/clis/notion/export.js +1 -1
- package/dist/clis/notion/favorites.d.ts +1 -1
- package/dist/clis/notion/favorites.js +1 -1
- package/dist/clis/notion/new.d.ts +1 -1
- package/dist/clis/notion/new.js +1 -1
- package/dist/clis/notion/read.d.ts +1 -1
- package/dist/clis/notion/read.js +1 -1
- package/dist/clis/notion/search.d.ts +1 -1
- package/dist/clis/notion/search.js +1 -1
- package/dist/clis/notion/sidebar.d.ts +1 -1
- package/dist/clis/notion/sidebar.js +1 -1
- package/dist/clis/notion/status.d.ts +1 -1
- package/dist/clis/notion/status.js +1 -1
- package/dist/clis/notion/write.d.ts +1 -1
- package/dist/clis/notion/write.js +1 -1
- package/dist/clis/ones/common.d.ts +1 -1
- package/dist/clis/ones/common.js +1 -1
- package/dist/clis/ones/enrich-tasks.d.ts +1 -1
- package/dist/clis/ones/login.js +2 -2
- package/dist/clis/ones/logout.js +1 -1
- package/dist/clis/ones/me.js +2 -2
- package/dist/clis/ones/my-tasks.js +2 -2
- package/dist/clis/ones/resolve-labels.d.ts +1 -1
- package/dist/clis/ones/task-helpers.js +1 -1
- package/dist/clis/ones/task.js +2 -2
- package/dist/clis/ones/tasks.js +2 -2
- package/dist/clis/ones/token-info.js +2 -2
- package/dist/clis/ones/worklog.js +2 -2
- package/dist/clis/paperreview/commands.test.js +1 -1
- package/dist/clis/paperreview/feedback.js +2 -2
- package/dist/clis/paperreview/review.js +2 -2
- package/dist/clis/paperreview/submit.js +2 -2
- package/dist/clis/paperreview/utils.js +1 -1
- package/dist/clis/paperreview/utils.test.js +1 -1
- package/dist/clis/pixiv/download.js +2 -2
- package/dist/clis/pixiv/download.test.js +2 -2
- package/dist/clis/pixiv/illusts.js +2 -2
- package/dist/clis/pixiv/illusts.test.js +2 -2
- package/dist/clis/pixiv/search.js +1 -1
- package/dist/clis/pixiv/search.test.js +2 -2
- package/dist/clis/pixiv/test-utils.d.ts +1 -1
- package/dist/clis/pixiv/utils.d.ts +1 -1
- package/dist/clis/pixiv/utils.js +1 -1
- package/dist/clis/producthunt/browse.js +2 -2
- package/dist/clis/producthunt/hot.js +2 -2
- package/dist/clis/producthunt/posts.js +1 -1
- package/dist/clis/producthunt/today.js +1 -1
- package/dist/clis/reddit/comment.js +2 -2
- package/dist/clis/reddit/read.js +2 -2
- package/dist/clis/reddit/read.test.js +1 -1
- package/dist/clis/reddit/save.js +2 -2
- package/dist/clis/reddit/saved.js +2 -2
- package/dist/clis/reddit/subscribe.js +2 -2
- package/dist/clis/reddit/upvote.js +2 -2
- package/dist/clis/reddit/upvoted.js +2 -2
- package/dist/clis/reuters/search.js +1 -1
- package/dist/clis/sinablog/article.js +1 -1
- package/dist/clis/sinablog/hot.js +1 -1
- package/dist/clis/sinablog/search.js +1 -1
- package/dist/clis/sinablog/user.js +1 -1
- package/dist/clis/sinablog/utils.d.ts +1 -1
- package/dist/clis/sinafinance/news.js +2 -2
- package/dist/clis/sinafinance/rolling-news.js +1 -1
- package/dist/clis/sinafinance/stock-rank.js +1 -1
- package/dist/clis/sinafinance/stock.js +2 -2
- package/dist/clis/smzdm/search.js +1 -1
- package/dist/clis/spotify/spotify.js +2 -2
- package/dist/clis/spotify/utils.js +1 -1
- package/dist/clis/substack/feed.js +1 -1
- package/dist/clis/substack/publication.js +1 -1
- package/dist/clis/substack/search.js +2 -2
- package/dist/clis/substack/utils.d.ts +1 -1
- package/dist/clis/substack/utils.js +1 -1
- package/dist/clis/tieba/commands.test.js +1 -1
- package/dist/clis/tieba/hot.js +2 -2
- package/dist/clis/tieba/posts.js +2 -2
- package/dist/clis/tieba/read.js +2 -2
- package/dist/clis/tieba/search.js +2 -2
- package/dist/clis/twitter/accept.js +2 -2
- package/dist/clis/twitter/article.js +2 -2
- package/dist/clis/twitter/block.js +2 -2
- package/dist/clis/twitter/bookmark.js +2 -2
- package/dist/clis/twitter/bookmarks.js +2 -2
- package/dist/clis/twitter/delete.d.ts +6 -0
- package/dist/clis/twitter/delete.js +82 -47
- package/dist/clis/twitter/delete.test.d.ts +1 -0
- package/dist/clis/twitter/delete.test.js +73 -0
- package/dist/clis/twitter/download.js +1 -1
- package/dist/clis/twitter/follow.js +2 -2
- package/dist/clis/twitter/followers.js +2 -2
- package/dist/clis/twitter/following.js +2 -2
- package/dist/clis/twitter/hide-reply.js +2 -2
- package/dist/clis/twitter/like.js +2 -2
- package/dist/clis/twitter/likes.js +2 -2
- package/dist/clis/twitter/notifications.js +2 -2
- package/dist/clis/twitter/post.js +2 -2
- package/dist/clis/twitter/post.test.js +1 -1
- package/dist/clis/twitter/profile.js +2 -2
- package/dist/clis/twitter/reply-dm.js +2 -2
- package/dist/clis/twitter/reply.js +2 -2
- package/dist/clis/twitter/reply.test.js +1 -1
- package/dist/clis/twitter/search.js +2 -2
- package/dist/clis/twitter/search.test.js +1 -1
- package/dist/clis/twitter/shared.d.ts +1 -1
- package/dist/clis/twitter/thread.js +2 -2
- package/dist/clis/twitter/timeline.js +2 -2
- package/dist/clis/twitter/trending.js +2 -2
- package/dist/clis/twitter/unblock.js +2 -2
- package/dist/clis/twitter/unbookmark.js +2 -2
- package/dist/clis/twitter/unfollow.js +2 -2
- package/dist/clis/v2ex/daily.js +2 -2
- package/dist/clis/v2ex/me.js +2 -2
- package/dist/clis/v2ex/notifications.js +2 -2
- package/dist/clis/web/read.js +1 -1
- package/dist/clis/weibo/comments.js +1 -1
- package/dist/clis/weibo/feed.js +1 -1
- package/dist/clis/weibo/hot.js +1 -1
- package/dist/clis/weibo/me.js +2 -2
- package/dist/clis/weibo/post.js +2 -2
- package/dist/clis/weibo/search.js +2 -2
- package/dist/clis/weibo/user.js +2 -2
- package/dist/clis/weibo/utils.d.ts +1 -1
- package/dist/clis/weibo/utils.js +1 -1
- package/dist/clis/weixin/download.js +1 -1
- package/dist/clis/weread/book.js +2 -2
- package/dist/clis/weread/commands.test.js +2 -2
- package/dist/clis/weread/highlights.js +1 -1
- package/dist/clis/weread/notebooks.js +1 -1
- package/dist/clis/weread/notes.js +1 -1
- package/dist/clis/weread/private-api-regression.test.js +2 -2
- package/dist/clis/weread/ranking.js +1 -1
- package/dist/clis/weread/search-regression.test.js +1 -1
- package/dist/clis/weread/search.js +1 -1
- package/dist/clis/weread/shelf.js +3 -3
- package/dist/clis/weread/utils.d.ts +1 -1
- package/dist/clis/weread/utils.js +1 -1
- package/dist/clis/wikipedia/random.js +2 -2
- package/dist/clis/wikipedia/search.js +2 -2
- package/dist/clis/wikipedia/summary.js +2 -2
- package/dist/clis/wikipedia/trending.js +2 -2
- package/dist/clis/wikipedia/utils.js +1 -1
- package/dist/clis/xianyu/chat.js +2 -2
- package/dist/clis/xianyu/item.js +2 -2
- package/dist/clis/xianyu/item.test.js +2 -2
- package/dist/clis/xianyu/search.js +2 -2
- package/dist/clis/xianyu/utils.js +1 -1
- package/dist/clis/xiaohongshu/comments.js +2 -2
- package/dist/clis/xiaohongshu/comments.test.js +3 -3
- package/dist/clis/xiaohongshu/creator-note-detail.d.ts +1 -1
- package/dist/clis/xiaohongshu/creator-note-detail.js +1 -1
- package/dist/clis/xiaohongshu/creator-note-detail.test.js +1 -1
- package/dist/clis/xiaohongshu/creator-notes-summary.js +1 -1
- package/dist/clis/xiaohongshu/creator-notes.d.ts +1 -1
- package/dist/clis/xiaohongshu/creator-notes.js +1 -1
- package/dist/clis/xiaohongshu/creator-notes.test.js +1 -1
- package/dist/clis/xiaohongshu/creator-profile.js +1 -1
- package/dist/clis/xiaohongshu/creator-stats.js +1 -1
- package/dist/clis/xiaohongshu/download.js +1 -1
- package/dist/clis/xiaohongshu/download.test.js +1 -1
- package/dist/clis/xiaohongshu/note-helpers.d.ts +2 -2
- package/dist/clis/xiaohongshu/note-helpers.js +5 -3
- package/dist/clis/xiaohongshu/note.d.ts +4 -0
- package/dist/clis/xiaohongshu/note.js +10 -12
- package/dist/clis/xiaohongshu/note.test.js +6 -6
- package/dist/clis/xiaohongshu/publish.js +1 -1
- package/dist/clis/xiaohongshu/publish.test.js +1 -1
- package/dist/clis/xiaohongshu/search.js +2 -2
- package/dist/clis/xiaohongshu/search.test.js +1 -1
- package/dist/clis/xiaohongshu/user.js +1 -1
- package/dist/clis/xiaoyuzhou/episode.js +2 -2
- package/dist/clis/xiaoyuzhou/podcast-episodes.js +2 -2
- package/dist/clis/xiaoyuzhou/podcast.js +2 -2
- package/dist/clis/xiaoyuzhou/utils.js +1 -1
- package/dist/clis/xueqiu/comments.d.ts +1 -1
- package/dist/clis/xueqiu/comments.js +4 -4
- package/dist/clis/xueqiu/comments.test.js +3 -3
- package/dist/clis/xueqiu/danjuan-utils.d.ts +1 -1
- package/dist/clis/xueqiu/fund-holdings.js +1 -1
- package/dist/clis/xueqiu/fund-snapshot.js +1 -1
- package/dist/clis/yahoo-finance/quote.js +1 -1
- package/dist/clis/yollomi/background.js +2 -2
- package/dist/clis/yollomi/edit.js +2 -2
- package/dist/clis/yollomi/face-swap.js +2 -2
- package/dist/clis/yollomi/generate.js +2 -2
- package/dist/clis/yollomi/models.js +1 -1
- package/dist/clis/yollomi/object-remover.js +2 -2
- package/dist/clis/yollomi/remove-bg.js +2 -2
- package/dist/clis/yollomi/restore.js +2 -2
- package/dist/clis/yollomi/try-on.js +2 -2
- package/dist/clis/yollomi/upload.js +2 -2
- package/dist/clis/yollomi/upscale.js +2 -2
- package/dist/clis/yollomi/utils.d.ts +1 -1
- package/dist/clis/yollomi/utils.js +1 -1
- package/dist/clis/yollomi/video.js +2 -2
- package/dist/clis/youtube/channel.js +2 -2
- package/dist/clis/youtube/comments.js +2 -2
- package/dist/clis/youtube/search.js +1 -1
- package/dist/clis/youtube/transcript.js +2 -2
- package/dist/clis/youtube/utils.d.ts +1 -1
- package/dist/clis/youtube/video.js +2 -2
- package/dist/clis/yuanbao/ask.d.ts +1 -1
- package/dist/clis/yuanbao/ask.js +2 -2
- package/dist/clis/yuanbao/ask.test.js +1 -1
- package/dist/clis/yuanbao/new.d.ts +1 -1
- package/dist/clis/yuanbao/new.js +1 -1
- package/dist/clis/yuanbao/new.test.js +1 -1
- package/dist/clis/yuanbao/shared.d.ts +2 -2
- package/dist/clis/yuanbao/shared.js +1 -1
- package/dist/clis/zhihu/download.js +1 -1
- package/dist/clis/zhihu/question.js +2 -2
- package/dist/clis/zhihu/question.test.js +2 -2
- package/dist/clis/zsxq/dynamics.js +1 -1
- package/dist/clis/zsxq/groups.js +1 -1
- package/dist/clis/zsxq/search.js +1 -1
- package/dist/clis/zsxq/search.test.js +1 -1
- package/dist/clis/zsxq/topic.js +2 -2
- package/dist/clis/zsxq/topic.test.js +1 -1
- package/dist/clis/zsxq/topics.js +1 -1
- package/dist/clis/zsxq/topics.test.js +1 -1
- package/dist/clis/zsxq/utils.d.ts +1 -1
- package/dist/clis/zsxq/utils.js +1 -1
- package/dist/download/article-download.d.ts +1 -59
- package/dist/download/article-download.js +2 -178
- package/dist/download/index.d.ts +1 -71
- package/dist/download/index.js +2 -345
- package/dist/download/media-download.d.ts +1 -49
- package/dist/download/media-download.js +2 -114
- package/dist/download/progress.d.ts +1 -36
- package/dist/download/progress.js +2 -111
- package/dist/pipeline/index.d.ts +1 -5
- package/dist/pipeline/index.js +2 -5
- package/dist/src/browser/cdp.d.ts +40 -0
- package/dist/src/browser/cdp.js +310 -0
- package/dist/src/browser/page.d.ts +62 -0
- package/dist/src/browser/page.js +304 -0
- package/dist/src/browser/utils.d.ts +10 -0
- package/dist/src/browser/utils.js +27 -0
- package/dist/{build-manifest.js → src/build-manifest.js} +5 -4
- package/dist/{cascade.js → src/cascade.js} +16 -31
- package/dist/src/cli.d.ts +22 -0
- package/dist/{cli.js → src/cli.js} +78 -8
- package/dist/{cli.test.js → src/cli.test.js} +84 -1
- package/dist/{commanderAdapter.d.ts → src/commanderAdapter.d.ts} +1 -0
- package/dist/{commanderAdapter.js → src/commanderAdapter.js} +26 -46
- package/dist/{discovery.d.ts → src/discovery.d.ts} +11 -2
- package/dist/{discovery.js → src/discovery.js} +101 -12
- package/dist/src/doctor.test.d.ts +1 -0
- package/dist/src/download/article-download.d.ts +59 -0
- package/dist/src/download/article-download.js +178 -0
- package/dist/src/download/index.d.ts +71 -0
- package/dist/src/download/index.js +345 -0
- package/dist/src/download/index.test.d.ts +1 -0
- package/dist/src/download/media-download.d.ts +49 -0
- package/dist/src/download/media-download.js +114 -0
- package/dist/src/download/progress.d.ts +36 -0
- package/dist/src/download/progress.js +111 -0
- package/dist/src/electron-apps.test.d.ts +1 -0
- package/dist/src/engine.test.d.ts +1 -0
- package/dist/src/errors.test.d.ts +1 -0
- package/dist/src/execution.test.d.ts +1 -0
- package/dist/src/extension-manifest-regression.test.d.ts +1 -0
- package/dist/src/external.test.d.ts +1 -0
- package/dist/{interceptor.d.ts → src/interceptor.d.ts} +2 -0
- package/dist/{interceptor.js → src/interceptor.js} +3 -6
- package/dist/src/launcher.test.d.ts +1 -0
- package/dist/{main.js → src/main.js} +3 -2
- package/dist/src/node-network.test.d.ts +1 -0
- package/dist/src/output.test.d.ts +1 -0
- package/{src/pipeline/index.ts → dist/src/pipeline/index.d.ts} +0 -1
- package/dist/src/pipeline/index.js +5 -0
- package/dist/src/pipeline/steps/download.test.d.ts +1 -0
- package/dist/src/pipeline/steps/fetch.test.d.ts +1 -0
- package/dist/{record.js → src/record.js} +1 -1
- package/dist/src/record.test.d.ts +1 -0
- package/dist/src/runtime-detect.test.d.ts +1 -0
- package/dist/src/serialization.test.d.ts +1 -0
- package/dist/{synthesize.d.ts → src/synthesize.d.ts} +0 -4
- package/dist/{synthesize.js → src/synthesize.js} +4 -15
- package/dist/src/tui.test.d.ts +1 -0
- package/dist/{version.js → src/version.js} +7 -1
- package/dist/src/weixin-download.test.d.ts +1 -0
- package/dist/{weixin-download.test.js → src/weixin-download.test.js} +1 -1
- package/package.json +26 -9
- package/scripts/check-doc-coverage.sh +2 -2
- package/scripts/copy-yaml.cjs +4 -4
- package/scripts/fetch-adapters.js +157 -0
- package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -83
- package/.github/ISSUE_TEMPLATE/config.yml +0 -8
- package/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
- package/.github/ISSUE_TEMPLATE/new_site_adapter.yml +0 -57
- package/.github/actions/setup-chrome/action.yml +0 -27
- package/.github/dependabot.yml +0 -27
- package/.github/pull_request_template.md +0 -33
- package/.github/workflows/build-extension.yml +0 -67
- package/.github/workflows/ci.yml +0 -147
- package/.github/workflows/doc-check.yml +0 -36
- package/.github/workflows/docs.yml +0 -17
- package/.github/workflows/e2e-headed.yml +0 -74
- package/.github/workflows/release.yml +0 -44
- package/.github/workflows/security.yml +0 -33
- package/CHANGELOG.md +0 -321
- package/CONTRIBUTING.md +0 -208
- package/PRIVACY.md +0 -57
- package/TESTING.md +0 -252
- package/autoresearch/baseline-browse.txt +0 -1
- package/autoresearch/baseline-skill.txt +0 -1
- package/autoresearch/browse-tasks.json +0 -686
- package/autoresearch/commands/debug.ts +0 -163
- package/autoresearch/commands/fix.ts +0 -145
- package/autoresearch/commands/plan.ts +0 -88
- package/autoresearch/commands/run.ts +0 -138
- package/autoresearch/config.ts +0 -82
- package/autoresearch/engine.ts +0 -359
- package/autoresearch/eval-all.ts +0 -127
- package/autoresearch/eval-browse.ts +0 -185
- package/autoresearch/eval-publish.ts +0 -238
- package/autoresearch/eval-save.ts +0 -249
- package/autoresearch/eval-skill.ts +0 -254
- package/autoresearch/eval-v2ex.ts +0 -220
- package/autoresearch/eval-zhihu.ts +0 -230
- package/autoresearch/logger.ts +0 -69
- package/autoresearch/presets/combined-reliability.ts +0 -27
- package/autoresearch/presets/index.ts +0 -23
- package/autoresearch/presets/operate-reliability.ts +0 -24
- package/autoresearch/presets/save-reliability.ts +0 -26
- package/autoresearch/presets/skill-quality.ts +0 -20
- package/autoresearch/presets/v2ex-reliability.ts +0 -24
- package/autoresearch/presets/zhihu-reliability.ts +0 -25
- package/autoresearch/publish-tasks.json +0 -345
- package/autoresearch/run-browse.sh +0 -9
- package/autoresearch/run-save.sh +0 -11
- package/autoresearch/run-skill.sh +0 -9
- package/autoresearch/save-adapters/xhs-explore-deep.ts +0 -64
- package/autoresearch/save-adapters/xhs-note-comments.ts +0 -61
- package/autoresearch/save-adapters/xhs-search-full.ts +0 -62
- package/autoresearch/save-adapters/zhihu-hot-detail.ts +0 -52
- package/autoresearch/save-adapters/zhihu-question-full.ts +0 -57
- package/autoresearch/save-adapters/zhihu-search-detail.ts +0 -53
- package/autoresearch/save-tasks.json +0 -281
- package/autoresearch/v2ex-tasks.json +0 -899
- package/autoresearch/zhihu-tasks.json +0 -848
- package/bun.lock +0 -615
- package/dist/cli.d.ts +0 -9
- package/docs/.vitepress/config.mts +0 -238
- package/docs/adapters/browser/1688.md +0 -52
- package/docs/adapters/browser/36kr.md +0 -48
- package/docs/adapters/browser/amazon.md +0 -53
- package/docs/adapters/browser/apple-podcasts.md +0 -28
- package/docs/adapters/browser/arxiv.md +0 -27
- package/docs/adapters/browser/band.md +0 -63
- package/docs/adapters/browser/barchart.md +0 -33
- package/docs/adapters/browser/bbc.md +0 -26
- package/docs/adapters/browser/bilibili.md +0 -47
- package/docs/adapters/browser/bloomberg.md +0 -70
- package/docs/adapters/browser/bluesky.md +0 -53
- package/docs/adapters/browser/boss.md +0 -28
- package/docs/adapters/browser/chaoxing.md +0 -39
- package/docs/adapters/browser/coupang.md +0 -28
- package/docs/adapters/browser/ctrip.md +0 -27
- package/docs/adapters/browser/devto.md +0 -35
- package/docs/adapters/browser/dictionary.md +0 -27
- package/docs/adapters/browser/douban.md +0 -62
- package/docs/adapters/browser/doubao.md +0 -39
- package/docs/adapters/browser/douyin.md +0 -75
- package/docs/adapters/browser/facebook.md +0 -36
- package/docs/adapters/browser/gemini.md +0 -72
- package/docs/adapters/browser/google.md +0 -62
- package/docs/adapters/browser/grok.md +0 -53
- package/docs/adapters/browser/hackernews.md +0 -42
- package/docs/adapters/browser/hf.md +0 -42
- package/docs/adapters/browser/hupu.md +0 -53
- package/docs/adapters/browser/imdb.md +0 -47
- package/docs/adapters/browser/instagram.md +0 -46
- package/docs/adapters/browser/jd.md +0 -27
- package/docs/adapters/browser/jike.md +0 -45
- package/docs/adapters/browser/jimeng.md +0 -39
- package/docs/adapters/browser/linkedin.md +0 -33
- package/docs/adapters/browser/linux-do.md +0 -206
- package/docs/adapters/browser/lobsters.md +0 -32
- package/docs/adapters/browser/medium.md +0 -32
- package/docs/adapters/browser/notebooklm.md +0 -69
- package/docs/adapters/browser/ones.md +0 -59
- package/docs/adapters/browser/paperreview.md +0 -43
- package/docs/adapters/browser/pixiv.md +0 -92
- package/docs/adapters/browser/producthunt.md +0 -49
- package/docs/adapters/browser/reddit.md +0 -50
- package/docs/adapters/browser/reuters.md +0 -27
- package/docs/adapters/browser/sinablog.md +0 -36
- package/docs/adapters/browser/sinafinance.md +0 -115
- package/docs/adapters/browser/smzdm.md +0 -27
- package/docs/adapters/browser/spotify.md +0 -62
- package/docs/adapters/browser/stackoverflow.md +0 -35
- package/docs/adapters/browser/steam.md +0 -26
- package/docs/adapters/browser/substack.md +0 -38
- package/docs/adapters/browser/tieba.md +0 -45
- package/docs/adapters/browser/tiktok.md +0 -68
- package/docs/adapters/browser/twitter.md +0 -56
- package/docs/adapters/browser/v2ex.md +0 -53
- package/docs/adapters/browser/web.md +0 -30
- package/docs/adapters/browser/weibo.md +0 -36
- package/docs/adapters/browser/weixin.md +0 -33
- package/docs/adapters/browser/weread.md +0 -48
- package/docs/adapters/browser/wikipedia.md +0 -32
- package/docs/adapters/browser/xianyu.md +0 -42
- package/docs/adapters/browser/xiaoe.md +0 -44
- package/docs/adapters/browser/xiaohongshu.md +0 -47
- package/docs/adapters/browser/xiaoyuzhou.md +0 -28
- package/docs/adapters/browser/xueqiu.md +0 -65
- package/docs/adapters/browser/yahoo-finance.md +0 -27
- package/docs/adapters/browser/yollomi.md +0 -69
- package/docs/adapters/browser/youtube.md +0 -29
- package/docs/adapters/browser/yuanbao.md +0 -64
- package/docs/adapters/browser/zhihu.md +0 -30
- package/docs/adapters/browser/zsxq.md +0 -49
- package/docs/adapters/desktop/antigravity.md +0 -49
- package/docs/adapters/desktop/chatgpt.md +0 -49
- package/docs/adapters/desktop/chatwise.md +0 -38
- package/docs/adapters/desktop/codex.md +0 -36
- package/docs/adapters/desktop/cursor.md +0 -37
- package/docs/adapters/desktop/discord.md +0 -28
- package/docs/adapters/desktop/doubao-app.md +0 -35
- package/docs/adapters/desktop/notion.md +0 -29
- package/docs/adapters/index.md +0 -96
- package/docs/adapters-doc/ones.md +0 -32
- package/docs/advanced/cdp.md +0 -103
- package/docs/advanced/download.md +0 -71
- package/docs/advanced/electron.md +0 -125
- package/docs/advanced/rate-limiter-plugin.md +0 -99
- package/docs/advanced/remote-chrome.md +0 -72
- package/docs/comparison.md +0 -125
- package/docs/developer/ai-workflow.md +0 -66
- package/docs/developer/architecture.md +0 -103
- package/docs/developer/contributing.md +0 -155
- package/docs/developer/testing.md +0 -263
- package/docs/developer/ts-adapter.md +0 -105
- package/docs/developer/yaml-adapter.md +0 -124
- package/docs/guide/browser-bridge.md +0 -49
- package/docs/guide/electron-app-cli.md +0 -200
- package/docs/guide/getting-started.md +0 -79
- package/docs/guide/installation.md +0 -37
- package/docs/guide/plugins.md +0 -261
- package/docs/guide/troubleshooting.md +0 -72
- package/docs/index.md +0 -35
- package/docs/superpowers/plans/2026-03-28-perf-smart-wait.md +0 -1143
- package/docs/superpowers/plans/2026-03-31-daemon-lifecycle-redesign.md +0 -857
- package/docs/superpowers/specs/2026-03-28-perf-smart-wait-design.md +0 -170
- package/docs/superpowers/specs/2026-03-31-daemon-lifecycle-redesign.md +0 -208
- package/docs/superpowers/specs/2026-04-02-browse-skill-testing-design.md +0 -144
- package/docs/superpowers/specs/2026-04-03-v2ex-autoresearch-design.md +0 -41
- package/docs/zh/adapters/index.md +0 -5
- package/docs/zh/advanced/cdp.md +0 -3
- package/docs/zh/developer/contributing.md +0 -24
- package/docs/zh/guide/browser-bridge.md +0 -36
- package/docs/zh/guide/electron-app-cli.md +0 -188
- package/docs/zh/guide/getting-started.md +0 -62
- package/docs/zh/guide/installation.md +0 -37
- package/docs/zh/guide/plugins.md +0 -183
- package/docs/zh/index.md +0 -29
- package/extension/dist/background.js +0 -1127
- package/extension/icons/icon-128.png +0 -0
- package/extension/icons/icon-16.png +0 -0
- package/extension/icons/icon-32.png +0 -0
- package/extension/icons/icon-48.png +0 -0
- package/extension/manifest.json +0 -39
- package/extension/package-lock.json +0 -1156
- package/extension/package.json +0 -17
- package/extension/popup.html +0 -84
- package/extension/popup.js +0 -25
- package/extension/scripts/package-release.mjs +0 -179
- package/extension/src/background.test.ts +0 -279
- package/extension/src/background.ts +0 -878
- package/extension/src/cdp.test.ts +0 -75
- package/extension/src/cdp.ts +0 -440
- package/extension/src/protocol.ts +0 -87
- package/extension/store-assets/screenshot-1280x800.png +0 -0
- package/extension/tsconfig.json +0 -15
- package/extension/vite.config.ts +0 -18
- package/skills/opencli-explorer/SKILL.md +0 -853
- package/skills/opencli-oneshot/SKILL.md +0 -222
- package/skills/opencli-operate/SKILL.md +0 -306
- package/skills/opencli-usage/SKILL.md +0 -163
- package/skills/opencli-usage/browser.md +0 -527
- package/skills/opencli-usage/desktop.md +0 -118
- package/skills/opencli-usage/plugins.md +0 -82
- package/skills/opencli-usage/public-api.md +0 -178
- package/skills/smart-search/SKILL.md +0 -156
- package/skills/smart-search/references/sources-ai.md +0 -74
- package/skills/smart-search/references/sources-info.md +0 -43
- package/skills/smart-search/references/sources-media.md +0 -50
- package/skills/smart-search/references/sources-other.md +0 -42
- package/skills/smart-search/references/sources-shopping.md +0 -31
- package/skills/smart-search/references/sources-social.md +0 -51
- package/skills/smart-search/references/sources-tech.md +0 -42
- package/skills/smart-search/references/sources-travel.md +0 -20
- package/src/analysis.ts +0 -170
- package/src/browser/base-page.ts +0 -232
- package/src/browser/bridge.ts +0 -129
- package/src/browser/cdp.test.ts +0 -66
- package/src/browser/cdp.ts +0 -341
- package/src/browser/daemon-client.test.ts +0 -103
- package/src/browser/daemon-client.ts +0 -175
- package/src/browser/discover.ts +0 -26
- package/src/browser/dom-helpers.test.ts +0 -114
- package/src/browser/dom-helpers.ts +0 -238
- package/src/browser/dom-snapshot.test.ts +0 -291
- package/src/browser/dom-snapshot.ts +0 -845
- package/src/browser/errors.ts +0 -63
- package/src/browser/index.ts +0 -14
- package/src/browser/page.test.ts +0 -58
- package/src/browser/page.ts +0 -315
- package/src/browser/stealth.test.ts +0 -153
- package/src/browser/stealth.ts +0 -354
- package/src/browser/tabs.ts +0 -76
- package/src/browser/utils.ts +0 -27
- package/src/browser.test.ts +0 -195
- package/src/build-manifest.test.ts +0 -200
- package/src/build-manifest.ts +0 -279
- package/src/capabilityRouting.test.ts +0 -47
- package/src/capabilityRouting.ts +0 -29
- package/src/cascade.ts +0 -192
- package/src/cli.test.ts +0 -133
- package/src/cli.ts +0 -1012
- package/src/clis/1688/item.test.ts +0 -69
- package/src/clis/1688/item.ts +0 -282
- package/src/clis/1688/search.test.ts +0 -81
- package/src/clis/1688/search.ts +0 -402
- package/src/clis/1688/shared.test.ts +0 -75
- package/src/clis/1688/shared.ts +0 -623
- package/src/clis/1688/store.test.ts +0 -69
- package/src/clis/1688/store.ts +0 -300
- package/src/clis/36kr/article.ts +0 -69
- package/src/clis/36kr/hot.test.ts +0 -19
- package/src/clis/36kr/hot.ts +0 -100
- package/src/clis/36kr/news.test.ts +0 -90
- package/src/clis/36kr/news.ts +0 -54
- package/src/clis/36kr/search.ts +0 -78
- package/src/clis/_shared/common.ts +0 -11
- package/src/clis/_shared/desktop-commands.ts +0 -121
- package/src/clis/amazon/bestsellers.test.ts +0 -31
- package/src/clis/amazon/bestsellers.ts +0 -8
- package/src/clis/amazon/discussion.test.ts +0 -38
- package/src/clis/amazon/discussion.ts +0 -131
- package/src/clis/amazon/movers-shakers.ts +0 -8
- package/src/clis/amazon/new-releases.ts +0 -8
- package/src/clis/amazon/offer.test.ts +0 -35
- package/src/clis/amazon/offer.ts +0 -185
- package/src/clis/amazon/product.test.ts +0 -26
- package/src/clis/amazon/product.ts +0 -131
- package/src/clis/amazon/rankings.test.ts +0 -47
- package/src/clis/amazon/rankings.ts +0 -312
- package/src/clis/amazon/search.test.ts +0 -24
- package/src/clis/amazon/search.ts +0 -128
- package/src/clis/amazon/shared.test.ts +0 -53
- package/src/clis/amazon/shared.ts +0 -438
- package/src/clis/antigravity/SKILL.md +0 -38
- package/src/clis/antigravity/dump.ts +0 -30
- package/src/clis/antigravity/extract-code.ts +0 -34
- package/src/clis/antigravity/model.ts +0 -47
- package/src/clis/antigravity/new.ts +0 -28
- package/src/clis/antigravity/read.ts +0 -36
- package/src/clis/antigravity/send.ts +0 -40
- package/src/clis/antigravity/serve.ts +0 -600
- package/src/clis/antigravity/status.ts +0 -19
- package/src/clis/antigravity/watch.ts +0 -45
- package/src/clis/apple-podcasts/commands.test.ts +0 -123
- package/src/clis/apple-podcasts/episodes.ts +0 -28
- package/src/clis/apple-podcasts/search.ts +0 -30
- package/src/clis/apple-podcasts/top.ts +0 -47
- package/src/clis/apple-podcasts/utils.test.ts +0 -72
- package/src/clis/apple-podcasts/utils.ts +0 -37
- package/src/clis/arxiv/paper.ts +0 -21
- package/src/clis/arxiv/search.ts +0 -24
- package/src/clis/arxiv/utils.ts +0 -63
- package/src/clis/band/bands.ts +0 -76
- package/src/clis/band/mentions.ts +0 -134
- package/src/clis/band/post.ts +0 -187
- package/src/clis/band/posts.ts +0 -106
- package/src/clis/barchart/flow.ts +0 -120
- package/src/clis/barchart/greeks.ts +0 -123
- package/src/clis/barchart/options.ts +0 -110
- package/src/clis/barchart/quote.ts +0 -137
- package/src/clis/bbc/news.ts +0 -41
- package/src/clis/bilibili/comments.test.ts +0 -103
- package/src/clis/bilibili/comments.ts +0 -44
- package/src/clis/bilibili/download.ts +0 -93
- package/src/clis/bilibili/dynamic.test.ts +0 -79
- package/src/clis/bilibili/dynamic.ts +0 -34
- package/src/clis/bilibili/favorite.ts +0 -45
- package/src/clis/bilibili/feed.ts +0 -71
- package/src/clis/bilibili/following.ts +0 -51
- package/src/clis/bilibili/history.ts +0 -48
- package/src/clis/bilibili/hot.yaml +0 -38
- package/src/clis/bilibili/me.ts +0 -14
- package/src/clis/bilibili/ranking.ts +0 -25
- package/src/clis/bilibili/search.ts +0 -25
- package/src/clis/bilibili/subtitle.test.ts +0 -61
- package/src/clis/bilibili/subtitle.ts +0 -106
- package/src/clis/bilibili/user-videos.ts +0 -42
- package/src/clis/bilibili/utils.test.ts +0 -21
- package/src/clis/bilibili/utils.ts +0 -143
- package/src/clis/bloomberg/businessweek.ts +0 -18
- package/src/clis/bloomberg/economics.ts +0 -18
- package/src/clis/bloomberg/feeds.ts +0 -16
- package/src/clis/bloomberg/industries.ts +0 -18
- package/src/clis/bloomberg/main.ts +0 -18
- package/src/clis/bloomberg/markets.ts +0 -18
- package/src/clis/bloomberg/news.ts +0 -136
- package/src/clis/bloomberg/opinions.ts +0 -18
- package/src/clis/bloomberg/politics.ts +0 -18
- package/src/clis/bloomberg/tech.ts +0 -18
- package/src/clis/bloomberg/utils.test.ts +0 -135
- package/src/clis/bloomberg/utils.ts +0 -429
- package/src/clis/bluesky/feeds.yaml +0 -29
- package/src/clis/bluesky/followers.yaml +0 -33
- package/src/clis/bluesky/following.yaml +0 -33
- package/src/clis/bluesky/profile.yaml +0 -27
- package/src/clis/bluesky/search.yaml +0 -34
- package/src/clis/bluesky/starter-packs.yaml +0 -34
- package/src/clis/bluesky/thread.yaml +0 -32
- package/src/clis/bluesky/trending.yaml +0 -27
- package/src/clis/bluesky/user.yaml +0 -34
- package/src/clis/boss/batchgreet.ts +0 -75
- package/src/clis/boss/chatlist.ts +0 -36
- package/src/clis/boss/chatmsg.ts +0 -46
- package/src/clis/boss/detail.ts +0 -69
- package/src/clis/boss/exchange.ts +0 -52
- package/src/clis/boss/greet.ts +0 -61
- package/src/clis/boss/invite.ts +0 -80
- package/src/clis/boss/joblist.ts +0 -34
- package/src/clis/boss/mark.ts +0 -75
- package/src/clis/boss/recommend.ts +0 -49
- package/src/clis/boss/resume.ts +0 -157
- package/src/clis/boss/search.ts +0 -162
- package/src/clis/boss/send.ts +0 -54
- package/src/clis/boss/stats.ts +0 -75
- package/src/clis/boss/utils.ts +0 -287
- package/src/clis/chaoxing/assignments.ts +0 -89
- package/src/clis/chaoxing/exams.ts +0 -88
- package/src/clis/chaoxing/utils.test.ts +0 -53
- package/src/clis/chaoxing/utils.ts +0 -266
- package/src/clis/chatgpt/ask.ts +0 -95
- package/src/clis/chatgpt/ax.ts +0 -260
- package/src/clis/chatgpt/model.ts +0 -27
- package/src/clis/chatgpt/new.ts +0 -29
- package/src/clis/chatgpt/read.ts +0 -35
- package/src/clis/chatgpt/send.ts +0 -59
- package/src/clis/chatgpt/status.ts +0 -27
- package/src/clis/chatwise/ask.ts +0 -90
- package/src/clis/chatwise/export.ts +0 -51
- package/src/clis/chatwise/history.ts +0 -61
- package/src/clis/chatwise/model.ts +0 -89
- package/src/clis/chatwise/new.ts +0 -3
- package/src/clis/chatwise/read.ts +0 -42
- package/src/clis/chatwise/screenshot.ts +0 -3
- package/src/clis/chatwise/send.ts +0 -53
- package/src/clis/chatwise/status.ts +0 -3
- package/src/clis/codex/ask.ts +0 -80
- package/src/clis/codex/dump.ts +0 -3
- package/src/clis/codex/export.ts +0 -42
- package/src/clis/codex/extract-diff.ts +0 -48
- package/src/clis/codex/history.ts +0 -47
- package/src/clis/codex/model.ts +0 -59
- package/src/clis/codex/new.ts +0 -3
- package/src/clis/codex/read.ts +0 -37
- package/src/clis/codex/screenshot.ts +0 -3
- package/src/clis/codex/send.ts +0 -48
- package/src/clis/codex/status.ts +0 -3
- package/src/clis/coupang/add-to-cart.ts +0 -148
- package/src/clis/coupang/search.ts +0 -464
- package/src/clis/coupang/utils.test.ts +0 -78
- package/src/clis/coupang/utils.ts +0 -302
- package/src/clis/ctrip/search.test.ts +0 -73
- package/src/clis/ctrip/search.ts +0 -111
- package/src/clis/cursor/ask.ts +0 -82
- package/src/clis/cursor/composer.ts +0 -51
- package/src/clis/cursor/dump.ts +0 -3
- package/src/clis/cursor/export.ts +0 -57
- package/src/clis/cursor/extract-code.ts +0 -39
- package/src/clis/cursor/history.ts +0 -47
- package/src/clis/cursor/model.ts +0 -57
- package/src/clis/cursor/new.ts +0 -3
- package/src/clis/cursor/read.ts +0 -48
- package/src/clis/cursor/screenshot.ts +0 -3
- package/src/clis/cursor/send.ts +0 -48
- package/src/clis/cursor/status.ts +0 -3
- package/src/clis/devto/tag.yaml +0 -34
- package/src/clis/devto/top.yaml +0 -29
- package/src/clis/devto/user.yaml +0 -33
- package/src/clis/dictionary/examples.yaml +0 -25
- package/src/clis/dictionary/search.yaml +0 -27
- package/src/clis/dictionary/synonyms.yaml +0 -25
- package/src/clis/discord-app/channels.ts +0 -60
- package/src/clis/discord-app/members.ts +0 -41
- package/src/clis/discord-app/read.ts +0 -49
- package/src/clis/discord-app/search.ts +0 -64
- package/src/clis/discord-app/send.ts +0 -32
- package/src/clis/discord-app/servers.ts +0 -39
- package/src/clis/discord-app/status.ts +0 -18
- package/src/clis/douban/book-hot.ts +0 -15
- package/src/clis/douban/download.test.ts +0 -196
- package/src/clis/douban/download.ts +0 -78
- package/src/clis/douban/marks.ts +0 -135
- package/src/clis/douban/movie-hot.ts +0 -15
- package/src/clis/douban/photos.ts +0 -36
- package/src/clis/douban/reviews.ts +0 -127
- package/src/clis/douban/search.ts +0 -17
- package/src/clis/douban/subject.yaml +0 -107
- package/src/clis/douban/top250.yaml +0 -70
- package/src/clis/douban/utils.test.ts +0 -97
- package/src/clis/douban/utils.ts +0 -472
- package/src/clis/doubao/ask.ts +0 -40
- package/src/clis/doubao/detail.test.ts +0 -53
- package/src/clis/doubao/detail.ts +0 -41
- package/src/clis/doubao/history.test.ts +0 -45
- package/src/clis/doubao/history.ts +0 -32
- package/src/clis/doubao/meeting-summary.ts +0 -53
- package/src/clis/doubao/meeting-transcript.ts +0 -48
- package/src/clis/doubao/new.ts +0 -22
- package/src/clis/doubao/read.ts +0 -20
- package/src/clis/doubao/send.ts +0 -25
- package/src/clis/doubao/status.ts +0 -27
- package/src/clis/doubao/utils.test.ts +0 -45
- package/src/clis/doubao/utils.ts +0 -1010
- package/src/clis/doubao-app/ask.ts +0 -60
- package/src/clis/doubao-app/dump.ts +0 -28
- package/src/clis/doubao-app/new.ts +0 -21
- package/src/clis/doubao-app/read.ts +0 -21
- package/src/clis/doubao-app/screenshot.ts +0 -19
- package/src/clis/doubao-app/send.ts +0 -30
- package/src/clis/doubao-app/status.ts +0 -17
- package/src/clis/doubao-app/utils.ts +0 -116
- package/src/clis/douyin/_shared/browser-fetch.test.ts +0 -37
- package/src/clis/douyin/_shared/browser-fetch.ts +0 -45
- package/src/clis/douyin/_shared/creation-id.test.ts +0 -26
- package/src/clis/douyin/_shared/creation-id.ts +0 -8
- package/src/clis/douyin/_shared/imagex-upload.test.ts +0 -113
- package/src/clis/douyin/_shared/imagex-upload.ts +0 -76
- package/src/clis/douyin/_shared/public-api.ts +0 -84
- package/src/clis/douyin/_shared/sts2.test.ts +0 -31
- package/src/clis/douyin/_shared/sts2.ts +0 -28
- package/src/clis/douyin/_shared/text-extra.test.ts +0 -42
- package/src/clis/douyin/_shared/text-extra.ts +0 -33
- package/src/clis/douyin/_shared/timing.test.ts +0 -38
- package/src/clis/douyin/_shared/timing.ts +0 -22
- package/src/clis/douyin/_shared/tos-upload-short-read.test.ts +0 -102
- package/src/clis/douyin/_shared/tos-upload.test.ts +0 -281
- package/src/clis/douyin/_shared/tos-upload.ts +0 -444
- package/src/clis/douyin/_shared/transcode.test.ts +0 -115
- package/src/clis/douyin/_shared/transcode.ts +0 -78
- package/src/clis/douyin/_shared/types.ts +0 -29
- package/src/clis/douyin/activities.test.ts +0 -65
- package/src/clis/douyin/activities.ts +0 -32
- package/src/clis/douyin/collections.test.ts +0 -59
- package/src/clis/douyin/collections.ts +0 -25
- package/src/clis/douyin/delete.test.ts +0 -12
- package/src/clis/douyin/delete.ts +0 -20
- package/src/clis/douyin/draft.test.ts +0 -452
- package/src/clis/douyin/draft.ts +0 -446
- package/src/clis/douyin/drafts.test.ts +0 -12
- package/src/clis/douyin/drafts.ts +0 -27
- package/src/clis/douyin/hashtag.test.ts +0 -68
- package/src/clis/douyin/hashtag.ts +0 -64
- package/src/clis/douyin/location.test.ts +0 -26
- package/src/clis/douyin/location.ts +0 -27
- package/src/clis/douyin/profile.test.ts +0 -54
- package/src/clis/douyin/profile.ts +0 -44
- package/src/clis/douyin/publish.test.ts +0 -45
- package/src/clis/douyin/publish.ts +0 -340
- package/src/clis/douyin/stats.test.ts +0 -25
- package/src/clis/douyin/stats.ts +0 -30
- package/src/clis/douyin/update.test.ts +0 -12
- package/src/clis/douyin/update.ts +0 -43
- package/src/clis/douyin/user-videos.test.ts +0 -122
- package/src/clis/douyin/user-videos.ts +0 -101
- package/src/clis/douyin/videos.test.ts +0 -62
- package/src/clis/douyin/videos.ts +0 -83
- package/src/clis/facebook/add-friend.yaml +0 -43
- package/src/clis/facebook/events.yaml +0 -44
- package/src/clis/facebook/feed.yaml +0 -63
- package/src/clis/facebook/friends.yaml +0 -42
- package/src/clis/facebook/groups.yaml +0 -50
- package/src/clis/facebook/join-group.yaml +0 -44
- package/src/clis/facebook/memories.yaml +0 -39
- package/src/clis/facebook/notifications.yaml +0 -40
- package/src/clis/facebook/profile.yaml +0 -37
- package/src/clis/facebook/search.test.ts +0 -68
- package/src/clis/facebook/search.yaml +0 -47
- package/src/clis/gemini/ask.test.ts +0 -116
- package/src/clis/gemini/ask.ts +0 -53
- package/src/clis/gemini/image.ts +0 -115
- package/src/clis/gemini/new.ts +0 -22
- package/src/clis/gemini/reply-state.test.ts +0 -708
- package/src/clis/gemini/utils.test.ts +0 -218
- package/src/clis/gemini/utils.ts +0 -1051
- package/src/clis/google/news.ts +0 -66
- package/src/clis/google/search.ts +0 -133
- package/src/clis/google/suggest.ts +0 -40
- package/src/clis/google/trends.ts +0 -44
- package/src/clis/google/utils.test.ts +0 -82
- package/src/clis/google/utils.ts +0 -24
- package/src/clis/grok/ask.test.ts +0 -78
- package/src/clis/grok/ask.ts +0 -334
- package/src/clis/hackernews/ask.yaml +0 -38
- package/src/clis/hackernews/best.yaml +0 -38
- package/src/clis/hackernews/jobs.yaml +0 -36
- package/src/clis/hackernews/new.yaml +0 -38
- package/src/clis/hackernews/search.yaml +0 -44
- package/src/clis/hackernews/show.yaml +0 -38
- package/src/clis/hackernews/top.yaml +0 -38
- package/src/clis/hackernews/user.yaml +0 -25
- package/src/clis/hf/top.ts +0 -141
- package/src/clis/hupu/detail.ts +0 -126
- package/src/clis/hupu/hot.yaml +0 -43
- package/src/clis/hupu/like.ts +0 -76
- package/src/clis/hupu/reply.ts +0 -76
- package/src/clis/hupu/search.ts +0 -95
- package/src/clis/hupu/unlike.ts +0 -76
- package/src/clis/hupu/utils.ts +0 -381
- package/src/clis/imdb/person.ts +0 -232
- package/src/clis/imdb/reviews.ts +0 -111
- package/src/clis/imdb/search.ts +0 -179
- package/src/clis/imdb/title.ts +0 -121
- package/src/clis/imdb/top.ts +0 -67
- package/src/clis/imdb/trending.ts +0 -66
- package/src/clis/imdb/utils.test.ts +0 -117
- package/src/clis/imdb/utils.ts +0 -305
- package/src/clis/instagram/_shared/private-publish.test.ts +0 -827
- package/src/clis/instagram/_shared/private-publish.ts +0 -1303
- package/src/clis/instagram/_shared/protocol-capture.test.ts +0 -148
- package/src/clis/instagram/_shared/protocol-capture.ts +0 -321
- package/src/clis/instagram/_shared/runtime-info.ts +0 -91
- package/src/clis/instagram/comment.yaml +0 -52
- package/src/clis/instagram/download.test.ts +0 -159
- package/src/clis/instagram/download.ts +0 -286
- package/src/clis/instagram/explore.yaml +0 -43
- package/src/clis/instagram/follow.yaml +0 -41
- package/src/clis/instagram/followers.yaml +0 -51
- package/src/clis/instagram/following.yaml +0 -51
- package/src/clis/instagram/like.yaml +0 -46
- package/src/clis/instagram/note.test.ts +0 -96
- package/src/clis/instagram/note.ts +0 -254
- package/src/clis/instagram/post.test.ts +0 -1716
- package/src/clis/instagram/post.ts +0 -1620
- package/src/clis/instagram/profile.yaml +0 -42
- package/src/clis/instagram/reel.test.ts +0 -191
- package/src/clis/instagram/reel.ts +0 -886
- package/src/clis/instagram/save.yaml +0 -46
- package/src/clis/instagram/saved.yaml +0 -40
- package/src/clis/instagram/search.yaml +0 -44
- package/src/clis/instagram/story.test.ts +0 -191
- package/src/clis/instagram/story.ts +0 -151
- package/src/clis/instagram/unfollow.yaml +0 -38
- package/src/clis/instagram/unlike.yaml +0 -46
- package/src/clis/instagram/unsave.yaml +0 -46
- package/src/clis/instagram/user.yaml +0 -54
- package/src/clis/jd/item.test.ts +0 -52
- package/src/clis/jd/item.ts +0 -104
- package/src/clis/jike/comment.ts +0 -112
- package/src/clis/jike/create.ts +0 -112
- package/src/clis/jike/feed.ts +0 -73
- package/src/clis/jike/like.ts +0 -64
- package/src/clis/jike/notifications.ts +0 -184
- package/src/clis/jike/post.yaml +0 -59
- package/src/clis/jike/repost.ts +0 -113
- package/src/clis/jike/search.ts +0 -73
- package/src/clis/jike/topic.yaml +0 -53
- package/src/clis/jike/user.yaml +0 -52
- package/src/clis/jike/utils.ts +0 -36
- package/src/clis/jimeng/generate.yaml +0 -85
- package/src/clis/jimeng/history.yaml +0 -46
- package/src/clis/linkedin/search.ts +0 -417
- package/src/clis/linkedin/timeline.test.ts +0 -99
- package/src/clis/linkedin/timeline.ts +0 -532
- package/src/clis/linux-do/categories.yaml +0 -70
- package/src/clis/linux-do/category.ts +0 -37
- package/src/clis/linux-do/feed.test.ts +0 -132
- package/src/clis/linux-do/feed.ts +0 -501
- package/src/clis/linux-do/hot.ts +0 -26
- package/src/clis/linux-do/latest.ts +0 -19
- package/src/clis/linux-do/search.yaml +0 -48
- package/src/clis/linux-do/tags.yaml +0 -41
- package/src/clis/linux-do/topic.yaml +0 -77
- package/src/clis/linux-do/user-posts.yaml +0 -67
- package/src/clis/linux-do/user-topics.yaml +0 -54
- package/src/clis/lobsters/active.yaml +0 -29
- package/src/clis/lobsters/hot.yaml +0 -29
- package/src/clis/lobsters/newest.yaml +0 -29
- package/src/clis/lobsters/tag.yaml +0 -34
- package/src/clis/medium/feed.ts +0 -16
- package/src/clis/medium/search.ts +0 -16
- package/src/clis/medium/user.ts +0 -16
- package/src/clis/medium/utils.ts +0 -84
- package/src/clis/notebooklm/compat.test.ts +0 -19
- package/src/clis/notebooklm/current.ts +0 -37
- package/src/clis/notebooklm/get.ts +0 -51
- package/src/clis/notebooklm/history.test.ts +0 -70
- package/src/clis/notebooklm/history.ts +0 -34
- package/src/clis/notebooklm/list.ts +0 -40
- package/src/clis/notebooklm/note-list.test.ts +0 -64
- package/src/clis/notebooklm/note-list.ts +0 -40
- package/src/clis/notebooklm/notes-get.test.ts +0 -88
- package/src/clis/notebooklm/notes-get.ts +0 -65
- package/src/clis/notebooklm/open.test.ts +0 -78
- package/src/clis/notebooklm/open.ts +0 -61
- package/src/clis/notebooklm/rpc.test.ts +0 -126
- package/src/clis/notebooklm/rpc.ts +0 -286
- package/src/clis/notebooklm/shared.ts +0 -98
- package/src/clis/notebooklm/source-fulltext.test.ts +0 -123
- package/src/clis/notebooklm/source-fulltext.ts +0 -67
- package/src/clis/notebooklm/source-get.test.ts +0 -100
- package/src/clis/notebooklm/source-get.ts +0 -58
- package/src/clis/notebooklm/source-guide.test.ts +0 -121
- package/src/clis/notebooklm/source-guide.ts +0 -67
- package/src/clis/notebooklm/source-list.ts +0 -43
- package/src/clis/notebooklm/status.ts +0 -33
- package/src/clis/notebooklm/summary.test.ts +0 -94
- package/src/clis/notebooklm/summary.ts +0 -43
- package/src/clis/notebooklm/utils.test.ts +0 -446
- package/src/clis/notebooklm/utils.ts +0 -902
- package/src/clis/notion/export.ts +0 -36
- package/src/clis/notion/favorites.ts +0 -87
- package/src/clis/notion/new.ts +0 -39
- package/src/clis/notion/read.ts +0 -33
- package/src/clis/notion/search.ts +0 -54
- package/src/clis/notion/sidebar.ts +0 -44
- package/src/clis/notion/status.ts +0 -18
- package/src/clis/notion/write.ts +0 -45
- package/src/clis/ones/common.ts +0 -187
- package/src/clis/ones/enrich-tasks.ts +0 -47
- package/src/clis/ones/login.ts +0 -103
- package/src/clis/ones/logout.ts +0 -19
- package/src/clis/ones/me.ts +0 -34
- package/src/clis/ones/my-tasks.ts +0 -148
- package/src/clis/ones/resolve-labels.ts +0 -80
- package/src/clis/ones/task-helpers.test.ts +0 -14
- package/src/clis/ones/task-helpers.ts +0 -214
- package/src/clis/ones/task.ts +0 -79
- package/src/clis/ones/tasks.ts +0 -92
- package/src/clis/ones/token-info.ts +0 -46
- package/src/clis/ones/worklog.test.ts +0 -24
- package/src/clis/ones/worklog.ts +0 -306
- package/src/clis/paperreview/commands.test.ts +0 -283
- package/src/clis/paperreview/feedback.ts +0 -64
- package/src/clis/paperreview/review.ts +0 -47
- package/src/clis/paperreview/submit.ts +0 -119
- package/src/clis/paperreview/utils.test.ts +0 -68
- package/src/clis/paperreview/utils.ts +0 -276
- package/src/clis/pixiv/detail.yaml +0 -49
- package/src/clis/pixiv/download.test.ts +0 -114
- package/src/clis/pixiv/download.ts +0 -91
- package/src/clis/pixiv/illusts.test.ts +0 -115
- package/src/clis/pixiv/illusts.ts +0 -78
- package/src/clis/pixiv/ranking.yaml +0 -53
- package/src/clis/pixiv/search.test.ts +0 -97
- package/src/clis/pixiv/search.ts +0 -53
- package/src/clis/pixiv/test-utils.ts +0 -29
- package/src/clis/pixiv/user.yaml +0 -46
- package/src/clis/pixiv/utils.ts +0 -62
- package/src/clis/producthunt/browse.ts +0 -109
- package/src/clis/producthunt/hot.ts +0 -127
- package/src/clis/producthunt/posts.ts +0 -29
- package/src/clis/producthunt/today.ts +0 -37
- package/src/clis/producthunt/utils.test.ts +0 -72
- package/src/clis/producthunt/utils.ts +0 -122
- package/src/clis/reddit/comment.ts +0 -60
- package/src/clis/reddit/frontpage.yaml +0 -30
- package/src/clis/reddit/hot.yaml +0 -47
- package/src/clis/reddit/popular.yaml +0 -40
- package/src/clis/reddit/read.test.ts +0 -34
- package/src/clis/reddit/read.ts +0 -186
- package/src/clis/reddit/save.ts +0 -54
- package/src/clis/reddit/saved.ts +0 -51
- package/src/clis/reddit/search.yaml +0 -61
- package/src/clis/reddit/subreddit.yaml +0 -50
- package/src/clis/reddit/subscribe.ts +0 -53
- package/src/clis/reddit/upvote.ts +0 -67
- package/src/clis/reddit/upvoted.ts +0 -51
- package/src/clis/reddit/user-comments.yaml +0 -46
- package/src/clis/reddit/user-posts.yaml +0 -44
- package/src/clis/reddit/user.yaml +0 -40
- package/src/clis/reuters/search.ts +0 -51
- package/src/clis/sinablog/article.ts +0 -15
- package/src/clis/sinablog/hot.ts +0 -15
- package/src/clis/sinablog/search.ts +0 -56
- package/src/clis/sinablog/user.ts +0 -16
- package/src/clis/sinablog/utils.ts +0 -197
- package/src/clis/sinafinance/news.ts +0 -76
- package/src/clis/sinafinance/rolling-news.ts +0 -42
- package/src/clis/sinafinance/stock-rank.ts +0 -68
- package/src/clis/sinafinance/stock.ts +0 -127
- package/src/clis/smzdm/search.ts +0 -56
- package/src/clis/spotify/spotify.ts +0 -328
- package/src/clis/spotify/utils.test.ts +0 -87
- package/src/clis/spotify/utils.ts +0 -92
- package/src/clis/stackoverflow/bounties.yaml +0 -29
- package/src/clis/stackoverflow/hot.yaml +0 -28
- package/src/clis/stackoverflow/search.yaml +0 -33
- package/src/clis/stackoverflow/unanswered.yaml +0 -28
- package/src/clis/steam/top-sellers.yaml +0 -29
- package/src/clis/substack/feed.ts +0 -16
- package/src/clis/substack/publication.ts +0 -16
- package/src/clis/substack/search.ts +0 -92
- package/src/clis/substack/utils.test.ts +0 -52
- package/src/clis/substack/utils.ts +0 -141
- package/src/clis/tieba/commands.test.ts +0 -86
- package/src/clis/tieba/hot.ts +0 -52
- package/src/clis/tieba/posts.ts +0 -108
- package/src/clis/tieba/read.ts +0 -158
- package/src/clis/tieba/search.ts +0 -119
- package/src/clis/tieba/utils.test.ts +0 -322
- package/src/clis/tieba/utils.ts +0 -348
- package/src/clis/tiktok/comment.yaml +0 -66
- package/src/clis/tiktok/explore.yaml +0 -39
- package/src/clis/tiktok/follow.yaml +0 -39
- package/src/clis/tiktok/following.yaml +0 -46
- package/src/clis/tiktok/friends.yaml +0 -47
- package/src/clis/tiktok/like.yaml +0 -38
- package/src/clis/tiktok/live.yaml +0 -51
- package/src/clis/tiktok/notifications.yaml +0 -52
- package/src/clis/tiktok/profile.yaml +0 -45
- package/src/clis/tiktok/save.yaml +0 -34
- package/src/clis/tiktok/search.yaml +0 -47
- package/src/clis/tiktok/unfollow.yaml +0 -44
- package/src/clis/tiktok/unlike.yaml +0 -38
- package/src/clis/tiktok/unsave.yaml +0 -36
- package/src/clis/tiktok/user.yaml +0 -44
- package/src/clis/twitter/accept.ts +0 -214
- package/src/clis/twitter/article.ts +0 -170
- package/src/clis/twitter/block.ts +0 -93
- package/src/clis/twitter/bookmark.ts +0 -68
- package/src/clis/twitter/bookmarks.ts +0 -202
- package/src/clis/twitter/delete.ts +0 -78
- package/src/clis/twitter/download.ts +0 -118
- package/src/clis/twitter/follow.ts +0 -70
- package/src/clis/twitter/followers.ts +0 -116
- package/src/clis/twitter/following.ts +0 -109
- package/src/clis/twitter/hide-reply.ts +0 -71
- package/src/clis/twitter/like.ts +0 -74
- package/src/clis/twitter/likes.test.ts +0 -91
- package/src/clis/twitter/likes.ts +0 -256
- package/src/clis/twitter/notifications.ts +0 -136
- package/src/clis/twitter/post.test.ts +0 -157
- package/src/clis/twitter/post.ts +0 -110
- package/src/clis/twitter/profile.ts +0 -108
- package/src/clis/twitter/reply-dm.ts +0 -194
- package/src/clis/twitter/reply.test.ts +0 -177
- package/src/clis/twitter/reply.ts +0 -309
- package/src/clis/twitter/search.test.ts +0 -265
- package/src/clis/twitter/search.ts +0 -185
- package/src/clis/twitter/shared.ts +0 -45
- package/src/clis/twitter/thread.ts +0 -182
- package/src/clis/twitter/timeline.test.ts +0 -109
- package/src/clis/twitter/timeline.ts +0 -248
- package/src/clis/twitter/trending.ts +0 -66
- package/src/clis/twitter/unblock.ts +0 -76
- package/src/clis/twitter/unbookmark.ts +0 -67
- package/src/clis/twitter/unfollow.ts +0 -76
- package/src/clis/v2ex/daily.ts +0 -106
- package/src/clis/v2ex/hot.yaml +0 -28
- package/src/clis/v2ex/latest.yaml +0 -28
- package/src/clis/v2ex/me.ts +0 -104
- package/src/clis/v2ex/member.yaml +0 -29
- package/src/clis/v2ex/node.yaml +0 -34
- package/src/clis/v2ex/nodes.yaml +0 -31
- package/src/clis/v2ex/notifications.ts +0 -76
- package/src/clis/v2ex/replies.yaml +0 -32
- package/src/clis/v2ex/topic.yaml +0 -33
- package/src/clis/v2ex/user.yaml +0 -34
- package/src/clis/web/read.ts +0 -210
- package/src/clis/weibo/comments.ts +0 -54
- package/src/clis/weibo/feed.ts +0 -57
- package/src/clis/weibo/hot.ts +0 -39
- package/src/clis/weibo/me.ts +0 -77
- package/src/clis/weibo/post.ts +0 -77
- package/src/clis/weibo/search.ts +0 -78
- package/src/clis/weibo/user.ts +0 -64
- package/src/clis/weibo/utils.ts +0 -32
- package/src/clis/weixin/download.ts +0 -382
- package/src/clis/weread/book.ts +0 -271
- package/src/clis/weread/commands.test.ts +0 -466
- package/src/clis/weread/highlights.ts +0 -25
- package/src/clis/weread/notebooks.ts +0 -23
- package/src/clis/weread/notes.ts +0 -31
- package/src/clis/weread/private-api-regression.test.ts +0 -435
- package/src/clis/weread/ranking.ts +0 -29
- package/src/clis/weread/search-regression.test.ts +0 -440
- package/src/clis/weread/search.ts +0 -207
- package/src/clis/weread/shelf.ts +0 -84
- package/src/clis/weread/utils.test.ts +0 -153
- package/src/clis/weread/utils.ts +0 -390
- package/src/clis/wikipedia/random.ts +0 -19
- package/src/clis/wikipedia/search.ts +0 -38
- package/src/clis/wikipedia/summary.ts +0 -23
- package/src/clis/wikipedia/trending.ts +0 -41
- package/src/clis/wikipedia/utils.ts +0 -51
- package/src/clis/xianyu/chat.test.ts +0 -20
- package/src/clis/xianyu/chat.ts +0 -175
- package/src/clis/xianyu/item.test.ts +0 -67
- package/src/clis/xianyu/item.ts +0 -172
- package/src/clis/xianyu/search.test.ts +0 -22
- package/src/clis/xianyu/search.ts +0 -151
- package/src/clis/xianyu/utils.ts +0 -9
- package/src/clis/xiaoe/catalog.yaml +0 -129
- package/src/clis/xiaoe/content.yaml +0 -43
- package/src/clis/xiaoe/courses.yaml +0 -73
- package/src/clis/xiaoe/detail.yaml +0 -39
- package/src/clis/xiaoe/play-url.yaml +0 -124
- package/src/clis/xiaohongshu/comments.test.ts +0 -171
- package/src/clis/xiaohongshu/comments.ts +0 -140
- package/src/clis/xiaohongshu/creator-note-detail.test.ts +0 -273
- package/src/clis/xiaohongshu/creator-note-detail.ts +0 -447
- package/src/clis/xiaohongshu/creator-notes-summary.test.ts +0 -54
- package/src/clis/xiaohongshu/creator-notes-summary.ts +0 -120
- package/src/clis/xiaohongshu/creator-notes.test.ts +0 -212
- package/src/clis/xiaohongshu/creator-notes.ts +0 -295
- package/src/clis/xiaohongshu/creator-profile.ts +0 -59
- package/src/clis/xiaohongshu/creator-stats.ts +0 -80
- package/src/clis/xiaohongshu/download.test.ts +0 -94
- package/src/clis/xiaohongshu/download.ts +0 -174
- package/src/clis/xiaohongshu/feed.yaml +0 -31
- package/src/clis/xiaohongshu/note-helpers.ts +0 -25
- package/src/clis/xiaohongshu/note.test.ts +0 -213
- package/src/clis/xiaohongshu/note.ts +0 -104
- package/src/clis/xiaohongshu/notifications.yaml +0 -37
- package/src/clis/xiaohongshu/publish.test.ts +0 -228
- package/src/clis/xiaohongshu/publish.ts +0 -598
- package/src/clis/xiaohongshu/search.test.ts +0 -191
- package/src/clis/xiaohongshu/search.ts +0 -143
- package/src/clis/xiaohongshu/user-helpers.test.ts +0 -129
- package/src/clis/xiaohongshu/user-helpers.ts +0 -89
- package/src/clis/xiaohongshu/user.ts +0 -64
- package/src/clis/xiaoyuzhou/episode.ts +0 -28
- package/src/clis/xiaoyuzhou/podcast-episodes.ts +0 -36
- package/src/clis/xiaoyuzhou/podcast.ts +0 -27
- package/src/clis/xiaoyuzhou/utils.test.ts +0 -122
- package/src/clis/xiaoyuzhou/utils.ts +0 -65
- package/src/clis/xueqiu/comments.test.ts +0 -823
- package/src/clis/xueqiu/comments.ts +0 -461
- package/src/clis/xueqiu/danjuan-utils.test.ts +0 -49
- package/src/clis/xueqiu/danjuan-utils.ts +0 -176
- package/src/clis/xueqiu/earnings-date.yaml +0 -69
- package/src/clis/xueqiu/feed.yaml +0 -53
- package/src/clis/xueqiu/fund-holdings.ts +0 -32
- package/src/clis/xueqiu/fund-snapshot.ts +0 -27
- package/src/clis/xueqiu/hot-stock.yaml +0 -49
- package/src/clis/xueqiu/hot.yaml +0 -46
- package/src/clis/xueqiu/search.yaml +0 -55
- package/src/clis/xueqiu/stock.yaml +0 -69
- package/src/clis/xueqiu/watchlist.yaml +0 -46
- package/src/clis/yahoo-finance/quote.ts +0 -72
- package/src/clis/yollomi/background.ts +0 -48
- package/src/clis/yollomi/edit.ts +0 -58
- package/src/clis/yollomi/face-swap.ts +0 -45
- package/src/clis/yollomi/generate.ts +0 -95
- package/src/clis/yollomi/models.ts +0 -38
- package/src/clis/yollomi/object-remover.ts +0 -44
- package/src/clis/yollomi/remove-bg.ts +0 -40
- package/src/clis/yollomi/restore.ts +0 -40
- package/src/clis/yollomi/try-on.ts +0 -48
- package/src/clis/yollomi/upload.ts +0 -78
- package/src/clis/yollomi/upscale.ts +0 -49
- package/src/clis/yollomi/utils.ts +0 -202
- package/src/clis/yollomi/video.ts +0 -61
- package/src/clis/youtube/channel.ts +0 -155
- package/src/clis/youtube/comments.ts +0 -97
- package/src/clis/youtube/search.ts +0 -99
- package/src/clis/youtube/transcript-group.test.ts +0 -108
- package/src/clis/youtube/transcript-group.ts +0 -287
- package/src/clis/youtube/transcript.ts +0 -279
- package/src/clis/youtube/utils.test.ts +0 -43
- package/src/clis/youtube/utils.ts +0 -97
- package/src/clis/youtube/video.ts +0 -118
- package/src/clis/yuanbao/ask.test.ts +0 -156
- package/src/clis/yuanbao/ask.ts +0 -522
- package/src/clis/yuanbao/new.test.ts +0 -36
- package/src/clis/yuanbao/new.ts +0 -81
- package/src/clis/yuanbao/shared.ts +0 -57
- package/src/clis/zhihu/download.test.ts +0 -14
- package/src/clis/zhihu/download.ts +0 -87
- package/src/clis/zhihu/hot.yaml +0 -46
- package/src/clis/zhihu/question.test.ts +0 -96
- package/src/clis/zhihu/question.ts +0 -63
- package/src/clis/zhihu/search.yaml +0 -59
- package/src/clis/zsxq/dynamics.ts +0 -60
- package/src/clis/zsxq/groups.ts +0 -41
- package/src/clis/zsxq/search.test.ts +0 -29
- package/src/clis/zsxq/search.ts +0 -54
- package/src/clis/zsxq/topic.test.ts +0 -34
- package/src/clis/zsxq/topic.ts +0 -68
- package/src/clis/zsxq/topics.test.ts +0 -29
- package/src/clis/zsxq/topics.ts +0 -36
- package/src/clis/zsxq/utils.ts +0 -351
- package/src/commanderAdapter.test.ts +0 -315
- package/src/commanderAdapter.ts +0 -319
- package/src/commands/daemon.test.ts +0 -204
- package/src/commands/daemon.ts +0 -87
- package/src/completion.test.ts +0 -30
- package/src/completion.ts +0 -132
- package/src/constants.ts +0 -41
- package/src/daemon.test.ts +0 -88
- package/src/daemon.ts +0 -339
- package/src/discovery.ts +0 -328
- package/src/doctor.test.ts +0 -111
- package/src/doctor.ts +0 -163
- package/src/download/article-download.ts +0 -272
- package/src/download/index.test.ts +0 -135
- package/src/download/index.ts +0 -422
- package/src/download/media-download.ts +0 -180
- package/src/download/progress.ts +0 -125
- package/src/electron-apps.test.ts +0 -50
- package/src/electron-apps.ts +0 -97
- package/src/engine.test.ts +0 -323
- package/src/errors.test.ts +0 -79
- package/src/errors.ts +0 -162
- package/src/execution.test.ts +0 -47
- package/src/execution.ts +0 -235
- package/src/explore.ts +0 -502
- package/src/extension-manifest-regression.test.ts +0 -18
- package/src/external-clis.yaml +0 -56
- package/src/external.test.ts +0 -97
- package/src/external.ts +0 -246
- package/src/generate.ts +0 -161
- package/src/hooks.test.ts +0 -126
- package/src/hooks.ts +0 -91
- package/src/idle-manager.ts +0 -60
- package/src/interceptor.test.ts +0 -94
- package/src/interceptor.ts +0 -204
- package/src/launcher.test.ts +0 -181
- package/src/launcher.ts +0 -263
- package/src/logger.ts +0 -57
- package/src/main.ts +0 -66
- package/src/node-network.test.ts +0 -93
- package/src/node-network.ts +0 -213
- package/src/output.test.ts +0 -69
- package/src/output.ts +0 -145
- package/src/pipeline/executor.test.ts +0 -191
- package/src/pipeline/executor.ts +0 -110
- package/src/pipeline/registry.ts +0 -62
- package/src/pipeline/steps/browser.ts +0 -76
- package/src/pipeline/steps/download.test.ts +0 -135
- package/src/pipeline/steps/download.ts +0 -320
- package/src/pipeline/steps/fetch.test.ts +0 -179
- package/src/pipeline/steps/fetch.ts +0 -160
- package/src/pipeline/steps/intercept.ts +0 -55
- package/src/pipeline/steps/tap.ts +0 -100
- package/src/pipeline/steps/transform.ts +0 -71
- package/src/pipeline/template.test.ts +0 -177
- package/src/pipeline/template.ts +0 -269
- package/src/pipeline/transform.test.ts +0 -140
- package/src/plugin-manifest.test.ts +0 -223
- package/src/plugin-manifest.ts +0 -206
- package/src/plugin-scaffold.test.ts +0 -98
- package/src/plugin-scaffold.ts +0 -170
- package/src/plugin.test.ts +0 -1427
- package/src/plugin.ts +0 -1537
- package/src/record.test.ts +0 -362
- package/src/record.ts +0 -824
- package/src/registry-api.ts +0 -14
- package/src/registry.test.ts +0 -133
- package/src/registry.ts +0 -160
- package/src/runtime-detect.test.ts +0 -30
- package/src/runtime-detect.ts +0 -36
- package/src/runtime.ts +0 -86
- package/src/scripts/framework.ts +0 -20
- package/src/scripts/interact.ts +0 -22
- package/src/scripts/store.ts +0 -40
- package/src/serialization.test.ts +0 -44
- package/src/serialization.ts +0 -92
- package/src/snapshotFormatter.test.ts +0 -579
- package/src/snapshotFormatter.ts +0 -359
- package/src/synthesize.ts +0 -296
- package/src/tui.test.ts +0 -23
- package/src/tui.ts +0 -237
- package/src/types.ts +0 -95
- package/src/update-check.ts +0 -114
- package/src/utils.ts +0 -44
- package/src/validate.ts +0 -103
- package/src/verify.ts +0 -93
- package/src/version.ts +0 -18
- package/src/weixin-download.test.ts +0 -91
- package/src/yaml-schema.ts +0 -48
- package/tests/e2e/band-auth.test.ts +0 -20
- package/tests/e2e/browser-auth-helpers.ts +0 -18
- package/tests/e2e/browser-auth.test.ts +0 -150
- package/tests/e2e/browser-public-extended.test.ts +0 -166
- package/tests/e2e/browser-public.test.ts +0 -417
- package/tests/e2e/helpers.ts +0 -64
- package/tests/e2e/management.test.ts +0 -106
- package/tests/e2e/output-formats.test.ts +0 -44
- package/tests/e2e/plugin-management.test.ts +0 -140
- package/tests/e2e/public-commands.test.ts +0 -569
- package/tests/smoke/api-health.test.ts +0 -131
- package/tsconfig.json +0 -17
- package/vitest.config.ts +0 -50
- /package/dist/{browser.test.d.ts → clis/gemini/deep-research-result.test.d.ts} +0 -0
- /package/dist/{browser/cdp.test.d.ts → clis/gemini/deep-research.test.d.ts} +0 -0
- /package/dist/{browser/daemon-client.test.d.ts → clis/hupu/mentions.d.ts} +0 -0
- /package/dist/{browser/dom-helpers.test.d.ts → clis/lesswrong/comments.d.ts} +0 -0
- /package/dist/{browser/page.test.d.ts → clis/lesswrong/curated.d.ts} +0 -0
- /package/dist/{browser/stealth.test.d.ts → clis/lesswrong/frontpage.d.ts} +0 -0
- /package/dist/{build-manifest.test.d.ts → clis/lesswrong/new.d.ts} +0 -0
- /package/dist/{capabilityRouting.test.d.ts → clis/lesswrong/read.d.ts} +0 -0
- /package/dist/{cli.test.d.ts → clis/lesswrong/sequences.d.ts} +0 -0
- /package/dist/{commanderAdapter.test.d.ts → clis/lesswrong/shortform.d.ts} +0 -0
- /package/dist/{commands/daemon.test.d.ts → clis/lesswrong/tag.d.ts} +0 -0
- /package/dist/{completion.test.d.ts → clis/lesswrong/tags.d.ts} +0 -0
- /package/dist/{daemon.test.d.ts → clis/lesswrong/top-month.d.ts} +0 -0
- /package/dist/{doctor.test.d.ts → clis/lesswrong/top-week.d.ts} +0 -0
- /package/dist/{download/index.test.d.ts → clis/lesswrong/top-year.d.ts} +0 -0
- /package/dist/{electron-apps.test.d.ts → clis/lesswrong/top.d.ts} +0 -0
- /package/dist/{engine.test.d.ts → clis/lesswrong/user-posts.d.ts} +0 -0
- /package/dist/{errors.test.d.ts → clis/lesswrong/user.d.ts} +0 -0
- /package/dist/{analysis.d.ts → src/analysis.d.ts} +0 -0
- /package/dist/{analysis.js → src/analysis.js} +0 -0
- /package/dist/{browser → src/browser}/base-page.d.ts +0 -0
- /package/dist/{browser → src/browser}/base-page.js +0 -0
- /package/dist/{browser → src/browser}/bridge.d.ts +0 -0
- /package/dist/{browser → src/browser}/bridge.js +0 -0
- /package/dist/{extension-manifest-regression.test.d.ts → src/browser/cdp.test.d.ts} +0 -0
- /package/dist/{browser → src/browser}/cdp.test.js +0 -0
- /package/dist/{browser → src/browser}/daemon-client.d.ts +0 -0
- /package/dist/{browser → src/browser}/daemon-client.js +0 -0
- /package/dist/{external.test.d.ts → src/browser/daemon-client.test.d.ts} +0 -0
- /package/dist/{browser → src/browser}/daemon-client.test.js +0 -0
- /package/dist/{browser → src/browser}/discover.d.ts +0 -0
- /package/dist/{browser → src/browser}/discover.js +0 -0
- /package/dist/{browser → src/browser}/dom-helpers.d.ts +0 -0
- /package/dist/{browser → src/browser}/dom-helpers.js +0 -0
- /package/dist/{launcher.test.d.ts → src/browser/dom-helpers.test.d.ts} +0 -0
- /package/dist/{browser → src/browser}/dom-helpers.test.js +0 -0
- /package/dist/{browser → src/browser}/dom-snapshot.d.ts +0 -0
- /package/dist/{browser → src/browser}/dom-snapshot.js +0 -0
- /package/dist/{browser → src/browser}/dom-snapshot.test.d.ts +0 -0
- /package/dist/{browser → src/browser}/dom-snapshot.test.js +0 -0
- /package/dist/{browser → src/browser}/errors.d.ts +0 -0
- /package/dist/{browser → src/browser}/errors.js +0 -0
- /package/dist/{browser → src/browser}/index.d.ts +0 -0
- /package/dist/{browser → src/browser}/index.js +0 -0
- /package/dist/{node-network.test.d.ts → src/browser/page.test.d.ts} +0 -0
- /package/dist/{browser → src/browser}/page.test.js +0 -0
- /package/dist/{browser → src/browser}/stealth.d.ts +0 -0
- /package/dist/{browser → src/browser}/stealth.js +0 -0
- /package/dist/{output.test.d.ts → src/browser/stealth.test.d.ts} +0 -0
- /package/dist/{browser → src/browser}/stealth.test.js +0 -0
- /package/dist/{browser → src/browser}/tabs.d.ts +0 -0
- /package/dist/{browser → src/browser}/tabs.js +0 -0
- /package/dist/{execution.test.d.ts → src/browser.test.d.ts} +0 -0
- /package/dist/{browser.test.js → src/browser.test.js} +0 -0
- /package/dist/{build-manifest.d.ts → src/build-manifest.d.ts} +0 -0
- /package/dist/{pipeline/steps/download.test.d.ts → src/build-manifest.test.d.ts} +0 -0
- /package/dist/{build-manifest.test.js → src/build-manifest.test.js} +0 -0
- /package/dist/{capabilityRouting.d.ts → src/capabilityRouting.d.ts} +0 -0
- /package/dist/{capabilityRouting.js → src/capabilityRouting.js} +0 -0
- /package/dist/{pipeline/steps/fetch.test.d.ts → src/capabilityRouting.test.d.ts} +0 -0
- /package/dist/{capabilityRouting.test.js → src/capabilityRouting.test.js} +0 -0
- /package/dist/{cascade.d.ts → src/cascade.d.ts} +0 -0
- /package/dist/{record.test.d.ts → src/cli.test.d.ts} +0 -0
- /package/dist/{runtime-detect.test.d.ts → src/commanderAdapter.test.d.ts} +0 -0
- /package/dist/{commanderAdapter.test.js → src/commanderAdapter.test.js} +0 -0
- /package/dist/{commands → src/commands}/daemon.d.ts +0 -0
- /package/dist/{commands → src/commands}/daemon.js +0 -0
- /package/dist/{serialization.test.d.ts → src/commands/daemon.test.d.ts} +0 -0
- /package/dist/{commands → src/commands}/daemon.test.js +0 -0
- /package/dist/{completion.d.ts → src/completion.d.ts} +0 -0
- /package/dist/{completion.js → src/completion.js} +0 -0
- /package/dist/{tui.test.d.ts → src/completion.test.d.ts} +0 -0
- /package/dist/{completion.test.js → src/completion.test.js} +0 -0
- /package/dist/{constants.d.ts → src/constants.d.ts} +0 -0
- /package/dist/{constants.js → src/constants.js} +0 -0
- /package/dist/{daemon.d.ts → src/daemon.d.ts} +0 -0
- /package/dist/{daemon.js → src/daemon.js} +0 -0
- /package/dist/{weixin-download.test.d.ts → src/daemon.test.d.ts} +0 -0
- /package/dist/{daemon.test.js → src/daemon.test.js} +0 -0
- /package/dist/{doctor.d.ts → src/doctor.d.ts} +0 -0
- /package/dist/{doctor.js → src/doctor.js} +0 -0
- /package/dist/{doctor.test.js → src/doctor.test.js} +0 -0
- /package/dist/{download → src/download}/index.test.js +0 -0
- /package/dist/{electron-apps.d.ts → src/electron-apps.d.ts} +0 -0
- /package/dist/{electron-apps.js → src/electron-apps.js} +0 -0
- /package/dist/{electron-apps.test.js → src/electron-apps.test.js} +0 -0
- /package/dist/{engine.test.js → src/engine.test.js} +0 -0
- /package/dist/{errors.d.ts → src/errors.d.ts} +0 -0
- /package/dist/{errors.js → src/errors.js} +0 -0
- /package/dist/{errors.test.js → src/errors.test.js} +0 -0
- /package/dist/{execution.d.ts → src/execution.d.ts} +0 -0
- /package/dist/{execution.js → src/execution.js} +0 -0
- /package/dist/{execution.test.js → src/execution.test.js} +0 -0
- /package/dist/{explore.d.ts → src/explore.d.ts} +0 -0
- /package/dist/{explore.js → src/explore.js} +0 -0
- /package/dist/{extension-manifest-regression.test.js → src/extension-manifest-regression.test.js} +0 -0
- /package/dist/{external-clis.yaml → src/external-clis.yaml} +0 -0
- /package/dist/{external.d.ts → src/external.d.ts} +0 -0
- /package/dist/{external.js → src/external.js} +0 -0
- /package/dist/{external.test.js → src/external.test.js} +0 -0
- /package/dist/{generate.d.ts → src/generate.d.ts} +0 -0
- /package/dist/{generate.js → src/generate.js} +0 -0
- /package/dist/{hooks.d.ts → src/hooks.d.ts} +0 -0
- /package/dist/{hooks.js → src/hooks.js} +0 -0
- /package/dist/{hooks.test.d.ts → src/hooks.test.d.ts} +0 -0
- /package/dist/{hooks.test.js → src/hooks.test.js} +0 -0
- /package/dist/{idle-manager.d.ts → src/idle-manager.d.ts} +0 -0
- /package/dist/{idle-manager.js → src/idle-manager.js} +0 -0
- /package/dist/{interceptor.test.d.ts → src/interceptor.test.d.ts} +0 -0
- /package/dist/{interceptor.test.js → src/interceptor.test.js} +0 -0
- /package/dist/{launcher.d.ts → src/launcher.d.ts} +0 -0
- /package/dist/{launcher.js → src/launcher.js} +0 -0
- /package/dist/{launcher.test.js → src/launcher.test.js} +0 -0
- /package/dist/{logger.d.ts → src/logger.d.ts} +0 -0
- /package/dist/{logger.js → src/logger.js} +0 -0
- /package/dist/{main.d.ts → src/main.d.ts} +0 -0
- /package/dist/{node-network.d.ts → src/node-network.d.ts} +0 -0
- /package/dist/{node-network.js → src/node-network.js} +0 -0
- /package/dist/{node-network.test.js → src/node-network.test.js} +0 -0
- /package/dist/{output.d.ts → src/output.d.ts} +0 -0
- /package/dist/{output.js → src/output.js} +0 -0
- /package/dist/{output.test.js → src/output.test.js} +0 -0
- /package/dist/{pipeline → src/pipeline}/executor.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/executor.js +0 -0
- /package/dist/{pipeline → src/pipeline}/executor.test.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/executor.test.js +0 -0
- /package/dist/{pipeline → src/pipeline}/registry.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/registry.js +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/browser.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/browser.js +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/download.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/download.js +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/download.test.js +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/fetch.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/fetch.js +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/fetch.test.js +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/intercept.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/intercept.js +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/tap.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/tap.js +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/transform.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/steps/transform.js +0 -0
- /package/dist/{pipeline → src/pipeline}/template.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/template.js +0 -0
- /package/dist/{pipeline → src/pipeline}/template.test.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/template.test.js +0 -0
- /package/dist/{pipeline → src/pipeline}/transform.test.d.ts +0 -0
- /package/dist/{pipeline → src/pipeline}/transform.test.js +0 -0
- /package/dist/{plugin-manifest.d.ts → src/plugin-manifest.d.ts} +0 -0
- /package/dist/{plugin-manifest.js → src/plugin-manifest.js} +0 -0
- /package/dist/{plugin-manifest.test.d.ts → src/plugin-manifest.test.d.ts} +0 -0
- /package/dist/{plugin-manifest.test.js → src/plugin-manifest.test.js} +0 -0
- /package/dist/{plugin-scaffold.d.ts → src/plugin-scaffold.d.ts} +0 -0
- /package/dist/{plugin-scaffold.js → src/plugin-scaffold.js} +0 -0
- /package/dist/{plugin-scaffold.test.d.ts → src/plugin-scaffold.test.d.ts} +0 -0
- /package/dist/{plugin-scaffold.test.js → src/plugin-scaffold.test.js} +0 -0
- /package/dist/{plugin.d.ts → src/plugin.d.ts} +0 -0
- /package/dist/{plugin.js → src/plugin.js} +0 -0
- /package/dist/{plugin.test.d.ts → src/plugin.test.d.ts} +0 -0
- /package/dist/{plugin.test.js → src/plugin.test.js} +0 -0
- /package/dist/{record.d.ts → src/record.d.ts} +0 -0
- /package/dist/{record.test.js → src/record.test.js} +0 -0
- /package/dist/{registry-api.d.ts → src/registry-api.d.ts} +0 -0
- /package/dist/{registry-api.js → src/registry-api.js} +0 -0
- /package/dist/{registry.d.ts → src/registry.d.ts} +0 -0
- /package/dist/{registry.js → src/registry.js} +0 -0
- /package/dist/{registry.test.d.ts → src/registry.test.d.ts} +0 -0
- /package/dist/{registry.test.js → src/registry.test.js} +0 -0
- /package/dist/{runtime-detect.d.ts → src/runtime-detect.d.ts} +0 -0
- /package/dist/{runtime-detect.js → src/runtime-detect.js} +0 -0
- /package/dist/{runtime-detect.test.js → src/runtime-detect.test.js} +0 -0
- /package/dist/{runtime.d.ts → src/runtime.d.ts} +0 -0
- /package/dist/{runtime.js → src/runtime.js} +0 -0
- /package/dist/{scripts → src/scripts}/framework.d.ts +0 -0
- /package/dist/{scripts → src/scripts}/framework.js +0 -0
- /package/dist/{scripts → src/scripts}/interact.d.ts +0 -0
- /package/dist/{scripts → src/scripts}/interact.js +0 -0
- /package/dist/{scripts → src/scripts}/store.d.ts +0 -0
- /package/dist/{scripts → src/scripts}/store.js +0 -0
- /package/dist/{serialization.d.ts → src/serialization.d.ts} +0 -0
- /package/dist/{serialization.js → src/serialization.js} +0 -0
- /package/dist/{serialization.test.js → src/serialization.test.js} +0 -0
- /package/dist/{snapshotFormatter.d.ts → src/snapshotFormatter.d.ts} +0 -0
- /package/dist/{snapshotFormatter.js → src/snapshotFormatter.js} +0 -0
- /package/dist/{snapshotFormatter.test.d.ts → src/snapshotFormatter.test.d.ts} +0 -0
- /package/dist/{snapshotFormatter.test.js → src/snapshotFormatter.test.js} +0 -0
- /package/dist/{tui.d.ts → src/tui.d.ts} +0 -0
- /package/dist/{tui.js → src/tui.js} +0 -0
- /package/dist/{tui.test.js → src/tui.test.js} +0 -0
- /package/dist/{types.d.ts → src/types.d.ts} +0 -0
- /package/dist/{types.js → src/types.js} +0 -0
- /package/dist/{update-check.d.ts → src/update-check.d.ts} +0 -0
- /package/dist/{update-check.js → src/update-check.js} +0 -0
- /package/dist/{utils.d.ts → src/utils.d.ts} +0 -0
- /package/dist/{utils.js → src/utils.js} +0 -0
- /package/dist/{validate.d.ts → src/validate.d.ts} +0 -0
- /package/dist/{validate.js → src/validate.js} +0 -0
- /package/dist/{verify.d.ts → src/verify.d.ts} +0 -0
- /package/dist/{verify.js → src/verify.js} +0 -0
- /package/dist/{version.d.ts → src/version.d.ts} +0 -0
- /package/dist/{yaml-schema.d.ts → src/yaml-schema.d.ts} +0 -0
- /package/dist/{yaml-schema.js → src/yaml-schema.js} +0 -0
|
@@ -1,1143 +0,0 @@
|
|
|
1
|
-
# Performance: Smart Wait & INTERCEPT Fix — Implementation Plan
|
|
2
|
-
|
|
3
|
-
> **For agentic workers:** REQUIRED SUB-SKILL: Use superpowers:subagent-driven-development (recommended) or superpowers:executing-plans to implement this plan task-by-task. Steps use checkbox (`- [ ]`) syntax for tracking.
|
|
4
|
-
|
|
5
|
-
**Goal:** Fix the INTERCEPT strategy correctness bug, add `wait({ selector })` for event-driven waits, and speed up daemon cold-start — eliminating up to 8s of unnecessary fixed sleeps per command.
|
|
6
|
-
|
|
7
|
-
**Architecture:** Three independent layers applied in order: (1) add `waitForCaptureJs` + `waitForSelectorJs` to `dom-helpers.ts` and expose via `IPage`, (2) update `page.ts`/`cdp.ts` implementations, (3) update adapters from the inside out — framework first, then adapters.
|
|
8
|
-
|
|
9
|
-
**Tech Stack:** TypeScript, Vitest (unit + adapter projects), Node.js, browser JS (eval'd strings)
|
|
10
|
-
|
|
11
|
-
---
|
|
12
|
-
|
|
13
|
-
## File Map
|
|
14
|
-
|
|
15
|
-
| File | Change |
|
|
16
|
-
|------|--------|
|
|
17
|
-
| `src/browser/dom-helpers.ts` | Add `waitForCaptureJs()`, `waitForSelectorJs()` |
|
|
18
|
-
| `src/browser/dom-helpers.test.ts` | **New** — unit tests for new helpers |
|
|
19
|
-
| `src/types.ts` | Add `selector?` to `WaitOptions`; add `waitForCapture()` to `IPage` |
|
|
20
|
-
| `src/browser/page.ts` | Implement `waitForCapture()`, add `selector` branch to `wait()` |
|
|
21
|
-
| `src/browser/cdp.ts` | Implement `waitForCapture()`, add `selector` branch to `wait()` |
|
|
22
|
-
| `src/pipeline/steps/intercept.ts` | Use `page.installInterceptor()` + `page.waitForCapture()` + `page.getInterceptedRequests()` |
|
|
23
|
-
| `src/browser/mcp.ts` | Exponential backoff in `_ensureDaemon()` |
|
|
24
|
-
| `src/clis/36kr/hot.ts` | `wait(6)` → `waitForCapture(10)` |
|
|
25
|
-
| `src/clis/36kr/search.ts` | `wait(6)` → `waitForCapture(10)` |
|
|
26
|
-
| `src/clis/twitter/search.ts` | `wait(5)` → `waitForCapture(8)` (already INTERCEPT) |
|
|
27
|
-
| `src/clis/twitter/followers.ts` | `wait(5)` → `waitForCapture(8)` (already INTERCEPT) |
|
|
28
|
-
| `src/clis/twitter/following.ts` | `wait(5)` → `waitForCapture(8)` (already INTERCEPT) |
|
|
29
|
-
| `src/clis/twitter/notifications.ts` | `wait(3)` → selector + `wait(5)` → `waitForCapture(8)` |
|
|
30
|
-
| `src/clis/producthunt/hot.ts` | `wait(5)` → `waitForCapture(8)` |
|
|
31
|
-
| `src/clis/producthunt/browse.ts` | `wait(5)` → `waitForCapture(8)` |
|
|
32
|
-
| `src/clis/twitter/reply.ts` | `wait(5)` → `wait({ selector: '[data-testid="tweetTextarea_0"]', timeout: 8 })` |
|
|
33
|
-
| `src/clis/twitter/follow.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
34
|
-
| `src/clis/twitter/unfollow.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
35
|
-
| `src/clis/twitter/like.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
36
|
-
| `src/clis/twitter/bookmark.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
37
|
-
| `src/clis/twitter/unbookmark.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
38
|
-
| `src/clis/twitter/block.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
39
|
-
| `src/clis/twitter/unblock.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
40
|
-
| `src/clis/twitter/hide-reply.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
41
|
-
| `src/clis/twitter/profile.ts` | `wait(5)` + `wait(3)` → selector variants |
|
|
42
|
-
| `src/clis/twitter/thread.ts` | `wait(3)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 4 })` |
|
|
43
|
-
| `src/clis/twitter/timeline.ts` | `wait(3)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 4 })` |
|
|
44
|
-
| `src/clis/twitter/delete.ts` | `wait(5)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })` |
|
|
45
|
-
| `src/clis/twitter/reply-dm.ts` | `wait(5)` + `wait(3)` → selector variants |
|
|
46
|
-
| `src/clis/medium/utils.ts` | `wait(5)` → selector; remove inline `setTimeout(3000)` |
|
|
47
|
-
| `src/clis/substack/utils.ts` | `wait(5)` × 2 → selector; remove inline `setTimeout(3000)` × 2 |
|
|
48
|
-
| `src/clis/bloomberg/news.ts` | `wait(5)` → `wait({ selector: '#__NEXT_DATA__', timeout: 8 })`; `wait(4)` → `wait({ selector: '#__NEXT_DATA__', timeout: 5 })` |
|
|
49
|
-
| `src/clis/sinablog/utils.ts` | `wait(3/5)` → selector; remove inline polling loop |
|
|
50
|
-
|
|
51
|
-
---
|
|
52
|
-
|
|
53
|
-
## Task 1: Add `waitForCaptureJs` and `waitForSelectorJs` to dom-helpers.ts
|
|
54
|
-
|
|
55
|
-
**Files:**
|
|
56
|
-
- Modify: `src/browser/dom-helpers.ts`
|
|
57
|
-
- Create: `src/browser/dom-helpers.test.ts`
|
|
58
|
-
|
|
59
|
-
- [ ] **Step 1: Add two new exported functions at the end of `src/browser/dom-helpers.ts`**
|
|
60
|
-
|
|
61
|
-
```typescript
|
|
62
|
-
/**
|
|
63
|
-
* Generate JS to wait until window.__opencli_xhr has ≥1 captured response.
|
|
64
|
-
* Polls every 100ms. Resolves 'captured' on success; rejects after maxMs.
|
|
65
|
-
* Used after installInterceptor() + goto() instead of a fixed sleep.
|
|
66
|
-
*/
|
|
67
|
-
export function waitForCaptureJs(maxMs: number): string {
|
|
68
|
-
return `
|
|
69
|
-
new Promise((resolve, reject) => {
|
|
70
|
-
const deadline = Date.now() + ${maxMs};
|
|
71
|
-
const check = () => {
|
|
72
|
-
if ((window.__opencli_xhr || []).length > 0) return resolve('captured');
|
|
73
|
-
if (Date.now() > deadline) return reject(new Error('No network capture within ${maxMs / 1000}s'));
|
|
74
|
-
setTimeout(check, 100);
|
|
75
|
-
};
|
|
76
|
-
check();
|
|
77
|
-
})
|
|
78
|
-
`;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* Generate JS to wait until document.querySelector(selector) returns a match.
|
|
83
|
-
* Polls every 100ms. Resolves 'found' on success; rejects after timeoutMs.
|
|
84
|
-
*/
|
|
85
|
-
export function waitForSelectorJs(selector: string, timeoutMs: number): string {
|
|
86
|
-
return `
|
|
87
|
-
new Promise((resolve, reject) => {
|
|
88
|
-
const deadline = Date.now() + ${timeoutMs};
|
|
89
|
-
const check = () => {
|
|
90
|
-
if (document.querySelector(${JSON.stringify(selector)})) return resolve('found');
|
|
91
|
-
if (Date.now() > deadline) return reject(new Error('Selector not found: ' + ${JSON.stringify(selector)}));
|
|
92
|
-
setTimeout(check, 100);
|
|
93
|
-
};
|
|
94
|
-
check();
|
|
95
|
-
})
|
|
96
|
-
`;
|
|
97
|
-
}
|
|
98
|
-
```
|
|
99
|
-
|
|
100
|
-
- [ ] **Step 2: Create `src/browser/dom-helpers.test.ts` with failing tests**
|
|
101
|
-
|
|
102
|
-
```typescript
|
|
103
|
-
import { describe, it, expect } from 'vitest';
|
|
104
|
-
import { waitForCaptureJs, waitForSelectorJs } from './dom-helpers.js';
|
|
105
|
-
|
|
106
|
-
describe('waitForCaptureJs', () => {
|
|
107
|
-
it('returns a non-empty string', () => {
|
|
108
|
-
const code = waitForCaptureJs(1000);
|
|
109
|
-
expect(typeof code).toBe('string');
|
|
110
|
-
expect(code.length).toBeGreaterThan(0);
|
|
111
|
-
expect(code).toContain('__opencli_xhr');
|
|
112
|
-
expect(code).toContain('resolve');
|
|
113
|
-
expect(code).toContain('reject');
|
|
114
|
-
});
|
|
115
|
-
|
|
116
|
-
it('resolves "captured" when __opencli_xhr is populated before deadline', async () => {
|
|
117
|
-
const g = globalThis as any;
|
|
118
|
-
g.__opencli_xhr = [];
|
|
119
|
-
const code = waitForCaptureJs(1000);
|
|
120
|
-
const promise = eval(code) as Promise<string>;
|
|
121
|
-
g.__opencli_xhr.push({ data: 'test' });
|
|
122
|
-
await expect(promise).resolves.toBe('captured');
|
|
123
|
-
delete g.__opencli_xhr;
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
it('rejects when __opencli_xhr stays empty past deadline', async () => {
|
|
127
|
-
const g = globalThis as any;
|
|
128
|
-
g.__opencli_xhr = [];
|
|
129
|
-
const code = waitForCaptureJs(50); // 50ms timeout
|
|
130
|
-
const promise = eval(code) as Promise<string>;
|
|
131
|
-
await expect(promise).rejects.toThrow('No network capture within 0.05s');
|
|
132
|
-
delete g.__opencli_xhr;
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
it('resolves immediately when __opencli_xhr already has data', async () => {
|
|
136
|
-
const g = globalThis as any;
|
|
137
|
-
g.__opencli_xhr = [{ data: 'already here' }];
|
|
138
|
-
const code = waitForCaptureJs(1000);
|
|
139
|
-
await expect(eval(code) as Promise<string>).resolves.toBe('captured');
|
|
140
|
-
delete g.__opencli_xhr;
|
|
141
|
-
});
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
describe('waitForSelectorJs', () => {
|
|
145
|
-
it('returns a non-empty string', () => {
|
|
146
|
-
const code = waitForSelectorJs('#app', 1000);
|
|
147
|
-
expect(typeof code).toBe('string');
|
|
148
|
-
expect(code).toContain('#app');
|
|
149
|
-
expect(code).toContain('querySelector');
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
it('rejects when document.querySelector returns null within timeout', async () => {
|
|
153
|
-
const g = globalThis as any;
|
|
154
|
-
g.document = { querySelector: (_: string) => null };
|
|
155
|
-
const code = waitForSelectorJs('#missing', 50);
|
|
156
|
-
await expect(eval(code) as Promise<string>).rejects.toThrow('Selector not found: #missing');
|
|
157
|
-
delete g.document;
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
it('resolves "found" when document.querySelector returns an element', async () => {
|
|
161
|
-
const g = globalThis as any;
|
|
162
|
-
const fakeEl = { tagName: 'DIV' };
|
|
163
|
-
g.document = { querySelector: (_: string) => fakeEl };
|
|
164
|
-
const code = waitForSelectorJs('[data-testid="primaryColumn"]', 1000);
|
|
165
|
-
await expect(eval(code) as Promise<string>).resolves.toBe('found');
|
|
166
|
-
delete g.document;
|
|
167
|
-
});
|
|
168
|
-
});
|
|
169
|
-
```
|
|
170
|
-
|
|
171
|
-
- [ ] **Step 3: Run tests to verify they fail (functions not yet exported)**
|
|
172
|
-
|
|
173
|
-
```bash
|
|
174
|
-
cd /Users/jakevin/code/opencli
|
|
175
|
-
npx vitest run --project unit src/browser/dom-helpers.test.ts
|
|
176
|
-
```
|
|
177
|
-
Expected: Tests for `waitForCaptureJs` pass (function exists), tests for `waitForSelectorJs` fail (not yet added).
|
|
178
|
-
|
|
179
|
-
- [ ] **Step 4: Run tests again after Step 1 to verify all pass**
|
|
180
|
-
|
|
181
|
-
```bash
|
|
182
|
-
npx vitest run --project unit src/browser/dom-helpers.test.ts
|
|
183
|
-
```
|
|
184
|
-
Expected: All 7 tests PASS.
|
|
185
|
-
|
|
186
|
-
- [ ] **Step 5: Commit**
|
|
187
|
-
|
|
188
|
-
```bash
|
|
189
|
-
git add src/browser/dom-helpers.ts src/browser/dom-helpers.test.ts
|
|
190
|
-
git commit -m "feat(perf): add waitForCaptureJs and waitForSelectorJs to dom-helpers"
|
|
191
|
-
```
|
|
192
|
-
|
|
193
|
-
---
|
|
194
|
-
|
|
195
|
-
## Task 2: Extend `IPage` interface and `WaitOptions` in `types.ts`
|
|
196
|
-
|
|
197
|
-
**Files:**
|
|
198
|
-
- Modify: `src/types.ts`
|
|
199
|
-
|
|
200
|
-
- [ ] **Step 1: Add `selector` to `WaitOptions` and `waitForCapture` to `IPage`**
|
|
201
|
-
|
|
202
|
-
In `src/types.ts`, find `WaitOptions` and add `selector?`:
|
|
203
|
-
|
|
204
|
-
```typescript
|
|
205
|
-
export interface WaitOptions {
|
|
206
|
-
text?: string;
|
|
207
|
-
selector?: string; // wait until document.querySelector(selector) matches
|
|
208
|
-
time?: number;
|
|
209
|
-
timeout?: number;
|
|
210
|
-
}
|
|
211
|
-
```
|
|
212
|
-
|
|
213
|
-
In the same file, find `IPage` and add `waitForCapture` after `getInterceptedRequests`:
|
|
214
|
-
|
|
215
|
-
```typescript
|
|
216
|
-
installInterceptor(pattern: string): Promise<void>;
|
|
217
|
-
getInterceptedRequests(): Promise<any[]>;
|
|
218
|
-
waitForCapture(timeout?: number): Promise<void>;
|
|
219
|
-
```
|
|
220
|
-
|
|
221
|
-
- [ ] **Step 2: Run unit tests to confirm no type errors**
|
|
222
|
-
|
|
223
|
-
```bash
|
|
224
|
-
npx vitest run --project unit
|
|
225
|
-
```
|
|
226
|
-
Expected: All existing unit tests PASS (no adapter tests broken since IPage is extended, not changed).
|
|
227
|
-
|
|
228
|
-
- [ ] **Step 3: Commit**
|
|
229
|
-
|
|
230
|
-
```bash
|
|
231
|
-
git add src/types.ts
|
|
232
|
-
git commit -m "feat(perf): extend WaitOptions with selector, add waitForCapture to IPage"
|
|
233
|
-
```
|
|
234
|
-
|
|
235
|
-
---
|
|
236
|
-
|
|
237
|
-
## Task 3: Implement `waitForCapture()` and `wait({ selector })` in `page.ts`
|
|
238
|
-
|
|
239
|
-
**Files:**
|
|
240
|
-
- Modify: `src/browser/page.ts`
|
|
241
|
-
|
|
242
|
-
- [ ] **Step 1: Add `waitForCaptureJs` and `waitForSelectorJs` to the imports at the top of `page.ts`**
|
|
243
|
-
|
|
244
|
-
Find the existing import from `./dom-helpers.js`:
|
|
245
|
-
|
|
246
|
-
```typescript
|
|
247
|
-
import {
|
|
248
|
-
clickJs,
|
|
249
|
-
typeTextJs,
|
|
250
|
-
pressKeyJs,
|
|
251
|
-
waitForTextJs,
|
|
252
|
-
scrollJs,
|
|
253
|
-
autoScrollJs,
|
|
254
|
-
networkRequestsJs,
|
|
255
|
-
waitForDomStableJs,
|
|
256
|
-
} from './dom-helpers.js';
|
|
257
|
-
```
|
|
258
|
-
|
|
259
|
-
Replace with:
|
|
260
|
-
|
|
261
|
-
```typescript
|
|
262
|
-
import {
|
|
263
|
-
clickJs,
|
|
264
|
-
typeTextJs,
|
|
265
|
-
pressKeyJs,
|
|
266
|
-
waitForTextJs,
|
|
267
|
-
waitForCaptureJs,
|
|
268
|
-
waitForSelectorJs,
|
|
269
|
-
scrollJs,
|
|
270
|
-
autoScrollJs,
|
|
271
|
-
networkRequestsJs,
|
|
272
|
-
waitForDomStableJs,
|
|
273
|
-
} from './dom-helpers.js';
|
|
274
|
-
```
|
|
275
|
-
|
|
276
|
-
- [ ] **Step 2: Add `selector` branch to the existing `wait()` method in `page.ts`**
|
|
277
|
-
|
|
278
|
-
Find the current `wait()` implementation and add the `selector` branch before the `text` branch:
|
|
279
|
-
|
|
280
|
-
```typescript
|
|
281
|
-
async wait(options: number | WaitOptions): Promise<void> {
|
|
282
|
-
if (typeof options === 'number') {
|
|
283
|
-
if (options >= 1) {
|
|
284
|
-
try {
|
|
285
|
-
const maxMs = options * 1000;
|
|
286
|
-
await sendCommand('exec', {
|
|
287
|
-
code: waitForDomStableJs(maxMs, Math.min(500, maxMs)),
|
|
288
|
-
...this._cmdOpts(),
|
|
289
|
-
});
|
|
290
|
-
return;
|
|
291
|
-
} catch {
|
|
292
|
-
// Fallback: fixed sleep (e.g. if page has no DOM yet)
|
|
293
|
-
}
|
|
294
|
-
}
|
|
295
|
-
await new Promise(resolve => setTimeout(resolve, options * 1000));
|
|
296
|
-
return;
|
|
297
|
-
}
|
|
298
|
-
if (typeof options.time === 'number') {
|
|
299
|
-
await new Promise(resolve => setTimeout(resolve, options.time! * 1000));
|
|
300
|
-
return;
|
|
301
|
-
}
|
|
302
|
-
if (options.selector) {
|
|
303
|
-
const timeout = (options.timeout ?? 10) * 1000;
|
|
304
|
-
const code = waitForSelectorJs(options.selector, timeout);
|
|
305
|
-
await sendCommand('exec', { code, ...this._cmdOpts() });
|
|
306
|
-
return;
|
|
307
|
-
}
|
|
308
|
-
if (options.text) {
|
|
309
|
-
const timeout = (options.timeout ?? 30) * 1000;
|
|
310
|
-
const code = waitForTextJs(options.text, timeout);
|
|
311
|
-
await sendCommand('exec', { code, ...this._cmdOpts() });
|
|
312
|
-
}
|
|
313
|
-
}
|
|
314
|
-
```
|
|
315
|
-
|
|
316
|
-
- [ ] **Step 3: Add `waitForCapture()` method to `page.ts`, just after `getInterceptedRequests()`**
|
|
317
|
-
|
|
318
|
-
Find `getInterceptedRequests()` at the end of the `Page` class and add after it:
|
|
319
|
-
|
|
320
|
-
```typescript
|
|
321
|
-
async waitForCapture(timeout: number = 10): Promise<void> {
|
|
322
|
-
const maxMs = timeout * 1000;
|
|
323
|
-
await sendCommand('exec', {
|
|
324
|
-
code: waitForCaptureJs(maxMs),
|
|
325
|
-
...this._cmdOpts(),
|
|
326
|
-
});
|
|
327
|
-
}
|
|
328
|
-
```
|
|
329
|
-
|
|
330
|
-
- [ ] **Step 4: Run unit tests**
|
|
331
|
-
|
|
332
|
-
```bash
|
|
333
|
-
npx vitest run --project unit
|
|
334
|
-
```
|
|
335
|
-
Expected: All PASS.
|
|
336
|
-
|
|
337
|
-
- [ ] **Step 5: Commit**
|
|
338
|
-
|
|
339
|
-
```bash
|
|
340
|
-
git add src/browser/page.ts
|
|
341
|
-
git commit -m "feat(perf): implement waitForCapture() and wait({ selector }) in Page"
|
|
342
|
-
```
|
|
343
|
-
|
|
344
|
-
---
|
|
345
|
-
|
|
346
|
-
## Task 4: Implement `waitForCapture()` and `wait({ selector })` in `cdp.ts`
|
|
347
|
-
|
|
348
|
-
**Files:**
|
|
349
|
-
- Modify: `src/browser/cdp.ts`
|
|
350
|
-
|
|
351
|
-
- [ ] **Step 1: Add `waitForCaptureJs` and `waitForSelectorJs` to the imports in `cdp.ts`**
|
|
352
|
-
|
|
353
|
-
Find the existing import from `./dom-helpers.js` in `cdp.ts`:
|
|
354
|
-
|
|
355
|
-
```typescript
|
|
356
|
-
import {
|
|
357
|
-
clickJs,
|
|
358
|
-
typeTextJs,
|
|
359
|
-
pressKeyJs,
|
|
360
|
-
waitForTextJs,
|
|
361
|
-
scrollJs,
|
|
362
|
-
autoScrollJs,
|
|
363
|
-
networkRequestsJs,
|
|
364
|
-
} from './dom-helpers.js';
|
|
365
|
-
```
|
|
366
|
-
|
|
367
|
-
Replace with:
|
|
368
|
-
|
|
369
|
-
```typescript
|
|
370
|
-
import {
|
|
371
|
-
clickJs,
|
|
372
|
-
typeTextJs,
|
|
373
|
-
pressKeyJs,
|
|
374
|
-
waitForTextJs,
|
|
375
|
-
waitForCaptureJs,
|
|
376
|
-
waitForSelectorJs,
|
|
377
|
-
scrollJs,
|
|
378
|
-
autoScrollJs,
|
|
379
|
-
networkRequestsJs,
|
|
380
|
-
} from './dom-helpers.js';
|
|
381
|
-
```
|
|
382
|
-
|
|
383
|
-
- [ ] **Step 2: Add `selector` branch to `wait()` in `cdp.ts`**
|
|
384
|
-
|
|
385
|
-
Find the current `wait()` in `cdp.ts` and replace it entirely:
|
|
386
|
-
|
|
387
|
-
```typescript
|
|
388
|
-
async wait(options: number | WaitOptions): Promise<void> {
|
|
389
|
-
if (typeof options === 'number') {
|
|
390
|
-
await new Promise((resolve) => setTimeout(resolve, options * 1000));
|
|
391
|
-
return;
|
|
392
|
-
}
|
|
393
|
-
if (typeof options.time === 'number') {
|
|
394
|
-
const waitTime = options.time;
|
|
395
|
-
await new Promise((resolve) => setTimeout(resolve, waitTime * 1000));
|
|
396
|
-
return;
|
|
397
|
-
}
|
|
398
|
-
if (options.selector) {
|
|
399
|
-
const timeout = (options.timeout ?? 10) * 1000;
|
|
400
|
-
await this.evaluate(waitForSelectorJs(options.selector, timeout));
|
|
401
|
-
return;
|
|
402
|
-
}
|
|
403
|
-
if (options.text) {
|
|
404
|
-
const timeout = (options.timeout ?? 30) * 1000;
|
|
405
|
-
await this.evaluate(waitForTextJs(options.text, timeout));
|
|
406
|
-
}
|
|
407
|
-
}
|
|
408
|
-
```
|
|
409
|
-
|
|
410
|
-
- [ ] **Step 3: Add `waitForCapture()` to `cdp.ts`, just after `getInterceptedRequests()`**
|
|
411
|
-
|
|
412
|
-
Find `getInterceptedRequests()` at the end of the `CDPPage` class and add after it:
|
|
413
|
-
|
|
414
|
-
```typescript
|
|
415
|
-
async waitForCapture(timeout: number = 10): Promise<void> {
|
|
416
|
-
const maxMs = timeout * 1000;
|
|
417
|
-
await this.evaluate(waitForCaptureJs(maxMs));
|
|
418
|
-
}
|
|
419
|
-
```
|
|
420
|
-
|
|
421
|
-
- [ ] **Step 4: Run unit tests**
|
|
422
|
-
|
|
423
|
-
```bash
|
|
424
|
-
npx vitest run --project unit
|
|
425
|
-
```
|
|
426
|
-
Expected: All PASS.
|
|
427
|
-
|
|
428
|
-
- [ ] **Step 5: Commit**
|
|
429
|
-
|
|
430
|
-
```bash
|
|
431
|
-
git add src/browser/cdp.ts
|
|
432
|
-
git commit -m "feat(perf): implement waitForCapture() and wait({ selector }) in CDPPage"
|
|
433
|
-
```
|
|
434
|
-
|
|
435
|
-
---
|
|
436
|
-
|
|
437
|
-
## Task 5: Update `stepIntercept` to use unified IPage methods
|
|
438
|
-
|
|
439
|
-
**Files:**
|
|
440
|
-
- Modify: `src/pipeline/steps/intercept.ts`
|
|
441
|
-
|
|
442
|
-
The current `stepIntercept` uses `generateInterceptorJs`/`generateReadInterceptedJs` directly, writing to `__opencli_intercepted`. We unify this to use `page.installInterceptor()` (→ `__opencli_xhr`) + `page.waitForCapture()` + `page.getInterceptedRequests()`.
|
|
443
|
-
|
|
444
|
-
- [ ] **Step 1: Rewrite `src/pipeline/steps/intercept.ts`**
|
|
445
|
-
|
|
446
|
-
```typescript
|
|
447
|
-
/**
|
|
448
|
-
* Pipeline step: intercept — declarative XHR interception.
|
|
449
|
-
*/
|
|
450
|
-
|
|
451
|
-
import type { IPage } from '../../types.js';
|
|
452
|
-
import { render, normalizeEvaluateSource } from '../template.js';
|
|
453
|
-
|
|
454
|
-
export async function stepIntercept(page: IPage | null, params: any, data: any, args: Record<string, any>): Promise<any> {
|
|
455
|
-
const cfg = typeof params === 'object' ? params : {};
|
|
456
|
-
const trigger = cfg.trigger ?? '';
|
|
457
|
-
const capturePattern = cfg.capture ?? '';
|
|
458
|
-
const timeout = cfg.timeout ?? 8;
|
|
459
|
-
const selectPath = cfg.select ?? null;
|
|
460
|
-
|
|
461
|
-
if (!capturePattern) return data;
|
|
462
|
-
|
|
463
|
-
// Step 1: Install fetch/XHR interceptor BEFORE trigger
|
|
464
|
-
await page!.installInterceptor(capturePattern);
|
|
465
|
-
|
|
466
|
-
// Step 2: Execute the trigger action
|
|
467
|
-
if (trigger.startsWith('navigate:')) {
|
|
468
|
-
const url = render(trigger.slice('navigate:'.length), { args, data });
|
|
469
|
-
await page!.goto(String(url));
|
|
470
|
-
} else if (trigger.startsWith('evaluate:')) {
|
|
471
|
-
const js = trigger.slice('evaluate:'.length);
|
|
472
|
-
await page!.evaluate(normalizeEvaluateSource(render(js, { args, data }) as string));
|
|
473
|
-
} else if (trigger.startsWith('click:')) {
|
|
474
|
-
const ref = render(trigger.slice('click:'.length), { args, data });
|
|
475
|
-
await page!.click(String(ref).replace(/^@/, ''));
|
|
476
|
-
} else if (trigger === 'scroll') {
|
|
477
|
-
await page!.scroll('down');
|
|
478
|
-
}
|
|
479
|
-
|
|
480
|
-
// Step 3: Wait for network capture instead of fixed sleep
|
|
481
|
-
await page!.waitForCapture(timeout);
|
|
482
|
-
|
|
483
|
-
// Step 4: Retrieve captured data
|
|
484
|
-
const matchingResponses = await page!.getInterceptedRequests();
|
|
485
|
-
|
|
486
|
-
// Step 5: Select from response if specified
|
|
487
|
-
let result = matchingResponses.length === 1 ? matchingResponses[0] :
|
|
488
|
-
matchingResponses.length > 1 ? matchingResponses : data;
|
|
489
|
-
|
|
490
|
-
if (selectPath && result) {
|
|
491
|
-
let current = result;
|
|
492
|
-
for (const part of String(selectPath).split('.')) {
|
|
493
|
-
if (current && typeof current === 'object' && !Array.isArray(current)) {
|
|
494
|
-
current = current[part];
|
|
495
|
-
} else break;
|
|
496
|
-
}
|
|
497
|
-
result = current ?? result;
|
|
498
|
-
}
|
|
499
|
-
|
|
500
|
-
return result;
|
|
501
|
-
}
|
|
502
|
-
```
|
|
503
|
-
|
|
504
|
-
- [ ] **Step 2: Run unit + adapter tests**
|
|
505
|
-
|
|
506
|
-
```bash
|
|
507
|
-
npx vitest run --project unit --project adapter
|
|
508
|
-
```
|
|
509
|
-
Expected: All PASS.
|
|
510
|
-
|
|
511
|
-
- [ ] **Step 3: Commit**
|
|
512
|
-
|
|
513
|
-
```bash
|
|
514
|
-
git add src/pipeline/steps/intercept.ts
|
|
515
|
-
git commit -m "perf(intercept): use installInterceptor+waitForCapture in stepIntercept pipeline step"
|
|
516
|
-
```
|
|
517
|
-
|
|
518
|
-
---
|
|
519
|
-
|
|
520
|
-
## Task 6: Fix INTERCEPT adapters (Layer 1)
|
|
521
|
-
|
|
522
|
-
**Files:** `36kr/hot.ts`, `36kr/search.ts`, `twitter/search.ts`, `twitter/followers.ts`, `twitter/following.ts`, `twitter/notifications.ts`, `producthunt/hot.ts`, `producthunt/browse.ts`
|
|
523
|
-
|
|
524
|
-
- [ ] **Step 1: Fix `src/clis/36kr/hot.ts`**
|
|
525
|
-
|
|
526
|
-
Find:
|
|
527
|
-
```typescript
|
|
528
|
-
await page.installInterceptor('36kr.com/api');
|
|
529
|
-
await page.goto(url);
|
|
530
|
-
await page.wait(6);
|
|
531
|
-
```
|
|
532
|
-
Replace with:
|
|
533
|
-
```typescript
|
|
534
|
-
await page.installInterceptor('36kr.com/api');
|
|
535
|
-
await page.goto(url);
|
|
536
|
-
await page.waitForCapture(10);
|
|
537
|
-
```
|
|
538
|
-
|
|
539
|
-
- [ ] **Step 2: Fix `src/clis/36kr/search.ts`**
|
|
540
|
-
|
|
541
|
-
Find:
|
|
542
|
-
```typescript
|
|
543
|
-
await page.installInterceptor('36kr.com/api');
|
|
544
|
-
await page.goto(`https://www.36kr.com/search/articles/${query}`);
|
|
545
|
-
await page.wait(6);
|
|
546
|
-
```
|
|
547
|
-
Replace with:
|
|
548
|
-
```typescript
|
|
549
|
-
await page.installInterceptor('36kr.com/api');
|
|
550
|
-
await page.goto(`https://www.36kr.com/search/articles/${query}`);
|
|
551
|
-
await page.waitForCapture(10);
|
|
552
|
-
```
|
|
553
|
-
|
|
554
|
-
- [ ] **Step 3: Fix `src/clis/twitter/search.ts`**
|
|
555
|
-
|
|
556
|
-
Find the two lines that contain `await page.wait(5)` in the `navigateToSearch` helper:
|
|
557
|
-
```typescript
|
|
558
|
-
await page.wait(5);
|
|
559
|
-
```
|
|
560
|
-
(there are two of them: one after `pushState`, one in the retry). Replace both with:
|
|
561
|
-
```typescript
|
|
562
|
-
await page.waitForCapture(8);
|
|
563
|
-
```
|
|
564
|
-
|
|
565
|
-
- [ ] **Step 4: Fix `src/clis/twitter/followers.ts`**
|
|
566
|
-
|
|
567
|
-
Find:
|
|
568
|
-
```typescript
|
|
569
|
-
await page.wait(5);
|
|
570
|
-
|
|
571
|
-
// 4. Scroll to trigger pagination API calls
|
|
572
|
-
```
|
|
573
|
-
Replace with:
|
|
574
|
-
```typescript
|
|
575
|
-
await page.waitForCapture(8);
|
|
576
|
-
|
|
577
|
-
// 4. Scroll to trigger pagination API calls
|
|
578
|
-
```
|
|
579
|
-
|
|
580
|
-
Also find the earlier `wait(5)` after going to profile and `wait(3)` after going to home — those are UI waits (not INTERCEPT), replace with selector:
|
|
581
|
-
```typescript
|
|
582
|
-
// After page.goto('https://x.com/home'):
|
|
583
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 5 });
|
|
584
|
-
// After page.goto(`https://x.com/${targetUser}`):
|
|
585
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 4 });
|
|
586
|
-
```
|
|
587
|
-
|
|
588
|
-
- [ ] **Step 5: Fix `src/clis/twitter/following.ts`**
|
|
589
|
-
|
|
590
|
-
Same pattern as `followers.ts`. Find and apply identically:
|
|
591
|
-
- `wait(5)` after `goto('https://x.com/home')` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 5 })`
|
|
592
|
-
- `wait(3)` after `goto(\`https://x.com/${targetUser}\`)` → `wait({ selector: '[data-testid="primaryColumn"]', timeout: 4 })`
|
|
593
|
-
- `wait(5)` after SPA click that triggers INTERCEPT → `waitForCapture(8)`
|
|
594
|
-
|
|
595
|
-
- [ ] **Step 6: Fix `src/clis/twitter/notifications.ts`**
|
|
596
|
-
|
|
597
|
-
Find:
|
|
598
|
-
```typescript
|
|
599
|
-
await page.goto('https://x.com/home');
|
|
600
|
-
await page.wait(3);
|
|
601
|
-
```
|
|
602
|
-
Replace with:
|
|
603
|
-
```typescript
|
|
604
|
-
await page.goto('https://x.com/home');
|
|
605
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 5 });
|
|
606
|
-
```
|
|
607
|
-
|
|
608
|
-
Find:
|
|
609
|
-
```typescript
|
|
610
|
-
await page.wait(5);
|
|
611
|
-
|
|
612
|
-
// Verify SPA navigation succeeded
|
|
613
|
-
```
|
|
614
|
-
Replace with:
|
|
615
|
-
```typescript
|
|
616
|
-
await page.waitForCapture(8);
|
|
617
|
-
|
|
618
|
-
// Verify SPA navigation succeeded
|
|
619
|
-
```
|
|
620
|
-
|
|
621
|
-
- [ ] **Step 7: Fix `src/clis/producthunt/hot.ts`**
|
|
622
|
-
|
|
623
|
-
Find:
|
|
624
|
-
```typescript
|
|
625
|
-
await page.installInterceptor(
|
|
626
|
-
```
|
|
627
|
-
Look at the full pattern and replace the subsequent `wait(5)` with `waitForCapture(8)`.
|
|
628
|
-
|
|
629
|
-
- [ ] **Step 8: Fix `src/clis/producthunt/browse.ts`**
|
|
630
|
-
|
|
631
|
-
Same as `hot.ts` — replace `wait(5)` after `installInterceptor` + `goto` with `waitForCapture(8)`.
|
|
632
|
-
|
|
633
|
-
- [ ] **Step 9: Run adapter tests**
|
|
634
|
-
|
|
635
|
-
```bash
|
|
636
|
-
npx vitest run --project adapter
|
|
637
|
-
```
|
|
638
|
-
Expected: All PASS (adapter tests mock `page.wait` and `page.waitForCapture`; existing mocks will need `waitForCapture: vi.fn()` if not already present).
|
|
639
|
-
|
|
640
|
-
If any adapter test file lacks `waitForCapture` mock, add `waitForCapture: vi.fn().mockResolvedValue(undefined)` to its mock page object.
|
|
641
|
-
|
|
642
|
-
- [ ] **Step 10: Commit**
|
|
643
|
-
|
|
644
|
-
```bash
|
|
645
|
-
git add src/clis/36kr/hot.ts src/clis/36kr/search.ts \
|
|
646
|
-
src/clis/twitter/search.ts src/clis/twitter/followers.ts \
|
|
647
|
-
src/clis/twitter/following.ts src/clis/twitter/notifications.ts \
|
|
648
|
-
src/clis/producthunt/hot.ts src/clis/producthunt/browse.ts
|
|
649
|
-
git commit -m "perf(intercept): replace wait(N) with waitForCapture() in all INTERCEPT adapters"
|
|
650
|
-
```
|
|
651
|
-
|
|
652
|
-
---
|
|
653
|
-
|
|
654
|
-
## Task 7: Daemon exponential backoff (Layer 3)
|
|
655
|
-
|
|
656
|
-
**Files:**
|
|
657
|
-
- Modify: `src/browser/mcp.ts`
|
|
658
|
-
|
|
659
|
-
- [ ] **Step 1: Replace fixed 300ms poll loop in `_ensureDaemon()`**
|
|
660
|
-
|
|
661
|
-
In `src/browser/mcp.ts`, find:
|
|
662
|
-
|
|
663
|
-
```typescript
|
|
664
|
-
// Wait for daemon to be ready AND extension to connect
|
|
665
|
-
const deadline = Date.now() + timeoutMs;
|
|
666
|
-
while (Date.now() < deadline) {
|
|
667
|
-
await new Promise(resolve => setTimeout(resolve, 300));
|
|
668
|
-
if (await isExtensionConnected()) return;
|
|
669
|
-
}
|
|
670
|
-
```
|
|
671
|
-
|
|
672
|
-
Replace with:
|
|
673
|
-
|
|
674
|
-
```typescript
|
|
675
|
-
// Wait for daemon to be ready AND extension to connect.
|
|
676
|
-
// Exponential backoff: daemon typically ready in 500–800ms,
|
|
677
|
-
// so first check at 50ms then 100ms gets a fast result without hammering.
|
|
678
|
-
const deadline = Date.now() + timeoutMs;
|
|
679
|
-
const backoffs = [50, 100, 200, 400, 800, 1500, 3000];
|
|
680
|
-
let backoffIdx = 0;
|
|
681
|
-
while (Date.now() < deadline) {
|
|
682
|
-
const delay = backoffs[Math.min(backoffIdx++, backoffs.length - 1)];
|
|
683
|
-
await new Promise(resolve => setTimeout(resolve, delay));
|
|
684
|
-
if (await isExtensionConnected()) return;
|
|
685
|
-
}
|
|
686
|
-
```
|
|
687
|
-
|
|
688
|
-
- [ ] **Step 2: Run unit tests**
|
|
689
|
-
|
|
690
|
-
```bash
|
|
691
|
-
npx vitest run --project unit
|
|
692
|
-
```
|
|
693
|
-
Expected: All PASS.
|
|
694
|
-
|
|
695
|
-
- [ ] **Step 3: Commit**
|
|
696
|
-
|
|
697
|
-
```bash
|
|
698
|
-
git add src/browser/mcp.ts
|
|
699
|
-
git commit -m "perf(daemon): exponential backoff for cold-start extension polling"
|
|
700
|
-
```
|
|
701
|
-
|
|
702
|
-
---
|
|
703
|
-
|
|
704
|
-
## Task 8: Fix Twitter UI adapters with `wait({ selector })` (Layer 2, part 1)
|
|
705
|
-
|
|
706
|
-
**Files:** 13 adapters in `src/clis/twitter/`
|
|
707
|
-
|
|
708
|
-
For all adapters below, the pattern is identical: `await page.goto(url)` followed by `await page.wait(5)` waiting for React to hydrate. Replace `wait(5)` with `wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 })`.
|
|
709
|
-
|
|
710
|
-
- [ ] **Step 1: Fix `src/clis/twitter/reply.ts`**
|
|
711
|
-
|
|
712
|
-
Find:
|
|
713
|
-
```typescript
|
|
714
|
-
await page.goto(kwargs.url);
|
|
715
|
-
await page.wait(5); // Wait for the react application to hydrate
|
|
716
|
-
```
|
|
717
|
-
Replace with:
|
|
718
|
-
```typescript
|
|
719
|
-
await page.goto(kwargs.url);
|
|
720
|
-
await page.wait({ selector: '[data-testid="tweetTextarea_0"]', timeout: 8 });
|
|
721
|
-
```
|
|
722
|
-
(reply.ts uses the reply textarea directly — more precise than primaryColumn)
|
|
723
|
-
|
|
724
|
-
- [ ] **Step 2: Fix `src/clis/twitter/follow.ts`**
|
|
725
|
-
|
|
726
|
-
Find:
|
|
727
|
-
```typescript
|
|
728
|
-
await page.goto(`https://x.com/${username}`);
|
|
729
|
-
await page.wait(5);
|
|
730
|
-
```
|
|
731
|
-
Replace with:
|
|
732
|
-
```typescript
|
|
733
|
-
await page.goto(`https://x.com/${username}`);
|
|
734
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
735
|
-
```
|
|
736
|
-
|
|
737
|
-
- [ ] **Step 3: Fix `src/clis/twitter/unfollow.ts`**
|
|
738
|
-
|
|
739
|
-
Find:
|
|
740
|
-
```typescript
|
|
741
|
-
await page.goto(`https://x.com/${username}`);
|
|
742
|
-
await page.wait(5);
|
|
743
|
-
```
|
|
744
|
-
Replace with:
|
|
745
|
-
```typescript
|
|
746
|
-
await page.goto(`https://x.com/${username}`);
|
|
747
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
748
|
-
```
|
|
749
|
-
|
|
750
|
-
- [ ] **Step 4: Fix `src/clis/twitter/like.ts`**
|
|
751
|
-
|
|
752
|
-
Find:
|
|
753
|
-
```typescript
|
|
754
|
-
await page.goto(kwargs.url);
|
|
755
|
-
await page.wait(5); // Wait for tweet to load completely
|
|
756
|
-
```
|
|
757
|
-
Replace with:
|
|
758
|
-
```typescript
|
|
759
|
-
await page.goto(kwargs.url);
|
|
760
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
761
|
-
```
|
|
762
|
-
|
|
763
|
-
- [ ] **Step 5: Fix `src/clis/twitter/bookmark.ts`**
|
|
764
|
-
|
|
765
|
-
Find:
|
|
766
|
-
```typescript
|
|
767
|
-
await page.goto(kwargs.url);
|
|
768
|
-
await page.wait(5);
|
|
769
|
-
```
|
|
770
|
-
Replace with:
|
|
771
|
-
```typescript
|
|
772
|
-
await page.goto(kwargs.url);
|
|
773
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
774
|
-
```
|
|
775
|
-
|
|
776
|
-
- [ ] **Step 6: Fix `src/clis/twitter/unbookmark.ts`**
|
|
777
|
-
|
|
778
|
-
Find:
|
|
779
|
-
```typescript
|
|
780
|
-
await page.goto(kwargs.url);
|
|
781
|
-
await page.wait(5);
|
|
782
|
-
```
|
|
783
|
-
Replace with:
|
|
784
|
-
```typescript
|
|
785
|
-
await page.goto(kwargs.url);
|
|
786
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
787
|
-
```
|
|
788
|
-
|
|
789
|
-
- [ ] **Step 7: Fix `src/clis/twitter/block.ts`**
|
|
790
|
-
|
|
791
|
-
Find:
|
|
792
|
-
```typescript
|
|
793
|
-
await page.goto(`https://x.com/${username}`);
|
|
794
|
-
await page.wait(5);
|
|
795
|
-
```
|
|
796
|
-
Replace with:
|
|
797
|
-
```typescript
|
|
798
|
-
await page.goto(`https://x.com/${username}`);
|
|
799
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
800
|
-
```
|
|
801
|
-
|
|
802
|
-
- [ ] **Step 8: Fix `src/clis/twitter/unblock.ts`**
|
|
803
|
-
|
|
804
|
-
Find:
|
|
805
|
-
```typescript
|
|
806
|
-
await page.goto(`https://x.com/${username}`);
|
|
807
|
-
await page.wait(5);
|
|
808
|
-
```
|
|
809
|
-
Replace with:
|
|
810
|
-
```typescript
|
|
811
|
-
await page.goto(`https://x.com/${username}`);
|
|
812
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
813
|
-
```
|
|
814
|
-
|
|
815
|
-
- [ ] **Step 9: Fix `src/clis/twitter/hide-reply.ts`**
|
|
816
|
-
|
|
817
|
-
Find:
|
|
818
|
-
```typescript
|
|
819
|
-
await page.goto(kwargs.url);
|
|
820
|
-
await page.wait(5);
|
|
821
|
-
```
|
|
822
|
-
Replace with:
|
|
823
|
-
```typescript
|
|
824
|
-
await page.goto(kwargs.url);
|
|
825
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
826
|
-
```
|
|
827
|
-
|
|
828
|
-
- [ ] **Step 10: Fix `src/clis/twitter/delete.ts`**
|
|
829
|
-
|
|
830
|
-
Find:
|
|
831
|
-
```typescript
|
|
832
|
-
await page.goto(kwargs.url);
|
|
833
|
-
await page.wait(5); // Wait for tweet to load completely
|
|
834
|
-
```
|
|
835
|
-
Replace with:
|
|
836
|
-
```typescript
|
|
837
|
-
await page.goto(kwargs.url);
|
|
838
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
839
|
-
```
|
|
840
|
-
|
|
841
|
-
- [ ] **Step 11: Fix `src/clis/twitter/profile.ts`**
|
|
842
|
-
|
|
843
|
-
There are two wait calls:
|
|
844
|
-
|
|
845
|
-
Find (detecting logged-in user):
|
|
846
|
-
```typescript
|
|
847
|
-
await page.goto('https://x.com/home');
|
|
848
|
-
await page.wait(5);
|
|
849
|
-
```
|
|
850
|
-
Replace with:
|
|
851
|
-
```typescript
|
|
852
|
-
await page.goto('https://x.com/home');
|
|
853
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 6 });
|
|
854
|
-
```
|
|
855
|
-
|
|
856
|
-
Find (after going to profile):
|
|
857
|
-
```typescript
|
|
858
|
-
await page.goto(`https://x.com/${username}`);
|
|
859
|
-
await page.wait(3);
|
|
860
|
-
```
|
|
861
|
-
Replace with:
|
|
862
|
-
```typescript
|
|
863
|
-
await page.goto(`https://x.com/${username}`);
|
|
864
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 4 });
|
|
865
|
-
```
|
|
866
|
-
|
|
867
|
-
- [ ] **Step 12: Fix `src/clis/twitter/thread.ts`**
|
|
868
|
-
|
|
869
|
-
Find:
|
|
870
|
-
```typescript
|
|
871
|
-
await page.goto('https://x.com');
|
|
872
|
-
await page.wait(3);
|
|
873
|
-
```
|
|
874
|
-
Replace with:
|
|
875
|
-
```typescript
|
|
876
|
-
await page.goto('https://x.com');
|
|
877
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 4 });
|
|
878
|
-
```
|
|
879
|
-
|
|
880
|
-
- [ ] **Step 13: Fix `src/clis/twitter/timeline.ts`**
|
|
881
|
-
|
|
882
|
-
Find:
|
|
883
|
-
```typescript
|
|
884
|
-
await page.goto('https://x.com');
|
|
885
|
-
await page.wait(3);
|
|
886
|
-
```
|
|
887
|
-
Replace with:
|
|
888
|
-
```typescript
|
|
889
|
-
await page.goto('https://x.com');
|
|
890
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 4 });
|
|
891
|
-
```
|
|
892
|
-
|
|
893
|
-
- [ ] **Step 14: Fix `src/clis/twitter/reply-dm.ts`**
|
|
894
|
-
|
|
895
|
-
Find:
|
|
896
|
-
```typescript
|
|
897
|
-
await page.goto('https://x.com/messages');
|
|
898
|
-
await page.wait(5);
|
|
899
|
-
```
|
|
900
|
-
Replace with:
|
|
901
|
-
```typescript
|
|
902
|
-
await page.goto('https://x.com/messages');
|
|
903
|
-
await page.wait({ selector: '[data-testid="DMDrawer"], [data-testid="primaryColumn"]', timeout: 6 });
|
|
904
|
-
```
|
|
905
|
-
|
|
906
|
-
Find the second wait in `reply-dm.ts`:
|
|
907
|
-
```typescript
|
|
908
|
-
await page.goto(convUrl);
|
|
909
|
-
await page.wait(3);
|
|
910
|
-
```
|
|
911
|
-
Replace with:
|
|
912
|
-
```typescript
|
|
913
|
-
await page.goto(convUrl);
|
|
914
|
-
await page.wait({ selector: '[data-testid="primaryColumn"]', timeout: 4 });
|
|
915
|
-
```
|
|
916
|
-
|
|
917
|
-
- [ ] **Step 15: Run adapter tests**
|
|
918
|
-
|
|
919
|
-
```bash
|
|
920
|
-
npx vitest run --project adapter
|
|
921
|
-
```
|
|
922
|
-
Expected: All PASS.
|
|
923
|
-
|
|
924
|
-
- [ ] **Step 16: Commit**
|
|
925
|
-
|
|
926
|
-
```bash
|
|
927
|
-
git add src/clis/twitter/reply.ts src/clis/twitter/follow.ts src/clis/twitter/unfollow.ts \
|
|
928
|
-
src/clis/twitter/like.ts src/clis/twitter/bookmark.ts src/clis/twitter/unbookmark.ts \
|
|
929
|
-
src/clis/twitter/block.ts src/clis/twitter/unblock.ts src/clis/twitter/hide-reply.ts \
|
|
930
|
-
src/clis/twitter/delete.ts src/clis/twitter/profile.ts src/clis/twitter/thread.ts \
|
|
931
|
-
src/clis/twitter/timeline.ts src/clis/twitter/reply-dm.ts
|
|
932
|
-
git commit -m "perf(twitter): replace wait(N) with wait({ selector }) for React hydration waits"
|
|
933
|
-
```
|
|
934
|
-
|
|
935
|
-
---
|
|
936
|
-
|
|
937
|
-
## Task 9: Fix medium, substack, bloomberg, sinablog (Layer 2, part 2)
|
|
938
|
-
|
|
939
|
-
**Files:** `medium/utils.ts`, `substack/utils.ts`, `bloomberg/news.ts`, `sinablog/utils.ts`
|
|
940
|
-
|
|
941
|
-
The pattern for medium/substack: outer `wait(5)` + inner `setTimeout(3000)` in `evaluate()`. Fix: replace outer with `wait({ selector: 'article', timeout: 8 })`, remove inner setTimeout, and let the evaluate run synchronously.
|
|
942
|
-
|
|
943
|
-
- [ ] **Step 1: Fix `src/clis/medium/utils.ts`**
|
|
944
|
-
|
|
945
|
-
Find the `loadMediumPosts` function. Replace:
|
|
946
|
-
```typescript
|
|
947
|
-
await page.goto(url);
|
|
948
|
-
await page.wait(5);
|
|
949
|
-
const data = await page.evaluate(`
|
|
950
|
-
(async () => {
|
|
951
|
-
await new Promise((resolve) => setTimeout(resolve, 3000));
|
|
952
|
-
```
|
|
953
|
-
With:
|
|
954
|
-
```typescript
|
|
955
|
-
await page.goto(url);
|
|
956
|
-
await page.wait({ selector: 'article', timeout: 8 });
|
|
957
|
-
const data = await page.evaluate(`
|
|
958
|
-
(() => {
|
|
959
|
-
```
|
|
960
|
-
Also remove the closing `})()` (async) and replace with `()()` (sync). The full evaluate becomes a sync IIFE since the inner sleep is removed.
|
|
961
|
-
|
|
962
|
-
**Complete replacement** — find the entire evaluate block starting with `(async () => {` and ending with `})()`:
|
|
963
|
-
|
|
964
|
-
The evaluate body starting line is:
|
|
965
|
-
```typescript
|
|
966
|
-
const data = await page.evaluate(`
|
|
967
|
-
(async () => {
|
|
968
|
-
await new Promise((resolve) => setTimeout(resolve, 3000));
|
|
969
|
-
|
|
970
|
-
const limit = ${Math.max(1, Math.min(limit, 50))};
|
|
971
|
-
```
|
|
972
|
-
Replace `(async () => {` with `(() => {` and remove the `await new Promise((resolve) => setTimeout(resolve, 3000));` line (and the blank line after it). Change `})()` closing to `})()`. Remove `async` from the arrow function signature.
|
|
973
|
-
|
|
974
|
-
- [ ] **Step 2: Fix `src/clis/substack/utils.ts` — `loadSubstackFeed`**
|
|
975
|
-
|
|
976
|
-
Find:
|
|
977
|
-
```typescript
|
|
978
|
-
await page.goto(url);
|
|
979
|
-
await page.wait(5);
|
|
980
|
-
const data = await page.evaluate(`
|
|
981
|
-
(async () => {
|
|
982
|
-
await new Promise((resolve) => setTimeout(resolve, 3000));
|
|
983
|
-
```
|
|
984
|
-
Replace with:
|
|
985
|
-
```typescript
|
|
986
|
-
await page.goto(url);
|
|
987
|
-
await page.wait({ selector: 'article, [class*="post"]', timeout: 8 });
|
|
988
|
-
const data = await page.evaluate(`
|
|
989
|
-
(() => {
|
|
990
|
-
```
|
|
991
|
-
And remove the `await new Promise((resolve) => setTimeout(resolve, 3000));` line. Change `(async () => {` to `(() => {`.
|
|
992
|
-
|
|
993
|
-
- [ ] **Step 3: Fix `src/clis/substack/utils.ts` — `loadSubstackArchive`**
|
|
994
|
-
|
|
995
|
-
Same fix as Step 2 but for `loadSubstackArchive`:
|
|
996
|
-
```typescript
|
|
997
|
-
await page.goto(`${baseUrl}/archive`);
|
|
998
|
-
await page.wait(5);
|
|
999
|
-
const data = await page.evaluate(`
|
|
1000
|
-
(async () => {
|
|
1001
|
-
await new Promise((resolve) => setTimeout(resolve, 3000));
|
|
1002
|
-
```
|
|
1003
|
-
Replace with:
|
|
1004
|
-
```typescript
|
|
1005
|
-
await page.goto(`${baseUrl}/archive`);
|
|
1006
|
-
await page.wait({ selector: 'a[href*="/p/"]', timeout: 8 });
|
|
1007
|
-
const data = await page.evaluate(`
|
|
1008
|
-
(() => {
|
|
1009
|
-
```
|
|
1010
|
-
Remove inner setTimeout line. Change async to sync.
|
|
1011
|
-
|
|
1012
|
-
- [ ] **Step 4: Fix `src/clis/bloomberg/news.ts`**
|
|
1013
|
-
|
|
1014
|
-
Find:
|
|
1015
|
-
```typescript
|
|
1016
|
-
await page.goto(url);
|
|
1017
|
-
await page.wait(5);
|
|
1018
|
-
```
|
|
1019
|
-
Replace with:
|
|
1020
|
-
```typescript
|
|
1021
|
-
await page.goto(url);
|
|
1022
|
-
await page.wait({ selector: '#__NEXT_DATA__, article', timeout: 8 });
|
|
1023
|
-
```
|
|
1024
|
-
|
|
1025
|
-
Find the retry wait:
|
|
1026
|
-
```typescript
|
|
1027
|
-
if (result?.errorCode === 'NO_NEXT_DATA' || result?.errorCode === 'NO_STORY') {
|
|
1028
|
-
await page.wait(4);
|
|
1029
|
-
result = await loadStory();
|
|
1030
|
-
}
|
|
1031
|
-
```
|
|
1032
|
-
Replace with:
|
|
1033
|
-
```typescript
|
|
1034
|
-
if (result?.errorCode === 'NO_NEXT_DATA' || result?.errorCode === 'NO_STORY') {
|
|
1035
|
-
await page.wait({ selector: '#__NEXT_DATA__', timeout: 5 });
|
|
1036
|
-
result = await loadStory();
|
|
1037
|
-
}
|
|
1038
|
-
```
|
|
1039
|
-
|
|
1040
|
-
- [ ] **Step 5: Fix `src/clis/sinablog/utils.ts`**
|
|
1041
|
-
|
|
1042
|
-
`sinablog` has three functions to fix.
|
|
1043
|
-
|
|
1044
|
-
**`loadSinaBlogHot` and `loadSinaBlogUser`** — find their `wait(3)` calls followed by inline `setTimeout(1500)` loops:
|
|
1045
|
-
|
|
1046
|
-
```typescript
|
|
1047
|
-
await page.goto(url);
|
|
1048
|
-
await page.wait(3);
|
|
1049
|
-
const data = await page.evaluate(`
|
|
1050
|
-
(async () => {
|
|
1051
|
-
await new Promise((resolve) => setTimeout(resolve, 1500));
|
|
1052
|
-
```
|
|
1053
|
-
Replace with:
|
|
1054
|
-
```typescript
|
|
1055
|
-
await page.goto(url);
|
|
1056
|
-
await page.wait({ selector: '.article-list, .blog-article, article', timeout: 6 });
|
|
1057
|
-
const data = await page.evaluate(`
|
|
1058
|
-
(() => {
|
|
1059
|
-
```
|
|
1060
|
-
Remove the inner setTimeout line. Change `async` arrow to sync.
|
|
1061
|
-
|
|
1062
|
-
**`loadSinaBlogSearch`** — find:
|
|
1063
|
-
```typescript
|
|
1064
|
-
await page.goto(buildSinaBlogSearchUrl(keyword));
|
|
1065
|
-
await page.wait(5);
|
|
1066
|
-
const data = await page.evaluate(`
|
|
1067
|
-
(async () => {
|
|
1068
|
-
const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
1069
|
-
for (let i = 0; i < 20; i += 1) {
|
|
1070
|
-
if (document.querySelector('.result-item')) break;
|
|
1071
|
-
await sleep(500);
|
|
1072
|
-
}
|
|
1073
|
-
```
|
|
1074
|
-
Replace with:
|
|
1075
|
-
```typescript
|
|
1076
|
-
await page.goto(buildSinaBlogSearchUrl(keyword));
|
|
1077
|
-
await page.wait({ selector: '.result-item', timeout: 8 });
|
|
1078
|
-
const data = await page.evaluate(`
|
|
1079
|
-
(() => {
|
|
1080
|
-
```
|
|
1081
|
-
Remove the `sleep` helper definition and the polling loop (they're replaced by the outer `wait({ selector })`). Change `async` to sync.
|
|
1082
|
-
|
|
1083
|
-
- [ ] **Step 6: Run full unit + adapter tests**
|
|
1084
|
-
|
|
1085
|
-
```bash
|
|
1086
|
-
npx vitest run --project unit --project adapter
|
|
1087
|
-
```
|
|
1088
|
-
Expected: All PASS.
|
|
1089
|
-
|
|
1090
|
-
- [ ] **Step 7: Commit**
|
|
1091
|
-
|
|
1092
|
-
```bash
|
|
1093
|
-
git add src/clis/medium/utils.ts src/clis/substack/utils.ts \
|
|
1094
|
-
src/clis/bloomberg/news.ts src/clis/sinablog/utils.ts
|
|
1095
|
-
git commit -m "perf(adapters): replace wait(N)+inline-sleep with wait({ selector }) in medium/substack/bloomberg/sinablog"
|
|
1096
|
-
```
|
|
1097
|
-
|
|
1098
|
-
---
|
|
1099
|
-
|
|
1100
|
-
## Task 10: Final verification and PR
|
|
1101
|
-
|
|
1102
|
-
- [ ] **Step 1: Run full test suite**
|
|
1103
|
-
|
|
1104
|
-
```bash
|
|
1105
|
-
npx vitest run --project unit --project adapter
|
|
1106
|
-
```
|
|
1107
|
-
Expected: All tests PASS with no regressions.
|
|
1108
|
-
|
|
1109
|
-
- [ ] **Step 2: TypeScript compile check**
|
|
1110
|
-
|
|
1111
|
-
```bash
|
|
1112
|
-
npx tsc --noEmit
|
|
1113
|
-
```
|
|
1114
|
-
Expected: No errors.
|
|
1115
|
-
|
|
1116
|
-
- [ ] **Step 3: Push and create PR**
|
|
1117
|
-
|
|
1118
|
-
```bash
|
|
1119
|
-
git push -u origin HEAD
|
|
1120
|
-
gh pr create \
|
|
1121
|
-
--title "perf: smart wait — waitForCapture, wait({ selector }), daemon backoff" \
|
|
1122
|
-
--body "$(cat <<'EOF'
|
|
1123
|
-
## Summary
|
|
1124
|
-
|
|
1125
|
-
Three layered performance + correctness improvements:
|
|
1126
|
-
|
|
1127
|
-
- **Layer 1 — `waitForCapture()`**: Fixes a correctness bug in INTERCEPT adapters where `wait(N)` (now DOM-stable-aware) could return before network captures arrive. Adds `waitForCapture(timeout)` to `IPage` — polls `window.__opencli_xhr` at 100ms intervals, resolves as soon as ≥1 capture exists. Applied to 36kr, twitter/search, followers, following, notifications, producthunt.
|
|
1128
|
-
- **Layer 2 — `wait({ selector })`**: Extends `WaitOptions` with `selector?: string`. Adds `waitForSelectorJs()` to dom-helpers. Applied to 14 Twitter adapters (replacing `wait(5)` "React hydration" waits with precise element checks) and medium/substack/bloomberg/sinablog (removing duplicate inner `setTimeout` inside `evaluate()`).
|
|
1129
|
-
- **Layer 3 — daemon backoff**: Replaces fixed 300ms poll with exponential backoff (50→100→200→400→800ms) in `_ensureDaemon()`. Cold-start first-success at ~150ms vs ~600ms.
|
|
1130
|
-
|
|
1131
|
-
## Expected gains
|
|
1132
|
-
- 36kr hot/search: 6s → ~1–2s
|
|
1133
|
-
- Twitter INTERCEPT commands: 5–8s → ~1–3s
|
|
1134
|
-
- Twitter UI commands: 5s → ~0.5–2s
|
|
1135
|
-
- Medium/Substack: 8s → ~1–3s
|
|
1136
|
-
- Daemon cold-start: ~600ms → ~150ms
|
|
1137
|
-
|
|
1138
|
-
## Test plan
|
|
1139
|
-
- [ ] `npx vitest run --project unit --project adapter` — all pass
|
|
1140
|
-
- [ ] `npx tsc --noEmit` — no type errors
|
|
1141
|
-
EOF
|
|
1142
|
-
)"
|
|
1143
|
-
```
|