Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/twitchlib/twitchlib
C# Twitch Chat, Whisper, API and PubSub Library. Allows for chatting, whispering, stream event subscription and channel/account modification. Supports everything that supports .NETStandard 2.0
https://github.com/twitchlib/twitchlib
api bot chat client csharp events pubsub twitch whisper
Last synced: 2 days ago
JSON representation
C# Twitch Chat, Whisper, API and PubSub Library. Allows for chatting, whispering, stream event subscription and channel/account modification. Supports everything that supports .NETStandard 2.0
- Host: GitHub
- URL: https://github.com/twitchlib/twitchlib
- Owner: TwitchLib
- License: mit
- Created: 2015-09-22T02:40:30.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-09-26T01:35:21.000Z (over 1 year ago)
- Last Synced: 2025-01-05T13:00:11.775Z (17 days ago)
- Topics: api, bot, chat, client, csharp, events, pubsub, twitch, whisper
- Homepage: https://twitchlib.github.io
- Size: 8.57 MB
- Stars: 852
- Watchers: 48
- Forks: 145
- Open Issues: 32
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
**PLEASE check the "Dev" build before doing a PR if master does not have a feature your looking for.**
## About
TwitchLib is a powerful C# library that allows for interaction with various Twitch services. Currently supported services are: chat and whisper, API's (v5(deprecated), helix, undocumented, and third party), PubSub event system, and Twitch Extensions. Below are the descriptions of the core components that make up TwitchLib.Talk directly with us on Discord. https://discord.gg/8NXaEyV
* **[TwitchLib.Client](https://github.com/TwitchLib/TwitchLib.Client)**: Handles chat and whisper Twitch services. Complete with a suite of events that fire for virtually every piece of data received from Twitch. Helper methods also exist for replying to whispers or fetching moderator lists.
* **[TwitchLib.Api](https://github.com/TwitchLib/TwitchLib.Api)**: Complete coverage of v5(deprecated), and Helix endpoints. The API is now a singleton class. This class allows fetching all publicly accessible data as well as modify Twitch services like profiles and streams.
* **[TwitchLib.PubSub](https://github.com/TwitchLib/TwitchLib.PubSub)**: Supports all documented Twitch PubSub topics as well as a few undocumented ones.
* **[TwitchLib.Extension](https://github.com/TwitchLib/TwitchLib.Extension)**: EBS implementation for validating requests, interacting with extension via PubSub and calling Extension endpoints.
* **[TwitchLib.Unity](https://github.com/TwitchLib/TwitchLib.Unity)**: Unity wrapper system for TwitchLib to allow easy usage of TwitchLib in Unity projects!
* **[TwitchLib.Webhook](https://github.com/TwitchLib/TwitchLib.Webhook)**: Implements ASP.NET Core Webhook Receiver with TwitchLib. [Requires DotNet Core 2.1+]## Features
* **TwitchLib.Client**:
* Send formatted or raw messages to Twitch
* Chat and Whisper command detection and parsing
* Helper methods
* Timeout, ban, unban users
* Change chat color and clear chat
* Invoke stream commercials and hosts
* Emote only, follower only, subscriber only, and slow mode
* Reply-to whisper support
* Handles chat and whisper events:
* Connected and Joined channel
* Channel and User state changed
* Message received/sent
* Whisper received/sent (Sending requires a known/verified bot)
* User joined/left
* Moderator joined/left
* New subscriptions and resubscriptions
* Hosting and raid detection
* Chat clear, user timeouts, user bans
* **TwitchLib.APi**:
* Supported Twitch API endpoints:**v5(deprecated)**, **Helix**
* Supported API sections:
* Badges, Bits, Blocks
* ChannelFeeds, Channels, Chat, Clips, Collections, Communities,
* Follows
* Games
* HypeTrain
* Ingests
* Root
* Search, Streams, Subscriptions
* Teams
* ThirdParty
* Moderator Lookup courtesy of 3v's [https://t.3v.fi](https://t.3v.fi)
* Twitch Authentication Flow courtesy of swiftyspiffy's [https://twitchtokengenerator.com/](https://twitchtokengenerator.com/)
* Undocumented
* ClipChat
* TwitchPrimeOffers
* ChannelHosts
* ChatProperties
* ChannelPanels
* CSMaps
* CSStreams
* RecentMessages
* Chatters
* RecentChannelEvents
* ChatUser
* UsernameAvailable
* User
* Videos
* Services
* **FollowerService**: Service for detection of new followers in somewhat real time.
* **LiveStreamMonitor**: Service for detecting when a channel goes online/offline in somewhat real time.
* **MessageThrottler**: Service to throttle chat messages to abide by Twitch use requirements.
* **TwitchLib.PubSub**:
* Supported topics:
* ChatModeratorActions
* BitsEvents
* VideoPlayback
* Whispers
* Subscriptions
* (Dev) Channel Points
* **TwitchLib.Extension**:
* Developed to be used as part of an EBS (extension back-end service) for a Twitch Extension.
* Perform API calls related to Extensions (create secret, revoke, channels using extension, etc.)
* Validation of requests to EBS using extension secret and JWT.
* Interact with extension via PubSub.## Documentation
#### Doxygen
For complete library documentation, view the doxygen docs here.
## Implementing
Below are basic examples of how to utilize each of the core components of TwitchLib. These are C# examples.
*NOTE: Twitchlib.API currently does not support Visual Basic. UPDATE: PR'd Visual Basic fix but requires testing by someone that uses it.*#### Twitchlib.Client - CSharp
```csharp
using System;
using TwitchLib.Client;
using TwitchLib.Client.Enums;
using TwitchLib.Client.Events;
using TwitchLib.Client.Extensions;
using TwitchLib.Client.Models;
using TwitchLib.Communication.Clients;
using TwitchLib.Communication.Models;namespace TestConsole
{
class Program
{
static void Main(string[] args)
{
Bot bot = new Bot();
Console.ReadLine();
}
}class Bot
{
TwitchClient client;
public Bot()
{
ConnectionCredentials credentials = new ConnectionCredentials("twitch_username", "access_token");
var clientOptions = new ClientOptions
{
MessagesAllowedInPeriod = 750,
ThrottlingPeriod = TimeSpan.FromSeconds(30)
};
WebSocketClient customClient = new WebSocketClient(clientOptions);
client = new TwitchClient(customClient);
client.Initialize(credentials, "channel");client.OnLog += Client_OnLog;
client.OnJoinedChannel += Client_OnJoinedChannel;
client.OnMessageReceived += Client_OnMessageReceived;
client.OnWhisperReceived += Client_OnWhisperReceived;
client.OnNewSubscriber += Client_OnNewSubscriber;
client.OnConnected += Client_OnConnected;client.Connect();
}
private void Client_OnLog(object sender, OnLogArgs e)
{
Console.WriteLine($"{e.DateTime.ToString()}: {e.BotUsername} - {e.Data}");
}
private void Client_OnConnected(object sender, OnConnectedArgs e)
{
Console.WriteLine($"Connected to {e.AutoJoinChannel}");
}
private void Client_OnJoinedChannel(object sender, OnJoinedChannelArgs e)
{
Console.WriteLine("Hey guys! I am a bot connected via TwitchLib!");
client.SendMessage(e.Channel, "Hey guys! I am a bot connected via TwitchLib!");
}private void Client_OnMessageReceived(object sender, OnMessageReceivedArgs e)
{
if (e.ChatMessage.Message.Contains("badword"))
client.TimeoutUser(e.ChatMessage.Channel, e.ChatMessage.Username, TimeSpan.FromMinutes(30), "Bad word! 30 minute timeout!");
}
private void Client_OnWhisperReceived(object sender, OnWhisperReceivedArgs e)
{
if (e.WhisperMessage.Username == "my_friend")
client.SendWhisper(e.WhisperMessage.Username, "Hey! Whispers are so cool!!");
}
private void Client_OnNewSubscriber(object sender, OnNewSubscriberArgs e)
{
if (e.Subscriber.SubscriptionPlan == SubscriptionPlan.Prime)
client.SendMessage(e.Channel, $"Welcome {e.Subscriber.DisplayName} to the substers! You just earned 500 points! So kind of you to use your Twitch Prime on this channel!");
else
client.SendMessage(e.Channel, $"Welcome {e.Subscriber.DisplayName} to the substers! You just earned 500 points!");
}
}
}
```#### Twitchlib.Client - Visual Basic
```vb
Imports System
Imports TwitchLib.Client
Imports TwitchLib.Client.Enums
Imports TwitchLib.Client.Events
Imports TwitchLib.Client.Extensions
Imports TwitchLib.Client.ModelsModule Module1
Sub Main()
Dim bot As New Bot()
Console.ReadLine()
End SubFriend Class Bot
Private client As TwitchClientPublic Sub New()
Dim credentials As New ConnectionCredentials("twitch_username", "Token")client = New TwitchClient()
client.Initialize(credentials, "Channel")AddHandler client.OnJoinedChannel, AddressOf onJoinedChannel
AddHandler client.OnMessageReceived, AddressOf onMessageReceived
AddHandler client.OnWhisperReceived, AddressOf onWhisperReceived
AddHandler client.OnNewSubscriber, AddressOf onNewSubscriber
AddHandler client.OnConnected, AddressOf Client_OnConnectedclient.Connect()
End Sub
Private Sub Client_OnConnected(ByVal sender As Object, ByVal e As OnConnectedArgs)
Console.WriteLine($"Connected to {e.AutoJoinChannel}")
End Sub
Private Sub onJoinedChannel(ByVal sender As Object, ByVal e As OnJoinedChannelArgs)
Console.WriteLine("Hey guys! I am a bot connected via TwitchLib!")
client.SendMessage(e.Channel, "Hey guys! I am a bot connected via TwitchLib!")
End SubPrivate Sub onMessageReceived(ByVal sender As Object, ByVal e As OnMessageReceivedArgs)
If e.ChatMessage.Message.Contains("badword") Then
client.TimeoutUser(e.ChatMessage.Channel, e.ChatMessage.Username, TimeSpan.FromMinutes(30), "Bad word! 30 minute timeout!")
End If
End Sub
Private Sub onWhisperReceived(ByVal sender As Object, ByVal e As OnWhisperReceivedArgs)
If e.WhisperMessage.Username = "my_friend" Then
client.SendWhisper(e.WhisperMessage.Username, "Hey! Whispers are so cool!!")
End If
End Sub
Private Sub onNewSubscriber(ByVal sender As Object, ByVal e As OnNewSubscriberArgs)
If e.Subscriber.SubscriptionPlan = SubscriptionPlan.Prime Then
client.SendMessage(e.Channel, $"Welcome {e.Subscriber.DisplayName} to the substers! You just earned 500 points! So kind of you to use your Twitch Prime on this channel!")
Else
client.SendMessage(e.Channel, $"Welcome {e.Subscriber.DisplayName} to the substers! You just earned 500 points!")
End If
End Sub
End ClassEnd Module
```For a complete list of TwitchClient events and calls, click here
#### Twitchlib.API - CSharp
Note: TwitchAPI is now a singleton class that needs to be instantiated with optional clientid and auth token. Please know that failure to provide at least a client id, and sometimes an access token will result in exceptions. v5(Deprecated) and Helix operate almost entirely on Twitch user id's. There are methods in all Twitch api versions to get corresponding usernames/userids.```csharp
using System.Collections.Generic;
using System.Threading.Tasks;using TwitchLib.Api;
using TwitchLib.Api.Helix.Models.Users;
using TwitchLib.Api.V5.Models.Subscriptions; //v5 Deprecatednamespace Example
{
class Program
{
private static TwitchAPI api;private void Main()
{
api = new TwitchAPI();
api.Settings.ClientId = "client_id";
api.Settings.AccessToken = "access_token"; // App Secret is not an Accesstoken
}private async Task ExampleCallsAsync()
{
//Gets a list of all the subscritions of the specified channel.
var allSubscriptions = await api.Helix.Subscriptions.GetBroadcasterSubscriptionsAsync("broadcasterID",null ,100 ,"accesstoken")//Get channels a specified user follows.
var userFollows = await api.Helix.Users.GetUsersFollowsAsync("user_id");//Get Specified Channel Follows
var channelFollowers = await api.Helix.Users.GetUsersFollowsAsync(fromId: "channel_id");//Returns a stream object if online, if channel is offline it will be null/empty.
var streams = await api.Helix.Streams.GetStreamsAsync(userIds: userIdsList); // Alternative: userLogins: userLoginsList//Update Channel Title/Game/Language/Delay - Only require 1 option here.
var request = new ModifyChannelInformationRequest(){GameId = "New_Game_Id", Title = "New stream title", BroadcasterLanguage = "New_Language", Delay = New_Delay};
await api.Helix.Channels.ModifyChannelInformationAsync("broadcaster_Id", request, "AccessToken");
}
}
}
```#### Twitchlib.API - Visual Basic
```vb
Imports System.Collections.Generic
Imports System.Threading.TasksImports TwitchLib.Api
Imports TwitchLib.Api.Models.Helix.Users.GetUsersFollows
Imports TwitchLib.Api.Models.Helix.Users.GetUsers
Imports TwitchLib.Api.Models.v5.Subscriptions // V5 deprecatedModule Module1
Public api As TwitchAPI
Sub Main()
api = New TwitchAPI()
api.Settings.ClientId = "Client_id"
api.Settings.AccessToken = "access_token" // App Secret is not an Accesstoken
streaming().Wait()
getchanfollows().Wait()
getusersubs().Wait()
getnumberofsubs().Wait()
getsubstochannel().Wait()
Console.ReadLine()
End SubPrivate Async Function getusersubs() As Task
'Checks subscription for a specific user and the channel specified.
Dim subscription As Subscription = Await api.Channels.v5.CheckChannelSubscriptionByUserAsync("channel_id", "user_id")
Console.WriteLine("User subed: " + subscription.User.Name.ToString)
End FunctionPrivate Async Function streaming() As Task
'shows if the channel is streaming or not (true/false)
Dim isStreaming As Boolean = Await api.Streams.v5.BroadcasterOnlineAsync("channel_id")
If isStreaming = True Then
Console.WriteLine("Streaming")
Else
Console.WriteLine("Not Streaming")
End If
End FunctionPrivate Async Function chanupdate() As Task
'Update Channel Title/Game
'not used this yet
Await api.Channels.v5.UpdateChannelAsync("channel_id", "New stream title", "Stronghold Crusader")
End FunctionPrivate Async Function getchanfollows() As Task
'Get Specified Channel Follows
Dim channelFollowers = Await api.Channels.v5.GetChannelFollowersAsync("channel_id")
Console.WriteLine(channelFollowers.Total.ToString)
End FunctionPrivate Async Function getchanuserfollow() As Task
'Get channels a specified user follows.
Dim userFollows As GetUsersFollowsResponse = Await api.Users.helix.GetUsersFollowsAsync("user_id")
Console.WriteLine(userFollows.TotalFollows.ToString)
End FunctionPrivate Async Function getnumberofsubs() As Task
'Get the number of subs to your channel
Dim numberofsubs = Await api.Channels.v5.GetChannelSubscribersAsync("channel_id")
Console.WriteLine(numberofsubs.Total.ToString)
End FunctionPrivate Async Function getsubstochannel() As Task
'Gets a list of all the subscritions of the specified channel.
Dim allSubscriptions As List(Of Subscription) = Await api.Channels.v5.GetAllSubscribersAsync("channel_id")
Dim num As Integer
For num = 0 To allSubscriptions.Count - 1
Console.WriteLine(allSubscriptions.Item(num).User.Name.ToString)
Next num
End FunctionEnd Module
```
For a complete list of TwitchAPI calls, click here
#### Twitchlib.PubSub
```csharp
using System;
using TwitchLib.PubSub;
using TwitchLib.PubSub.Events;namespace TwitchLibPubSubExample
{
class Program
{
private TwitchPubSub client;
static void Main(string[] args)
{
new Program().Run();
}
private void Run()
{
client = new TwitchPubSub();client.OnPubSubServiceConnected += onPubSubServiceConnected;
client.OnListenResponse += onListenResponse;
client.OnStreamUp += onStreamUp;
client.OnStreamDown += onStreamDown;client.ListenToVideoPlayback("channelUsername");
client.ListenToBitsEvents("channelTwitchID");
client.Connect();
Console.ReadLine(); // Quick fix to keep program from closing right away. ReadKey could also be used.
}
private void onPubSubServiceConnected(object sender, EventArgs e)
{
// SendTopics accepts an oauth optionally, which is necessary for some topics
client.SendTopics();
}
private void onListenResponse(object sender, OnListenResponseArgs e)
{
if (!e.Successful)
throw new Exception($"Failed to listen! Response: {e.Response}");
}private void onStreamUp(object sender, OnStreamUpArgs e)
{
Console.WriteLine($"Stream just went up! Play delay: {e.PlayDelay}, server time: {e.ServerTime}");
}private void onStreamDown(object sender, OnStreamDownArgs e)
{
Console.WriteLine($"Stream just went down! Server time: {e.ServerTime}");
}
}
}
```
For a complete list of TwitchPubSub functionality, click here#### TwitchLib.Extension
See the Extension README here.## Examples, Applications, Community Work, and Projects
*NOTE: Use these projects as a reference, they are NOT guaranteed to be up-to-date.*
*If you have any issues using these examples, please indicate what example you are referencing in the Issue or in Discord.*
- Recent commits in projects using TwitchLib: [Link](https://github.com/search?o=desc&q=twitchlib&s=indexed&type=Code)
- [Bacon_Donut](https://www.twitch.tv/bacon_donut)'s VOD on building a Twitch bot using TwitchLib: [twitch.tv/videos/115788601](https://www.twitch.tv/videos/115788601)
- Prom3theu5's Conan Exiles Dedicated Server Updater / Service - [Steam](http://steamcommunity.com/app/440900/discussions/6/133256240742484919/) [Github](https://steamcommunity.com/linkfilter/?url=https://github.com/prom3theu5/ConanExilesServerUpdater)
- Von Jan Suchotzki's German Video Tutorial Series - [His Website](http://www.lernmoment.de/csharp-tutorial-deutsch/twitch-client-architektur/) [Youtube](https://www.youtube.com/watch?v=N0OPTdTGgTI)
- DHSean's TwitchAutomator [Reddit](https://www.reddit.com/r/pcgaming/comments/4wfosp/ive_created_an_app_called_twitchautomator_which/) [Github](https://github.com/XenZibe/TwitchUpdater)
- Moerty's Avia Bot, a fully featured bot that is a good example of a built out bot: [https://github.com/Moerty/AivaBot](https://github.com/Moerty/AivaBot)
- [HardlyDifficult](https://www.twitch.tv/hardlydifficult)'s Chat Bot Creation VODs: [#1](https://www.twitch.tv/videos/141096702) [#2](https://www.twitch.tv/videos/141154684) [#3](https://www.twitch.tv/videos/141210422) [#4](https://www.twitch.tv/videos/141535267)
- Prom3theu5's TwitchBotBase - [github.com/prom3theu5/TwitchBotBase](https://github.com/prom3theu5/TwitchBotBase)
- Trump Academi's ASP.NET TwitchLib Implementation - [trumpacademi.com/day-9-twitch-bot-and-mvc-asp-net-implementing-twitchlib/](http://www.trumpacademi.com/day-9-twitch-bot-and-mvc-asp-net-implementing-twitchlib/)
- ubhkid's Zombie Twitch chat game/overlay - [reddit.com/r/Unity3D/comments/6ll10k/i_made_a_game_for_my_twitch_chat/](https://www.reddit.com/r/Unity3D/comments/6ll10k/i_made_a_game_for_my_twitch_chat/)
- FPH SpedV: Virtual Freight Company Tool - [sped-v.de](https://www.sped-v.de/)
- Foglio's Tera Custom Cooldowns - [Tera Custom Cooldowns](https://github.com/Foglio1024/Tera-custom-cooldowns)## Installation
### [NuGet](https://www.nuget.org/packages/TwitchLib/)
To install this library via NuGet via NuGet console, use:
```
Install-Package TwitchLib
```
and via Package Manager, simply search:
```
TwitchLib
```
You are also more than welcome to clone/fork this repo and build the library yourself!## Dependencies
* Newtonsoft.Json 7.0.1+ ([nuget link](https://www.nuget.org/packages/Newtonsoft.Json/7.0.1)) ([GitHub](https://github.com/JamesNK/Newtonsoft.Json))
* WebSocketSharp-NonPreRelease ([nuget link](https://www.nuget.org/packages/WebSocketSharp-NonPreRelease/)) ([GitHub](https://github.com/sta/websocket-sharp))## Contributors
* Cole ([swiftyspiffy](http://twitter.com/swiftyspiffy))
* SkyHuk ([SkyHukTV](http://twitter.com/SkyHukTV))
* Nadermane ([Nadermane](http://twitter.com/nadermane))
* BenWoodford ([BenWoodford](https://github.com/BenWoodford))
* igor523 ([igor523](https://github.com/igor523))
* jxlarrea ([jxlarrea](https://github.com/jxlarrea))
* GlitchHound ([GlitchHound](https://github.com/GlitchHound))
* Krutonium ([Krutonium](https://github.com/Krutonium))
* toffaste1337([toffaste1337](https://github.com/toffaste1337))
* Mr_Examed ([Mr_Examed](https://www.twitch.tv/mr_examed))
* XuluniX ([XuluniX](https://github.com/XuluniX))
* prom3theu5 ([prom3theu5](https://twitter.com/prom3theu5))
* Ethan Lu ([elu00](https://github.com/elu00))
* BeerHawk ([BeerHawk](https://github.com/BeerHawk))
* Syzuna ([Syzuna](https://github.com/Syzuna))
* LuckyNoS7evin ([luckynos7evin](https://twitch.tv/luckynos7evin))
* Peter Richter ([DumpsterDoofus](DumpsterDoofus))
* Mahsaap ([Mahsaap](https://twitter.com/mahsabludra))
* neon-sunset ([neon-sunset](https://github.com/neon-sunset))
* AoshiW ([AoshiW](https://github.com/AoshiW))
* JulanDeAlb ([JulanDeAlb](https://github.com/JulanDeAlb))
* GimliCZ ([GimliCZ](https://github.com/GimliCZ))
* Bukk94 ([Bukk94](https://github.com/Bukk94))## Credits and Other Project Licenses
* TwitchChatSharp - https://github.com/3ventic/TwitchChatSharp
* We used a good portion of the parsing in this project to improve our parsing. Special thanks to [@3ventic](https://3v.fi).## License
This project is available under the MIT license. See the LICENSE file for more info.
:)