Skip to content

Latest commit

 

History

History
122 lines (87 loc) · 4.5 KB

README.md

File metadata and controls

122 lines (87 loc) · 4.5 KB

BitABit - Twitch Lib for C#


Main Branch Workflow .NET CORE 6.0 build - development Licensed under MIT Open Source Open for Contributions C#

BitABit is a Twitch library made in C# (.NET 6.0) for Twitch.TV!

Distributed under MIT License.

BE AWARE: THIS IS "OIDC AUTHORIZATION CODE GRANT FLOW" (check here): It means that BitABit has a buit-in server, so be careful about distribuite the application with your TWITCH APPLICATION SECRET TOKEN (this is secret and cannot be shared, lol)! We EXTREMLY RECOMMEND that you make YOUR OWN SERVER for authentication, and use only the other functions if you are going to use BitABit to create a production Client-side Application. If you gonna use BitABit for personal propouses or server-side then you are safe!

PS: In the nearest future i will make a Implicit Code Flow for C# and integrate in BitABit.

How to use

Initialize

  • Import BitABit DLL in references inside your project;
using BitABit;
//
Initialize.Keys("YOUR_APP_CLIENT_ID", "YOUR_APP_SECRET");

(i'm gonna use the above variables for all examples...)


Authentication (OIDC AUTHORIZATION CODE FLOW)

Code Auth

string[] scopes = {"moderator:read:followers", "moderator:read:chatters"};
Auth.RequestAuth(scopes:scopes, force_verify:false);
//output
string? token = auth.Token;
string? refresh_token = auth.Refresh_Token;
Console.WriteLine("Token: " + token);
Console.WriteLine("Refresh Token: " + refresh_token);

Token Validation

To verify if Token is Valid:

bool token_valid = await Auth.IsValidToken(access_token:token);
//output
if(token == false){
	Console.WriteLine("Token is not valid or is expired...");
}

Request New Token

To generate another access token (you need previous refresh token):

await Auth.RefreshToken(refresh_Token:refresh_token);
//output
string? token = auth.RToken;
string? refresh_token = auth.RRefresh_Token;
Console.WriteLine("New Token: " + token);
Console.WriteLine("New Refresh Token: " + refresh_token);

PS: If you try to revalidate using refresh token 2/3 times and operation fails, you probably need to ask user to repeat the RequestAuth() process, this happens because: User remove your app, User lost the refresh token for some reason or Twitch run into some error and she are forcing you to revalidate.

PSS: On a multi-thread app is highly recommended that you use 1 token for multiple requests instead of re-gen another one... Se more info about this here.


Chat

Connecting to a Twitch.tv Chat

//access_token is the same you generated in RequestAuth() or RefreshToken() function. 
await Chat.StartChat(nick:"YOUR_USER_NAME", access_token:token, channel:"CHANNEL_TO_CONNECT", debug:true);

Disconnecting from a Twitch.tv Chat

//true if disconnect has been successful, otherwise will give an error an return False.
if(await Chat.CloseChat()) {
	Console.WriteLine("GOOD JOB!");
}

PS: StartChat() already make login, and get the Twitch CAPS. Also set's the loop.

Get Last Message From Chat

var last_message = Chat.GetLastMessage();
//will return as a List<MESSAGE_PARSED>

Send a Normal Message in Chat User must be connected

await Chat.SendChatMessage("Hello World from BitABit!");

Chat [ EVENTS ]

Event ‘OnChatMessageReceived’
executes every time that a chat user sent a message

Chat.OnChatMessageReceived += Chat_OnChatMessageReceived;
private static void Chat_OnChatMessageReceived() {
    Console.WriteLine("New message received.");
    /* Do your stuff ... */
}

more comming soon...