Skip to main content

XMPP bots for humans

Project description

xbotlib

PyPI version Build Status

XMPP bots for humans

status: experimental

A friendly lightweight wrapper around slixmpp for writing XMPP bots in Python. The goal is to make writing and running XMPP bots easy and fun. xbotlib is a single file implementation which can easily be understood and extended. It provides a small API surface which reflects the slixmpp way of doing things.

Install

$ pip install xbotlib

Example

Put the following in a echo.py file. xbotlib provides a number of example bots which you can use to get moving fast and try things out.

from xbotlib import EchoBot

EchotBot()

And then python echo.py. You will be asked a few questions like which account details your bot will be using.

This will generate a bot.conf file in the same working directory for further use.

Here's the code for the EchoBot.

class EchoBot(Bot):
    def direct(self, message):
        self.reply(message.body, to=message.sender)

    def group(self, message):
        if "echobot" in message.body:
            self.reply(message.body.split(":")[-1], room=message.room)

Read more in the API reference for how to write your own bots.

All examples

  • EchoBot: Sends back what you sent it
  • WhisperBot: Pseudo-anonymous whispering in group chats

See xbotlib.py for all example bots.

API Reference

When writing your own bot, you always sub-class the Bot class provided from xbotlib. Then if you want to respond to a direct message, you write a direct function. If you want to respond to a group chat message, you write a group function.

Bot.direct(message)

Respond to direct messages.

Arguments:

  • message: received message (see SimpleMessage below for available attributes)

Bot.group(message)

Respond to a message in a group chat.

Arguments:

  • message: received message (see SimpleMessage below for available attributes)

SimpleMessage

A simple message interface.

Attributes:

  • body: the body of the message
  • sender: the user the message came from
  • room: the room the message came from
  • receiver: the receiver of the message
  • nickname: the nickname of the sender
  • type: the type of message (chat or groupchat)

Configure your bot

Using the environment

You can pass the --no-input option to your script invocation (e.g. python bot.py --no-input).

xbotlib will try to read the following configuration values from the environment.

  • XBOT_JID: The username of the bot account
  • XBOT_PASSWORD: The password of the bot account
  • XBOT_NICK: The nickname that the bot uses

Roadmap

See the issue tracker.

Changes

See the CHANGELOG.md.

License

See the LICENSE.

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

xbotlib-0.7.1.tar.gz (17.3 kB view details)

Uploaded Source

Built Distribution

xbotlib-0.7.1-py3-none-any.whl (16.9 kB view details)

Uploaded Python 3

File details

Details for the file xbotlib-0.7.1.tar.gz.

File metadata

  • Download URL: xbotlib-0.7.1.tar.gz
  • Upload date:
  • Size: 17.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.0 Linux/4.19.0-13-amd64

File hashes

Hashes for xbotlib-0.7.1.tar.gz
Algorithm Hash digest
SHA256 5113650b216352a9929de4730f56d0f0b75eaa24781a6f311aeb6c42ee13debc
MD5 26c6f3ba695757723c687f5298264700
BLAKE2b-256 437809c5c29ccb10954be47f6bad1f72db8b61ad81f38a92a7db101ac48e91d3

See more details on using hashes here.

File details

Details for the file xbotlib-0.7.1-py3-none-any.whl.

File metadata

  • Download URL: xbotlib-0.7.1-py3-none-any.whl
  • Upload date:
  • Size: 16.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.9.0 Linux/4.19.0-13-amd64

File hashes

Hashes for xbotlib-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c067ff08f4e55ec4c129a66e8894448158d79f02f7a8c06f484cdef67b119f8b
MD5 51dad798395b96675dc43ffd4a9bfce3
BLAKE2b-256 947a6c6db59681641bc31fda8f52b3157094b71ba5b367f6127ac4eeb7c3feb2

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