براؤزر (openclaw کے زیرِ انتظام)¶
OpenClaw ایک مخصوص Chrome/Brave/Edge/Chromium پروفائل چلا سکتا ہے جسے ایجنٹ کنٹرول کرتا ہے۔ It is isolated from your personal browser and is managed through a small local control service inside the Gateway (loopback only).
ابتدائی جائزہ:
- اسے ایک علیحدہ، صرف ایجنٹ کے لیے براؤزر سمجھیں۔
openclawپروفائل آپ کے ذاتی براؤزر پروفائل کو بالکل نہیں چھوتا۔- ایجنٹ ایک محفوظ ماحول میں ٹیب کھول سکتا ہے، صفحات پڑھ سکتا ہے، کلک اور ٹائپ کر سکتا ہے۔
- ڈیفالٹ
chromeپروفائل ایکسٹینشن ریلے کے ذریعے سسٹم ڈیفالٹ Chromium براؤزر استعمال کرتا ہے؛ الگ تھلگ منیجڈ براؤزر کے لیےopenclawپر سوئچ کریں۔
آپ کو کیا ملتا ہے¶
- openclaw نام کا ایک علیحدہ براؤزر پروفائل (بطورِ طے شدہ نارنجی ایکسنٹ کے ساتھ)۔
- قابلِ پیش گوئی ٹیب کنٹرول (list/open/focus/close)۔
- ایجنٹ ایکشنز (click/type/drag/select)، اسنیپ شاٹس، اسکرین شاٹس، PDFs۔
- اختیاری ملٹی پروفائل سپورٹ (
openclaw,work,remote, ...)۔
یہ براؤزر آپ کا روزمرہ استعمال والا براؤزر نہیں ہے۔ یہ ایک محفوظ، الگ تھلگ ماحول فراہم کرتا ہے برائے agent automation and verification.
فوری آغاز¶
openclaw browser --browser-profile openclaw status
openclaw browser --browser-profile openclaw start
openclaw browser --browser-profile openclaw open https://example.com
openclaw browser --browser-profile openclaw snapshot
اگر آپ کو “Browser disabled” ملے، تو کنفیگ میں اسے فعال کریں (نیچے دیکھیں) اور Gateway کو ری اسٹارٹ کریں۔
پروفائلز: openclaw بمقابلہ chrome¶
openclaw: منیجڈ، الگ تھلگ براؤزر (کسی ایکسٹینشن کی ضرورت نہیں)۔chrome: آپ کے سسٹم براؤزر تک ایکسٹینشن ریلے (OpenClaw ایکسٹینشن کو کسی ٹیب سے منسلک کرنا ضروری ہے)۔
اگر آپ منیجڈ موڈ کو بطورِ طے شدہ چاہتے ہیں تو browser.defaultProfile: "openclaw" سیٹ کریں۔
Configuration¶
براؤزر سیٹنگز ~/.openclaw/openclaw.json میں ہوتی ہیں۔
{
browser: {
enabled: true, // default: true
// cdpUrl: "http://127.0.0.1:18792", // legacy single-profile override
remoteCdpTimeoutMs: 1500, // remote CDP HTTP timeout (ms)
remoteCdpHandshakeTimeoutMs: 3000, // remote CDP WebSocket handshake timeout (ms)
defaultProfile: "chrome",
color: "#FF4500",
headless: false,
noSandbox: false,
attachOnly: false,
executablePath: "/Applications/Brave Browser.app/Contents/MacOS/Brave Browser",
profiles: {
openclaw: { cdpPort: 18800, color: "#FF4500" },
work: { cdpPort: 18801, color: "#0066CC" },
remote: { cdpUrl: "http://10.0.0.42:9222", color: "#00AA00" },
},
},
}
Notes:
- The browser control service binds to loopback on a port derived from
gateway.port(default:18791, which is gateway + 2). The relay uses the next port (18792). - اگر آپ Gateway پورٹ (
gateway.portیاOPENCLAW_GATEWAY_PORT) اوور رائیڈ کریں، تو اخذ شدہ براؤزر پورٹس اسی “فیملی” میں رہنے کے لیے شفٹ ہو جاتے ہیں۔ cdpUrlاگر سیٹ نہ ہو تو بطورِ طے شدہ ریلے پورٹ لیتا ہے۔remoteCdpTimeoutMsریموٹ (non-loopback) CDP رسائی کی جانچ پر لاگو ہوتا ہے۔remoteCdpHandshakeTimeoutMsریموٹ CDP WebSocket رسائی کی جانچ پر لاگو ہوتا ہے۔attachOnly: trueکا مطلب ہے “کبھی مقامی براؤزر لانچ نہ کریں؛ صرف اسی صورت منسلک کریں جب وہ پہلے سے چل رہا ہو۔”color+ فی پروفائلcolorبراؤزر UI کو رنگ دیتے ہیں تاکہ معلوم ہو سکے کون سا پروفائل فعال ہے۔- Default profile is
chrome(extension relay). UsedefaultProfile: "openclaw"for the managed browser. - آٹو ڈیٹیکٹ آرڈر: اگر Chromium-based ہو تو سسٹم ڈیفالٹ براؤزر؛ ورنہ Chrome → Brave → Edge → Chromium → Chrome Canary۔
- مقامی
openclawپروفائلز خود بخودcdpPort/cdpUrlاسائن کرتے ہیں — انہیں صرف ریموٹ CDP کے لیے سیٹ کریں۔
Use Brave (or another Chromium-based browser)¶
If your system default browser is Chromium-based (Chrome/Brave/Edge/etc),
OpenClaw uses it automatically. Set browser.executablePath to override
auto-detection:
CLI example:
openclaw config set browser.executablePath "/usr/bin/google-chrome"
// macOS
{
browser: {
executablePath: "/Applications/Brave Browser.app/Contents/MacOS/Brave Browser"
}
}
// Windows
{
browser: {
executablePath: "C:\\Program Files\\BraveSoftware\\Brave-Browser\\Application\\brave.exe"
}
}
// Linux
{
browser: {
executablePath: "/usr/bin/brave-browser"
}
}
Local vs remote control¶
- Local control (default): Gateway loopback کنٹرول سروس شروع کرتا ہے اور مقامی براؤزر لانچ کر سکتا ہے۔
- Remote control (node host): اس مشین پر node host چلائیں جہاں براؤزر موجود ہو؛ Gateway براؤزر ایکشنز کو وہاں پروکسی کرتا ہے۔
- Remote CDP: set
browser.profiles.<name>.cdpUrl(orbrowser.cdpUrl) to attach to a remote Chromium-based browser. In this case, OpenClaw will not launch a local browser.
Remote CDP URLs میں auth شامل ہو سکتا ہے:
- Query tokens (مثلاً
https://provider.example?token=<token>) - HTTP Basic auth (مثلاً
https://user:pass@provider.example)
OpenClaw preserves the auth when calling /json/* endpoints and when connecting
to the CDP WebSocket. Prefer environment variables or secrets managers for
tokens instead of committing them to config files.
Node browser proxy (zero-config default)¶
If you run a node host on the machine that has your browser, OpenClaw can auto-route browser tool calls to that node without any extra browser config. This is the default path for remote gateways.
Notes:
- node host ایک proxy command کے ذریعے اپنا مقامی براؤزر کنٹرول سرور ایکسپوز کرتا ہے۔
- پروفائلز node کی اپنی
browser.profilesکنفیگ سے آتے ہیں (بالکل مقامی کی طرح)۔ - اگر آپ نہیں چاہتے تو غیر فعال کریں:
- node پر:
nodeHost.browserProxy.enabled=false - gateway پر:
gateway.nodes.browser.mode="off"
Browserless (hosted remote CDP)¶
Browserless is a hosted Chromium service that exposes CDP endpoints over HTTPS. You can point a OpenClaw browser profile at a Browserless region endpoint and authenticate with your API key.
Example:
{
browser: {
enabled: true,
defaultProfile: "browserless",
remoteCdpTimeoutMs: 2000,
remoteCdpHandshakeTimeoutMs: 4000,
profiles: {
browserless: {
cdpUrl: "https://production-sfo.browserless.io?token=<BROWSERLESS_API_KEY>",
color: "#00AA00",
},
},
},
}
Notes:
<BROWSERLESS_API_KEY>کو اپنے اصل Browserless ٹوکن سے بدلیں۔- اپنے Browserless اکاؤنٹ کے مطابق ریجن endpoint منتخب کریں (ان کی دستاویزات دیکھیں)۔
Security¶
اہم نکات:
- براؤزر کنٹرول صرف loopback تک محدود ہے؛ رسائی Gateway کی auth یا node pairing کے ذریعے ہوتی ہے۔
- Gateway اور کسی بھی node host کو نجی نیٹ ورک (Tailscale) پر رکھیں؛ عوامی ایکسپوژر سے بچیں۔
- Remote CDP URLs/ٹوکنز کو راز سمجھیں؛ env vars یا secrets manager کو ترجیح دیں۔
Remote CDP tips:
- جہاں ممکن ہو HTTPS endpoints اور قلیل مدتی ٹوکنز استعمال کریں۔
- طویل مدتی ٹوکنز کو براہِ راست کنفیگ فائلز میں شامل کرنے سے گریز کریں۔
Profiles (multi-browser)¶
OpenClaw supports multiple named profiles (routing configs). Profiles can be:
- openclaw-managed: ایک وقف شدہ Chromium-based براؤزر انسٹینس جس کی اپنی user data directory + CDP پورٹ ہو
- remote: ایک واضح CDP URL (کہیں اور چل رہا Chromium-based براؤزر)
- extension relay: مقامی ریلے + Chrome ایکسٹینشن کے ذریعے آپ کے موجودہ Chrome ٹیبز
Defaults:
- اگر موجود نہ ہو تو
openclawپروفائل خود بخود بنایا جاتا ہے۔ chromeپروفائل Chrome ایکسٹینشن ریلے کے لیے built-in ہے (بطورِ طے شدہhttp://127.0.0.1:18792کی طرف اشارہ کرتا ہے)۔- مقامی CDP پورٹس بطورِ طے شدہ 18800–18899 سے الاٹ ہوتے ہیں۔
- کسی پروفائل کو حذف کرنے سے اس کی مقامی data directory Trash میں منتقل ہو جاتی ہے۔
تمام کنٹرول endpoints ?profile=<name> قبول کرتے ہیں؛ CLI --browser-profile استعمال کرتا ہے۔
Chrome extension relay (use your existing Chrome)¶
OpenClaw مقامی CDP ریلے + Chrome ایکسٹینشن کے ذریعے آپ کے موجودہ Chrome ٹیبز کو بھی کنٹرول کر سکتا ہے (کوئی علیحدہ “openclaw” Chrome انسٹینس نہیں)۔
مکمل رہنمائی: Chrome extension
Flow:
- Gateway مقامی طور پر چلتا ہے (اسی مشین پر) یا براؤزر مشین پر node host چلتا ہے۔
- ایک مقامی relay server loopback
cdpUrlپر سنتا ہے (ڈیفالٹ:http://127.0.0.1:18792)۔ - آپ جس ٹیب کو کنٹرول کرنا چاہتے ہیں اس پر OpenClaw Browser Relay ایکسٹینشن آئیکن پر کلک کرتے ہیں (یہ خودکار طور پر منسلک نہیں ہوتی)۔
- ایجنٹ درست پروفائل منتخب کر کے عام
browserٹول کے ذریعے اس ٹیب کو کنٹرول کرتا ہے۔
اگر Gateway کہیں اور چل رہا ہو، تو براؤزر مشین پر node host چلائیں تاکہ Gateway براؤزر ایکشنز کو پروکسی کر سکے۔
Sandboxed sessions¶
If the agent session is sandboxed, the browser tool may default to target="sandbox" (sandbox browser).
Chrome extension relay takeover requires host browser control, so either:
- سیشن unsandboxed چلائیں، یا
agents.defaults.sandbox.browser.allowHostControl: trueسیٹ کریں اور ٹول کال کرتے وقتtarget="host"استعمال کریں۔
Setup¶
- ایکسٹینشن لوڈ کریں (dev/unpacked):
openclaw browser extension install
- Chrome →
chrome://extensions→ “Developer mode” فعال کریں - “Load unpacked” → وہ ڈائریکٹری منتخب کریں جو
openclaw browser extension pathپرنٹ کرتا ہے - ایکسٹینشن کو پن کریں، پھر جس ٹیب کو کنٹرول کرنا ہے اس پر کلک کریں (بیج
ONدکھاتا ہے)۔
- استعمال کریں:
- CLI:
openclaw browser --browser-profile chrome tabs - Agent tool:
browserمعprofile="chrome"
اختیاری: اگر آپ مختلف نام یا ریلے پورٹ چاہتے ہیں تو اپنا پروفائل بنائیں:
openclaw browser create-profile \
--name my-chrome \
--driver extension \
--cdp-url http://127.0.0.1:18792 \
--color "#00AA00"
Notes:
- یہ موڈ زیادہ تر آپریشنز (screenshots/snapshots/actions) کے لیے Playwright-on-CDP پر انحصار کرتا ہے۔
- ایکسٹینشن آئیکن دوبارہ کلک کر کے detach کریں۔
Isolation guarantees¶
- وقف شدہ user data dir: آپ کے ذاتی براؤزر پروفائل کو کبھی نہیں چھوتا۔
- وقف شدہ پورٹس: dev workflows کے ساتھ ٹکراؤ سے بچنے کے لیے
9222سے گریز۔ - قابلِ پیش گوئی ٹیب کنٹرول: “آخری ٹیب” کے بجائے
targetIdکے ذریعے ٹیب ہدف بنائیں۔
Browser selection¶
مقامی لانچ پر، OpenClaw دستیاب ہونے پر پہلا منتخب کرتا ہے:
- Chrome
- Brave
- Edge
- Chromium
- Chrome Canary
آپ browser.executablePath کے ساتھ اوور رائیڈ کر سکتے ہیں۔
Platforms:
- macOS:
/Applicationsاور~/Applicationsچیک کرتا ہے۔ - Linux:
google-chrome,brave,microsoft-edge,chromiumوغیرہ تلاش کرتا ہے۔ - Windows: عام انسٹال لوکیشنز چیک کرتا ہے۔
Control API (optional)¶
صرف مقامی انضمام کے لیے، Gateway ایک چھوٹی loopback HTTP API ایکسپوز کرتا ہے:
- Status/start/stop:
GET /,POST /start,POST /stop - Tabs:
GET /tabs,POST /tabs/open,POST /tabs/focus,DELETE /tabs/:targetId - Snapshot/screenshot:
GET /snapshot,POST /screenshot - Actions:
POST /navigate,POST /act - Hooks:
POST /hooks/file-chooser,POST /hooks/dialog - Downloads:
POST /download,POST /wait/download - Debugging:
GET /console,POST /pdf - Debugging:
GET /errors,GET /requests,POST /trace/start,POST /trace/stop,POST /highlight - Network:
POST /response/body - State:
GET /cookies,POST /cookies/set,POST /cookies/clear - State:
GET /storage/:kind,POST /storage/:kind/set,POST /storage/:kind/clear - Settings:
POST /set/offline,POST /set/headers,POST /set/credentials,POST /set/geolocation,POST /set/media,POST /set/timezone,POST /set/locale,POST /set/device
تمام endpoints ?profile=<name> قبول کرتے ہیں۔
Playwright requirement¶
Some features (navigate/act/AI snapshot/role snapshot, element screenshots, PDF) require Playwright. If Playwright isn’t installed, those endpoints return a clear 501 error. ARIA snapshots and basic screenshots still work for openclaw-managed Chrome. For the Chrome extension relay driver, ARIA snapshots and screenshots require Playwright.
اگر آپ Playwright is not available in this gateway build دیکھیں، تو مکمل
Playwright پیکج انسٹال کریں ( playwright-core نہیں ) اور gateway ری اسٹارٹ کریں، یا
براؤزر سپورٹ کے ساتھ OpenClaw دوبارہ انسٹال کریں۔
Docker Playwright install¶
If your Gateway runs in Docker, avoid npx playwright (npm override conflicts).
Use the bundled CLI instead:
docker compose run --rm openclaw-cli \
node /app/node_modules/playwright-core/cli.js install chromium
To persist browser downloads, set PLAYWRIGHT_BROWSERS_PATH (for example,
/home/node/.cache/ms-playwright) and make sure /home/node is persisted via
OPENCLAW_HOME_VOLUME or a bind mount. See Docker.
How it works (internal)¶
High-level flow:
- ایک چھوٹا control server HTTP درخواستیں قبول کرتا ہے۔
- یہ CDP کے ذریعے Chromium-based براؤزرز (Chrome/Brave/Edge/Chromium) سے جڑتا ہے۔
- جدید ایکشنز (click/type/snapshot/PDF) کے لیے، یہ CDP کے اوپر Playwright استعمال کرتا ہے۔
- جب Playwright موجود نہ ہو، تو صرف non-Playwright آپریشنز دستیاب ہوتے ہیں۔
یہ ڈیزائن ایجنٹ کو ایک مستحکم، قابلِ پیش گوئی انٹرفیس پر رکھتا ہے جبکہ آپ کو مقامی/ریموٹ براؤزرز اور پروفائلز تبدیل کرنے کی سہولت دیتا ہے۔
CLI quick reference¶
All commands accept --browser-profile <name> to target a specific profile.
All commands also accept --json for machine-readable output (stable payloads).
Basics:
openclaw browser statusopenclaw browser startopenclaw browser stopopenclaw browser tabsopenclaw browser tabopenclaw browser tab newopenclaw browser tab select 2openclaw browser tab close 2openclaw browser open https://example.comopenclaw browser focus abcd1234openclaw browser close abcd1234
Inspection:
openclaw browser screenshotopenclaw browser screenshot --full-pageopenclaw browser screenshot --ref 12openclaw browser screenshot --ref e12openclaw browser snapshotopenclaw browser snapshot --format aria --limit 200openclaw browser snapshot --interactive --compact --depth 6openclaw browser snapshot --efficientopenclaw browser snapshot --labelsopenclaw browser snapshot --selector "#main" --interactiveopenclaw browser snapshot --frame "iframe#main" --interactiveopenclaw browser console --level erroropenclaw browser errors --clearopenclaw browser requests --filter api --clearopenclaw browser pdfopenclaw browser responsebody "**/api" --max-chars 5000
Actions:
openclaw browser navigate https://example.comopenclaw browser resize 1280 720openclaw browser click 12 --doubleopenclaw browser click e12 --doubleopenclaw browser type 23 "hello" --submitopenclaw browser press Enteropenclaw browser hover 44openclaw browser scrollintoview e12openclaw browser drag 10 11openclaw browser select 9 OptionA OptionBopenclaw browser download e12 /tmp/report.pdfopenclaw browser waitfordownload /tmp/report.pdfopenclaw browser upload /tmp/file.pdfopenclaw browser fill --fields '[{"ref":"1","type":"text","value":"Ada"}]'openclaw browser dialog --acceptopenclaw browser wait --text "Done"openclaw browser wait "#main" --url "**/dash" --load networkidle --fn "window.ready===true"openclaw browser evaluate --fn '(el) => el.textContent' --ref 7openclaw browser highlight e12openclaw browser trace startopenclaw browser trace stop
State:
openclaw browser cookiesopenclaw browser cookies set session abc123 --url "https://example.com"openclaw browser cookies clearopenclaw browser storage local getopenclaw browser storage local set theme darkopenclaw browser storage session clearopenclaw browser set offline onopenclaw browser set headers --json '{"X-Debug":"1"}'openclaw browser set credentials user passopenclaw browser set credentials --clearopenclaw browser set geo 37.7749 -122.4194 --origin "https://example.com"openclaw browser set geo --clearopenclaw browser set media darkopenclaw browser set timezone America/New_Yorkopenclaw browser set locale en-USopenclaw browser set device "iPhone 14"
Notes:
uploadاورdialogarming کالز ہیں؛ chooser/dialog کو ٹرگر کرنے والے click/press سے پہلے انہیں چلائیں۔uploadفائل ان پٹس کو براہِ راست--input-refیا--elementکے ذریعے بھی سیٹ کر سکتا ہے۔snapshot:--format ai(جب Playwright انسٹال ہو تو ڈیفالٹ): عددی refs (aria-ref="<n>") کے ساتھ AI snapshot لوٹاتا ہے۔--format aria: accessibility tree لوٹاتا ہے (کوئی refs نہیں؛ صرف معائنہ)۔--efficient(یا--mode efficient): compact role snapshot preset (interactive + compact + depth + کم maxChars)۔- کنفیگ ڈیفالٹ (صرف tool/CLI):
browser.snapshotDefaults.mode: "efficient"سیٹ کریں تاکہ جب کالر موڈ نہ دے تو مؤثر snapshots استعمال ہوں (دیکھیں Gateway configuration)۔ - Role snapshot options (
--interactive,--compact,--depth,--selector) role-based snapshot کو refs جیسےref=e12کے ساتھ مجبور کرتے ہیں۔ --frame "<iframe selector>"role snapshots کو کسی iframe تک محدود کرتا ہے (role refs جیسےe12کے ساتھ جوڑا جاتا ہے)۔--interactiveinteractive عناصر کی ایک سادہ، آسان فہرست آؤٹ پٹ کرتا ہے (ایکشنز چلانے کے لیے بہترین)۔--labelsviewport-only اسکرین شاٹ شامل کرتا ہے جس پر overlayed ref labels ہوتے ہیں (MEDIA:<path>پرنٹ کرتا ہے)۔click/type/etc require areffromsnapshot(either numeric12or role refe12). CSS selectors are intentionally not supported for actions.
Snapshots and refs¶
OpenClaw دو “snapshot” طرزیں سپورٹ کرتا ہے:
- AI snapshot (numeric refs):
openclaw browser snapshot(ڈیفالٹ؛--format ai) - Output: ایک ٹیکسٹ snapshot جس میں عددی refs شامل ہوتے ہیں۔
- Actions:
openclaw browser click 12,openclaw browser type 23 "hello"۔ -
اندرونی طور پر، ref Playwright کے
aria-refکے ذریعے resolve ہوتا ہے۔ -
Role snapshot (role refs جیسے
e12):openclaw browser snapshot --interactive(یا--compact,--depth,--selector,--frame) - Output:
[ref=e12]کے ساتھ role-based فہرست/درخت (اور اختیاری[nth=1])۔ - Actions:
openclaw browser click e12,openclaw browser highlight e12۔ - اندرونی طور پر، ref
getByRole(...)کے ذریعے resolve ہوتا ہے (ڈپلیکیٹس کے لیےnth()کے ساتھ)۔ - viewport اسکرین شاٹ شامل کرنے کے لیے
--labelsشامل کریں جس پر overlayede12لیبلز ہوں۔
Ref behavior:
- Refs نیویگیشن کے بعد مستحکم نہیں رہتے؛ اگر کچھ ناکام ہو جائے تو
snapshotدوبارہ چلائیں اور نیا ref استعمال کریں۔ - اگر role snapshot
--frameکے ساتھ لیا گیا ہو، تو role refs اگلے role snapshot تک اسی iframe تک محدود رہتے ہیں۔
Wait power-ups¶
آپ صرف وقت/متن ہی نہیں بلکہ مزید چیزوں کا انتظار کر سکتے ہیں:
- URL کا انتظار (Playwright کے globs سپورٹڈ):
openclaw browser wait --url "**/dash"- load state کا انتظار:
openclaw browser wait --load networkidle- JS predicate کا انتظار:
openclaw browser wait --fn "window.ready===true"- کسی selector کے visible ہونے کا انتظار:
openclaw browser wait "#main"
انہیں یکجا بھی کیا جا سکتا ہے:
openclaw browser wait "#main" \
--url "**/dash" \
--load networkidle \
--fn "window.ready===true" \
--timeout-ms 15000
Debug workflows¶
جب کوئی ایکشن ناکام ہو (مثلاً “not visible”، “strict mode violation”، “covered”):
openclaw browser snapshot --interactiveclick <ref>/type <ref>استعمال کریں (interactive موڈ میں role refs کو ترجیح دیں)- اگر پھر بھی ناکام ہو:
openclaw browser highlight <ref>تاکہ دیکھا جا سکے Playwright کیا ہدف بنا رہا ہے - اگر صفحہ عجیب برتاؤ کرے:
-
openclaw browser errors --clear-openclaw browser requests --filter api --clear - گہری ڈیبگنگ کے لیے: trace ریکارڈ کریں:
-
openclaw browser trace start- مسئلہ دوبارہ پیدا کریں -openclaw browser trace stop(TRACE:<path>پرنٹ کرتا ہے)
JSON output¶
--json اسکرپٹنگ اور ساختی ٹولنگ کے لیے ہے۔
Examples:
openclaw browser status --json
openclaw browser snapshot --interactive --json
openclaw browser requests --filter api --json
openclaw browser cookies --json
JSON میں role snapshots میں refs کے ساتھ ایک چھوٹا stats بلاک (lines/chars/refs/interactive) شامل ہوتا ہے تاکہ ٹولز payload کے سائز اور کثافت پر غور کر سکیں۔
State and environment knobs¶
یہ “سائٹ کو X کی طرح برتاؤ کرو” والے ورک فلو کے لیے مفید ہیں:
- Cookies:
cookies,cookies set,cookies clear - Storage:
storage local|session get|set|clear - Offline:
set offline on|off - Headers:
set headers --json '{"X-Debug":"1"}'(یا--clear) - HTTP basic auth:
set credentials user pass(یا--clear) - Geolocation:
set geo <lat> <lon> --origin "https://example.com"(یا--clear) - Media:
set media dark|light|no-preference|none - Timezone / locale:
set timezone ...,set locale ... - Device / viewport:
set device "iPhone 14"(Playwright device presets)set viewport 1280 720
Security & privacy¶
- openclaw براؤزر پروفائل میں لاگ اِن سیشنز ہو سکتے ہیں؛ اسے حساس سمجھیں۔
browser act kind=evaluate/openclaw browser evaluateandwait --fnexecute arbitrary JavaScript in the page context. Prompt injection can steer this. Disable it withbrowser.evaluateEnabled=falseif you do not need it.- لاگ اِنز اور anti-bot نوٹس (X/Twitter وغیرہ) کے لیے دیکھیں Browser login + X/Twitter posting۔
- Gateway/node host کو نجی رکھیں (loopback یا tailnet-only)۔
- Remote CDP endpoints طاقتور ہوتے ہیں؛ انہیں tunnel اور محفوظ رکھیں۔
Troubleshooting¶
Linux مخصوص مسائل (خصوصاً snap Chromium) کے لیے دیکھیں Browser troubleshooting۔
Agent tools + how control works¶
ایجنٹ کو براؤزر آٹومیشن کے لیے ایک ٹول ملتا ہے:
browser— status/start/stop/tabs/open/focus/close/snapshot/screenshot/navigate/act
How it maps:
browser snapshotایک مستحکم UI درخت (AI یا ARIA) لوٹاتا ہے۔browser actsnapshot کےrefIDs استعمال کر کے click/type/drag/select کرتا ہے۔browser screenshotپکسلز کیپچر کرتا ہے (پورا صفحہ یا عنصر)۔browserقبول کرتا ہے:profileنامی براؤزر پروفائل منتخب کرنے کے لیے (openclaw، chrome، یا remote CDP)۔target(sandbox|host|node) یہ منتخب کرنے کے لیے کہ براؤزر کہاں ہے۔- sandboxed سیشنز میں،
target: "host"کے لیےagents.defaults.sandbox.browser.allowHostControl=trueدرکار ہوتا ہے۔ - اگر
targetچھوڑ دیا جائے: sandboxed سیشنز بطورِ طے شدہsandbox، غیر sandbox سیشنز بطورِ طے شدہhostلیتے ہیں۔ - اگر براؤزر-قابل node منسلک ہو، تو ٹول خودکار طور پر اسی کی طرف روٹ کر سکتا ہے جب تک کہ آپ
target="host"یاtarget="node"پن نہ کریں۔
یہ ایجنٹ کو قابلِ پیش گوئی رکھتا ہے اور نازک selectors سے بچاتا ہے۔