ai-search-hub
Run the AI Search Hub browser automation scripts for Yuanbao, LongCat, Doubao, Qwen, Gemini, Grok, and MiniMax. Use this skill when the user wants to ask one of those sites a prompt, auto-start or attach to a Chrome DevTools session on port 9222, seed an isolated debug browser profile from the user's local browser data, detect whether login is required, wait for the user to finish logging in if needed, and then continue automatically.
git clone https://github.com/minsight-ai-info/AI-Search-Hub
git clone --depth=1 https://github.com/minsight-ai-info/AI-Search-Hub ~/.claude/skills/minsight-ai-info-ai-search-hub-ai-search-hub
SKILL.mdAI Search Hub
Use this skill only for this repository's AI Search Hub browser automation scripts:
scripts/yuanbao_playwright.pyscripts/longcat_playwright.pyscripts/doubao_playwright.pyscripts/qwen_playwright.pyscripts/gemini_playwright.pyscripts/grok_playwright.pyscripts/minimaxi_playwright.py
When To Use
Use this skill when the user asks to:
- run one of the supported chat sites from this repo
- normalize invocation across the three scripts
- auto-start a debug Chromium-family browser session
- detect whether
is available127.0.0.1:9222 - prompt for login if the target site is not logged in, then continue automatically
- seed an isolated debug profile from the user's local browser data
Installation
Before first use, ensure dependencies are installed. See
INSTALL.md for the complete setup sequence:
- Python 3.10+ with pip
pip install playwrightplaywright install chromium
The wrapper auto-detects Chrome/Edge/Brave/Chromium on macOS, Linux, and Windows.
Routing Strategy
Do not send every question to every platform. Analyze the question first, then route to the platform(s) whose underlying data world is most likely to contain the best answer.
See
ROUTING.md for the full decision framework. Quick reference:
| Question Type | Recommended Site | Parent Company |
|---|---|---|
| Twitter / X / real-time social | | xAI |
| Google / global web | | |
| 微信公众号 / WeChat content | | 腾讯 |
| 抖音 / 头条 / ByteDance trends | | 字节跳动 |
| 美团 / 大众点评 / 本地生活 | | 美团 |
| 淘宝 / 阿里 / 通用中文 | | 阿里巴巴 |
| 用户明确要求 MiniMax / MiniMax Agent | | MiniMax |
How To Run
Run the bundled wrapper script instead of calling the site script directly:
python3 scripts/run_web_chat.py --site doubao --prompt "Give me a short Hangzhou food guide."
Key arguments:
--site yuanbao|longcat|doubao|qwen|gemini|grok|minimaxi
required--prompt "..."
if the current working directory is not the repo root--repo-root <path>
to reuse an existing DevTools endpoint--cdp-http http://127.0.0.1:9222
to force a specific Chromium-family browser binary--browser-path <path>
to control the isolated debug profile location--debug-profile-dir <path>
to force a specific source browser user-data-dir--user-data-source <path>
to control the destination file--output <path>
Workflow
The wrapper script is the low-freedom path and should be preferred over hand-rolling the sequence.
It does the following:
- Finds the repo root and target site script.
- Reuses
if--cdp-http
is already listening.9222 - Otherwise seeds an isolated Chromium-family debug profile from the user's source browser data and starts the browser with a remote-debugging port, opening the requested site directly instead of leaving a separate
startup tab behind.about:blank - For legacy sites (
,yuanbao
,longcat
), opens the target site and checks for login UI before dispatching the site-specific script.doubao - For generic sites (
,qwen
,gemini
,grok
), opens the target site, enters the prompt, and waits for a reply.minimaxi - If the site requires login or produces no usable reply because login is required, prints a prompt and waits until login completes, then continues automatically.
- Invokes the matching site script with standardized flags and the resolved
.--cdp-url - Reuses the single startup page when possible so the browser does not keep an extra blank tab, and prefers DOM-side text entry over keyboard typing to reduce accidental interference from the user working elsewhere.
Site Notes
: requires a logged-in session. The visitor page usually does not answer prompts.doubao
: login may appear as a modal with QQ, WeChat, or last-login buttons even when the page shell is visible.yuanbao
: the wrapper prefers a new chat before sending unlesslongcat
is requested downstream.--no-new-chat
,qwen
,gemini
,grok
: each has its own Playwright entry script backed by a shared site-chat core.minimaxi
first targets the visible composer and attempts the send once before falling back to the login-wait loop, because the landing page exposes a real textbox even when the account is not yet in a usable chat state.gemini
Constraints
- Prefer headed Chromium browsers for login-recovery flows. Headless mode only makes sense when the copied debug profile is already logged in.
- Do not kill the user's normal browser session unless the user explicitly asks for that.
- The wrapper copies browser data into an isolated debug profile and skips lock files, so the user's normal browser can stay open.
- The wrapper bypasses Python proxy settings for local DevTools requests because
may otherwise return a falsehttp://127.0.0.1:9222/json/version
.502