Slack
Socket rejimi (standart)
Tezkor sozlash (boshlovchilar uchun)
- Slack ilovasini yarating va Socket Mode ni yoqing.
- App Token (
xapp-...) va Bot Token (xoxb-...) yarating. - Tokenlarni OpenClaw uchun o‘rnating va gateway’ni ishga tushiring.
Sozlash
- https://api.slack.com/apps sahifasida Slack ilovasini (From scratch) yarating.
- Socket Mode → yoqing. So‘ng Basic Information → App-Level Tokens →
connections:writescope’i bilan Generate Token and Scopes ni tanlang. App Token (xapp-...) ni nusxalang. - OAuth & Permissions → bot token scope’larini qo‘shing (quyidagi manifestdan foydalaning). Install to Workspace tugmasini bosing. Bot User OAuth Token (
xoxb-...) ni nusxalang. - Ixtiyoriy: OAuth & Permissions → User Token Scopes qo‘shing (quyidagi faqat o‘qish ro‘yxatiga qarang). Ilovani qayta o‘rnating va User OAuth Token (
xoxp-...) ni nusxalang. - Event Subscriptions → hodisalarni yoqing va quyidagilarga obuna bo‘ling:
message.*(tahrirlar/o‘chirishlar/iplar oqimini o‘z ichiga oladi)app_mentionreaction_added,reaction_removedmember_joined_channel,member_left_channelchannel_renamepin_added,pin_removed
- Botni o‘qishi kerak bo‘lgan kanallarga taklif qiling.
channels.slack.slashCommanddan foydalansangiz, Slash Commands →/openclawyarating. Agar mahalliy buyruqlarni yoqsangiz, har bir ichki buyruq uchun bittadan slash command qo‘shing (/helpdagi nomlar bilan bir xil). Slack uchun mahalliy buyruqlar sukut bo‘yicha o‘chiq; faqatchannels.slack.commands.native: trueo‘rnatilganda yoqiladi (globalcommands.native="auto", bu Slack’ni o‘chiq qoldiradi).- App Home → foydalanuvchilar botga DM yozishi uchun Messages Tab ni yoqing.
name bilan channels.slack.accounts dan foydalaning. Umumiy namunani ko‘rish uchun gateway/configuration ga qarang.
OpenClaw konfiguratsiyasi (Socket rejimi)
Tokenlarni muhit o‘zgaruvchilari orqali o‘rnating (tavsiya etiladi):SLACK_APP_TOKEN=xapp-...SLACK_BOT_TOKEN=xoxb-...
Foydalanuvchi tokeni (ixtiyoriy)
OpenClaw o‘qish amallari (tarix, pinlar, reaksiyalar, emoji, a’zo ma’lumoti) uchun Slack foydalanuvchi tokenidan (xoxp-...) foydalanishi mumkin. Standart holatda bu faqat o‘qish rejimida qoladi: agar mavjud bo‘lsa, o‘qishlar foydalanuvchi tokenini afzal ko‘radi, yozishlar esa siz aniq ruxsat bermaguningizcha bot tokenidan foydalanadi. userTokenReadOnly: false bo‘lsa ham, yozishlar uchun bot tokeni mavjud bo‘lsa, u afzal bo‘lib qoladi.
Foydalanuvchi tokenlari konfiguratsiya faylida sozlanadi (env o‘zgaruvchilar qo‘llab-quvvatlanmaydi). Ko‘p akkauntli holatda channels.slack.accounts.<id> ni sozlang.userToken`.
Bot + app + foydalanuvchi tokenlari bilan misol:
Tokenlardan foydalanish
- O‘qish amallari (tarix, reaksiyalar ro‘yxati, pinlar ro‘yxati, emoji ro‘yxati, a’zo ma’lumoti, qidiruv) sozlangan bo‘lsa foydalanuvchi tokenini, aks holda bot tokenini afzal ko‘radi.
- Yozish amallari (xabar yuborish/tahrirlash/o‘chirish, reaksiyalar qo‘shish/o‘chirish, pinlash/pindan chiqarish, fayl yuklash) standart bo‘yicha bot tokenidan foydalanadi. Agar
userTokenReadOnly: falsebo‘lsa va bot tokeni mavjud bo‘lmasa, OpenClaw foydalanuvchi tokeniga o‘tadi.
Tarix konteksti
channels.slack.historyLimit(yokichannels.slack.accounts.*.historyLimit) so‘rovga qancha so‘nggi kanal/guruh xabarlari qo‘shilishini boshqaradi.messages.groupChat.historyLimitga qaytadi. O‘chirish uchun0ni o‘rnating (standart 50).
HTTP rejimi (Events API)
Gateway’ingiz Slack tomonidan HTTPS orqali ochiq bo‘lsa (odatda server joylashtirishlar uchun), HTTP webhook rejimidan foydalaning. HTTP rejimi umumiy so‘rov URL manzili bilan Events API + Interactivity + Slash Commands’dan foydalanadi.Sozlash (HTTP rejimi)
- Slack ilovasini yarating va Socket Mode ni o‘chiring (faqat HTTP’dan foydalansangiz ixtiyoriy).
- Basic Information → Signing Secret ni nusxalang.
- OAuth & Permissions → ilovani o‘rnating va Bot User OAuth Token (
xoxb-...) ni nusxalang. - Event Subscriptions → hodisalarni yoqing va Request URL ni gateway webhook yo‘liga o‘rnating (standart
/slack/events). - Interactivity & Shortcuts → yoqing va xuddi shu Request URL ni o‘rnating.
- Slash Commands → buyruqlaringiz uchun xuddi shu Request URL ni o‘rnating.
https://gateway-host/slack/events
OpenClaw konfiguratsiyasi (minimal)
channels.slack.accounts.<id> ni o‘rnating.mode = “http”va har bir akkaunt uchun noyobwebhookPath` taqdim eting, shunda har bir Slack ilovasi o‘z URL’iga ega bo‘ladi.
Manifest (ixtiyoriy)
Ilovani tez yaratish uchun ushbu Slack ilova manifestidan foydalaning (xohlasangiz nom/buyruqni moslang). Agar foydalanuvchi tokenini sozlamoqchi bo‘lsangiz, foydalanuvchi scope’larini qo‘shing.slash_commands yozuvini qo‘shing (/help ro‘yxatiga mos). channels.slack.commands.native bilan almashtiring.
Scope’lar (joriy va ixtiyoriy)
Slack’ning Conversations API turi bo‘yicha scope’langan: siz faqat haqiqatan ishlatadigan suhbat turlari (channels, groups, im, mpim) uchun scope’lar kerak. Umumiy ko‘rinish uchun qarang: https://docs.slack.dev/apis/web-api/using-the-conversations-api/Bot tokeni scope’lari (majburiy)
chat:write(chat.postMessageorqali xabar yuborish/yangilash/o‘chirish) https://docs.slack.dev/reference/methods/chat.postMessageim:write(conversations.openorqali foydalanuvchi DM’larini ochish) https://docs.slack.dev/reference/methods/conversations.openchannels:history,groups:history,im:history,mpim:historyhttps://docs.slack.dev/reference/methods/conversations.historychannels:read,groups:read,im:read,mpim:readhttps://docs.slack.dev/reference/methods/conversations.infousers:read(foydalanuvchini topish) https://docs.slack.dev/reference/methods/users.inforeactions:read,reactions:write(reactions.get/reactions.add) https://docs.slack.dev/reference/methods/reactions.get https://docs.slack.dev/reference/methods/reactions.addpins:read,pins:write(pins.list/pins.add/pins.remove) https://docs.slack.dev/reference/scopes/pins.read https://docs.slack.dev/reference/scopes/pins.writeemoji:read(emoji.list) https://docs.slack.dev/reference/scopes/emoji.readfiles:write(uploads viafiles.uploadV2) https://docs.slack.dev/messaging/working-with-files/#upload
User token scopes (optional, read-only by default)
Add these under User Token Scopes if you configurechannels.slack.userToken.
channels:history,groups:history,im:history,mpim:historychannels:read,groups:read,im:read,mpim:readusers:readreactions:readpins:reademoji:readsearch:read
Not needed today (but likely future)
mpim:write(only if we add group-DM open/DM start viaconversations.open)groups:write(only if we add private-channel management: create/rename/invite/archive)chat:write.public(only if we want to post to channels the bot isn’t in) https://docs.slack.dev/reference/scopes/chat.write.publicusers:read.email(only if we need email fields fromusers.info) https://docs.slack.dev/changelog/2017-04-narrowing-email-accessfiles:read(only if we start listing/reading file metadata)
Config
Slack uses Socket Mode only (no HTTP webhook server). Provide both tokens:SLACK_BOT_TOKENSLACK_APP_TOKEN
messages.ackReaction +
messages.ackReactionScope. Use messages.removeAckAfterReply to clear the
ack reaction after the bot replies.
Limits
- Outbound text is chunked to
channels.slack.textChunkLimit(default 4000). - Optional newline chunking: set
channels.slack.chunkMode="newline"to split on blank lines (paragraph boundaries) before length chunking. - Media uploads are capped by
channels.slack.mediaMaxMb(default 20).
Reply threading
By default, OpenClaw replies in the main channel. Usechannels.slack.replyToMode to control automatic threading:
| Mode | Behavior |
|---|---|
off | Default. Reply in main channel. Only thread if the triggering message was already in a thread. |
first | First reply goes to thread (under the triggering message), subsequent replies go to main channel. Useful for keeping context visible while avoiding thread clutter. |
all | All replies go to thread. Keeps conversations contained but may reduce visibility. |
slack sendMessage).
Per-chat-type threading
You can configure different threading behavior per chat type by settingchannels.slack.replyToModeByChatType:
direct: 1:1 DMs (Slackim)group: group DMs / MPIMs (Slackmpim)channel: standard channels (public/private)
replyToModeByChatType.<chatType>replyToMode- Provider default (
off)
channels.slack.dm.replyToMode is still accepted as a fallback for direct when no chat-type override is set.
Examples:
Thread DMs only:
Manual threading tags
For fine-grained control, use these tags in agent responses:[[reply_to_current]]— reply to the triggering message (start/continue thread).[[reply_to:<id>]]— reply to a specific message id.
Sessions + routing
- DMs share the
mainsession (like WhatsApp/Telegram). - Channels map to
agent:<agentId>:slack:channel:<channelId>sessions. - Slash commands use
agent:<agentId>:slack:slash:<userId>sessions (prefix configurable viachannels.slack.slashCommand.sessionPrefix). - If Slack doesn’t provide
channel_type, OpenClaw infers it from the channel ID prefix (D,C,G) and defaults tochannelto keep session keys stable. - Native command registration uses
commands.native(global default"auto"→ Slack off) and can be overridden per-workspace withchannels.slack.commands.native. Text commands require standalone/...messages and can be disabled withcommands.text: false. Slack slash commands are managed in the Slack app and are not removed automatically. Usecommands.useAccessGroups: falseto bypass access-group checks for commands. - Full command list + config: Slash commands
DM security (pairing)
- Default:
channels.slack.dm.policy="pairing"— unknown DM senders get a pairing code (expires after 1 hour). - Approve via:
openclaw pairing approve slack <code>. - To allow anyone: set
channels.slack.dm.policy="open"andchannels.slack.dm.allowFrom=["*"]. channels.slack.dm.allowFromaccepts user IDs, @handles, or emails (resolved at startup when tokens allow). The wizard accepts usernames and resolves them to ids during setup when tokens allow.
Group policy
channels.slack.groupPolicycontrols channel handling (open|disabled|allowlist).allowlistrequires channels to be listed inchannels.slack.channels.- If you only set
SLACK_BOT_TOKEN/SLACK_APP_TOKENand never create achannels.slacksection, the runtime defaultsgroupPolicytoopen. Addchannels.slack.groupPolicy,channels.defaults.groupPolicy, or a channel allowlist to lock it down. - The configure wizard accepts
#channelnames and resolves them to IDs when possible (public + private); if multiple matches exist, it prefers the active channel. - On startup, OpenClaw resolves channel/user names in allowlists to IDs (when tokens allow) and logs the mapping; unresolved entries are kept as typed.
- To allow no channels, set
channels.slack.groupPolicy: "disabled"(or keep an empty allowlist).
channels.slack.channels.<id> or channels.slack.channels.<name>):
allow: allow/deny the channel whengroupPolicy="allowlist".requireMention: mention gating for the channel.tools: kanal bo‘yicha ixtiyoriy asbob siyosati override’lari (allow/deny/alsoAllow).toolsBySender: kanal ichida jo‘natuvchi bo‘yicha ixtiyoriy asbob siyosati override’lari (kalitlar — jo‘natuvchi ID’lari/@handle’lar/email’lar;"*"wildcard qo‘llab-quvvatlanadi).allowBots: ushbu kanalda bot tomonidan yozilgan xabarlarga ruxsat berish (standart: false).users: kanal bo‘yicha ixtiyoriy foydalanuvchi allowlist.skills: ko‘nikmalar filtri (qoldirilsa = barcha ko‘nikmalar, bo‘sh = hech biri).systemPrompt: kanal uchun qo‘shimcha system prompt (mavzu/maqsad bilan birlashtiriladi).enabled:falseqilib o‘rnatsangiz kanal o‘chiriladi.
Yetkazib berish maqsadlari
Bularni cron/CLI yuborishlar bilan ishlating:user:<id>— DM’lar uchunchannel:<id>— kanallar uchun
Asbob harakatlari
Slack asbob harakatlarichannels.slack.actions.* orqali cheklanishi mumkin:
| Harakat guruhi | Standart | Eslatmalar |
|---|---|---|
| reaksiyalar | yoqilgan | Reaksiya qo‘shish + reaksiya ro‘yxati |
| xabarlar | yoqilgan | O‘qish/jo‘natish/tahrirlash/o‘chirish |
| pinlar | yoqilgan | Pin qo‘yish/olib tashlash/ro‘yxat |
| memberInfo | yoqilgan | A’zo ma’lumoti |
| emojiList | yoqilgan | Maxsus emoji ro‘yxati |
Xavfsizlik bo‘yicha eslatmalar
- Yozishlar sukut bo‘yicha bot tokenidan foydalanadi, shuning uchun holatni o‘zgartiruvchi harakatlar ilovaning bot ruxsatlari va identiteti doirasida qoladi.
userTokenReadOnly: falseni sozlash bot tokeni mavjud bo‘lmaganda yozish amallari uchun foydalanuvchi tokenidan foydalanishga ruxsat beradi, bu esa harakatlar o‘rnatgan foydalanuvchining kirish huquqlari bilan bajarilishini anglatadi. Foydalanuvchi tokenini yuqori darajada imtiyozli deb hisoblang va harakatlar uchun gate’lar hamda allowlist’larni qat’iy saqlang.- Agar foydalanuvchi-token yozishlarini yoqsangiz, foydalanuvchi tokenida kutilgan yozish scope’lari (
chat:write,reactions:write,pins:write,files:write) mavjudligiga ishonch hosil qiling, aks holda bu amallar bajarilmaydi.
Nosozliklarni bartaraf etish
Avval ushbu ketma-ketlikni ishga tushiring:- Ulangan, ammo kanalda javob yo‘q: kanal
groupPolicytomonidan bloklangan yokichannels.slack.channelsallowlist’ida yo‘q. - DM’lar e’tiborsiz qoldiriladi:
channels.slack.dm.policy="pairing"bo‘lganda jo‘natuvchi tasdiqlanmagan. - API xatolari (
missing_scope,not_in_channel, autentifikatsiya xatolari): bot/ilova tokenlari yoki Slack scope’lari to‘liq emas.
Eslatmalar
- Mention gate’lash
channels.slack.channelsorqali boshqariladi (requireMentionnitrueqilib qo‘ying);agents.list[].groupChat.mentionPatterns(yokimessages.groupChat.mentionPatterns) ham mention sifatida hisoblanadi. - Multi-agent override: set per-agent patterns on
agents.list[].groupChat.mentionPatterns. - Reaksiya bildirishnomalari
channels.slack.reactionNotificationsga amal qiladi (reactionAllowlistniallowlistrejimi bilan ishlating). - Bot-authored messages are ignored by default; enable via
channels.slack.allowBotsorchannels.slack.channels.<id>3. Ogohlantirish: Agar boshqa botlarga javob berishga ruxsat bersangiz (channels.slack.allowBots=trueyokichannels.slack.channels.<id> 4. .allowBots=true),requireMention,channels.slack.channels.<id> 5. .usersruxsat ro‘yxatlari va/yokiAGENTS.mdhamdaSOUL.md` dagi aniq himoya qoidalari bilan botdan-botga javob aylanishlarining oldini oling. -
- Slack vositasi uchun reaksiya olib tashlash semantikasi /tools/reactions da keltirilgan..allowBots=true
), prevent bot-to-bot reply loops withrequireMention,channels.slack.channels.<id>8. Telegram bot qo‘llab-quvvatlash holati, imkoniyatlari va sozlamalari
- Slack vositasi uchun reaksiya olib tashlash semantikasi /tools/reactions da keltirilgan..allowBots=true
-
- Telegram funksiyalari yoki webhooklar ustida ishlash
-
- Telegram