This repository has been archived on 2024-07-28. You can view files and clone it, but cannot push or open issues or pull requests.
2021-01-12 21:29:20 +01:00
2021-01-13 14:08:10 +01:00
2021-01-10 14:10:39 +01:00
2021-01-10 14:10:39 +01:00
2021-01-13 14:08:25 +01:00
2021-01-13 14:00:59 +01:00

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.

from xbotlib import Bot

class EchoBot(Bot):
    def react(self, message):
        if message.type == "chat":
          self.reply(message.body, to=message.sender)

MyBot()

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.

More Examples

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

See the examples directoy for all listings.

API Reference

Your bot always sub-classes the Bot class provided from xbotlib. All underling functions can be extended. For example, if you want to enable more plugins or add different functionality. If something feels awkward then please raise a ticket for that. Seamlessness is still a bitch but we're trying anyway.

Bot.react(message)

A function which you define in your bot implementation in order to respond to chat messages. You can respond to both direct messages and group chat messages in this function by checking the message.type which can be either chat or groupchat.

Arguments:

  • message: sent message and metadata (see message reference below)

Bot.reply(body, to=None, room=None)

Send back a response to a direct chat message.

Arguments:

  • body: the message to send
  • to: which user account to reply to (direct chat)
  • room: which room to reply to (group chat)

SimpleMessage

A simple message format. This is the type that you work with when your function accepts a message argument.

Attributes:

  • body: the body of the message
  • sender: the sender of the message
  • receive: the receive 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_ROOM: The room that the bot can join
  • XBOT_NICK: The nickname that the bot uses

Roadmap

See the issue tracker.

Changes

See the CHANGELOG.md.

License

See the LICENSE.

Description
XMPP bots for humans
Readme 312 KiB
Languages
Python 100%