Metadata-Version: 2.1
Name: spellbot
Version: 6.0.2
Summary: The Discord bot for SpellTable
Home-page: http://spellbot.io/
License: MIT
Keywords: discord,magic,bot,mtg,SpellTable
Author: Amy
Author-email: amy@lexicalunit.com
Requires-Python: >=3.8,<4
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: End Users/Desktop
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Topic :: Communications :: Chat
Classifier: Topic :: Games/Entertainment :: Board Games
Requires-Dist: aiofiles (>=0.6.0,<0.7.0)
Requires-Dist: aiohttp (>=3.7.4.post0,<4.0.0)
Requires-Dist: aioredis (>=1.3.1,<2.0.0)
Requires-Dist: alembic (>=1.5.8,<2.0.0)
Requires-Dist: click (>=7.1.2,<8.0.0)
Requires-Dist: coloredlogs (>=15.0,<16.0)
Requires-Dist: discord.py (>=1.7.1,<2.0.0)
Requires-Dist: dunamai (>=1.5.4,<2.0.0)
Requires-Dist: expiringdict (>=1.2.1,<2.0.0)
Requires-Dist: fastapi (>=0.63,<0.65)
Requires-Dist: fastapi-cache2 (>=0.1.3.4,<0.2.0.0)
Requires-Dist: httpx (>=0.17.1,<0.19.0)
Requires-Dist: humanize (>=3.3.0,<4.0.0)
Requires-Dist: hupper (>=1.10.2,<2.0.0)
Requires-Dist: itsdangerous (>=1.1.0,<2.0.0)
Requires-Dist: psycopg2-binary (>=2.8.6,<3.0.0)
Requires-Dist: python-dateutil (>=2.8.1,<3.0.0)
Requires-Dist: python-dotenv (>=0.17.0,<0.18.0)
Requires-Dist: python-jose[cryptography] (>=3.2.0,<4.0.0)
Requires-Dist: pytz (>=2021.1,<2022.0)
Requires-Dist: pyyaml (>=5.4.1,<6.0.0)
Requires-Dist: redis (>=3.5.3,<4.0.0)
Requires-Dist: requests (>=2.25.1,<3.0.0)
Requires-Dist: sqlalchemy (>=1.4.6,<2.0.0)
Requires-Dist: unidecode (>=1.2.0,<2.0.0)
Requires-Dist: uvicorn (>=0.13.4,<0.14.0)
Project-URL: Repository, https://github.com/lexicalunit/spellbot
Description-Content-Type: text/markdown

<img align="right" width="200" src="https://raw.githubusercontent.com/lexicalunit/spellbot/master/spellbot.png" />

# SpellBot

[![build][build-badge]][build]
[![top][top-badge]][top]
[![uptime][uptime-badge]][uptime]
[![metrics][metrics-badge]][metrics]
[![pypi][pypi-badge]][pypi]
[![codecov][codecov-badge]][codecov]
[![CodeFactor][factor-badge]][factor]
[![CodeQL][codeql-badge]][security]
[![python][python-badge]][python]
[![black][black-badge]][black]
[![mit][mit-badge]][mit]
[![patreon][patreon-button]][patreon]
[![follow][follow-badge]][follow]

The Discord bot for [SpellTable][spelltable].

[![add-bot][add-bot-button]][add-bot]

## 🤖 Using SpellBot

Once you've connected the bot to your server, you can interact with it over
Discord via the following commands in any of the authorized channels. **Keep in
mind that sometimes SpellBot will respond to you via Direct Message to avoid
being too spammy in text channels.**

- `!spellbot help`: Provides detailed help about all of the following commands.
- `!about`: Get information about SpellBot and its creators.

