Giter Site home page Giter Site logo

mengmengtech / mmpy_bot Goto Github PK

View Code? Open in Web Editor NEW

This project forked from attzonko/mmpy_bot

0.0 0.0 0.0 591 KB

A python-based chatbot for Mattermost (http://www.mattermost.org).

License: MIT License

Python 98.85% Makefile 0.78% Dockerfile 0.37%

mmpy_bot's Introduction

PyPI Maintainability Python Support Mattermost License

Documentation available at Read the Docs.

Description

A Python based chat bot framework for Mattermost. The code for this bot framework was heavily re-factored in v2.0.0 and will only work with Python 3.8 or higher. For Python 2 and Python3 < 3.8 support, please use versions v1.3.9 or lower.

Features

  • Based on Mattermost WebSocket API(V4.0.0)
  • Simple plugins mechanism
  • Concurrent message handling
  • Attachment support
  • Auto-reconnect to Mattermost after connection loss
Additional features added in v2.x:
  • Multi-threading and asyncio execution
  • Integrated webhook server
  • Support for click functions
  • Job scheduling

Compatibility

Mattermost mmpy_bot
>= 4.0 > 1.2.0
< 4.0 unsupported

Installation

โš ๏ธ Warning: pip will grab v1.x if your Python version is less than 3.8!

v2.x (latest)
pip install mmpy-bot
v1.3.9 (force legacy)
pip install mmpy-bot==1.3.9

Usage (v2.x)

Registration

First you need to create a bot account on your Mattermost server. Note: Enable Bot Account Creation must be enabled under System Console

  1. Login to your Mattermost server as a user with Administrative privileges.
  2. Navigate to Integrations -> Bot Accounts -> Add Bot Account
  3. Fill in the configuration options and upon creation take note of the Access Token

Note that some API functions, such as ephemeral message replies, will require the bot to be part of the System Admin group, however most API functions will work with a regular Member account role. Just be aware that if some API functions are not working, it may be due to a lack of appropriate permissions.

Configure and run the bot

Create an entrypoint file (or copy the one provided), that defines your Mattermost server and bot account settings and imports the desired modules.

Example my_bot.py:

#!/usr/bin/env python

from mmpy_bot import Bot, Settings
from my_plugin import MyPlugin

bot = Bot(
    settings=Settings(
        MATTERMOST_URL = "http://chat.example.com",
        MATTERMOST_PORT = 443,
        BOT_TOKEN = "a69155mvlsobcnqpfdceqihaa",
        BOT_TEAM = "test",
        SSL_VERIFY = True,
    ),  # Either specify your settings here or as environment variables.
    plugins=[MyPlugin()],  # Add your own plugins here.
)
bot.run()

Set the executable bit on the entrypoint file (i.e. chmod +x my_bot.py) and start your bot from the command prompt. Now you can talk to your bot in your Mattermost client!

In order to get the most out of your bot, you will need to write your own plugins. Refer to the Plugins Documentation to get started.

Talk to us

The primary channel for communication is GitHub via Issues or Pull requests but you may also find some of us in Discord for some real-time interaction.

mmpy_bot's People

Contributors

dependabot[bot] avatar attzonko avatar gotlium avatar unode avatar selain avatar jneeven avatar github-actions[bot] avatar tgly307 avatar grokzen avatar blampe avatar ttuffin avatar thorlock12 avatar aconitumnapellus avatar rwky avatar nathanjordan avatar sheiun avatar scottleedavis avatar michaelcrunch avatar benbart avatar bezumkin avatar roy-orbison avatar pschmitt avatar pdericson avatar epatpol avatar leanny avatar knedlsepp avatar uusijani avatar nautics889 avatar hloeung avatar crocmagnon avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.