- टेक्स्ट सेक्शन
- छोटा संदर्भ/फुटर टेक्स्ट
- डिवाइडर
- बटन
- चयन मेनू
- कार्ड शीर्षक और टोन
components, Slack
blocks, Telegram buttons, Teams card, या Feishu card जैसे नए provider-native फ़ील्ड न जोड़ें। ये channel plugin के स्वामित्व वाले renderer outputs हैं।
अनुबंध
Plugin लेखक public contract को यहां से import करते हैं:action.type: "command"core के command path के माध्यम से native slash command चलाता है। built-in command buttons और menus के लिए इसका उपयोग करें।action.type: "callback"channel के interaction path के माध्यम से opaque plugin data ले जाता है। Channel plugins को callback data को slash commands के रूप में दोबारा व्याख्यायित नहीं करना चाहिए।valuelegacy opaque callback value है। नए controls कोactionका उपयोग करना चाहिए ताकि channel plugins text से अनुमान लगाए बिना commands और callbacks को map कर सकें।urlएक link button है। यहvalueके बिना मौजूद हो सकता है।webAppchannel-native web app button का वर्णन करता है। Telegram इसेweb_appके रूप में render करता है और केवल private chats में इसका समर्थन करता है। compatibility के लिए loose JSON payloads मेंweb_appअभी भी स्वीकार किया जाता है, लेकिन TypeScript producers कोwebAppका उपयोग करना चाहिए।labelआवश्यक है और text fallback में भी उपयोग किया जाता है।styleadvisory है। Renderers को unsupported styles को सुरक्षित default पर map करना चाहिए, send को fail नहीं करना चाहिए।priorityवैकल्पिक है। जब कोई channel action limits advertise करता है और controls को हटाना पड़ता है, core पहले उच्च-priority buttons रखता है और समान priority वाले buttons के बीच मूल क्रम संरक्षित करता है। जब सभी controls fit होते हैं, authored order संरक्षित रहता है।disabledवैकल्पिक है। Channels कोsupportsDisabledके साथ opt in करना होगा; अन्यथा core disabled control को non-interactive fallback text में degrade करता है।reusableवैकल्पिक है। वे channels जो reusable native callbacks का समर्थन करते हैं, सफल interaction के बाद action को उपलब्ध रख सकते हैं। refresh, inspect, या अधिक details जैसी repeatable या idempotent actions के लिए इसका उपयोग करें; normal one-shot approvals और destructive actions के लिए इसे unset छोड़ें।
options[].actionका command/callback अर्थ buttonactionजैसा ही है।options[].valuelegacy selected application value है।placeholderadvisory है और native select support के बिना channels द्वारा अनदेखा किया जा सकता है।- यदि कोई channel selects का समर्थन नहीं करता, fallback text labels की सूची दिखाता है।
Producer उदाहरण
सरल कार्ड:Renderer अनुबंध
Channel plugins अपने outbound adapter पर render support declare करते हैं:limits generic envelope का वर्णन करते हैं जिसे core renderer को call करने से पहले adapt कर सकता है:
Core render flow
जब किसीReplyPayload या message action में presentation शामिल होता है, core:
- presentation payload को normalize करता है।
- target channel के outbound adapter को resolve करता है।
presentationCapabilitiesपढ़ता है।- adapter द्वारा advertise किए जाने पर action count, label length, और select option count जैसी generic capability limits लागू करता है।
- जब adapter payload को render कर सकता है,
renderPresentationcall करता है। - adapter अनुपस्थित होने या render न कर पाने पर conservative text पर fallback करता है।
- resulting payload को normal channel delivery path के माध्यम से भेजता है।
- पहली सफल sent message के बाद
delivery.pinजैसी delivery metadata लागू करता है।
Degradation rules
Presentation सीमित channels पर भेजने के लिए सुरक्षित होनी चाहिए। Fallback text में शामिल है:- पहली line के रूप में
title - normal paragraphs के रूप में
textblocks - compact context lines के रूप में
contextblocks - visual separator के रूप में
dividerblocks - button labels, link buttons के URLs सहित
- select option labels
- inline buttons disabled होने पर Telegram text fallback भेजता है।
- select support के बिना कोई channel select options को text के रूप में सूचीबद्ध करता है।
- केवल-URL button या तो native link button बनता है या fallback URL line।
- वैकल्पिक pin failures delivered message को fail नहीं करते।
delivery.pin.required: true है; यदि pinning को required के रूप में request किया गया है और channel sent message को pin नहीं कर सकता, तो delivery failure report करती है।
Provider mapping
वर्तमान bundled renderers:| Channel | Native render target | Notes |
|---|---|---|
| Discord | Components और component containers | मौजूदा provider-native payload producers के लिए legacy channelData.discord.components को संरक्षित करता है, लेकिन नए shared sends को presentation का उपयोग करना चाहिए। |
| Slack | Block Kit | मौजूदा provider-native payload producers के लिए legacy channelData.slack.blocks को संरक्षित करता है, लेकिन नए shared sends को presentation का उपयोग करना चाहिए। |
| Telegram | Text plus inline keyboards | Buttons/selects को target surface के लिए inline button capability चाहिए; अन्यथा text fallback उपयोग होता है। |
| Mattermost | Text plus interactive props | अन्य blocks text में degrade होते हैं। |
| Microsoft Teams | Adaptive Cards | जब दोनों प्रदान किए जाते हैं, plain message text card के साथ शामिल होता है। |
| Feishu | Interactive cards | Card header title का उपयोग कर सकता है; body उस title को duplicate करने से बचती है। |
| Plain channels | Text fallback | renderer के बिना channels को भी readable output मिलता है। |
प्रस्तुति बनाम InteractiveReply
InteractiveReply वह पुराना आंतरिक उपसमुच्चय है जिसका उपयोग अनुमोदन और इंटरैक्शन
हेल्पर करते हैं। यह समर्थन करता है:
- टेक्स्ट
- बटन
- चयन
MessagePresentation कैननिकल साझा भेजने का अनुबंध है। यह जोड़ता है:
- शीर्षक
- टोन
- संदर्भ
- विभाजक
- केवल-URL बटन
ReplyPayload.deliveryके माध्यम से सामान्य डिलीवरी मेटाडेटा
openclaw/plugin-sdk/interactive-runtime से हेल्पर उपयोग करें:
MessagePresentation स्वीकार या उत्पन्न करना चाहिए। मौजूदा
interactive पेलोड presentation का एक अप्रचलित उपसमुच्चय हैं; पुराने उत्पादकों के लिए रनटाइम
समर्थन बना रहता है।
पुराने InteractiveReply* प्रकार और रूपांतरण हेल्पर SDK में
@deprecated के रूप में चिह्नित हैं:
InteractiveReply,InteractiveReplyBlock,InteractiveReplyButton,InteractiveReplyOption,InteractiveReplySelectBlock, औरInteractiveReplyTextBlocknormalizeInteractiveReply(...)hasInteractiveReplyBlocks(...)interactiveReplyToPresentation(...)presentationToInteractiveReply(...)presentationToInteractiveControlsReply(...)resolveInteractiveTextFallback(...)reduceInteractiveReply(...)
presentationToInteractiveReply(...) और
presentationToInteractiveControlsReply(...) पुराने चैनल कार्यान्वयनों के लिए रेंडरर
ब्रिज के रूप में उपलब्ध रहते हैं। नए उत्पादक कोड को इन्हें कॉल नहीं करना चाहिए;
presentation भेजें और कोर/चैनल अनुकूलन को रेंडरिंग संभालने दें।
अनुमोदन हेल्पर में भी प्रस्तुति-प्रथम प्रतिस्थापन हैं:
buildApprovalInteractiveReplyFromActionDescriptors(...)के बजायbuildApprovalPresentationFromActionDescriptors(...)उपयोग करेंbuildApprovalInteractiveReply(...)के बजायbuildApprovalPresentation(...)उपयोग करेंbuildExecApprovalInteractiveReply(...)के बजायbuildExecApprovalPresentation(...)उपयोग करें
renderMessagePresentationFallbackText(...) उन प्रस्तुति ब्लॉक के लिए खाली स्ट्रिंग लौटाता है
जिनमें कोई टेक्स्ट फ़ॉलबैक नहीं होता, जैसे केवल-विभाजक प्रस्तुति।
ऐसे ट्रांसपोर्ट जिन्हें गैर-खाली भेजने का बॉडी चाहिए, डिफ़ॉल्ट फ़ॉलबैक
अनुबंध बदले बिना न्यूनतम बॉडी चुनने के लिए emptyFallback पास कर सकते हैं।
डिलीवरी पिन
पिन करना डिलीवरी व्यवहार है, प्रस्तुति नहीं।channelData.telegram.pin जैसे
प्रदाता-नेटिव फ़ील्ड के बजाय delivery.pin उपयोग करें।
अर्थ:
pin: trueपहले सफलतापूर्वक डिलीवर किए गए संदेश को पिन करता है।pin.notifyका डिफ़ॉल्टfalseहै।pin.requiredका डिफ़ॉल्टfalseहै।- वैकल्पिक पिन विफलताएं घटकर रह जाती हैं और भेजे गए संदेश को यथावत छोड़ती हैं।
- आवश्यक पिन विफलताएं डिलीवरी को विफल करती हैं।
- खंडित संदेश पहले डिलीवर किए गए खंड को पिन करते हैं, अंतिम खंड को नहीं।
pin, unpin, और pins संदेश क्रियाएं अभी भी उन मौजूदा
संदेशों के लिए मौजूद हैं जहां प्रदाता उन ऑपरेशन का समर्थन करता है।
Plugin लेखक चेकलिस्ट
- जब चैनल अर्थपूर्ण प्रस्तुति को रेंडर कर सकता हो या सुरक्षित रूप से घटा सकता हो, तब
describeMessageTool(...)सेpresentationघोषित करें। - रनटाइम आउटबाउंड एडेप्टर में
presentationCapabilitiesजोड़ें। - रनटाइम कोड में
renderPresentationलागू करें, कंट्रोल-प्लेन Plugin सेटअप कोड में नहीं। - नेटिव UI लाइब्रेरी को हॉट सेटअप/कैटलॉग पथों से बाहर रखें।
- ज्ञात होने पर
presentationCapabilities.limitsपर सामान्य क्षमता सीमाएं घोषित करें। - रेंडरर और परीक्षणों में अंतिम प्लेटफ़ॉर्म सीमाएं सुरक्षित रखें।
- असमर्थित बटन, चयन, URL बटन, शीर्षक/टेक्स्ट
डुप्लिकेशन, और मिश्रित
messageप्लसpresentationभेजने के लिए फ़ॉलबैक परीक्षण जोड़ें। deliveryCapabilities.pinऔरpinDeliveredMessageके माध्यम से डिलीवरी पिन समर्थन केवल तभी जोड़ें जब प्रदाता भेजे गए संदेश id को पिन कर सके।- साझा संदेश क्रिया स्कीमा के माध्यम से नए प्रदाता-नेटिव कार्ड/ब्लॉक/कंपोनेंट/बटन फ़ील्ड उजागर न करें।