Developer and self-hosted
Twitch
Supporto alla chat di Twitch tramite connessione IRC. OpenClaw si connette come utente Twitch (account bot) per ricevere e inviare messaggi nei canali.
Plugin incluso
Se usi una build precedente o un'installazione personalizzata che esclude Twitch, installa direttamente il pacchetto npm:
registro npm
openclaw plugins install @openclaw/twitchCheckout locale
openclaw plugins install ./path/to/local/twitch-pluginUsa il pacchetto senza vincoli per seguire l'attuale tag di rilascio ufficiale. Fissa una versione esatta solo quando hai bisogno di un'installazione riproducibile.
Dettagli: Plugins
Configurazione rapida (principiante)
Assicurati che il Plugin sia disponibile
Le versioni pacchettizzate correnti di OpenClaw lo includono già. Le installazioni precedenti/personalizzate possono aggiungerlo manualmente con i comandi sopra.
Crea un account bot Twitch
Crea un account Twitch dedicato per il bot (oppure usa un account esistente).
Genera le credenziali
- Seleziona Bot Token
- Verifica che gli scope
chat:readechat:writesiano selezionati - Copia Client ID e Access Token
Trova il tuo ID utente Twitch
Usa https://www.streamweasels.com/tools/convert-twitch-username-to-user-id/ per convertire un nome utente in un ID utente Twitch.
Configura il token
- Env:
OPENCLAW_TWITCH_ACCESS_TOKEN=...(solo account predefinito) - Oppure configurazione:
channels.twitch.accessToken
Se entrambi sono impostati, la configurazione ha la precedenza (il fallback env vale solo per l'account predefinito).
Avvia il Gateway
Avvia il Gateway con il canale configurato.
Configurazione minima:
{ channels: { twitch: { enabled: true, username: "openclaw", // Bot's Twitch account accessToken: "oauth:abc123...", // OAuth Access Token (or use OPENCLAW_TWITCH_ACCESS_TOKEN env var) clientId: "xyz789...", // Client ID from Token Generator channel: "vevisk", // Which Twitch channel's chat to join (required) allowFrom: ["123456789"], // (recommended) Your Twitch user ID only - get it from https://www.streamweasels.com/tools/convert-twitch-username-to-user-id/ }, },}Che cos'è
- Un canale Twitch posseduto dal Gateway.
- Routing deterministico: le risposte tornano sempre a Twitch.
- Ogni account viene mappato a una chiave di sessione isolata
agent:<agentId>:twitch:<accountName>. usernameè l'account del bot (chi si autentica),channelè la chat room a cui unirsi.
Configurazione (dettagliata)
Genera le credenziali
- Seleziona Bot Token
- Verifica che gli scope
chat:readechat:writesiano selezionati - Copia Client ID e Access Token
Configura il bot
Variabile env (solo account predefinito)
OPENCLAW_TWITCH_ACCESS_TOKEN=oauth:abc123...Configurazione
{ channels: { twitch: { enabled: true, username: "openclaw", accessToken: "oauth:abc123...", clientId: "xyz789...", channel: "vevisk", }, },}Se sono impostati sia env sia configurazione, la configurazione ha la precedenza.
Controllo degli accessi (consigliato)
{ channels: { twitch: { allowFrom: ["123456789"], // (recommended) Your Twitch user ID only }, },}Preferisci allowFrom per una allowlist rigida. Usa invece allowedRoles se vuoi un accesso basato sui ruoli.
Ruoli disponibili: "moderator", "owner", "vip", "subscriber", "all".
Aggiornamento del token (opzionale)
I token di Twitch Token Generator non possono essere aggiornati automaticamente: rigenerali quando scadono.
Per l'aggiornamento automatico del token, crea la tua applicazione Twitch in Twitch Developer Console e aggiungi alla configurazione:
{ channels: { twitch: { clientSecret: "your_client_secret", refreshToken: "your_refresh_token", }, },}Il bot aggiorna automaticamente i token prima della scadenza e registra gli eventi di aggiornamento.
Supporto multi-account
Usa channels.twitch.accounts con token per account. Consulta Configurazione per il pattern condiviso.
Esempio (un account bot in due canali):
{ channels: { twitch: { accounts: { channel1: { username: "openclaw", accessToken: "oauth:abc123...", clientId: "xyz789...", channel: "vevisk", }, channel2: { username: "openclaw", accessToken: "oauth:def456...", clientId: "uvw012...", channel: "secondchannel", }, }, }, },}Controllo degli accessi
Allowlist di ID utente (più sicura)
{ channels: { twitch: { accounts: { default: { allowFrom: ["123456789", "987654321"], }, }, }, },}Basato sui ruoli
{ channels: { twitch: { accounts: { default: { allowedRoles: ["moderator", "vip"], }, }, }, },}allowFrom è una allowlist rigida. Quando è impostata, sono consentiti solo quegli ID utente. Se vuoi un accesso basato sui ruoli, lascia allowFrom non impostato e configura invece allowedRoles.
Disabilita il requisito @mention
Per impostazione predefinita, requireMention è true. Per disabilitarlo e rispondere a tutti i messaggi:
{ channels: { twitch: { accounts: { default: { requireMention: false, }, }, }, },}Risoluzione dei problemi
Per prima cosa, esegui i comandi diagnostici:
openclaw doctoropenclaw channels status --probeIl bot non risponde ai messaggi
- Controlla il controllo degli accessi: assicurati che il tuo ID utente sia in
allowFrom, oppure rimuovi temporaneamenteallowFrome impostaallowedRoles: ["all"]per provare. - Controlla che il bot sia nel canale: il bot deve unirsi al canale specificato in
channel.
Problemi con il token
Errori "Failed to connect" o di autenticazione:
- Verifica che
accessTokensia il valore del token di accesso OAuth (in genere inizia con il prefissooauth:) - Controlla che il token abbia gli scope
chat:readechat:write - Se usi l'aggiornamento del token, verifica che
clientSecreterefreshTokensiano impostati
L'aggiornamento del token non funziona
Controlla nei log gli eventi di aggiornamento:
Using env token source for mybotAccess token refreshed for user 123456 (expires in 14400s)Se vedi "token refresh disabled (no refresh token)":
- Assicurati che
clientSecretsia fornito - Assicurati che
refreshTokensia fornito
Configurazione
Configurazione dell'account
usernamestringNome utente del bot.
accessTokenstringToken di accesso OAuth con chat:read e chat:write.
clientIdstringTwitch Client ID (da Token Generator o dalla tua app).
channelstringrequiredCanale a cui unirsi.
enabledbooleandefault: trueAbilita questo account.
clientSecretstringOpzionale: per l'aggiornamento automatico del token.
refreshTokenstringOpzionale: per l'aggiornamento automatico del token.
expiresInnumberScadenza del token in secondi.
obtainmentTimestampnumberTimestamp di ottenimento del token.
allowFromstring[]Allowlist di ID utente.
allowedRoles'Array<"moderator"requireMentionbooleandefault: trueRichiede @mention.
Opzioni del provider
channels.twitch.enabled- Abilita/disabilita l'avvio del canalechannels.twitch.username- Nome utente del bot (configurazione semplificata per account singolo)channels.twitch.accessToken- Token di accesso OAuth (configurazione semplificata per account singolo)channels.twitch.clientId- Twitch Client ID (configurazione semplificata per account singolo)channels.twitch.channel- Canale a cui unirsi (configurazione semplificata per account singolo)channels.twitch.accounts.<accountName>- Configurazione multi-account (tutti i campi account sopra)
Esempio completo:
{ channels: { twitch: { enabled: true, username: "openclaw", accessToken: "oauth:abc123...", clientId: "xyz789...", channel: "vevisk", clientSecret: "secret123...", refreshToken: "refresh456...", allowFrom: ["123456789"], allowedRoles: ["moderator", "vip"], accounts: { default: { username: "mybot", accessToken: "oauth:abc123...", clientId: "xyz789...", channel: "your_channel", enabled: true, clientSecret: "secret123...", refreshToken: "refresh456...", expiresIn: 14400, obtainmentTimestamp: 1706092800000, allowFrom: ["123456789", "987654321"], allowedRoles: ["moderator"], }, }, }, },}Azioni degli strumenti
L'agente può chiamare twitch con l'azione:
send- Invia un messaggio a un canale
Esempio:
{ action: "twitch", params: { message: "Hello Twitch!", to: "#mychannel", },}Sicurezza e operazioni
- Tratta i token come password — Non committare mai token in git.
- Usa l'aggiornamento automatico del token per bot a lunga esecuzione.
- Usa allowlist di ID utente invece dei nomi utente per il controllo degli accessi.
- Monitora i log per gli eventi di aggiornamento del token e lo stato della connessione.
- Limita al minimo gli scope dei token — Richiedi solo
chat:readechat:write. - Se sei bloccato: riavvia il Gateway dopo aver confermato che nessun altro processo possieda la sessione.
Limiti
- 500 caratteri per messaggio (suddivisi automaticamente ai confini delle parole).
- Il Markdown viene rimosso prima della suddivisione.
- Nessun rate limiting (usa i limiti di frequenza integrati di Twitch).
Correlati
- Routing dei canali — routing di sessione per i messaggi
- Panoramica dei canali — tutti i canali supportati
- Gruppi — comportamento delle chat di gruppo e gating delle mention
- Pairing — autenticazione DM e flusso di pairing
- Sicurezza — modello di accesso e rafforzamento