Status: meegeleverde Plugin (bottoken + WebSocket-gebeurtenissen). Kanalen, groepen en DM’s worden ondersteund. Mattermost is een zelf te hosten platform voor teambberichten; zie de officiële site op mattermost.com voor productdetails en downloads.Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Meegeleverde Plugin
Mattermost wordt in huidige OpenClaw-releases meegeleverd als Plugin, dus normale verpakte builds hebben geen aparte installatie nodig.
- npm-register
- Lokale checkout
Snelle installatie
Zorg dat de Plugin beschikbaar is
Huidige verpakte OpenClaw-releases leveren deze al mee. Oudere/aangepaste installaties kunnen deze handmatig toevoegen met de bovenstaande opdrachten.
Native slash-commando’s
Native slash-commando’s zijn opt-in. Wanneer ze zijn ingeschakeld, registreert OpenClawoc_* slash-commando’s via de Mattermost-API en ontvangt callback-POSTs op de Gateway-HTTP-server.
Gedragsnotities
Gedragsnotities
native: "auto"is standaard uitgeschakeld voor Mattermost. Stelnative: truein om dit in te schakelen.- Als
callbackUrlis weggelaten, leidt OpenClaw er een af uit de Gateway-host/poort +callbackPath. - Voor setups met meerdere accounts kan
commandsop het hoogste niveau worden ingesteld of onderchannels.mattermost.accounts.<id>.commands(accountwaarden overschrijven velden op het hoogste niveau). - Commandocallbacks worden gevalideerd met de tokens per commando die Mattermost retourneert wanneer OpenClaw
oc_*-commando’s registreert. - Slash-callbacks falen gesloten wanneer registratie is mislukt, opstarten gedeeltelijk was, of de callbacktoken niet overeenkomt met een van de geregistreerde commando’s.
Bereikbaarheidsvereiste
Bereikbaarheidsvereiste
Het callback-eindpunt moet bereikbaar zijn vanaf de Mattermost-server.
- Stel
callbackUrlniet in oplocalhost, tenzij Mattermost op dezelfde host/netwerknamespace draait als OpenClaw. - Stel
callbackUrlniet in op je Mattermost-basis-URL, tenzij die URL/api/channels/mattermost/commandvia een reverse proxy naar OpenClaw doorstuurt. - Een snelle controle is
curl https://<gateway-host>/api/channels/mattermost/command; een GET moet405 Method Not Allowedvan OpenClaw retourneren, niet404.
Mattermost-uitgaande allowlist
Mattermost-uitgaande allowlist
Als je callback privé-/tailnet-/interne adressen target, stel dan Mattermost
ServiceSettings.AllowedUntrustedInternalConnections zo in dat de callbackhost/het callbackdomein is opgenomen.Gebruik host-/domeinvermeldingen, geen volledige URL’s.- Goed:
gateway.tailnet-name.ts.net - Fout:
https://gateway.tailnet-name.ts.net
Omgevingsvariabelen (standaardaccount)
Stel deze in op de Gateway-host als je de voorkeur geeft aan env-vars:MATTERMOST_BOT_TOKEN=...MATTERMOST_URL=https://chat.example.com
Env-vars gelden alleen voor het standaardaccount (
default). Andere accounts moeten configuratiewaarden gebruiken.MATTERMOST_URL kan niet worden ingesteld vanuit een workspace-.env; zie Workspace-.env-bestanden.Chatmodi
Mattermost reageert automatisch op DM’s. Kanaalgedrag wordt beheerd doorchatmode:
- oncall (standaard)
- onmessage
- onchar
Reageer alleen wanneer er in kanalen een @mention is.
oncharreageert nog steeds op expliciete @mentions.channels.mattermost.requireMentionwordt gerespecteerd voor legacy-configuraties, maarchatmodeheeft de voorkeur.
Threads en sessies
Gebruikchannels.mattermost.replyToMode om te bepalen of kanaal- en groepsantwoorden in het hoofdkanaal blijven of een thread starten onder de activerende post.
off(standaard): antwoord alleen in een thread wanneer de inkomende post er al in staat.first: start voor posts op het hoogste niveau in kanalen/groepen een thread onder die post en routeer het gesprek naar een thread-scoped sessie.all: hetzelfde gedrag alsfirstvoor Mattermost vandaag.- Directe berichten negeren deze instelling en blijven zonder thread.
- Thread-scoped sessies gebruiken de ID van de activerende post als threadroot.
firstenallzijn momenteel equivalent, omdat vervolgchunks en media in dezelfde thread doorgaan zodra Mattermost een threadroot heeft.
Toegangscontrole (DM’s)
- Standaard:
channels.mattermost.dmPolicy = "pairing"(onbekende afzenders krijgen een koppelingscode). - Goedkeuren via:
openclaw pairing list mattermostopenclaw pairing approve mattermost <CODE>
- Openbare DM’s:
channels.mattermost.dmPolicy="open"pluschannels.mattermost.allowFrom=["*"].
Kanalen (groepen)
- Standaard:
channels.mattermost.groupPolicy = "allowlist"(mention-gated). - Zet afzenders op de allowlist met
channels.mattermost.groupAllowFrom(gebruikers-ID’s aanbevolen). - Mentionsoverschrijvingen per kanaal staan onder
channels.mattermost.groups.<channelId>.requireMentionofchannels.mattermost.groups["*"].requireMentionvoor een standaardwaarde. @username-matching is veranderlijk en alleen ingeschakeld wanneerchannels.mattermost.dangerouslyAllowNameMatching: true.- Open kanalen:
channels.mattermost.groupPolicy="open"(mention-gated). - Runtimenotitie: als
channels.mattermostvolledig ontbreekt, valt runtime terug opgroupPolicy="allowlist"voor groepscontroles (zelfs alschannels.defaults.groupPolicyis ingesteld).
Targets voor uitgaande aflevering
Gebruik deze targetformaten metopenclaw message send of cron/webhooks:
channel:<id>voor een kanaaluser:<id>voor een DM@usernamevoor een DM (opgelost via de Mattermost-API)
DM-kanaalretry
Wanneer OpenClaw naar een Mattermost-DM-target stuurt en eerst het directe kanaal moet oplossen, probeert het standaard tijdelijke fouten bij het maken van directe kanalen opnieuw. Gebruikchannels.mattermost.dmChannelRetry om dat gedrag globaal voor de Mattermost-Plugin af te stemmen, of channels.mattermost.accounts.<id>.dmChannelRetry voor één account.
- Dit geldt alleen voor het maken van DM-kanalen (
/api/v4/channels/direct), niet voor elke Mattermost-API-aanroep. - Retries gelden voor tijdelijke fouten zoals rate limits, 5xx-responses en netwerk- of timeoutfouten.
- 4xx-clientfouten anders dan
429worden als permanent behandeld en worden niet opnieuw geprobeerd.
Previewstreaming
Mattermost streamt denkwerk, toolactiviteit en gedeeltelijke antwoordtekst naar één conceptpreviewpost die ter plekke wordt afgerond wanneer het definitieve antwoord veilig kan worden verzonden. De preview wordt bijgewerkt op dezelfde post-ID in plaats van het kanaal te spammen met berichten per chunk. Media-/foutfinals annuleren openstaande previewbewerkingen en gebruiken normale aflevering in plaats van een wegwerppreviewpost te flushen. Inschakelen viachannels.mattermost.streaming:
Streamingmodi
Streamingmodi
partialis de gebruikelijke keuze: één previewpost die wordt bewerkt terwijl het antwoord groeit, en daarna wordt afgerond met het volledige antwoord.blockgebruikt conceptchunks in append-stijl binnen de previewpost.progresstoont een statuspreview tijdens het genereren en plaatst het definitieve antwoord pas na voltooiing.offschakelt previewstreaming uit.
Notities over streaminggedrag
Notities over streaminggedrag
- Als de stream niet ter plekke kan worden afgerond (bijvoorbeeld omdat de post halverwege de stream is verwijderd), valt OpenClaw terug op het sturen van een nieuwe definitieve post zodat het antwoord nooit verloren gaat.
- Payloads met alleen redenering worden onderdrukt in kanaalposts, inclusief tekst die binnenkomt als een
> Reasoning:-blockquote. Stel/reasoning onin om denkwerk in andere oppervlakken te zien; de definitieve Mattermost-post behoudt alleen het antwoord. - Zie Streaming voor de kanaalmappingmatrix.
Reacties (berichttool)
- Gebruik
message action=reactmetchannel=mattermost. messageIdis de Mattermost-post-ID.emojiaccepteert namen zoalsthumbsupof:+1:(dubbele punten zijn optioneel).- Stel
remove=true(booleaans) in om een reactie te verwijderen. - Gebeurtenissen voor toevoegen/verwijderen van reacties worden als systeemgebeurtenissen doorgestuurd naar de gerouteerde agentsessie.
channels.mattermost.actions.reactions: schakel reactieacties in/uit (standaard true).- Overschrijving per account:
channels.mattermost.accounts.<id>.actions.reactions.
Interactieve knoppen (berichttool)
Stuur berichten met klikbare knoppen. Wanneer een gebruiker op een knop klikt, ontvangt de agent de selectie en kan reageren. Schakel knoppen in doorinlineButtons toe te voegen aan de kanaalcapabilities:
message action=send met een buttons-parameter. Knoppen zijn een 2D-array (rijen met knoppen):
Weergavelabel.
Waarde die bij klikken wordt teruggestuurd (gebruikt als de actie-ID).
Knopstijl.
Knoppen vervangen door bevestiging
Alle knoppen worden vervangen door een bevestigingsregel (bijv. ”✓ Ja geselecteerd door @user”).
Implementatieopmerkingen
Implementatieopmerkingen
- Button-callbacks gebruiken HMAC-SHA256-verificatie (automatisch, geen configuratie nodig).
- Mattermost verwijdert callbackgegevens uit de API-responses (beveiligingsfunctie), dus alle knoppen worden bij een klik verwijderd — gedeeltelijke verwijdering is niet mogelijk.
- Actie-ID’s met koppeltekens of underscores worden automatisch opgeschoond (routeringsbeperking van Mattermost).
Configuratie en bereikbaarheid
Configuratie en bereikbaarheid
channels.mattermost.capabilities: array met capability-strings. Voeg"inlineButtons"toe om de beschrijving van de knoppentool in de systeemprompt van de agent in te schakelen.channels.mattermost.interactions.callbackBaseUrl: optionele externe basis-URL voor button-callbacks (bijvoorbeeldhttps://gateway.example.com). Gebruik dit wanneer Mattermost de Gateway niet rechtstreeks kan bereiken via de bind-host.- In multi-account-configuraties kun je hetzelfde veld ook instellen onder
channels.mattermost.accounts.<id>.interactions.callbackBaseUrl. - Als
interactions.callbackBaseUrlwordt weggelaten, leidt OpenClaw de callback-URL af uitgateway.customBindHost+gateway.porten valt daarna terug ophttp://localhost:<port>. - Bereikbaarheidsregel: de button-callback-URL moet bereikbaar zijn vanaf de Mattermost-server.
localhostwerkt alleen wanneer Mattermost en OpenClaw op dezelfde host/netwerknamespace draaien. - Als je callbackdoel privé/tailnet/intern is, voeg de host/het domein ervan toe aan Mattermost
ServiceSettings.AllowedUntrustedInternalConnections.
Directe API-integratie (externe scripts)
Externe scripts en Webhooks kunnen knoppen rechtstreeks plaatsen via de Mattermost REST API in plaats van via demessage-tool van de agent. Gebruik waar mogelijk buildButtonAttachments() uit de Plugin; volg deze regels als je raw JSON plaatst:
Payloadstructuur:
Leid het geheim af uit het bottoken
HMAC-SHA256(key="openclaw-mattermost-interactions", data=botToken)Serialiseer met gesorteerde sleutels
Serialiseer met gesorteerde sleutels en geen spaties (de Gateway gebruikt
JSON.stringify met gesorteerde sleutels, wat compacte output oplevert).Veelvoorkomende HMAC-valkuilen
Veelvoorkomende HMAC-valkuilen
- Python’s
json.dumpsvoegt standaard spaties toe ({"key": "val"}). Gebruikseparators=(",", ":")om overeen te komen met de compacte output van JavaScript ({"key":"val"}). - Onderteken altijd alle contextvelden (min
_token). De Gateway verwijdert_tokenen ondertekent daarna alles wat overblijft. Het ondertekenen van een subset veroorzaakt een stille verificatiefout. - Gebruik
sort_keys=True— de Gateway sorteert sleutels voor het ondertekenen, en Mattermost kan contextvelden opnieuw ordenen bij het opslaan van de payload. - Leid het geheim af uit het bottoken (deterministisch), niet uit willekeurige bytes. Het geheim moet hetzelfde zijn in het proces dat knoppen maakt en de Gateway die verifieert.
Directory-adapter
De Mattermost-Plugin bevat een directory-adapter die kanaal- en gebruikersnamen via de Mattermost API oplost. Dit maakt#channel-name- en @username-doelen mogelijk in openclaw message send en cron-/webhookleveringen.
Er is geen configuratie nodig — de adapter gebruikt het bottoken uit de accountconfiguratie.
Multi-account
Mattermost ondersteunt meerdere accounts onderchannels.mattermost.accounts:
Probleemoplossing
Geen antwoorden in kanalen
Geen antwoorden in kanalen
Zorg dat de bot in het kanaal zit en vermeld hem (oncall), gebruik een triggerprefix (onchar), of stel
chatmode: "onmessage" in.Auth- of multi-account-fouten
Auth- of multi-account-fouten
- Controleer het bottoken, de basis-URL en of het account is ingeschakeld.
- Multi-account-problemen: env-vars gelden alleen voor het
default-account.
Native slash-commands mislukken
Native slash-commands mislukken
Unauthorized: invalid command token.: OpenClaw heeft het callbacktoken niet geaccepteerd. Typische oorzaken:- registratie van slash-commands is mislukt of slechts gedeeltelijk voltooid bij het opstarten
- de callback raakt de verkeerde Gateway/het verkeerde account
- Mattermost heeft nog oude commands die naar een eerder callbackdoel wijzen
- de Gateway is opnieuw gestart zonder slash-commands opnieuw te activeren
- Als native slash-commands niet meer werken, controleer de logs op
mattermost: failed to register slash commandsofmattermost: native slash commands enabled but no commands could be registered. - Als
callbackUrlis weggelaten en logs waarschuwen dat de callback is opgelost naarhttp://127.0.0.1:18789/..., is die URL waarschijnlijk alleen bereikbaar wanneer Mattermost op dezelfde host/netwerknamespace draait als OpenClaw. Stel in plaats daarvan een expliciete extern bereikbarecommands.callbackUrlin.
Problemen met knoppen
Problemen met knoppen
- Knoppen verschijnen als witte vakken: de agent verzendt mogelijk misvormde knopgegevens. Controleer of elke knop zowel
text- alscallback_data-velden heeft. - Knoppen worden weergegeven, maar klikken doet niets: controleer of
AllowedUntrustedInternalConnectionsin de Mattermost-serverconfiguratie127.0.0.1 localhostbevat en ofEnablePostActionIntegrationtrueis in ServiceSettings. - Knoppen retourneren 404 bij klikken: de knop-
idbevat waarschijnlijk koppeltekens of underscores. De actierouter van Mattermost breekt op niet-alfanumerieke ID’s. Gebruik alleen[a-zA-Z0-9]. - Gateway-logt
invalid _token: HMAC komt niet overeen. Controleer of je alle contextvelden ondertekent (geen subset), gesorteerde sleutels gebruikt en compacte JSON gebruikt (geen spaties). Zie de HMAC-sectie hierboven. - Gateway-logt
missing _token in context: het veld_tokenstaat niet in de context van de knop. Zorg dat het wordt opgenomen bij het bouwen van de integratiepayload. - Bevestiging toont raw ID in plaats van knopnaam:
context.action_idkomt niet overeen met deidvan de knop. Stel beide in op dezelfde opgeschoonde waarde. - Agent weet niets van knoppen: voeg
capabilities: ["inlineButtons"]toe aan de Mattermost-kanaalconfiguratie.
Gerelateerd
- Kanaalroutering — sessieroutering voor berichten
- Overzicht van kanalen — alle ondersteunde kanalen
- Groepen — gedrag van groepschats en vermeldingsgating
- Koppeling — DM-authenticatie en koppelingsflow
- Beveiliging — toegangsmodel en hardening