Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mmesek/mbot.py
MFramework.py's based commands/systems used by my Discord Bots
https://github.com/mmesek/mbot.py
Last synced: 3 months ago
JSON representation
MFramework.py's based commands/systems used by my Discord Bots
- Host: GitHub
- URL: https://github.com/mmesek/mbot.py
- Owner: Mmesek
- License: agpl-3.0
- Created: 2021-08-29T21:34:01.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-05-20T19:46:42.000Z (9 months ago)
- Last Synced: 2024-05-20T22:45:56.889Z (9 months ago)
- Language: Python
- Homepage:
- Size: 1.2 MB
- Stars: 2
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# MBot.py
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Code style: black"](https://github.com/psf/black)
[data:image/s3,"s3://crabby-images/f250b/f250be75323b4a29d7b71ccd81c1f433748b8199" alt="Open in Visual Studio Code"](https://open.vscode.dev/Mmesek/MBot.py)[data:image/s3,"s3://crabby-images/37d2a/37d2a105688ff1169dbd4ae2e3535e46345b7ed9" alt="CodeFactor Grade"](https://www.codefactor.io/repository/github/mmesek/mbot.py)
[data:image/s3,"s3://crabby-images/22550/2255054cdc0127e7b1269602872966fb262a711d" alt="Lines of code"]()
[data:image/s3,"s3://crabby-images/2c4df/2c4df2a4118c7c3e8ba85634a5e0c0eb1662342f" alt="GitHub code size in bytes"]()
[data:image/s3,"s3://crabby-images/b1748/b1748f7673bfd0defedefe6602cfc8fff6cd1306" alt="GitHub repo size"]()[data:image/s3,"s3://crabby-images/a89d5/a89d53a5bd522b3856b350a220f01fbc1dfffa47" alt="GitHub issues"](../../issues)
[data:image/s3,"s3://crabby-images/6945b/6945b7fdd7cfa038d3470c2240a4fa8fed883ffe" alt="GitHub pull requests"](../../pulls)
[data:image/s3,"s3://crabby-images/e6781/e678163fddced55703d6415c6b360c7e51586ab3" alt="GitHub contributors"](../../graphs/contributors)Multipurpose collection of systems written from scratch for automation & moderation of chat communities. Used as Modmail on [Dying Light](https://discord.gg/dyinglight)'s server.
## Features
- Forum-based [Modmail](bot/commands_slash/modmail.py) system forwarding communication between user direct messages and server moderation team's thread
- [Logging](bot/dispatch/logging.py)
- [Stream](bot/dispatch/dispatch.py) Log (based on presence)
- [Infractions](bot/infractions) system with automated actions
- [Info](bot/commands_slash/info.py) (about Discord objects (User, Role, Channel, Guild etc)
- Basic [interacting](bot/commands_slash/mod.py) as bot - (Say/React)
- [Leaderboards](bot/commands_slash/leaderboards.py)
- [Giveaways](bot/commands_slash/giveaways.py)
- [Reaction](bot/dispatch/reactions.py)/[Presence](bot/dispatch/dispatch.py) [Roles](bot/systems/roles.py)
- Auto [Moderation](bot/dispatch/actions.py)
- [Ghostping](bot/dispatch/actions.py) detection
- Spoiler *[only](bot/dispatch/actions.py)* channel
- [Antiraid](bot/dispatch/guild.py) system (autokick)
- Database "[Stash](bot/commands_slash/database.py)" for memes/rules etc
- [Custom role](bot/commands_slash/database.py) for Nitro Users
- Tracking [Chat](bot/dispatch/actions.py)/[Voice](bot/dispatch/voice.py)/[Presence](bot/dispatch/dispatch.py) activity
- [Steam](bot/commands_slash/steam.py) calculator
- [Graphing](bot/commands_slash/graphs.py) (things like member join over time histograph)
- Auto dice roll in [RPG](bot/dispatch/actions.py) channels
- [Dynamic](bot/dispatch/dynamic.py) Voice Channel generation
- [Voice](bot/dispatch/voice.py#L54-L126) & [Text](bot/systems/xp.py) chat activity tracking
- Miscellaneous commands for [random](bot/commands_slash/rand.py) rolls (Dice roll, coinflip etc)
- Various [converters](bot/commands_slash/converters.py) (Like Morse Transaltor, Making text upsidedown or Currency Converter)
- [Search](bot/commands_slash/search.py)ing other APIs (Like Steam, UrbanDict or Word Definitions)
- [Story](bot/commands_slash/story.py) conversation executor (Reads json or yaml file with story flow and responds to user accordingly)## Minigames
- [Hangman](bot/commands_slash/games.py) game
- [Wordle](bot/commands_slash/games.py)
- [Halloween](bot/events/Halloween)
- Reaction [Hunt](bot/events/hunts.py) events
- [Christmas](bot/events/Christmas)---
## Running locally
Run once to generate `secrets.ini`, modify to suit your needs.
Make sure to set `intents` in `bot` section to at least `1`.#### Docker Compose:
```sh
docker compose up -f .docker/docker-compose.yml
```#### Docker
```sh
docker run -it Mmesek/MFramework \
-v data:/app/data \
-v bot:/app/bot \
-v locale:/app/locale \
```### Manually
#### Install required packages
```sh
python -m pip install -r requirements.txt
```#### Run
```sh
python -m MFramework bot
```