> **Note:** To use the
> [commands for event runners](#%EF%B8%8F-commands-for-event-runners)
> and [commands for admins](#-commands-for-admins), you will need to
> [create a role on your server][create-role] called `SpellBot Admin`
> (capitalization matters). Only users with that role will be able to use those
> commands.

### ✋ Commands for Players

Just looking to play some games of Magic? These commands are for you!

- `!lfg`: Find or start up a game of Magic: The Gathering!
- `!leave`: Leave any games that you've signed up for.
- `!power`: Set your current power level.
- `!report`: Report the results of the game you just played.
- `!team`: Join one of the teams available on your server.
- `!points`: Find out how many points you currently have.
- `!plays`: Find out how many games you've played.
- `!block`: Block other users from joining your games.
- `!unblock`: Unblock previously blocked users.

When you run the `!lfg` command, SpellBot will post a message for sign ups.

![lfg][lfg]

Other users can react to it with the ✋ emoji to be added to the game. When the
game is ready, SpellBot will update the message with your SpellTable details.

![ready][ready]

Users can also use the 🚫 emoji reaction to leave the game.

### 🎟️ Commands for Event Runners

These commands are intended to be run by SpellBot Admins and help facilitate
online events.

- `!game`: Directly create games for the mentioned users.
- `!event`: Create a bunch of games all at once based on some uploaded data.
- `!begin`: Start an event that you previously created with `!event`.
- `!export`: Export historical game data for your server.

### 👑 Commands for Admins

These commands will help you configure SpellBot for your server.

- `!spellbot`: This command allows admins to configure SpellBot for their
  server. It supports the following subcommands:
  - `config`: Just show the current configuration for this server.
  - `prefix`: Set the command prefix for SpellBot in text channels.
  - `links`: Set the privacy level for generated SpellTable links.
  - `spectate`: Add a spectator link to the posts SpellBot makes.
  - `expire`: Set how many minutes before games are expired due to inactivity.
  - `teams`: Sets the teams available on this server.
  - `power`: Turns the power command on or off for this server.
  - `voice`: When on, SpellBot will automatically create voice channels.
  - `tags`: Turn on or off the ability to use tags. Optionally mention specific channels.
  - `queue-time`: Turn on or off average queue time details. Optionally mention specific channels.
  - `smotd`: Set the server message of the day.
  - `cmotd`: Set the message of the day for the channel where you run it.
  - `motd`: Set the privacy level for messages of the day.
  - `size`: Sets the default game size for a specific channel.
  - `toggle-verify`: Toggles requirement of verification for a specific channel.
  - `auto-verify`: Set the channels that will trigger user auto verification.
  - `unverified-only`: Set the channels that are only for unverified users.
  - `verify-message`: Set the verification message for a specific channel.
  - `voice-category`: Set category for voice channels created by !game.
  - `awards`: Coming Soon - Attach a config file to award users who have played enough games.
  - `stats`: Gets some statistics about SpellBot usage on your server.
  - `help`: Get detailed usage help for SpellBot.
- `!verify`: Allows moderators to verify a user on their server.
- `!unverify`: Un-verifies a user for this server.
- `!watch`: Allows moderators to watch a user on their server.
- `!unwatch`: Un-watches a user for this server.

### 🛋️ Ergonomics

SpellBot will always try and assume useful defaults or try to do the right thing
when you give it a command. For example if you use the tag <code>~modern</code>
or other format names when creating a game, it will automatically assume the
correct number of players for you. Hopefully these features are intuitive and
helpful 🤞 — and if not, [please report bugs and request features][issues]
to your heart's content.

### 🎤 Feedback

Thoughts and suggestions? Come join us on the
[SpellTable Discord server][discord-invite]! Please also feel free
to [directly report any bugs][issues] that you encounter.

## 🙌 Support Me

I'm keeping SpellBot running using my own money but if you like the bot and want
to help me out, please consider [becoming a patron][patreon].

## ❤️ Contributing

If you'd like to become a part of the SpellBot development community please
first know that we have a documented [code of conduct](CODE_OF_CONDUCT.md) and
then see our [documentation on how to contribute](CONTRIBUTING.md) for details
on how to get started.

## 🔧 Running SpellBot Yourself

First install `spellbot` using [`pip`](https://pip.pypa.io/en/stable/):

```shell
pip install spellbot
```

Provide your Discord bot token with the environment variable `SPELLBOT_TOKEN`.
As well as your SpellTable API authorization token via `SPELLTABLE_AUTH`.

You can get [your bot token from Discord][discord-bot-docs]. Your bot will
need the following permissions enabled:

- Manage Channels
- Create Instant Invite
- View Channels
- Send Messages
- Manage Messages
- Embed Links
- Read Message History
- Add Reactions

As for the SpellTable API authorization token, you'll have to talk to the
SpellTable developers. Come join us on the
[SpellTable Discord server][spelltable-discord].

By default SpellBot will use sqlite3 as its database. You can however choose to
use another database by providing a [SQLAlchemy Connection URL][db-url]. This
can be done via the `--database-url` command line option or the environment
variable `SPELLBOT_DB_URL`. Note that, at the time of this writing, SpellBot is
only tested against sqlite3 and PostgreSQL.

More usage help can be found by running `spellbot --help`.

## 🐳 Docker Support

You can also run SpellBot via docker. Our image is published to
[lexicalunit/spellbot][docker-hub]. See [our documentation on Docker Support](DOCKER.md) for help
with installing and using it.

---

[MIT][mit] © [amy@lexicalunit][lexicalunit] et [al][contributors]

[add-bot-button]: https://user-images.githubusercontent.com/1903876/88951823-5d6c9a00-d24b-11ea-8523-d256ccbf4a3c.png
[add-bot]: https://discordapp.com/api/oauth2/authorize?client_id=725510263251402832&permissions=268528721&scope=bot
[black-badge]: https://img.shields.io/badge/code%20style-black-000000.svg
[black]: https://github.com/psf/black
[build-badge]: https://github.com/lexicalunit/spellbot/workflows/build/badge.svg
[build]: https://github.com/lexicalunit/spellbot/actions
[codecov-badge]: https://codecov.io/gh/lexicalunit/spellbot/branch/master/graph/badge.svg
[codecov]: https://codecov.io/gh/lexicalunit/spellbot
[codeql-badge]: https://github.com/lexicalunit/spellbot/workflows/CodeQL/badge.svg
[contributors]: https://github.com/lexicalunit/spellbot/graphs/contributors
[create-role]: https://support.discord.com/hc/en-us/articles/206029707-How-do-I-set-up-Permissions-
[db-url]: https://docs.sqlalchemy.org/en/latest/core/engines.html
[discord-bot-docs]: https://discord.com/developers/docs/topics/oauth2#bots
[discord-invite]: https://discord.gg/zXzgqMN
[docker-hub]: https://hub.docker.com/r/lexicalunit/spellbot
[factor-badge]: https://www.codefactor.io/repository/github/lexicalunit/spellbot/badge
[factor]: https://www.codefactor.io/repository/github/lexicalunit/spellbot
[follow-badge]: https://img.shields.io/twitter/follow/SpellBotIO?style=social
[follow]: https://twitter.com/intent/follow?screen_name=SpellBotIO
[issues]: https://github.com/lexicalunit/spellbot/issues
[patreon]: https://www.patreon.com/lexicalunit
[patreon-button]: https://img.shields.io/endpoint.svg?url=https%3A%2F%2Fshieldsio-patreon.vercel.app%2Fapi%3Fusername%3Dlexicalunit%26type%3Dpatrons88951826-5e053080-d24b-11ea-9a81-f1b5431a5d4b.png
[lexicalunit]: http://github.com/lexicalunit
[lfg]: https://user-images.githubusercontent.com/1903876/91242259-cedd2280-e6fb-11ea-8d30-e7127b6f96e9.png
[metrics-badge]: https://img.shields.io/badge/metrics-grafana-orange.svg
[metrics]: https://lexicalunit.grafana.net/d/4TSUCbcMz/spellbot?orgId=1
[mit-badge]: https://img.shields.io/badge/License-MIT-yellow.svg
[mit]: https://opensource.org/licenses/MIT
[pypi-badge]: https://img.shields.io/pypi/v/spellbot
[pypi]: https://pypi.org/project/spellbot/
[python-badge]: https://img.shields.io/badge/python-3.8+-blue.svg
[python]: https://www.python.org/
[ready]: https://user-images.githubusercontent.com/1903876/91242257-cdabf580-e6fb-11ea-86ad-8f1aaf6d34dc.png
[security]: https://github.com/lexicalunit/spellbot/security
[spelltable-discord]: https://discord.gg/zXzgqMN
[spelltable]: https://www.spelltable.com/
[top-badge]: https://top.gg/api/widget/status/725510263251402832.svg?noavatar=true
[top]: https://top.gg/bot/725510263251402832
[uptime-badge]: https://img.shields.io/uptimerobot/ratio/m785764282-c51c742e56a87d802968efcc
[uptime]: https://uptimerobot.com/dashboard#785764282

