Skip to main content

Simple bot for MatterMost

Project description

[![PyPI](https://badge.fury.io/py/mattermost_bot.svg)](https://pypi.python.org/pypi/mattermost_bot)

A chat bot for [mattermost](http://www.mattermost.org) inspired by [limbo](https://github.com/llimllib/limbo), [will](https://github.com/skoczen/will) and [slackbot](lins05/slackbot).

## Features

* Based on MatterMost [WebSocket API](https://github.com/mattermost/platform)
* Simple plugins mechanism
* Messages can be handled concurrently
* Automatically reconnect to mattermost when connection is lost
* Python3 Support

## Installation

```
pip install mattermost_bot
```

## Usage

### Registration

First you need create the mattermost email/password for your bot.

### Configuration

Then you need to configure the `BOT_URL`, `BOT_LOGIN`, `BOT_PASSWORD`, `BOT_TEAM` in a python module
`mattermost_bot_settings.py`, which must be located in a python import path.


mattermost_bot_settings.py:

```python
BOT_URL = '<http://mm.example.com/api/v1>'
BOT_LOGIN = '<bot-email-address>'
BOT_PASSWORD = '<bot-password>'
BOT_TEAM = '<your-team>'
```

Alternatively, you can use the environment variable `MATTERMOST_BOT_URL`,
`MATTERMOST_BOT_LOGIN`, `MATTERMOST_BOT_PASSWORD`, `MATTERMOST_BOT_TEAM`.

### Run the bot

```python
from mattermost_bot.bot import Bot

if __name__ == "__main__":
Bot().run()
```

Now you can talk to your bot in your mattermost client!

## Plugins

A chat bot is meaningless unless you can extend/customize it to fit your own use cases.

To write a new plugin, simply create a function decorated by `mattermost_bot.bot.respond_to` or `mattermost_bot.bot.listen_to`:

- A function decorated with `respond_to` is called when a message matching the pattern is sent to the bot (direct message or @botname in a channel/group chat)
- A function decorated with `listen_to` is called when a message matching the pattern is sent on a channel/group chat (not directly sent to the bot)

```python
import re

from mattermost_bot.bot import listen_to
from mattermost_bot.bot import respond_to


@respond_to('hi', re.IGNORECASE)
def hi(message):
message.reply('I can understand hi or HI!')


@respond_to('I love you')
def love(message):
message.reply('I love you too!')


@listen_to('Can someone help me?')
def help(message):
# Message is replied to the sender (prefixed with @user)
message.reply('Yes, I can!')

# Message is sent on the channel
# message.send('I can help everybody!')
```

To extract params from the message, you can use regular expression:
```python
from mattermost_bot.bot import respond_to


@respond_to('Give me (.*)')
def giveme(message, something):
message.reply('Here is %s' % something)
```

If you would like to have a command like 'stats' and 'stats start_date end_date', you can create reg ex like so:

```python
from mattermost_bot.bot import respond_to
import re


@respond_to('stat$', re.IGNORECASE)
@respond_to('stat (.*) (.*)', re.IGNORECASE)
def stats(message, start_date=None, end_date=None):
pass
```


And add the plugins module to `PLUGINS` list of mattermost_bot settings, e.g. mattermost_bot_settings.py:

```python
PLUGINS = [
'mattermost_bot.plugins',
'mybot.plugins',
]
```

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

mattermost_bot-1.0.0.tar.gz (6.6 kB view details)

Uploaded Source

Built Distribution

mattermost_bot-1.0.0-py2.py3-none-any.whl (11.3 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file mattermost_bot-1.0.0.tar.gz.

File metadata

File hashes

Hashes for mattermost_bot-1.0.0.tar.gz
Algorithm Hash digest
SHA256 8839c9bf14375409dca164b2190f2dd49d00b12b86d26910a1a2f5b0df2ecbaa
MD5 267d9932062008b06a581933bc29c1f0
BLAKE2b-256 2753f7dbe8dd4422302c2e5fce1be052e1399fd11e7598b27ee99834fc894b37

See more details on using hashes here.

File details

Details for the file mattermost_bot-1.0.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for mattermost_bot-1.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 98db303c87361a34f196cbadf84d2cd8551a070fb5ffcc55a99190fc7b44be6a
MD5 4e92418b5b9404057e0627dbfd5233fd
BLAKE2b-256 43c509ae86dae8b9c9893fc4c8806fd3776a88746e68d9e6352f6a43e3930991

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