定制 voniersa/twitch-live-chat 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

voniersa/twitch-live-chat

最新稳定版本:1.0.1

Composer 安装命令:

composer require voniersa/twitch-live-chat

包简介

A simple and easy to use library for reading from and writing to the twitch irc live chats by partially using the observer design pattern

README 文档

README

Unit tests

A simple and easy to use library for reading from and writing to the twitch irc live chats by partially using the observer design pattern.

With this library you can easily build your own twitch chatbot with PHP.

Requirements

PHP Version 8.2 or higher

How to use

You can install the library with composer:

composer require voniersa/twitch-live-chat

Functionalities

Firstly you have to create a new TwitchChatAdapter:

use voniersa\twitch\livechat\TwitchChatAdapter;
use voniersa\twitch\livechat\IrcConnector;
use voniersa\twitch\livechat\ConnectionVerifier;

$adapter = new TwitchChatAdapter(new IrcConnector(), new ConnectionVerifier());

With this Adapter you can open a connection to twitch live chats by executing the openConnection() function. This function needs the parameters

  • UserName - the username of your account which you want to use as your chatbot
  • Password - the authentication code of your chatbot account. You can get your oauth code at https://twitchtokengenerator.com/
  • ChannelCollection - a collection of all channels where your chatbot should be active. A channel always needs a # in front of the channel name

You can open multiple connections with different users and channels.

$connection = $adapter->openConnection(
    UserName::fromString("xxxxxx"),
    Password::fromString("oauth:xxxxxx"),
    ChannelCollection::fromArray([
        ChannelName::fromString("#xxxxxx"),
        ChannelName::fromString("#xxxxxx")
    ])
);

To this connection you can add as many observers as you want by executing the attach() function and later also the detach() function to remove an observer.

$exampleObserver = new ExampleObserver();
$connection->attach($exampleObserver);

$connection->detach($exampleObserver);

You have to write the Observers by yourself. For that simply create a new class which implements the MessageObserver interface. You need to add the Method update() with the parameter of type Message.

use voniersa\twitch\livechat\MessageObserver;

class ExampleObserver implements MessageObserver
{
    public function update(Message $message): void
    {
        // do here what ever you want ...
    }
}

This update() method gets called everytime when a message is written to the live chats. Here you can define what should happen if a message appears.

To actually start reading the chat simply call the function readLiveChat() of the Adapter. You need to provide the connection and a time after how many seconds the reading process should stop. The function returns a MessageCollection which contains all messages that are written to the chat in that time period:

$adapter->readLiveChat($connection, 30);

With this library you cannot only read from specific live chats. You can also write something to the chat by simply call the writeMessage() function.

$adapter->writeMessage($connection, ChannelName::fromString("#xxxxxx"), "This message is send to the live chat!");

Example

In the demo.php you can find a simple code snippet, how you can use this library.

To run this example script, execute the following command:

make demo username="xxxxxx" password="oauth:xxxxxx" channel="#xxxxxx"

License

This library is released under the MIT Licence. See the bundled LICENSE file for details.

Author

Sascha Vonier (@voniersa)

统计信息

  • 总下载量: 20
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-10-24