@jackwener/opencli 1.5.5 → 1.5.7
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/CHANGELOG.md +26 -0
- package/README.md +31 -4
- package/README.zh-CN.md +40 -5
- package/SKILL.md +1 -1
- package/dist/browser/cdp.d.ts +1 -0
- package/dist/browser/cdp.js +30 -27
- package/dist/browser/daemon-client.d.ts +11 -1
- package/dist/browser/daemon-client.js +3 -0
- package/dist/browser/dom-helpers.js +1 -0
- package/dist/browser/dom-helpers.test.js +14 -1
- package/dist/browser/mcp.js +18 -13
- package/dist/browser/page.d.ts +6 -0
- package/dist/browser/page.js +37 -2
- package/dist/browser/page.test.d.ts +1 -0
- package/dist/browser/page.test.js +44 -0
- package/dist/browser/stealth.js +198 -0
- package/dist/browser/stealth.test.d.ts +1 -0
- package/dist/browser/stealth.test.js +134 -0
- package/dist/browser.test.js +1 -1
- package/dist/build-manifest.d.ts +1 -0
- package/dist/build-manifest.js +5 -1
- package/dist/build-manifest.test.js +2 -0
- package/dist/cli-manifest.json +1821 -252
- package/dist/cli.js +20 -3
- package/dist/clis/antigravity/serve.d.ts +1 -1
- package/dist/clis/antigravity/serve.js +5 -8
- package/dist/clis/band/bands.d.ts +1 -0
- package/dist/clis/band/bands.js +72 -0
- package/dist/clis/band/mentions.d.ts +1 -0
- package/dist/clis/band/mentions.js +127 -0
- package/dist/clis/band/post.d.ts +1 -0
- package/dist/clis/band/post.js +175 -0
- package/dist/clis/band/posts.d.ts +1 -0
- package/dist/clis/band/posts.js +94 -0
- package/dist/clis/bilibili/subtitle.js +4 -0
- package/dist/clis/bilibili/subtitle.test.d.ts +1 -0
- package/dist/clis/bilibili/subtitle.test.js +48 -0
- package/dist/clis/chatwise/ask.js +0 -2
- package/dist/clis/chatwise/export.js +0 -2
- package/dist/clis/chatwise/history.js +0 -2
- package/dist/clis/chatwise/model.js +0 -2
- package/dist/clis/chatwise/new.js +1 -2
- package/dist/clis/chatwise/read.js +0 -2
- package/dist/clis/chatwise/screenshot.js +1 -2
- package/dist/clis/chatwise/send.js +0 -2
- package/dist/clis/chatwise/status.js +1 -2
- package/dist/clis/ctrip/search.d.ts +13 -0
- package/dist/clis/ctrip/search.js +73 -48
- package/dist/clis/ctrip/search.test.d.ts +1 -0
- package/dist/clis/ctrip/search.test.js +64 -0
- package/dist/clis/doubao/detail.d.ts +1 -0
- package/dist/clis/doubao/detail.js +33 -0
- package/dist/clis/doubao/detail.test.d.ts +1 -0
- package/dist/clis/doubao/detail.test.js +42 -0
- package/dist/clis/doubao/history.d.ts +1 -0
- package/dist/clis/doubao/history.js +28 -0
- package/dist/clis/doubao/history.test.d.ts +1 -0
- package/dist/clis/doubao/history.test.js +37 -0
- package/dist/clis/doubao/meeting-summary.d.ts +1 -0
- package/dist/clis/doubao/meeting-summary.js +39 -0
- package/dist/clis/doubao/meeting-transcript.d.ts +1 -0
- package/dist/clis/doubao/meeting-transcript.js +36 -0
- package/dist/clis/doubao/utils.d.ts +27 -0
- package/dist/clis/doubao/utils.js +317 -0
- package/dist/clis/doubao/utils.test.d.ts +1 -0
- package/dist/clis/doubao/utils.test.js +24 -0
- package/dist/clis/douyin/_shared/public-api.d.ts +33 -0
- package/dist/clis/douyin/_shared/public-api.js +29 -0
- package/dist/clis/douyin/_shared/sts2.js +8 -2
- package/dist/clis/douyin/_shared/sts2.test.d.ts +1 -0
- package/dist/clis/douyin/_shared/sts2.test.js +27 -0
- package/dist/clis/douyin/activities.js +4 -2
- package/dist/clis/douyin/activities.test.js +34 -1
- package/dist/clis/douyin/collections.js +1 -1
- package/dist/clis/douyin/collections.test.js +24 -2
- package/dist/clis/douyin/draft.d.ts +8 -11
- package/dist/clis/douyin/draft.js +302 -185
- package/dist/clis/douyin/draft.test.d.ts +1 -1
- package/dist/clis/douyin/draft.test.js +357 -2
- package/dist/clis/douyin/hashtag.js +9 -2
- package/dist/clis/douyin/hashtag.test.js +35 -2
- package/dist/clis/douyin/profile.js +1 -1
- package/dist/clis/douyin/profile.test.js +36 -1
- package/dist/clis/douyin/user-videos.d.ts +5 -0
- package/dist/clis/douyin/user-videos.js +74 -0
- package/dist/clis/douyin/user-videos.test.d.ts +1 -0
- package/dist/clis/douyin/user-videos.test.js +108 -0
- package/dist/clis/douyin/videos.js +22 -5
- package/dist/clis/douyin/videos.test.js +45 -2
- package/dist/clis/facebook/search.test.d.ts +5 -0
- package/dist/clis/facebook/search.test.js +60 -0
- package/dist/clis/facebook/search.yaml +4 -3
- package/dist/clis/instagram/download.d.ts +16 -0
- package/dist/clis/instagram/download.js +225 -0
- package/dist/clis/instagram/download.test.d.ts +1 -0
- package/dist/clis/instagram/download.test.js +118 -0
- package/dist/clis/notebooklm/bind-current.d.ts +1 -0
- package/dist/clis/notebooklm/bind-current.js +29 -0
- package/dist/clis/notebooklm/bind-current.test.d.ts +1 -0
- package/dist/clis/notebooklm/bind-current.test.js +35 -0
- package/dist/clis/notebooklm/binding.test.d.ts +1 -0
- package/dist/clis/notebooklm/binding.test.js +44 -0
- package/dist/clis/notebooklm/compat.test.d.ts +3 -0
- package/dist/clis/notebooklm/compat.test.js +16 -0
- package/dist/clis/notebooklm/current.d.ts +1 -0
- package/dist/clis/notebooklm/current.js +28 -0
- package/dist/clis/notebooklm/get.d.ts +1 -0
- package/dist/clis/notebooklm/get.js +37 -0
- package/dist/clis/notebooklm/history.d.ts +1 -0
- package/dist/clis/notebooklm/history.js +25 -0
- package/dist/clis/notebooklm/history.test.d.ts +1 -0
- package/dist/clis/notebooklm/history.test.js +58 -0
- package/dist/clis/notebooklm/list.d.ts +1 -0
- package/dist/clis/notebooklm/list.js +35 -0
- package/dist/clis/notebooklm/note-list.d.ts +1 -0
- package/dist/clis/notebooklm/note-list.js +28 -0
- package/dist/clis/notebooklm/note-list.test.d.ts +1 -0
- package/dist/clis/notebooklm/note-list.test.js +56 -0
- package/dist/clis/notebooklm/notes-get.d.ts +1 -0
- package/dist/clis/notebooklm/notes-get.js +47 -0
- package/dist/clis/notebooklm/notes-get.test.d.ts +1 -0
- package/dist/clis/notebooklm/notes-get.test.js +72 -0
- package/dist/clis/notebooklm/rpc.d.ts +36 -0
- package/dist/clis/notebooklm/rpc.js +189 -0
- package/dist/clis/notebooklm/rpc.test.d.ts +1 -0
- package/dist/clis/notebooklm/rpc.test.js +105 -0
- package/dist/clis/notebooklm/shared.d.ts +87 -0
- package/dist/clis/notebooklm/shared.js +3 -0
- package/dist/clis/notebooklm/source-fulltext.d.ts +1 -0
- package/dist/clis/notebooklm/source-fulltext.js +44 -0
- package/dist/clis/notebooklm/source-fulltext.test.d.ts +1 -0
- package/dist/clis/notebooklm/source-fulltext.test.js +106 -0
- package/dist/clis/notebooklm/source-get.d.ts +1 -0
- package/dist/clis/notebooklm/source-get.js +40 -0
- package/dist/clis/notebooklm/source-get.test.d.ts +1 -0
- package/dist/clis/notebooklm/source-get.test.js +84 -0
- package/dist/clis/notebooklm/source-guide.d.ts +1 -0
- package/dist/clis/notebooklm/source-guide.js +44 -0
- package/dist/clis/notebooklm/source-guide.test.d.ts +1 -0
- package/dist/clis/notebooklm/source-guide.test.js +104 -0
- package/dist/clis/notebooklm/source-list.d.ts +1 -0
- package/dist/clis/notebooklm/source-list.js +30 -0
- package/dist/clis/notebooklm/status.d.ts +1 -0
- package/dist/clis/notebooklm/status.js +31 -0
- package/dist/clis/notebooklm/summary.d.ts +1 -0
- package/dist/clis/notebooklm/summary.js +30 -0
- package/dist/clis/notebooklm/summary.test.d.ts +1 -0
- package/dist/clis/notebooklm/summary.test.js +78 -0
- package/dist/clis/notebooklm/utils.d.ts +37 -0
- package/dist/clis/notebooklm/utils.js +739 -0
- package/dist/clis/notebooklm/utils.test.d.ts +1 -0
- package/dist/clis/notebooklm/utils.test.js +390 -0
- package/dist/clis/ones/common.d.ts +32 -0
- package/dist/clis/ones/common.js +144 -0
- package/dist/clis/ones/enrich-tasks.d.ts +5 -0
- package/dist/clis/ones/enrich-tasks.js +37 -0
- package/dist/clis/ones/login.d.ts +1 -0
- package/dist/clis/ones/login.js +80 -0
- package/dist/clis/ones/logout.d.ts +1 -0
- package/dist/clis/ones/logout.js +17 -0
- package/dist/clis/ones/me.d.ts +1 -0
- package/dist/clis/ones/me.js +30 -0
- package/dist/clis/ones/my-tasks.d.ts +1 -0
- package/dist/clis/ones/my-tasks.js +120 -0
- package/dist/clis/ones/resolve-labels.d.ts +10 -0
- package/dist/clis/ones/resolve-labels.js +64 -0
- package/dist/clis/ones/task-helpers.d.ts +29 -0
- package/dist/clis/ones/task-helpers.js +212 -0
- package/dist/clis/ones/task-helpers.test.d.ts +1 -0
- package/dist/clis/ones/task-helpers.test.js +12 -0
- package/dist/clis/ones/task.d.ts +1 -0
- package/dist/clis/ones/task.js +66 -0
- package/dist/clis/ones/tasks.d.ts +1 -0
- package/dist/clis/ones/tasks.js +79 -0
- package/dist/clis/ones/token-info.d.ts +1 -0
- package/dist/clis/ones/token-info.js +42 -0
- package/dist/clis/ones/worklog.d.ts +11 -0
- package/dist/clis/ones/worklog.js +267 -0
- package/dist/clis/ones/worklog.test.d.ts +1 -0
- package/dist/clis/ones/worklog.test.js +20 -0
- package/dist/clis/spotify/spotify.d.ts +1 -0
- package/dist/clis/spotify/spotify.js +316 -0
- package/dist/clis/spotify/utils.d.ts +21 -0
- package/dist/clis/spotify/utils.js +66 -0
- package/dist/clis/spotify/utils.test.d.ts +1 -0
- package/dist/clis/spotify/utils.test.js +67 -0
- package/dist/clis/substack/utils.d.ts +4 -0
- package/dist/clis/substack/utils.js +8 -2
- package/dist/clis/substack/utils.test.d.ts +1 -0
- package/dist/clis/substack/utils.test.js +46 -0
- package/dist/clis/tieba/commands.test.d.ts +4 -0
- package/dist/clis/tieba/commands.test.js +79 -0
- package/dist/clis/tieba/hot.d.ts +1 -0
- package/dist/clis/tieba/hot.js +48 -0
- package/dist/clis/tieba/posts.d.ts +1 -0
- package/dist/clis/tieba/posts.js +85 -0
- package/dist/clis/tieba/read.d.ts +1 -0
- package/dist/clis/tieba/read.js +140 -0
- package/dist/clis/tieba/search.d.ts +1 -0
- package/dist/clis/tieba/search.js +108 -0
- package/dist/clis/tieba/utils.d.ts +101 -0
- package/dist/clis/tieba/utils.js +240 -0
- package/dist/clis/tieba/utils.test.d.ts +1 -0
- package/dist/clis/tieba/utils.test.js +290 -0
- package/dist/clis/v2ex/hot.yaml +4 -1
- package/dist/clis/v2ex/latest.yaml +4 -1
- package/dist/clis/v2ex/topic.yaml +6 -1
- package/dist/clis/weixin/download.d.ts +9 -0
- package/dist/clis/weixin/download.js +76 -6
- package/dist/clis/weread/book.js +206 -13
- package/dist/clis/weread/commands.test.js +331 -0
- package/dist/clis/weread/private-api-regression.test.d.ts +1 -0
- package/dist/{weread-private-api-regression.test.js → clis/weread/private-api-regression.test.js} +92 -30
- package/dist/clis/weread/search-regression.test.d.ts +1 -0
- package/dist/clis/weread/search-regression.test.js +407 -0
- package/dist/clis/weread/search.js +143 -7
- package/dist/clis/weread/shelf.js +13 -95
- package/dist/clis/weread/utils.d.ts +56 -0
- package/dist/clis/weread/utils.js +234 -7
- package/dist/clis/weread/utils.test.js +71 -1
- package/dist/clis/xiaohongshu/comments.d.ts +3 -0
- package/dist/clis/xiaohongshu/comments.js +76 -17
- package/dist/clis/xiaohongshu/comments.test.js +70 -9
- package/dist/clis/xiaohongshu/download.d.ts +4 -1
- package/dist/clis/xiaohongshu/download.js +83 -22
- package/dist/clis/xiaohongshu/download.test.d.ts +1 -0
- package/dist/clis/xiaohongshu/download.test.js +75 -0
- package/dist/clis/xiaohongshu/note-helpers.d.ts +12 -0
- package/dist/clis/xiaohongshu/note-helpers.js +23 -0
- package/dist/clis/xiaohongshu/note.d.ts +7 -0
- package/dist/clis/xiaohongshu/note.js +76 -0
- package/dist/clis/xiaohongshu/note.test.d.ts +1 -0
- package/dist/clis/xiaohongshu/note.test.js +136 -0
- package/dist/clis/xiaohongshu/publish.d.ts +1 -1
- package/dist/clis/xiaohongshu/publish.js +78 -31
- package/dist/clis/xiaohongshu/publish.test.js +66 -1
- package/dist/clis/xiaohongshu/search.js +9 -0
- package/dist/clis/xiaohongshu/search.test.js +10 -4
- package/dist/clis/xiaohongshu/user-helpers.d.ts +1 -0
- package/dist/clis/xiaohongshu/user-helpers.js +2 -0
- package/dist/clis/xiaohongshu/user-helpers.test.js +18 -0
- package/dist/clis/xueqiu/comments.d.ts +118 -0
- package/dist/clis/xueqiu/comments.js +354 -0
- package/dist/clis/xueqiu/comments.test.d.ts +1 -0
- package/dist/clis/xueqiu/comments.test.js +696 -0
- package/dist/clis/youtube/search.js +57 -17
- package/dist/clis/youtube/transcript.js +2 -4
- package/dist/clis/youtube/utils.d.ts +9 -0
- package/dist/clis/youtube/utils.js +67 -3
- package/dist/clis/youtube/utils.test.d.ts +1 -0
- package/dist/clis/youtube/utils.test.js +37 -0
- package/dist/clis/youtube/video.js +16 -15
- package/dist/clis/zhihu/question.js +19 -17
- package/dist/clis/zhihu/question.test.d.ts +1 -0
- package/dist/clis/zhihu/question.test.js +54 -0
- package/dist/clis/zsxq/dynamics.d.ts +1 -0
- package/dist/clis/zsxq/dynamics.js +47 -0
- package/dist/clis/zsxq/groups.d.ts +1 -0
- package/dist/clis/zsxq/groups.js +32 -0
- package/dist/clis/zsxq/search.d.ts +1 -0
- package/dist/clis/zsxq/search.js +43 -0
- package/dist/clis/zsxq/search.test.d.ts +1 -0
- package/dist/clis/zsxq/search.test.js +24 -0
- package/dist/clis/zsxq/topic.d.ts +1 -0
- package/dist/clis/zsxq/topic.js +47 -0
- package/dist/clis/zsxq/topic.test.d.ts +1 -0
- package/dist/clis/zsxq/topic.test.js +29 -0
- package/dist/clis/zsxq/topics.d.ts +1 -0
- package/dist/clis/zsxq/topics.js +25 -0
- package/dist/clis/zsxq/topics.test.d.ts +1 -0
- package/dist/clis/zsxq/topics.test.js +24 -0
- package/dist/clis/zsxq/utils.d.ts +97 -0
- package/dist/clis/zsxq/utils.js +230 -0
- package/dist/commanderAdapter.js +10 -1
- package/dist/commanderAdapter.test.js +64 -0
- package/dist/commands/daemon.d.ts +9 -0
- package/dist/commands/daemon.js +124 -0
- package/dist/commands/daemon.test.d.ts +1 -0
- package/dist/commands/daemon.test.js +185 -0
- package/dist/completion.js +3 -1
- package/dist/constants.d.ts +2 -0
- package/dist/constants.js +2 -0
- package/dist/daemon.d.ts +1 -1
- package/dist/daemon.js +25 -14
- package/dist/daemon.test.d.ts +1 -0
- package/dist/daemon.test.js +65 -0
- package/dist/discovery.d.ts +9 -0
- package/dist/discovery.js +47 -2
- package/dist/electron-apps.d.ts +29 -0
- package/dist/electron-apps.js +65 -0
- package/dist/electron-apps.test.d.ts +1 -0
- package/dist/electron-apps.test.js +43 -0
- package/dist/engine.test.js +41 -9
- package/dist/execution.js +20 -16
- package/dist/external-clis.yaml +17 -0
- package/dist/idle-manager.d.ts +19 -0
- package/dist/idle-manager.js +54 -0
- package/dist/launcher.d.ts +36 -0
- package/dist/launcher.js +152 -0
- package/dist/launcher.test.d.ts +1 -0
- package/dist/launcher.test.js +57 -0
- package/dist/main.js +3 -3
- package/dist/registry.d.ts +1 -0
- package/dist/registry.js +31 -3
- package/dist/registry.test.js +13 -0
- package/dist/runtime.d.ts +5 -3
- package/dist/runtime.js +12 -5
- package/dist/serialization.d.ts +1 -0
- package/dist/serialization.js +3 -0
- package/dist/serialization.test.js +17 -1
- package/dist/tui.d.ts +7 -0
- package/dist/tui.js +52 -0
- package/dist/tui.test.d.ts +1 -0
- package/dist/tui.test.js +19 -0
- package/dist/types.d.ts +5 -0
- package/dist/weixin-download.test.js +14 -0
- package/docs/.vitepress/config.mts +4 -0
- package/docs/adapters/browser/band.md +63 -0
- package/docs/adapters/browser/notebooklm.md +69 -0
- package/docs/adapters/browser/ones.md +59 -0
- package/docs/adapters/browser/spotify.md +62 -0
- package/docs/adapters/browser/tieba.md +45 -0
- package/docs/adapters/browser/xiaohongshu.md +19 -10
- package/docs/adapters/browser/xueqiu.md +5 -0
- package/docs/adapters/browser/zsxq.md +49 -0
- package/docs/adapters/index.md +67 -63
- package/docs/adapters-doc/ones.md +32 -0
- package/docs/guide/browser-bridge.md +12 -0
- package/docs/guide/troubleshooting.md +9 -4
- package/docs/superpowers/plans/2026-03-31-daemon-lifecycle-redesign.md +857 -0
- package/docs/superpowers/specs/2026-03-31-daemon-lifecycle-redesign.md +208 -0
- package/docs/zh/guide/browser-bridge.md +12 -0
- package/extension/dist/background.js +794 -513
- package/extension/src/background.test.ts +202 -2
- package/extension/src/background.ts +189 -10
- package/extension/src/cdp.ts +54 -0
- package/extension/src/protocol.ts +11 -5
- package/package.json +1 -1
- package/scripts/postinstall.js +16 -0
- package/src/browser/cdp.ts +24 -17
- package/src/browser/daemon-client.ts +11 -1
- package/src/browser/dom-helpers.test.ts +15 -1
- package/src/browser/dom-helpers.ts +1 -0
- package/src/browser/mcp.ts +18 -13
- package/src/browser/page.test.ts +58 -0
- package/src/browser/page.ts +34 -2
- package/src/browser/stealth.test.ts +153 -0
- package/src/browser/stealth.ts +198 -0
- package/src/browser.test.ts +1 -1
- package/src/build-manifest.test.ts +2 -0
- package/src/build-manifest.ts +6 -1
- package/src/cli.ts +21 -3
- package/src/clis/antigravity/SKILL.md +3 -12
- package/src/clis/antigravity/serve.ts +5 -10
- package/src/clis/band/bands.ts +76 -0
- package/src/clis/band/mentions.ts +134 -0
- package/src/clis/band/post.ts +187 -0
- package/src/clis/band/posts.ts +106 -0
- package/src/clis/bilibili/subtitle.test.ts +60 -0
- package/src/clis/bilibili/subtitle.ts +4 -0
- package/src/clis/chatwise/ask.ts +0 -2
- package/src/clis/chatwise/export.ts +0 -2
- package/src/clis/chatwise/history.ts +0 -2
- package/src/clis/chatwise/model.ts +0 -2
- package/src/clis/chatwise/new.ts +1 -2
- package/src/clis/chatwise/read.ts +0 -2
- package/src/clis/chatwise/screenshot.ts +1 -2
- package/src/clis/chatwise/send.ts +0 -2
- package/src/clis/chatwise/status.ts +1 -2
- package/src/clis/ctrip/search.test.ts +73 -0
- package/src/clis/ctrip/search.ts +97 -47
- package/src/clis/doubao/detail.test.ts +53 -0
- package/src/clis/doubao/detail.ts +41 -0
- package/src/clis/doubao/history.test.ts +45 -0
- package/src/clis/doubao/history.ts +32 -0
- package/src/clis/doubao/meeting-summary.ts +53 -0
- package/src/clis/doubao/meeting-transcript.ts +48 -0
- package/src/clis/doubao/utils.test.ts +45 -0
- package/src/clis/doubao/utils.ts +371 -0
- package/src/clis/douyin/_shared/public-api.ts +84 -0
- package/src/clis/douyin/_shared/sts2.test.ts +31 -0
- package/src/clis/douyin/_shared/sts2.ts +11 -3
- package/src/clis/douyin/activities.test.ts +41 -1
- package/src/clis/douyin/activities.ts +12 -3
- package/src/clis/douyin/collections.test.ts +35 -2
- package/src/clis/douyin/collections.ts +1 -1
- package/src/clis/douyin/draft.test.ts +444 -2
- package/src/clis/douyin/draft.ts +382 -218
- package/src/clis/douyin/hashtag.test.ts +42 -2
- package/src/clis/douyin/hashtag.ts +11 -3
- package/src/clis/douyin/profile.test.ts +43 -1
- package/src/clis/douyin/profile.ts +9 -2
- package/src/clis/douyin/user-videos.test.ts +122 -0
- package/src/clis/douyin/user-videos.ts +101 -0
- package/src/clis/douyin/videos.test.ts +52 -2
- package/src/clis/douyin/videos.ts +49 -15
- package/src/clis/facebook/search.test.ts +70 -0
- package/src/clis/facebook/search.yaml +4 -3
- package/src/clis/instagram/download.test.ts +159 -0
- package/src/clis/instagram/download.ts +286 -0
- package/src/clis/notebooklm/bind-current.test.ts +43 -0
- package/src/clis/notebooklm/bind-current.ts +36 -0
- package/src/clis/notebooklm/binding.test.ts +53 -0
- package/src/clis/notebooklm/compat.test.ts +19 -0
- package/src/clis/notebooklm/current.ts +38 -0
- package/src/clis/notebooklm/get.ts +53 -0
- package/src/clis/notebooklm/history.test.ts +70 -0
- package/src/clis/notebooklm/history.ts +36 -0
- package/src/clis/notebooklm/list.ts +40 -0
- package/src/clis/notebooklm/note-list.test.ts +64 -0
- package/src/clis/notebooklm/note-list.ts +42 -0
- package/src/clis/notebooklm/notes-get.test.ts +88 -0
- package/src/clis/notebooklm/notes-get.ts +67 -0
- package/src/clis/notebooklm/rpc.test.ts +126 -0
- package/src/clis/notebooklm/rpc.ts +286 -0
- package/src/clis/notebooklm/shared.ts +98 -0
- package/src/clis/notebooklm/source-fulltext.test.ts +123 -0
- package/src/clis/notebooklm/source-fulltext.ts +69 -0
- package/src/clis/notebooklm/source-get.test.ts +100 -0
- package/src/clis/notebooklm/source-get.ts +60 -0
- package/src/clis/notebooklm/source-guide.test.ts +121 -0
- package/src/clis/notebooklm/source-guide.ts +69 -0
- package/src/clis/notebooklm/source-list.ts +45 -0
- package/src/clis/notebooklm/status.ts +34 -0
- package/src/clis/notebooklm/summary.test.ts +94 -0
- package/src/clis/notebooklm/summary.ts +45 -0
- package/src/clis/notebooklm/utils.test.ts +446 -0
- package/src/clis/notebooklm/utils.ts +893 -0
- package/src/clis/ones/common.ts +187 -0
- package/src/clis/ones/enrich-tasks.ts +47 -0
- package/src/clis/ones/login.ts +103 -0
- package/src/clis/ones/logout.ts +19 -0
- package/src/clis/ones/me.ts +34 -0
- package/src/clis/ones/my-tasks.ts +148 -0
- package/src/clis/ones/resolve-labels.ts +80 -0
- package/src/clis/ones/task-helpers.test.ts +14 -0
- package/src/clis/ones/task-helpers.ts +214 -0
- package/src/clis/ones/task.ts +79 -0
- package/src/clis/ones/tasks.ts +92 -0
- package/src/clis/ones/token-info.ts +46 -0
- package/src/clis/ones/worklog.test.ts +24 -0
- package/src/clis/ones/worklog.ts +306 -0
- package/src/clis/spotify/spotify.ts +328 -0
- package/src/clis/spotify/utils.test.ts +87 -0
- package/src/clis/spotify/utils.ts +92 -0
- package/src/clis/substack/utils.test.ts +54 -0
- package/src/clis/substack/utils.ts +10 -2
- package/src/clis/tieba/commands.test.ts +86 -0
- package/src/clis/tieba/hot.ts +52 -0
- package/src/clis/tieba/posts.ts +108 -0
- package/src/clis/tieba/read.ts +158 -0
- package/src/clis/tieba/search.ts +119 -0
- package/src/clis/tieba/utils.test.ts +322 -0
- package/src/clis/tieba/utils.ts +348 -0
- package/src/clis/v2ex/hot.yaml +4 -1
- package/src/clis/v2ex/latest.yaml +4 -1
- package/src/clis/v2ex/topic.yaml +6 -1
- package/src/clis/weixin/download.ts +95 -6
- package/src/clis/weread/book.ts +256 -13
- package/src/clis/weread/commands.test.ts +409 -0
- package/src/{weread-private-api-regression.test.ts → clis/weread/private-api-regression.test.ts} +108 -30
- package/src/clis/weread/search-regression.test.ts +440 -0
- package/src/clis/weread/search.ts +189 -9
- package/src/clis/weread/shelf.ts +20 -122
- package/src/clis/weread/utils.test.ts +81 -1
- package/src/clis/weread/utils.ts +293 -7
- package/src/clis/xiaohongshu/comments.test.ts +85 -9
- package/src/clis/xiaohongshu/comments.ts +76 -17
- package/src/clis/xiaohongshu/download.test.ts +96 -0
- package/src/clis/xiaohongshu/download.ts +83 -22
- package/src/clis/xiaohongshu/note-helpers.ts +25 -0
- package/src/clis/xiaohongshu/note.test.ts +164 -0
- package/src/clis/xiaohongshu/note.ts +86 -0
- package/src/clis/xiaohongshu/publish.test.ts +79 -1
- package/src/clis/xiaohongshu/publish.ts +84 -30
- package/src/clis/xiaohongshu/search.test.ts +11 -4
- package/src/clis/xiaohongshu/search.ts +13 -0
- package/src/clis/xiaohongshu/user-helpers.test.ts +23 -0
- package/src/clis/xiaohongshu/user-helpers.ts +4 -0
- package/src/clis/xueqiu/comments.test.ts +823 -0
- package/src/clis/xueqiu/comments.ts +461 -0
- package/src/clis/youtube/search.ts +57 -17
- package/src/clis/youtube/transcript.ts +2 -4
- package/src/clis/youtube/utils.test.ts +43 -0
- package/src/clis/youtube/utils.ts +69 -0
- package/src/clis/youtube/video.ts +16 -15
- package/src/clis/zhihu/question.test.ts +71 -0
- package/src/clis/zhihu/question.ts +27 -15
- package/src/clis/zsxq/dynamics.ts +60 -0
- package/src/clis/zsxq/groups.ts +41 -0
- package/src/clis/zsxq/search.test.ts +29 -0
- package/src/clis/zsxq/search.ts +54 -0
- package/src/clis/zsxq/topic.test.ts +34 -0
- package/src/clis/zsxq/topic.ts +68 -0
- package/src/clis/zsxq/topics.test.ts +29 -0
- package/src/clis/zsxq/topics.ts +36 -0
- package/src/clis/zsxq/utils.ts +351 -0
- package/src/commanderAdapter.test.ts +77 -0
- package/src/commanderAdapter.ts +8 -1
- package/src/commands/daemon.test.ts +238 -0
- package/src/commands/daemon.ts +135 -0
- package/src/completion.ts +2 -1
- package/src/constants.ts +3 -0
- package/src/daemon.test.ts +88 -0
- package/src/daemon.ts +26 -14
- package/src/discovery.ts +52 -2
- package/src/electron-apps.test.ts +50 -0
- package/src/electron-apps.ts +89 -0
- package/src/engine.test.ts +45 -9
- package/src/execution.ts +24 -19
- package/src/external-clis.yaml +17 -0
- package/src/idle-manager.ts +60 -0
- package/src/launcher.test.ts +67 -0
- package/src/launcher.ts +185 -0
- package/src/main.ts +3 -2
- package/src/registry.test.ts +15 -0
- package/src/registry.ts +32 -3
- package/src/runtime.ts +13 -7
- package/src/serialization.test.ts +19 -1
- package/src/serialization.ts +2 -0
- package/src/tui.test.ts +23 -0
- package/src/tui.ts +65 -0
- package/src/types.ts +5 -0
- package/src/weixin-download.test.ts +27 -0
- package/tests/e2e/band-auth.test.ts +20 -0
- package/tests/e2e/browser-auth-helpers.ts +18 -0
- package/tests/e2e/browser-auth.test.ts +35 -47
- package/tests/e2e/browser-public-extended.test.ts +6 -2
- package/tests/e2e/browser-public.test.ts +288 -0
- package/tests/e2e/management.test.ts +1 -1
- package/tests/e2e/plugin-management.test.ts +1 -1
- package/vitest.config.ts +1 -0
- package/chatwise-opencli.ps1 +0 -82
- package/dist/clis/chatwise/shared.d.ts +0 -2
- package/dist/clis/chatwise/shared.js +0 -6
- package/dist/weread-private-api-regression.test.d.ts +0 -1
- package/dist/weread-search-regression.test.d.ts +0 -1
- package/dist/weread-search-regression.test.js +0 -39
- package/src/clis/chatwise/shared.ts +0 -8
- package/src/weread-search-regression.test.ts +0 -44
package/dist/browser/stealth.js
CHANGED
|
@@ -149,6 +149,204 @@ export function generateStealthJs() {
|
|
|
149
149
|
}
|
|
150
150
|
} catch {}
|
|
151
151
|
|
|
152
|
+
// ── Shared toString disguise infrastructure ──
|
|
153
|
+
// Save the pristine Function.prototype.toString BEFORE any patches,
|
|
154
|
+
// so all subsequent disguises use the real native reference.
|
|
155
|
+
// Anti-bot scripts detect per-instance toString overrides via:
|
|
156
|
+
// Function.hasOwnProperty('toString') → true if patched
|
|
157
|
+
// Function.prototype.toString.call(fn) !== fn.toString()
|
|
158
|
+
// Instead we patch Function.prototype.toString once with a WeakMap
|
|
159
|
+
// lookup, making disguised functions indistinguishable from native.
|
|
160
|
+
const _origToString = Function.prototype.toString;
|
|
161
|
+
const _disguised = new WeakMap();
|
|
162
|
+
try {
|
|
163
|
+
Object.defineProperty(Function.prototype, 'toString', {
|
|
164
|
+
value: function() {
|
|
165
|
+
const override = _disguised.get(this);
|
|
166
|
+
return override !== undefined ? override : _origToString.call(this);
|
|
167
|
+
},
|
|
168
|
+
writable: true, configurable: true,
|
|
169
|
+
});
|
|
170
|
+
} catch {}
|
|
171
|
+
const _disguise = (fn, name) => {
|
|
172
|
+
_disguised.set(fn, 'function ' + name + '() { [native code] }');
|
|
173
|
+
try { Object.defineProperty(fn, 'name', { value: name, configurable: true }); } catch {}
|
|
174
|
+
return fn;
|
|
175
|
+
};
|
|
176
|
+
|
|
177
|
+
// 8. Anti-debugger statement trap
|
|
178
|
+
// Sites inject debugger statements to detect DevTools/CDP.
|
|
179
|
+
// When a CDP debugger is attached, the statement pauses execution
|
|
180
|
+
// and the site measures the time gap to confirm automation.
|
|
181
|
+
// We neutralize this by overriding the Function constructor and
|
|
182
|
+
// eval to strip debugger statements from dynamically created code.
|
|
183
|
+
// Note: this does NOT affect static debugger statements in parsed
|
|
184
|
+
// scripts — those require CDP Debugger.setBreakpointsActive(false)
|
|
185
|
+
// which we handle at the extension level.
|
|
186
|
+
// Caveat: the regex targets standalone debugger statements (preceded
|
|
187
|
+
// by a statement boundary) to minimise false positives inside string
|
|
188
|
+
// literals, but cannot perfectly distinguish all cases without a
|
|
189
|
+
// full parser. This is an acceptable trade-off for stealth code.
|
|
190
|
+
try {
|
|
191
|
+
const _OrigFunction = Function;
|
|
192
|
+
// Match standalone debugger statements preceded by a statement
|
|
193
|
+
// boundary (start of string, semicolon, brace, or newline).
|
|
194
|
+
// This avoids most false positives inside string literals like
|
|
195
|
+
// "use debugger mode" while still catching the anti-bot patterns.
|
|
196
|
+
const _debuggerRe = /(?:^|(?<=[;{}\\n\\r]))\\s*debugger\\s*;?/g;
|
|
197
|
+
const _cleanDebugger = (src) => typeof src === 'string' ? src.replace(_debuggerRe, '') : src;
|
|
198
|
+
// Patch Function constructor to strip debugger from dynamic code.
|
|
199
|
+
// Support both Function('code') and new Function('code') via
|
|
200
|
+
// new.target / Reflect.construct.
|
|
201
|
+
const _PatchedFunction = function(...args) {
|
|
202
|
+
if (args.length > 0) {
|
|
203
|
+
args[args.length - 1] = _cleanDebugger(args[args.length - 1]);
|
|
204
|
+
}
|
|
205
|
+
if (new.target) {
|
|
206
|
+
return Reflect.construct(_OrigFunction, args, new.target);
|
|
207
|
+
}
|
|
208
|
+
return _OrigFunction.apply(this, args);
|
|
209
|
+
};
|
|
210
|
+
_PatchedFunction.prototype = _OrigFunction.prototype;
|
|
211
|
+
Object.setPrototypeOf(_PatchedFunction, _OrigFunction);
|
|
212
|
+
_disguise(_PatchedFunction, 'Function');
|
|
213
|
+
try { window.Function = _PatchedFunction; } catch {}
|
|
214
|
+
|
|
215
|
+
// Patch eval to strip debugger
|
|
216
|
+
const _origEval = window.eval;
|
|
217
|
+
const _patchedEval = function(code) {
|
|
218
|
+
return _origEval.call(this, _cleanDebugger(code));
|
|
219
|
+
};
|
|
220
|
+
_disguise(_patchedEval, 'eval');
|
|
221
|
+
try { window.eval = _patchedEval; } catch {}
|
|
222
|
+
} catch {}
|
|
223
|
+
|
|
224
|
+
// 9. Console method fingerprinting defense
|
|
225
|
+
// When CDP Runtime.enable is called, Chrome replaces console.log etc.
|
|
226
|
+
// with CDP-bound versions. These bound functions have a different
|
|
227
|
+
// toString() output: "function log() { [native code] }" becomes
|
|
228
|
+
// something like "function () { [native code] }" (no name) or the
|
|
229
|
+
// bound function signature leaks. Anti-bot scripts check:
|
|
230
|
+
// console.log.toString().includes('[native code]')
|
|
231
|
+
// console.log.name === 'log'
|
|
232
|
+
// We re-wrap console methods and register them via the shared
|
|
233
|
+
// _disguise infrastructure so Function.prototype.toString.call()
|
|
234
|
+
// also returns the correct native string.
|
|
235
|
+
try {
|
|
236
|
+
const _consoleMethods = ['log', 'warn', 'error', 'info', 'debug', 'table', 'trace', 'dir', 'group', 'groupEnd', 'groupCollapsed', 'clear', 'count', 'assert', 'profile', 'profileEnd', 'time', 'timeEnd', 'timeStamp'];
|
|
237
|
+
for (const _m of _consoleMethods) {
|
|
238
|
+
if (typeof console[_m] !== 'function') continue;
|
|
239
|
+
const _origMethod = console[_m];
|
|
240
|
+
const _nativeStr = 'function ' + _m + '() { [native code] }';
|
|
241
|
+
// Only patch if toString is wrong (i.e. CDP has replaced it)
|
|
242
|
+
try {
|
|
243
|
+
const _currentStr = _origToString.call(_origMethod);
|
|
244
|
+
if (_currentStr === _nativeStr) continue; // already looks native
|
|
245
|
+
} catch {}
|
|
246
|
+
const _wrapper = function() { return _origMethod.apply(console, arguments); };
|
|
247
|
+
Object.defineProperty(_wrapper, 'length', { value: _origMethod.length || 0, configurable: true });
|
|
248
|
+
_disguise(_wrapper, _m);
|
|
249
|
+
try { console[_m] = _wrapper; } catch {}
|
|
250
|
+
}
|
|
251
|
+
} catch {}
|
|
252
|
+
|
|
253
|
+
// 10. window.outerWidth/outerHeight defense
|
|
254
|
+
// When DevTools or CDP debugger is attached, Chrome may alter the
|
|
255
|
+
// window dimensions. Anti-bot scripts compare outerWidth/innerWidth
|
|
256
|
+
// and outerHeight/innerHeight — a significant difference indicates
|
|
257
|
+
// DevTools is open. We freeze the relationship so the delta stays
|
|
258
|
+
// consistent with a normal browser window.
|
|
259
|
+
// Thresholds: width delta > 100px or height delta > 200px indicates
|
|
260
|
+
// a docked DevTools panel. When triggered, we report outerWidth
|
|
261
|
+
// equal to innerWidth (normal for maximised windows) and
|
|
262
|
+
// outerHeight as innerHeight + the captured "normal" delta (capped
|
|
263
|
+
// to a reasonable range), so the result is plausible across OSes.
|
|
264
|
+
try {
|
|
265
|
+
const _normalWidthDelta = window.outerWidth - window.innerWidth;
|
|
266
|
+
const _normalHeightDelta = window.outerHeight - window.innerHeight;
|
|
267
|
+
// Only patch if the delta looks suspicious (e.g. DevTools docked)
|
|
268
|
+
if (_normalWidthDelta > 100 || _normalHeightDelta > 200) {
|
|
269
|
+
Object.defineProperty(window, 'outerWidth', {
|
|
270
|
+
get: () => window.innerWidth,
|
|
271
|
+
configurable: true,
|
|
272
|
+
});
|
|
273
|
+
// Use a clamped height offset (40-120px covers macOS ~78px,
|
|
274
|
+
// Windows ~40px, and Linux ~37-50px title bar heights).
|
|
275
|
+
const _heightOffset = Math.max(40, Math.min(120, _normalHeightDelta));
|
|
276
|
+
Object.defineProperty(window, 'outerHeight', {
|
|
277
|
+
get: () => window.innerHeight + _heightOffset,
|
|
278
|
+
configurable: true,
|
|
279
|
+
});
|
|
280
|
+
}
|
|
281
|
+
} catch {}
|
|
282
|
+
|
|
283
|
+
// 11. Performance API cleanup
|
|
284
|
+
// CDP injects internal resources and timing entries that don't exist
|
|
285
|
+
// in normal browsing. Filter entries with debugger/devtools URLs.
|
|
286
|
+
try {
|
|
287
|
+
const _origGetEntries = Performance.prototype.getEntries;
|
|
288
|
+
const _origGetByType = Performance.prototype.getEntriesByType;
|
|
289
|
+
const _origGetByName = Performance.prototype.getEntriesByName;
|
|
290
|
+
const _suspiciousPatterns = ['debugger', 'devtools', '__puppeteer', '__playwright', 'pptr:'];
|
|
291
|
+
const _filterEntries = (entries) => {
|
|
292
|
+
if (!Array.isArray(entries)) return entries;
|
|
293
|
+
return entries.filter(e => {
|
|
294
|
+
const name = e.name || '';
|
|
295
|
+
return !_suspiciousPatterns.some(p => name.includes(p));
|
|
296
|
+
});
|
|
297
|
+
};
|
|
298
|
+
Performance.prototype.getEntries = function() {
|
|
299
|
+
return _filterEntries(_origGetEntries.call(this));
|
|
300
|
+
};
|
|
301
|
+
Performance.prototype.getEntriesByType = function(type) {
|
|
302
|
+
return _filterEntries(_origGetByType.call(this, type));
|
|
303
|
+
};
|
|
304
|
+
Performance.prototype.getEntriesByName = function(name, type) {
|
|
305
|
+
return _filterEntries(_origGetByName.call(this, name, type));
|
|
306
|
+
};
|
|
307
|
+
} catch {}
|
|
308
|
+
|
|
309
|
+
// 12. WebDriver-related property defense
|
|
310
|
+
// Some anti-bot systems check additional navigator properties
|
|
311
|
+
// and document properties that may indicate automation.
|
|
312
|
+
try {
|
|
313
|
+
// document.$cdc_ properties (ChromeDriver specific, backup for #6)
|
|
314
|
+
for (const _prop of Object.getOwnPropertyNames(document)) {
|
|
315
|
+
if (_prop.startsWith('$cdc_') || _prop.startsWith('$chrome_')) {
|
|
316
|
+
try { delete document[_prop]; } catch {}
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
} catch {}
|
|
320
|
+
|
|
321
|
+
// 13. Iframe contentWindow.chrome consistency
|
|
322
|
+
// Anti-bot scripts create iframes and check if
|
|
323
|
+
// iframe.contentWindow.chrome exists and matches the parent.
|
|
324
|
+
// CDP-controlled pages may have inconsistent iframe contexts.
|
|
325
|
+
try {
|
|
326
|
+
const _origHTMLIFrame = HTMLIFrameElement.prototype;
|
|
327
|
+
const _origContentWindow = Object.getOwnPropertyDescriptor(_origHTMLIFrame, 'contentWindow');
|
|
328
|
+
if (_origContentWindow && _origContentWindow.get) {
|
|
329
|
+
Object.defineProperty(_origHTMLIFrame, 'contentWindow', {
|
|
330
|
+
get: function() {
|
|
331
|
+
const _w = _origContentWindow.get.call(this);
|
|
332
|
+
if (_w) {
|
|
333
|
+
try {
|
|
334
|
+
if (!_w.chrome) {
|
|
335
|
+
Object.defineProperty(_w, 'chrome', {
|
|
336
|
+
value: window.chrome,
|
|
337
|
+
writable: true,
|
|
338
|
+
configurable: true,
|
|
339
|
+
});
|
|
340
|
+
}
|
|
341
|
+
} catch {}
|
|
342
|
+
}
|
|
343
|
+
return _w;
|
|
344
|
+
},
|
|
345
|
+
configurable: true,
|
|
346
|
+
});
|
|
347
|
+
}
|
|
348
|
+
} catch {}
|
|
349
|
+
|
|
152
350
|
return 'applied';
|
|
153
351
|
})()
|
|
154
352
|
`;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { generateStealthJs } from './stealth.js';
|
|
3
|
+
/**
|
|
4
|
+
* Tests for the stealth anti-detection module.
|
|
5
|
+
*
|
|
6
|
+
* We test the generated JS string for expected content and structure.
|
|
7
|
+
* Evaluating in Node is fragile because stealth patches target browser
|
|
8
|
+
* globals (navigator, Performance, HTMLIFrameElement) that don't exist
|
|
9
|
+
* or behave differently in Node. Instead we verify the code string
|
|
10
|
+
* contains the right patches and is syntactically valid.
|
|
11
|
+
*/
|
|
12
|
+
describe('generateStealthJs', () => {
|
|
13
|
+
it('returns a non-empty string', () => {
|
|
14
|
+
const code = generateStealthJs();
|
|
15
|
+
expect(typeof code).toBe('string');
|
|
16
|
+
expect(code.length).toBeGreaterThan(0);
|
|
17
|
+
});
|
|
18
|
+
it('is a valid self-contained IIFE', () => {
|
|
19
|
+
const code = generateStealthJs();
|
|
20
|
+
// Should start/end as an IIFE
|
|
21
|
+
expect(code.trim()).toMatch(/^\(\(\) => \{/);
|
|
22
|
+
expect(code.trim()).toMatch(/\}\)\(\)$/);
|
|
23
|
+
});
|
|
24
|
+
it('patches navigator.webdriver', () => {
|
|
25
|
+
const code = generateStealthJs();
|
|
26
|
+
expect(code).toContain("navigator, 'webdriver'");
|
|
27
|
+
expect(code).toContain('() => false');
|
|
28
|
+
});
|
|
29
|
+
it('stubs window.chrome', () => {
|
|
30
|
+
const code = generateStealthJs();
|
|
31
|
+
expect(code).toContain('window.chrome');
|
|
32
|
+
expect(code).toContain('runtime');
|
|
33
|
+
expect(code).toContain('loadTimes');
|
|
34
|
+
expect(code).toContain('csi');
|
|
35
|
+
});
|
|
36
|
+
it('fakes navigator.plugins if empty', () => {
|
|
37
|
+
const code = generateStealthJs();
|
|
38
|
+
expect(code).toContain('navigator.plugins');
|
|
39
|
+
expect(code).toContain('PDF Viewer');
|
|
40
|
+
expect(code).toContain('Chrome PDF Viewer');
|
|
41
|
+
});
|
|
42
|
+
it('ensures navigator.languages is non-empty', () => {
|
|
43
|
+
const code = generateStealthJs();
|
|
44
|
+
expect(code).toContain('navigator.languages');
|
|
45
|
+
expect(code).toContain("'en-US'");
|
|
46
|
+
});
|
|
47
|
+
it('normalizes Permissions.query for notifications', () => {
|
|
48
|
+
const code = generateStealthJs();
|
|
49
|
+
expect(code).toContain('Permissions');
|
|
50
|
+
expect(code).toContain('notifications');
|
|
51
|
+
});
|
|
52
|
+
it('cleans automation artifacts', () => {
|
|
53
|
+
const code = generateStealthJs();
|
|
54
|
+
expect(code).toContain('__playwright');
|
|
55
|
+
expect(code).toContain('__puppeteer');
|
|
56
|
+
expect(code).toContain("'cdc_'");
|
|
57
|
+
expect(code).toContain("'__cdc_'");
|
|
58
|
+
});
|
|
59
|
+
it('filters CDP patterns from Error.stack', () => {
|
|
60
|
+
const code = generateStealthJs();
|
|
61
|
+
expect(code).toContain('puppeteer_evaluation_script');
|
|
62
|
+
expect(code).toContain("'pptr:'");
|
|
63
|
+
expect(code).toContain("'debugger://'");
|
|
64
|
+
});
|
|
65
|
+
it('neutralizes debugger statement traps', () => {
|
|
66
|
+
const code = generateStealthJs();
|
|
67
|
+
// Should patch Function constructor with new.target / Reflect.construct
|
|
68
|
+
expect(code).toContain('_OrigFunction');
|
|
69
|
+
expect(code).toContain('_PatchedFunction');
|
|
70
|
+
expect(code).toContain('new.target');
|
|
71
|
+
expect(code).toContain('Reflect.construct');
|
|
72
|
+
// Should patch eval
|
|
73
|
+
expect(code).toContain('_origEval');
|
|
74
|
+
expect(code).toContain('_patchedEval');
|
|
75
|
+
// Regex to strip debugger (lookbehind for statement boundaries)
|
|
76
|
+
expect(code).toContain('_debuggerRe');
|
|
77
|
+
});
|
|
78
|
+
it('uses shared toString disguise via WeakMap', () => {
|
|
79
|
+
const code = generateStealthJs();
|
|
80
|
+
// Shared infrastructure at the top of the IIFE
|
|
81
|
+
expect(code).toContain('_origToString');
|
|
82
|
+
expect(code).toContain('WeakMap');
|
|
83
|
+
expect(code).toContain('_disguised');
|
|
84
|
+
expect(code).toContain('_disguise');
|
|
85
|
+
// Should NOT have per-instance toString overrides on Function/eval
|
|
86
|
+
// (they go through _disguise instead)
|
|
87
|
+
});
|
|
88
|
+
it('defends console method fingerprinting', () => {
|
|
89
|
+
const code = generateStealthJs();
|
|
90
|
+
expect(code).toContain('_consoleMethods');
|
|
91
|
+
expect(code).toContain("'log'");
|
|
92
|
+
expect(code).toContain("'warn'");
|
|
93
|
+
expect(code).toContain("'error'");
|
|
94
|
+
expect(code).toContain('[native code]');
|
|
95
|
+
// Uses saved _origToString reference
|
|
96
|
+
expect(code).toContain('_origToString.call');
|
|
97
|
+
});
|
|
98
|
+
it('defends window dimension detection', () => {
|
|
99
|
+
const code = generateStealthJs();
|
|
100
|
+
expect(code).toContain('outerWidth');
|
|
101
|
+
expect(code).toContain('outerHeight');
|
|
102
|
+
expect(code).toContain('innerWidth');
|
|
103
|
+
expect(code).toContain('innerHeight');
|
|
104
|
+
});
|
|
105
|
+
it('filters Performance API entries', () => {
|
|
106
|
+
const code = generateStealthJs();
|
|
107
|
+
expect(code).toContain('getEntries');
|
|
108
|
+
expect(code).toContain('getEntriesByType');
|
|
109
|
+
expect(code).toContain('getEntriesByName');
|
|
110
|
+
expect(code).toContain('_suspiciousPatterns');
|
|
111
|
+
});
|
|
112
|
+
it('cleans document $cdc_ properties', () => {
|
|
113
|
+
const code = generateStealthJs();
|
|
114
|
+
expect(code).toContain("'$cdc_'");
|
|
115
|
+
expect(code).toContain("'$chrome_'");
|
|
116
|
+
});
|
|
117
|
+
it('patches iframe contentWindow.chrome consistency', () => {
|
|
118
|
+
const code = generateStealthJs();
|
|
119
|
+
expect(code).toContain('contentWindow');
|
|
120
|
+
expect(code).toContain('HTMLIFrameElement');
|
|
121
|
+
});
|
|
122
|
+
it('uses non-enumerable guard flag on EventTarget.prototype', () => {
|
|
123
|
+
const code = generateStealthJs();
|
|
124
|
+
expect(code).toContain('EventTarget.prototype');
|
|
125
|
+
expect(code).toContain("'__lsn'");
|
|
126
|
+
expect(code).toContain('enumerable: false');
|
|
127
|
+
});
|
|
128
|
+
it('generates syntactically valid JavaScript', () => {
|
|
129
|
+
const code = generateStealthJs();
|
|
130
|
+
// new Function() parses the code without executing it in a real
|
|
131
|
+
// browser context, catching syntax errors from template literal issues.
|
|
132
|
+
expect(() => new Function(code)).not.toThrow();
|
|
133
|
+
});
|
|
134
|
+
});
|
package/dist/browser.test.js
CHANGED
|
@@ -108,7 +108,7 @@ describe('BrowserBridge state', () => {
|
|
|
108
108
|
vi.spyOn(daemonClient, 'isExtensionConnected').mockResolvedValue(false);
|
|
109
109
|
vi.spyOn(daemonClient, 'isDaemonRunning').mockResolvedValue(true);
|
|
110
110
|
const mcp = new BrowserBridge();
|
|
111
|
-
await expect(mcp.connect()).rejects.toThrow('Browser Extension is not connected');
|
|
111
|
+
await expect(mcp.connect({ timeout: 0.1 })).rejects.toThrow('Browser Extension is not connected');
|
|
112
112
|
});
|
|
113
113
|
});
|
|
114
114
|
describe('stealth anti-detection', () => {
|
package/dist/build-manifest.d.ts
CHANGED
package/dist/build-manifest.js
CHANGED
|
@@ -46,6 +46,7 @@ function toManifestEntry(cmd, modulePath) {
|
|
|
46
46
|
return {
|
|
47
47
|
site: cmd.site,
|
|
48
48
|
name: cmd.name,
|
|
49
|
+
aliases: cmd.aliases,
|
|
49
50
|
description: cmd.description ?? '',
|
|
50
51
|
domain: cmd.domain,
|
|
51
52
|
strategy: (cmd.strategy ?? 'public').toString().toLowerCase(),
|
|
@@ -78,6 +79,9 @@ function scanYaml(filePath, site) {
|
|
|
78
79
|
domain: cliDef.domain,
|
|
79
80
|
strategy: strategy.toLowerCase(),
|
|
80
81
|
browser,
|
|
82
|
+
aliases: isRecord(cliDef) && Array.isArray(cliDef.aliases)
|
|
83
|
+
? cliDef.aliases.filter((value) => typeof value === 'string')
|
|
84
|
+
: undefined,
|
|
81
85
|
args,
|
|
82
86
|
columns: cliDef.columns,
|
|
83
87
|
pipeline: cliDef.pipeline,
|
|
@@ -181,7 +185,7 @@ export async function buildManifest() {
|
|
|
181
185
|
}
|
|
182
186
|
}
|
|
183
187
|
}
|
|
184
|
-
return [...manifest.values()];
|
|
188
|
+
return [...manifest.values()].sort((a, b) => a.site.localeCompare(b.site) || a.name.localeCompare(b.name));
|
|
185
189
|
}
|
|
186
190
|
async function main() {
|
|
187
191
|
const manifest = await buildManifest();
|
|
@@ -70,6 +70,7 @@ describe('manifest helper rules', () => {
|
|
|
70
70
|
description: 'dynamic command',
|
|
71
71
|
strategy: Strategy.PUBLIC,
|
|
72
72
|
browser: false,
|
|
73
|
+
aliases: ['metadata'],
|
|
73
74
|
args: [
|
|
74
75
|
{
|
|
75
76
|
name: 'model',
|
|
@@ -94,6 +95,7 @@ describe('manifest helper rules', () => {
|
|
|
94
95
|
domain: 'localhost',
|
|
95
96
|
strategy: 'public',
|
|
96
97
|
browser: false,
|
|
98
|
+
aliases: ['metadata'],
|
|
97
99
|
args: [
|
|
98
100
|
{
|
|
99
101
|
name: 'model',
|