Skip to main content

A python package for creating Twitch Bots

Project description

J-Core

Python Version PyPI version

This framework is a simple wrapper for creating Twitch bots using Python. The Jarvis chatbot for twitch and discord has been built using the J-Core framework for it's Twitch components.

A full set of documentation is still being developed, however, a getting started guide is outlined below.

Getting started

Prerequisites

To get started creating a bot using the J-Core framwork is pretty simple, but it does require that you have Python installed on your computer.
Some operating systems come with python pre-installed (e.g. MacOS and most Linux systems), but if you're on Windows, you will need to download Python first to create a bot.
Once you have installed Python, you can use pip to install the J-Core framework and start creating your first bot.

Installation

To install the J-Core framework using pip: pip install jcore

To install using this repository:

  1. clone the directory using git clone
  2. navigate into the directory and use pip install

Creating a Simple Bot

To create a simple bot, start by creating a new python file called simple_bot.py and copy the code below into the file.

import asyncio
import jcore
from jcore.message import CommandMessage

class SimpleBot(jcore.Client):

    async def on_command(self, message: CommandMessage):
        if message.KEYWORD == "hi":
            await message.send(f"hello {message.display_name}")


if __name__ == "__main__":
    client = SimpleBot()
    loop = asyncio.get_event_loop()
    loop.run_until_complete(client.run())
    loop.close()

Next, create a file called config.json and copy the following snippet into the file.

{
    "nick": "<nick>",
    "token": "<token>",
    "channels": [
        "<channel>",
        "<channel>",
        "<channel>"
    ]
}

Replace:

  • <nick> with the username of your bot account.
  • <token> with the oauth token for your bot. Refer to the Twitch Documentation - Getting Tokens for more information about generating an oauth token.
  • <channel> with the channels you want to connect to.

Once all the values have been set, you can start your bot using:

python3 simple_bot.py

or

py simple_bot.py

Adding Logging

If you need to view the logging output of from the framework for your bot, you can configure logging by adding the logging import to the top of your file:

import asyncio
import jcore
from jcore.message import CommandMessage
import logging

Then update the main section of your code to the following:

if __name__ == "__main__":
    
    logging.basicConfig(level=logging.INFO, format='%(asctime)s [%(levelname)s] %(name)s: %(message)s')

    client = SimpleBot()
    loop = asyncio.get_event_loop()
    loop.run_until_complete(client.run())
    loop.close()

For more information on using the logging library, refer to the python logging documentation.

Examples

These examples above and more can be found in the examples folder.

Support

If you require any further support, please join the discord and seek help from the commuity.

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

jcore-0.2.0.552.tar.gz (32.7 kB view details)

Uploaded Source

Built Distribution

jcore-0.2.0.552-py3-none-any.whl (34.4 kB view details)

Uploaded Python 3

File details

Details for the file jcore-0.2.0.552.tar.gz.

File metadata

  • Download URL: jcore-0.2.0.552.tar.gz
  • Upload date:
  • Size: 32.7 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.10.2

File hashes

Hashes for jcore-0.2.0.552.tar.gz
Algorithm Hash digest
SHA256 76355b97f49e00605fab350fbe0f13c192728c23c1deec5467916b3896f8d0dc
MD5 2e844ddcdf82fd39e67f39ad56dff3cd
BLAKE2b-256 9d659a00f424b71411cd4f75b743ec09894d7310415ad2dcecd2b0c1a7e9313e

See more details on using hashes here.

File details

Details for the file jcore-0.2.0.552-py3-none-any.whl.

File metadata

  • Download URL: jcore-0.2.0.552-py3-none-any.whl
  • Upload date:
  • Size: 34.4 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.10.2

File hashes

Hashes for jcore-0.2.0.552-py3-none-any.whl
Algorithm Hash digest
SHA256 9f92da86f3abd980aa96a10933700fceee0c5a7e5aee1b89c12546404ecf8550
MD5 f5cf2eb1288c96c254b5e4f0b7d6e6a2
BLAKE2b-256 4b60eeacf70c0da54758c38536323e08909652b8cd6e4a93ed28a562c2e87af3

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