You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Andrei b76d119e98 Bump v0.0.2 9 years ago
disco Bump v0.0.2 9 years ago
docs Refactoring, manhole, ETF support 9 years ago
examples Readme, more fixes/changes 9 years ago
.gitignore Fix gitignore for package name 9 years ago
MANIFEST.in Add manifest file 9 years ago
README.md Fix py2.x inspect.getargspec 9 years ago
requirements.txt Remove skema in favor of simple custom data modeling stuff 9 years ago
setup.py Temporarily rename to disco-py on pypi 9 years ago

README.md

disco

Disco is a simple and extendable library for the Discord API.

  • Expressive, functional interface that gets out of the way
  • Built for high-performance and efficiency
  • Configurable and modular, take the bits you need
  • Full support for Python 2.x/3.x
  • Evented networking and IO using Gevent

WARNING

Disco is currently in an early-alpha phase. What you see today may change a lot tomorrow. If you are looking to build a serious bot with this, wait for a stable release.

Installation

Disco was built to run both as a generic-use library, and a standalone bot toolkit. Installing disco is as easy as running pip install disco-py, however some extra packages are recommended for power-users, namely:

Name Reason
requests[security] adds packages for a proper SSL implementation
ujson faster json parser, improves performance
erlpack ETF parser, only Python 2.x, run with the --encoder=etf flag

Examples

Simple bot using the builtin bot authoring tools:

from disco.bot import Bot, Plugin


class SimplePlugin(Plugin):
    # Plugins provide an easy interface for listening to Discord events
    @Plugin.listen('ChannelCreate')
    def on_channel_create(self, event):
        event.channel.send_message('Woah, a new channel huh!')

    # They also provide an easy-to-use command component
    @Plugin.command('ping')
    def on_ping_command(self, event):
        event.msg.reply('Pong!')

    # Which includes command argument parsing
    @Plugin.command('echo', '<content:str...>')
    def on_echo_command(self, event, content):
        event.msg.reply(content)

if __name__ == '__main__':
    Bot.from_cli(
        SimplePlugin
    ).run_forever()

Using the default bot configuration, we can now run this script like so:

./simple.py --token="MY_DISCORD_TOKEN"

And commands can be triggered by mentioning the bot (configued by the BotConfig.command_require_mention flag):