मल्टी-एजेंट Sandbox और Tools विन्यास
अवलोकन
मल्टी-एजेंट सेटअप में प्रत्येक एजेंट के पास अब अपना स्वयं का हो सकता है:- Sandbox विन्यास (
agents.list[].sandboxagents.defaults.sandboxको ओवरराइड करता है) - टूल प्रतिबंध (
tools.allow/tools.deny, तथाagents.list[].tools)
- पूर्ण एक्सेस वाला व्यक्तिगत सहायक
- सीमित टूल वाले परिवार/कार्य एजेंट
- sandbox में चलने वाले सार्वजनिक एजेंट
setupCommand sandbox.docker (वैश्विक या प्रति-एजेंट) के अंतर्गत आता है और कंटेनर बनने पर केवल एक बार चलता है।
प्रमाणीकरण प्रति-एजेंट है: प्रत्येक एजेंट अपने स्वयं के agentDir auth स्टोर से पढ़ता है, जो यहाँ स्थित है:
agentDir को एजेंट्स के बीच reuse न करें।
यदि आप creds साझा करना चाहते हैं, तो auth-profiles.json को दूसरे एजेंट के agentDir में कॉपी करें।
runtime पर sandboxing कैसे व्यवहार करता है, इसके लिए देखें Sandboxing।
“यह blocked क्यों है?” के debugging के लिए, देखें Sandbox vs Tool Policy vs Elevated और openclaw sandbox explain।
विन्यास उदाहरण
उदाहरण 1: व्यक्तिगत + प्रतिबंधित पारिवारिक एजेंट
mainएजेंट: होस्ट पर चलता है, पूर्ण टूल एक्सेसfamilyएजेंट: Docker में चलता है (प्रति एजेंट एक कंटेनर), केवलreadटूल
उदाहरण 2: साझा Sandbox के साथ कार्य एजेंट
उदाहरण 2b: वैश्विक कोडिंग प्रोफ़ाइल + केवल मैसेजिंग एजेंट
- डिफ़ॉल्ट एजेंटों को कोडिंग टूल मिलते हैं
supportएजेंट केवल मैसेजिंग के लिए है (+ Slack टूल)
उदाहरण 3: प्रति एजेंट अलग Sandbox मोड
विन्यास की प्राथमिकता
जब वैश्विक (agents.defaults.*) और एजेंट-विशिष्ट (agents.list[].*) दोनों विन्यास मौजूद हों:
Sandbox विन्यास
एजेंट-विशिष्ट सेटिंग्स वैश्विक को ओवरराइड करती हैं:- उस एजेंट के लिए
agents.list[].sandbox.{docker,browser,prune}.*,agents.defaults.sandbox.{docker,browser,prune}.*को ओवरराइड करता है (जब sandbox स्कोप"shared"पर रेज़ॉल्व होता है, तब अनदेखा किया जाता है)।
टूल प्रतिबंध
फ़िल्टरिंग क्रम इस प्रकार है:- टूल प्रोफ़ाइल (
tools.profileयाagents.list[].tools.profile) - प्रदाता टूल प्रोफ़ाइल (
tools.byProvider[provider].profileयाagents.list[].tools.byProvider[provider].profile) - वैश्विक टूल नीति (
tools.allow/tools.deny) - प्रदाता टूल नीति (
tools.byProvider[provider].allow/deny) - एजेंट-विशिष्ट टूल नीति (
agents.list[].tools.allow/deny) - एजेंट प्रदाता नीति (
agents.list[].tools.byProvider[provider].allow/deny) - Sandbox टूल नीति (
tools.sandbox.toolsयाagents.list[].tools.sandbox.tools) - सबएजेंट टूल नीति (
tools.subagents.tools, यदि लागू हो)
agents.list[].tools.sandbox.tools सेट है, तो यह उस एजेंट के लिए tools.sandbox.tools को replace करता है।
यदि agents.list[].tools.profile सेट है, तो यह उस एजेंट के लिए tools.profile को override करता है।
Provider टूल keys provider (जैसे google-antigravity) या provider/model (जैसे openai/gpt-5.2) में से किसी को भी स्वीकार करती हैं।
टूल समूह (शॉर्टहैंड)
टूल नीतियाँ (वैश्विक, एजेंट, sandbox)group:* प्रविष्टियों का समर्थन करती हैं, जो कई ठोस टूल्स में विस्तारित होती हैं:
group:runtime:exec,bash,processgroup:fs:read,write,edit,apply_patchgroup:sessions:sessions_list,sessions_history,sessions_send,sessions_spawn,session_statusgroup:memory:memory_search,memory_getgroup:ui:browser,canvasgroup:automation:cron,gatewaygroup:messaging:messagegroup:nodes:nodesgroup:openclaw: सभी अंतर्निहित OpenClaw टूल्स (प्रदाता प्लगइन्स शामिल नहीं)
Elevated मोड
tools.elevated global baseline है (sender-based allowlist)। agents.list[].tools.elevated specific एजेंट्स के लिए elevated को और सीमित कर सकता है (दोनों को allow करना होगा)।
निवारण पैटर्न:
- अविश्वसनीय एजेंटों के लिए
execको अस्वीकार करें (agents.list[].tools.deny: ["exec"]) - ऐसे प्रेषकों को allowlist करने से बचें जो प्रतिबंधित एजेंटों तक रूट होते हों
- यदि आप केवल sandboxed निष्पादन चाहते हैं, तो वैश्विक रूप से elevated अक्षम करें (
tools.elevated.enabled: false) - संवेदनशील प्रोफ़ाइल के लिए प्रति एजेंट elevated अक्षम करें (
agents.list[].tools.elevated.enabled: false)
सिंगल एजेंट से माइग्रेशन
पहले (सिंगल एजेंट):agent.* विन्यासों को openclaw doctor द्वारा माइग्रेट किया जाता है; आगे के लिए agents.defaults + agents.list को प्राथमिकता दें।
टूल प्रतिबंध उदाहरण
केवल-पठन एजेंट
सुरक्षित निष्पादन एजेंट (फ़ाइल संशोधन नहीं)
केवल-संचार एजेंट
सामान्य समस्या: “non-main”
agents.defaults.sandbox.mode: "non-main" session.mainKey (default "main") पर आधारित है,
agent id पर नहीं। Group/channel sessions को हमेशा अपने अलग keys मिलते हैं, इसलिए उन्हें non-main माना जाता है और वे sandboxed होंगे। यदि आप चाहते हैं कि कोई एजेंट कभी
sandbox न हो, तो agents.list[].sandbox.mode: "off" सेट करें।
परीक्षण
मल्टी-एजेंट sandbox और tools कॉन्फ़िगर करने के बाद:-
एजेंट रेज़ॉल्यूशन जाँचें:
-
Sandbox कंटेनरों की पुष्टि करें:
-
टूल प्रतिबंधों का परीक्षण करें:
- ऐसे संदेश भेजें जिनमें प्रतिबंधित टूल्स की आवश्यकता हो
- सत्यापित करें कि एजेंट अस्वीकृत टूल्स का उपयोग नहीं कर सकता
-
लॉग्स की निगरानी करें:
समस्या-निवारण
mode: "all" के बावजूद एजेंट sandboxed नहीं है
- जाँचें कि कहीं कोई वैश्विक
agents.defaults.sandbox.modeतो नहीं है जो इसे ओवरराइड कर रहा हो - एजेंट-विशिष्ट विन्यास को प्राथमिकता मिलती है, इसलिए
agents.list[].sandbox.mode: "all"सेट करें
deny सूची के बावजूद टूल उपलब्ध हैं
- टूल फ़िल्टरिंग क्रम जाँचें: वैश्विक → एजेंट → sandbox → सबएजेंट
- प्रत्येक स्तर केवल और अधिक प्रतिबंधित कर सकता है, वापस अनुमति नहीं दे सकता
- लॉग्स से सत्यापित करें:
[tools] filtering tools for agent:${agentId}
प्रति एजेंट कंटेनर पृथक नहीं है
- एजेंट-विशिष्ट sandbox विन्यास में
scope: "agent"सेट करें - डिफ़ॉल्ट
"session"है, जो प्रति सत्र एक कंटेनर बनाता है