Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jcarbaugh/butterfield

A Python Slack bot framework using asyncio and Slack's Real Time Messaging API
https://github.com/jcarbaugh/butterfield

Last synced: 2 months ago
JSON representation

A Python Slack bot framework using asyncio and Slack's Real Time Messaging API

Awesome Lists containing this project

README

        

# Butterfield

A Slack bot framework using Slack's [Real Time Messaging API](https://api.slack.com/rtm), Python 3 and [asyncio](https://docs.python.org/3/library/asyncio.html).

**Butterfield is unstable and being actively developed. Breaking changes will occur.**

## Echo bot example

This simple bot will listen for *message* events and echo the message to the same channel.

import asyncio
from butterfield import Bot

@asyncio.coroutine
def echo(bot, message: 'message'):
yield from bot.post(
message['channel'],
message['text']
)

b = Bot('slack-bot-key')
b.listen(echo)

butterfield.run(b)

## Running butterfield

This package provides the *butterfield* command line utility. This command takes one argument, a path to a configuration file, and runs the bot as defined.

$ butterfield mybot-config.json

If you are running butterfield in development, you can launch the command line utility directly:

$ python -m "butterfield.cli" mybot-config.json

### Bot configuration files

A butterfield config file contains a JSON array containing objects defining the bots that will be created.

[
{
"key": "i-made-this-key-up",
"plugins": [
"butterfield.handlers.devel.log",
"butterfield.handlers.devel.emoji"
]
},
{
"key": "also-a-made-up-key",
"plugins": [
"butterfield.handlers.devel.log",
]
}
]

The *key* property contains the [Slack bot user](https://api.slack.com/bot-users) key. The *plugins* property is a list of strings that are module paths to event handler plugins.

## Writing your own bot

Bots are created by instantiating an instance with a [Slack bot user](https://api.slack.com/bot-users) key.

from butterfield import Bot

mybot = Bot('this-is-not-a-real-key')

### Receiving Slack events

Message handlers are asyncio [coroutines](https://docs.python.org/3/library/asyncio-task.html#coroutine). When executed, they receive the bot instance that invoked the handler and a copy of the event message from Slack.

import asyncio

@asyncio.coroutine
def console_printer(bot, message: "message"):
if 'text' in message:
print(message['text'])

A [parameter annotation](https://www.python.org/dev/peps/pep-3107/) is used on the message parameter to specify the message types the coroutine will receive. This can be a single string or a list of strings to specificy multiple message types. To trigger the handler for all event types, use `"*"` or `butterfield.ALL`. The full list of event types can be found in the [RTM API docs](https://api.slack.com/rtm).

Handlers are added to the bot using the *listen* method. The handler parameter can be either a direct reference to the coroutine or the module path as a string.

mybot.listen(console_printer)
mybot.listen("butterfield.handlers.devel.log")

Now just start the bot and it will run... FOREVER.

butterfield.run(mybot)

Multiple bots can be started by passing multiple instances to *butterfield.run()*:

butterfield.run(mybot, myotherbot)

or

allthebots = [mybot, myotherbot]
butterfield.run(*allthebots)

### Posting to Slack

Handlers can post messages back to Slack using the *post* method on the bot that was passed to it. The first parameter is the id of the channel that will receive the post. The second parameter is the message that will be posted.

bot.post(channel_id, 'Hi, channel!')

### Daemons

They exist. This section should tell you about them.

## TODO

* Add HTTP API so messages can be pushed through Butterfield to Slack.
* Listen for meta events and modify local Slack environment appropriately (list of channels, users, etc.).
* EVERYTHING ELSE!