Skip to main content

A unified API wrapper for YouTube and Twitch chat bots.

Project description

Chatto

PyPi version Downloads GitHub Workflow Status Docs License

A unified API wrapper for YouTube and Twitch chat bots.

CPython versions 3.8 through 3.10 and PyPy version 3.8 are officially supported.

Windows, MacOS, and Linux are all supported.

Installation

To install the latest stable version of Chatto:

pip install chatto

# If you need types:
pip install "chatto[types]"

To install the latest development version:

pip install git+https://github.com/parafoxia/chatto

You may need to prefix these commands with a call to the Python interpreter depending on your OS and Python configuration.

Setup

Before you begin, you will need to have a Google Developers project with the YouTube Data API V3 enabled. You need an API key, and if you want to send and delete messages, you will need an OAuth client ID.

I made a video walking through all the necessary steps.

Creating a YouTube bot

To create a simple YouTube bot, you could do something like this:

import os

from chatto import YouTubeBot
from chatto.events import MessageCreatedEvent

bot = YouTubeBot(
    # Your project's API key.
    os.environ["API_KEY"],
    # The ID of the channel whose stream you want to connect to.
    os.environ["CHANNEL_ID"],
    # Your OAuth client ID secrets file.
    secrets_file="secrets.json",
)


# Listen for MessageCreatedEvents, and run this awaitable whenever a
# new message is received.
@bot.listen(MessageCreatedEvent)
async def on_message_created(event):
    # Ignore messages sent by the broadcaster.
    if event.message.channel.is_owner:
        return

    # Respond to messages starting with "!hello".
    if event.message.content.startswith("!hello"):
        await bot.send_message(f"Hi {event.message.channel.name}!")


if __name__ == "__main__":
    # This is blocking, so should be the last thing you call.
    bot.run()

Chatto relies on the /search endpoint to find a live broadcast from a channel, which is not 100% reliable. If you are having major issues getting Chatto to find your channel's live stream, you can pass the stream ID directly:

bot.run(with_stream_id=os.environ["STREAM_ID"])

If you don't want to use OAuth, you can launch Chatto in read-only mode. Note that your bot will not be able to send or delete messages in this mode:

bot.run(read_only=True)

To learn how to make more advanced bots, check the documentation.

Creating a Twitch bot

Twitch bots are not yet supported.

Contributing

Contributions are very much welcome! To get started:

License

The Chatto module for Python is licensed under the BSD 3-Clause License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

chatto-0.5.0.tar.gz (18.8 kB view details)

Uploaded Source

Built Distribution

chatto-0.5.0-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

Details for the file chatto-0.5.0.tar.gz.

File metadata

  • Download URL: chatto-0.5.0.tar.gz
  • Upload date:
  • Size: 18.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.10

File hashes

Hashes for chatto-0.5.0.tar.gz
Algorithm Hash digest
SHA256 9a8ebabc0ff059ce36801b13a970c34990b7d0acefbad1ad73615d1f1137f705
MD5 7c23f1c2255ac8d01d77b35d16d9f45f
BLAKE2b-256 33056fdc3202dd970c772f6b6ea65449d8edc38e9c9327305fff35aa2076ce12

See more details on using hashes here.

File details

Details for the file chatto-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: chatto-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 27.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.10

File hashes

Hashes for chatto-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e8488c737c22063bb9e51d9c02fdabc6607513d016f48248be7a426c090e1bac
MD5 494fe8217b7992d544404faf2ca5e424
BLAKE2b-256 ed3d776cae0a9c15d2417381238c55cedb55955e303d58d9d6c1df4ea6823b0d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page