Canvas Plugin रिफैक्टर
Canvas कम उपयोग वाला और प्रयोगात्मक है। इसे कोर सुविधा नहीं, बल्कि बंडल किए गए Plugin के रूप में मानें। कोर सामान्य Gateway, Node, HTTP, प्रमाणीकरण, कॉन्फिगरेशन, और नेटिव-क्लाइंट प्लंबिंग रख सकता है, लेकिन Canvas-विशिष्ट व्यवहारextensions/canvas के अंतर्गत रहना चाहिए।
लक्ष्य
वर्तमान पेयर्ड-Node व्यवहार को सुरक्षित रखते हुए Canvas स्वामित्व कोextensions/canvas में ले जाएं:
- एजेंट-उन्मुख
canvasटूल Canvas Plugin द्वारा पंजीकृत होता है - Canvas Node कमांड केवल तब अनुमत होते हैं जब Canvas Plugin उन्हें पंजीकृत करता है
- A2UI होस्ट/स्रोत फ़ाइलें Canvas Plugin के अंतर्गत रहती हैं
- Canvas दस्तावेज़ मटेरियलाइज़ेशन Canvas Plugin के अंतर्गत रहता है
- CLI कमांड कार्यान्वयन Canvas Plugin के अंतर्गत रहता है, या Plugin-स्वामित्व वाले रनटाइम बैरल के माध्यम से प्रतिनिधि करता है
- दस्तावेज़ और Plugin इन्वेंटरी Canvas को प्रयोगात्मक और Plugin-समर्थित के रूप में वर्णित करते हैं
गैर-लक्ष्य
- इस रिफैक्टर में नेटिव ऐप Canvas UI को फिर से डिज़ाइन न करें।
- iOS, Android, या macOS से Canvas प्रोटोकॉल/क्लाइंट समर्थन न हटाएं, जब तक कोई अलग उत्पाद निर्णय यह न कहे कि Canvas हटाया जाना चाहिए।
- केवल Canvas के लिए व्यापक Plugin सेवा फ़्रेमवर्क न बनाएं, जब तक कम से कम एक अन्य बंडल किए गए Plugin को उसी सीम की आवश्यकता न हो।
वर्तमान ब्रांच स्थिति
पूर्ण:extensions/canvasमें बंडल किया गया Plugin पैकेज जोड़ा।extensions/canvas/openclaw.plugin.jsonजोड़ा।- एजेंट
canvasटूल कोsrc/agents/tools/canvas-tool.tsसेextensions/canvas/src/tool.tsमें ले जाया। src/agents/openclaw-tools.tsसेcreateCanvasToolका कोर पंजीकरण हटाया।- Canvas होस्ट कार्यान्वयन को
src/canvas-hostसेextensions/canvas/src/hostमें ले जाया। - परीक्षणों, पैकेजिंग, और बाहरी सार्वजनिक Canvas हेल्पर के लिए
extensions/canvas/runtime-api.tsको Plugin-स्वामित्व वाले संगतता बैरल के रूप में रखा। - Canvas दस्तावेज़ मटेरियलाइज़ेशन को
src/gateway/canvas-documents.tsसेextensions/canvas/src/documents.tsमें ले जाया। - Canvas CLI कार्यान्वयन और A2UI JSONL हेल्पर को
extensions/canvas/src/cli.tsमें ले जाया। - Canvas होस्ट URL और स्कोप्ड क्षमता हेल्पर को
extensions/canvas/srcमें ले जाया। - Canvas Node कमांड डिफ़ॉल्ट को हार्डकोडेड कोर सूचियों से हटाकर Plugin
nodeInvokePoliciesमें ले जाया। plugins.entries.canvas.config.hostपर Plugin-स्वामित्व वाला Canvas होस्ट कॉन्फिगरेशन जोड़ा।- Canvas और A2UI HTTP सर्विंग को Canvas Plugin HTTP रूट पंजीकरण के पीछे ले जाया।
- Plugin-स्वामित्व वाले HTTP रूट के लिए सामान्य Plugin WebSocket अपग्रेड डिस्पैच जोड़ा।
- Canvas-विशिष्ट Gateway होस्ट URL और Node क्षमता प्रमाणीकरण को सामान्य होस्टेड Plugin सतह और Node क्षमता हेल्पर से बदला।
- Plugin-स्वामित्व वाले होस्टेड मीडिया रिज़ॉल्वर जोड़े, ताकि Canvas दस्तावेज़ URL कोर द्वारा Canvas दस्तावेज़ आंतरिक भागों को इम्पोर्ट करने के बजाय Canvas Plugin के माध्यम से रिज़ॉल्व हों।
api.registerNodeCliFeature(...)जोड़ा, ताकि Canvas पैरेंट कमांड पाथ को मैन्युअल रूप से लिखे बिनाopenclaw nodes canvasको Plugin-स्वामित्व वाली Node सुविधा के रूप में घोषित कर सके।extensions/canvas/runtime-api.jsके उत्पादनsrc/**इम्पोर्ट हटाए।- A2UI बंडल स्रोत को
apps/shared/OpenClawKit/Tools/CanvasA2UIसेextensions/canvas/src/host/a2ui-appमें ले जाया। - A2UI बिल्ड/कॉपी कार्यान्वयन को
extensions/canvas/scriptsके अंतर्गत ले जाया और रूट बिल्ड वायरिंग को सामान्य बंडल किए गए-Plugin एसेट हुक से बदला। - रनटाइम लेगेसी शीर्ष-स्तरीय
canvasHostकॉन्फिगरेशन उपनाम हटाया। - Canvas डॉक्टर माइग्रेशन रखा, ताकि
openclaw doctor --fixपुरानेcanvasHostकॉन्फिगरेशन कोplugins.entries.canvas.config.hostमें फिर से लिखे। - Gateway प्रोटोकॉल v4 के पीछे पुराने-एजेंट Canvas प्रोटोकॉल संगतता हटाई। नेटिव क्लाइंट और Gateway अब केवल
pluginSurfaceUrls.canvasतथाnode.pluginSurface.refreshका उपयोग करते हैं; इस प्रयोगात्मक रिफैक्टर में अप्रचलितcanvasHostUrl,canvasCapability, औरnode.canvas.capability.refreshपाथ जानबूझकर असमर्थित है। - Canvas शामिल करने के लिए जनरेट की गई Plugin इन्वेंटरी अपडेट की।
docs/plugins/reference/canvas.mdपर Plugin संदर्भ दस्तावेज़ जोड़े।
apps/के अंतर्गत नेटिव ऐप Canvas हैंडलर अभी भी जानबूझकर Canvas Plugin सतह का उपयोग करते हैंapps/के अंतर्गत नेटिव ऐप Canvas प्रोटोकॉल/क्लाइंट हैंडलर- प्रकाशित आर्टिफैक्ट आउटपुट अभी भी पीछे-संगत रनटाइम लुकअप के लिए
dist/canvas-host/a2uiका उपयोग करता है, लेकिन कॉपी चरण अब Plugin-स्वामित्व वाला है
लक्षित आकार
extensions/canvas को इनका स्वामी होना चाहिए:
- Plugin मैनिफेस्ट और पैकेज मेटाडेटा
- एजेंट टूल पंजीकरण
- Node invoke कमांड नीति
- Canvas होस्ट और A2UI रनटाइम
- Canvas A2UI बंडल स्रोत और एसेट बिल्ड/कॉपी स्क्रिप्ट
- Canvas दस्तावेज़ निर्माण और एसेट रिज़ॉल्यूशन
- Canvas CLI कार्यान्वयन
- Canvas दस्तावेज़ पेज और Plugin इन्वेंटरी प्रविष्टि
- Plugin खोज और पंजीकरण
- सामान्य एजेंट टूल रजिस्ट्री
- सामान्य Node invoke नीति रजिस्ट्री
- सामान्य Gateway HTTP/प्रमाणीकरण और WebSocket अपग्रेड डिस्पैच
- सामान्य होस्टेड Plugin सतह URL रिज़ॉल्यूशन
- सामान्य होस्टेड मीडिया रिज़ॉल्वर पंजीकरण
- सामान्य Node क्षमता ट्रांसपोर्ट
- सामान्य कॉन्फिगरेशन प्लंबिंग
- सामान्य बंडल किए गए-Plugin एसेट हुक खोज
माइग्रेशन चरण
plugins.entries.canvas.config.hostको Plugin-स्वामित्व वाली कॉन्फिगरेशन सतह मानें।- दस्तावेज़ अपडेट करें, ताकि Canvas को प्रयोगात्मक बंडल किए गए Plugin के रूप में वर्णित किया जाए।
- केंद्रित Canvas परीक्षण, Plugin इन्वेंटरी जांच, Plugin SDK API जांच, और रनटाइम सीमाओं से प्रभावित बिल्ड/टाइप गेट चलाएं।
ऑडिट चेकलिस्ट
रिफैक्टर को पूर्ण कहने से पहले:rg "src/canvas-host|../canvas-host"कोई लाइव स्रोत इम्पोर्ट नहीं लौटाता।rg "canvas-tool|createCanvasTool" srcकोई कोर-स्वामित्व वाला Canvas टूल कार्यान्वयन नहीं पाता।rg "canvas.present|canvas.snapshot|canvas.a2ui" src/gatewayसामान्य Plugin नीति परीक्षणों के बाहर कोई हार्डकोडेड अनुमति-सूची डिफ़ॉल्ट नहीं पाता।rg "extensions/canvas/runtime-api" src --glob '!**/*.test.ts'खाली है।rg "canvas-documents" srcखाली है।rg "registerNodesCanvasCommands|nodes-canvas" srcखाली है; Canvas Plugin नेस्टेड Plugin CLI मेटाडेटा के माध्यम सेopenclaw nodes canvasपंजीकृत करता है।rg "createCanvasHostHandler|handleA2uiHttpRequest" src/gatewayकोई Gateway रनटाइम स्वामित्व नहीं लौटाता।rg "apps/shared/OpenClawKit/Tools/CanvasA2UI|canvas-a2ui-copy|extensions/canvas/src/host/a2ui" scripts .github package.jsonकेवल संगतता रैपर या Plugin-स्वामित्व वाले पाथ पाता है।pnpm plugins:inventory:checkपास होता है।pnpm plugin-sdk:api:checkपास होता है, या जनरेट की गई API बेसलाइन जानबूझकर अपडेट और समीक्षा की गई हैं।- लक्षित Canvas परीक्षण पास होते हैं।
- Canvas होस्ट/A2UI पाथ के लिए बदली-लेन परीक्षण पास होते हैं।
- PR बॉडी स्पष्ट रूप से कहती है कि Canvas प्रयोगात्मक और Plugin-समर्थित है।
सत्यापन कमांड
दोहराव के दौरान लक्षित स्थानीय जांचों का उपयोग करें:pnpm build चलाएं।