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.

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:

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

EasyMessage

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)

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.3.0.tar.gz (16.5 kB view details)

Uploaded Source

Built Distribution

xbotlib-0.3.0-py3-none-any.whl (16.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: xbotlib-0.3.0.tar.gz
  • Upload date:
  • Size: 16.5 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.3.0.tar.gz
Algorithm Hash digest
SHA256 3d77fed1fe0a10346e582e176c4e890a9be1f136c1a6c9db4f35c20385ec7739
MD5 783474591d3c8c7e45452c6a8d7508c6
BLAKE2b-256 023dcf0d217031b1a7096a74527929b91a2148695a4460336e8a3c7447c48ac0

See more details on using hashes here.

File details

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

File metadata

  • Download URL: xbotlib-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 16.0 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.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 05d98f41b2d415e89cb9018ef5ad598b3b212a59fcc30fff14df1a33e2407bab
MD5 36069cbaf7edfec97cd1c6bea6b884bc
BLAKE2b-256 686687d607543479383aa2704f486c8fe362159507b0c8adb7494aaef05a8ba3

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