> ## Documentation Index
> Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# बॉट लूप सुरक्षा

# बॉट लूप सुरक्षा

OpenClaw उन चैनलों पर दूसरे बॉट द्वारा लिखे गए संदेश स्वीकार कर सकता है जो `allowBots` का समर्थन करते हैं।
जब वह पथ सक्षम होता है, तो जोड़ी लूप सुरक्षा दो बॉट पहचानों को अनिश्चित काल तक
एक-दूसरे को जवाब देने से रोकती है।

यह गार्ड कोर इनबाउंड उत्तर रनर द्वारा लागू किया जाता है। प्रत्येक समर्थित चैनल
अपने इनबाउंड इवेंट को सामान्य तथ्यों में मैप करता है: खाता या स्कोप, बातचीत id,
भेजने वाले बॉट की id, और प्राप्तकर्ता बॉट की id। फिर कोर दोनों दिशाओं में प्रतिभागी
जोड़ी को ट्रैक करता है, स्लाइडिंग-विंडो बजट लागू करता है, और बजट पार हो जाने के बाद
कूलडाउन के दौरान उस जोड़ी को दबा देता है।

## डिफ़ॉल्ट

जब कोई चैनल बॉट-लिखित संदेशों को डिस्पैच तक पहुंचने देता है, तब जोड़ी लूप सुरक्षा सक्रिय होती है।
बिल्ट-इन डिफ़ॉल्ट हैं:

* `maxEventsPerWindow: 20` - कोई बॉट जोड़ी विंडो के भीतर 20 इवेंट का आदान-प्रदान कर सकती है
* `windowSeconds: 60` - स्लाइडिंग विंडो की लंबाई
* `cooldownSeconds: 60` - जोड़ी द्वारा बजट पार करने के बाद दमन समय

गार्ड सामान्य मानव-लिखित संदेशों, एकल-बॉट डिप्लॉयमेंट,
स्वयं-संदेश फ़िल्टरिंग, या बजट के भीतर रहने वाले एक-बारगी बॉट उत्तरों को प्रभावित नहीं करता।

## साझा डिफ़ॉल्ट कॉन्फ़िगर करें

हर समर्थित चैनल को समान बेसलाइन देने के लिए `channels.defaults.botLoopProtection` को एक बार सेट करें।
चैनल और खाता ओवरराइड अब भी अलग-अलग सतहों को ट्यून कर सकते हैं।

```json5 theme={"theme":{"light":"min-light","dark":"min-dark"}}
{
  channels: {
    defaults: {
      botLoopProtection: {
        maxEventsPerWindow: 20,
        windowSeconds: 60,
        cooldownSeconds: 60,
      },
    },
  },
}
```

`enabled: false` केवल तब सेट करें जब आपकी चैनल नीति जानबूझकर
स्वचालित दमन के बिना बॉट-से-बॉट बातचीत की अनुमति देती हो।

## प्रति चैनल या खाते के लिए ओवरराइड करें

समर्थित चैनल अपनी कॉन्फ़िग को साझा डिफ़ॉल्ट के ऊपर परतबद्ध करते हैं। प्राथमिकता क्रम है:

* `channels.<channel>.<room-or-space>.botLoopProtection`, जब चैनल प्रति-बातचीत ओवरराइड का समर्थन करता है
* `channels.<channel>.accounts.<account>.botLoopProtection`, जब चैनल खातों का समर्थन करता है
* `channels.<channel>.botLoopProtection`, जब चैनल शीर्ष-स्तरीय डिफ़ॉल्ट का समर्थन करता है
* `channels.defaults.botLoopProtection`
* बिल्ट-इन डिफ़ॉल्ट

```json5 theme={"theme":{"light":"min-light","dark":"min-dark"}}
{
  channels: {
    defaults: {
      botLoopProtection: {
        maxEventsPerWindow: 20,
      },
    },
    discord: {
      botLoopProtection: {
        maxEventsPerWindow: 8,
      },
      accounts: {
        molty: {
          allowBots: "mentions",
          botLoopProtection: {
            maxEventsPerWindow: 5,
            cooldownSeconds: 90,
          },
        },
      },
    },
    slack: {
      allowBots: "mentions",
      botLoopProtection: {
        maxEventsPerWindow: 8,
      },
    },
    matrix: {
      allowBots: "mentions",
      groups: {
        "!roomid:example.org": {
          botLoopProtection: {
            maxEventsPerWindow: 5,
          },
        },
      },
    },
    googlechat: {
      allowBots: true,
      groups: {
        "spaces/AAAA": {
          botLoopProtection: {
            maxEventsPerWindow: 5,
          },
        },
      },
    },
  },
}
```

## चैनल समर्थन

* Discord: मूल `author.bot` तथ्य, Discord खाते, चैनल, और बॉट जोड़ी द्वारा की किए गए।
* Slack: स्वीकार किए गए बॉट-लिखित संदेशों के लिए मूल `bot_id` तथ्य, Slack खाते, चैनल, और बॉट जोड़ी द्वारा की किए गए।
* Matrix: कॉन्फ़िगर किए गए Matrix बॉट खाते, Matrix खाते, रूम, और कॉन्फ़िगर की गई बॉट जोड़ी द्वारा की किए गए।
* Google Chat: स्वीकार किए गए बॉट-लिखित संदेशों के लिए मूल `sender.type=BOT` तथ्य, खाते, स्पेस, और बॉट जोड़ी द्वारा की किए गए।

वे चैनल जो भरोसेमंद इनबाउंड बॉट पहचान उजागर नहीं करते, अपने
सामान्य स्वयं-संदेश और एक्सेस-नीति फ़िल्टर का उपयोग जारी रखते हैं। उन्हें इस
गार्ड में तब तक ऑप्ट इन नहीं करना चाहिए जब तक वे बॉट जोड़ी में दोनों प्रतिभागियों की पहचान न कर सकें।

Plugin
कार्यान्वयन विवरणों के लिए [SDK रनटाइम](/hi/plugins/sdk-runtime#reusable-runtime-utilities) देखें।
