Skip to main content

A multi-platform chat bot framework

Project description

Chatty

A multi-platform chat bot framework

Description

Chatty is a Python 3 package designed to map any chat platform to the same standardized interface. The goal is to allow a chat bot to be remapped from one platform to another, or even to multiple platforms at the same time, with nothing more than a minor change in configuration.

Chatty is organized around 3 core abstractions:

  • Signals: A signal is any single indivisible element of communication, such as a message or a notification, which may or may not contain content or data of some sort. Signals always come with certain attached metadata which indicates where the signal originated, who it was sent to, when it was sent, etc.
  • Bots: A bot is an endpoint where inbound signals are handled, and outbound signals are generated.
  • Sessions: A session is an open channel over which signals can be sent and/or received by a bot.

Usage

from chatty.bots.decorator import as_bot
from chatty.configuration import get_config
from chatty.sessions.slack import SlackSession
from chatty.signals.message import Message
from chatty.signals.metadata import SignalMetaData


# FRIENDLY REMINDER: Never store bot tokens or login passwords in your source
# code, and be careful that they aren't in a place where they could get picked 
# up by source control!

# Load the bot's handle and login token from the config file.
handle, token = get_config('Slack', '~/.chatty_config', ['handle'], ['token'])


@as_bot
def converse(session, signal):
    """Say 'hi!' back on the same channel whenever someone says 'hello'"""
    if isinstance(signal, Message) and 'hello' in str(signal.content).lower():
        meta_data = SignalMetaData(
            origin=handle,
            addressees=[signal.meta_data.room or signal.meta_data.origin],
            response_to=signal.meta_data.identifier
        )
        return Message(meta_data, 'hi!')


session = SlackSession(token)        # Create a new Slack session
session.add_bot(converse)            # Connect our bot to it
session.join(timeout=5 * 60)         # Hang out for 5 minutes
session.close()                      # Drop offline

Current Development Status

Chatty is brand new, and has currently only been tested for basic messaging via email (imap & smtp), xmpp, and Slack. See the TODO list for a list of other platforms that should eventually be supported.

Contributing

If you have a need for a specific platform or protocol to be supported, I'll be happy to accept pull requests. If you're looking to contribute but need a place to start, please see the TODO list. There are plenty of platforms and functionality yet to be added. Each supported platform has its own module in the chatty/sessions folder, and its dependencies should be added to the extras_require parameter in setup.py. Tests go in the test_chatty folder and are named with test_ prefixed to the name of the module being tested.

Submitted code should adhere to pep8 guidelines and should, in general, follow the conventions established elsewhere in the Chatty code base. For the sake of clarity, please note that by submitting a pull request, you agree, as per standard practice (and also the GitHub terms of service) to make your code available under the same license that governs this project.

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

Chatty-0.2.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

Chatty-0.2-py3-none-any.whl (30.8 kB view details)

Uploaded Python 3

File details

Details for the file Chatty-0.2.tar.gz.

File metadata

  • Download URL: Chatty-0.2.tar.gz
  • Upload date:
  • Size: 18.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for Chatty-0.2.tar.gz
Algorithm Hash digest
SHA256 7dc221940abcedfa1f7cd32f95606d2bf73278dfc33367986d8a92ec63fd5978
MD5 4a17c99653a40f9c787c1894bf069803
BLAKE2b-256 4e314c03ae6639644c511e9a40f1d34eb494a45eff8f0db03d617ca01130de0c

See more details on using hashes here.

File details

Details for the file Chatty-0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for Chatty-0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3f2fe962cefd38dc46b743dbc42be851f11b2fd95925a9b2b476395db06ce7d9
MD5 3dc156a93f2600a27830322996c5c9d3
BLAKE2b-256 f7414a79d0db7b8e24f55385088e457a3bac235ad9112f533f95ddfe91bf53c1

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