# Matchy Matchy matches matchees. ![Tests](https://github.com/mdiluz/matchy/actions/workflows/test.yml/badge.svg) Matchy is a Discord bot that groups up users for fun and vibes. Matchy can be installed by clicking [here](https://discord.com/oauth2/authorize?client_id=1270849346987884696). ## Commands ### /match [group_min: int(3)] [matchee_role: str(@Matchee)] Matches groups of users with a given role and posts those groups to the channel. Tracks historical matches and attempts to match users to make new connections with people with divergent roles, in an attempt to maximise diversity. ### $sync and $close Only usable by `OWNER` users, reloads the config and syncs commands, or closes down the bot. Only usable in DMs with the bot user. ## Dependencies * `python3` - Obviously ### Python modules * `discord.py` - Discord bot functionality * `pytest` - Testing * `schema` - File format validation * `pytest-cov` - Code coverage testing ## Config Matchy is configured by a `config.json` file that takes this format: ``` { "token": "<>", "owners": [ <> ] } ``` User IDs can be grabbed by turning on Discord's developer mode and right clicking on a user. ## TODO * Write bot tests with [dpytest](https://dpytest.readthedocs.io/en/latest/tutorials/getting_started.html) * Add scheduling functionality * Improve the weirdo