Skip to content

A Discord.py-based Discord bot framework, adds a reloadable module system, command suggestions, translation support, error handling, and premium features.

License

Notifications You must be signed in to change notification settings

MerelyServices/Merely-Framework

Repository files navigation

Merely logo

Merelybot

Python build status Merelybot is an extended feature-set framework for Discord.py bots. Adding features like configuration-defined bots, hot-reloading of code, a feature rich help command, translation support, authorization, security, error handling, and paywalled commands.

Featured implementations

You can test these implementations on my official Discord server.

  • Merely is an example implementation of the framework. Merely uses the default config included with this code so you can run it yourself.
  • ConfessionBot is an anonymous messaging system for Discord. ConfessionBot uses the help command, translation support, and module reloading features to speed up development and shares improvements to the framework back here.

News

MerelyBot v2.0 has launched! This is a major release because we are changing the underlying library back to Discord.py in order to support user installation. This means you can now add Merely to your account and use the new command (/download) anywhere!

Migration advice for developers >

Usage

  • Clone the project to a folder
  • Install python >= 3.10
  • Install required python packages with python3 -m pip install -r requirements.txt
  • Create a discord bot in the Discord Developer Portal, you will need the token to continue
  • Give MerelyBot the token by setting it in the [main] section of the config
  • Run MerelyBot with python3 merelybot.py
  • Add your instance of merely to your server
  • Optional: change the behaviour and features of your bot in the config/config.ini file.
    • Restart the bot to apply changes.

Contributing

The best way to contribute is to create your own discord bot using this framework, and send any improvements to the framework my way in the form of a pull request!

Translation

I have built a website which makes it easier to translate my projects, including Merely-Framework. Babel Translator.

Code contribution

Merely-Framework is written in Python with the help of the Discord.py API wrapper. Refer to the Project roadmap for future features we'd like to implement. All contributions are welcome and support can be given in the Discord server.

Design

Merely is a highly customizable and extensible framework for discord bots. through the config file, people can enable and disable extensions, change the bot name, and configure extensions. Developers can even write their own extensions to further extend the Merely Framework.

Code structure

Extensions should operate entirely independant of each other and should rarely need to communicate with each other. Extensions must inherit from the discord.ext.commands.Cog class and bind themselves on import. Effort should be made to avoid clashes with existing commands. extensions/example.py should demonstrate all of this.

Writing a different bot using the framework

If you would like to make a bot that changes functionality of existing commands or strings, you may want to use an overlay. Create a folder named 'overlay' in this directory, refer to the source code for ConfessionBot to see an example of how an overlay is structured. Note that babel is given a language file prefix so Merely Language files can still be inherited from.

This overlay system allows for improvements to the framework to be easily shared upstream and downstream.

Strings

As the Babel language framework is being used, there's no need to provide strings for your code. Myself and the volunteer translators can add strings later. In place of strings, simply invent a meaningful key, for example;

self.bot.babel('example', 'echo', content=userinput)
# Appears like the following until a string is written:
"<ECHO: content={content}>"
# Appears like this after the string is written:
"You said: \"content\"."

In babel/en.ini;

[example]
echo = You said: "{content}"

File structure

  • Core plugins are stored in the top directory, these elements cannot be disabled. Reloading babel or config refreshes the data, but not the code.
  • Extensions are placed in the extensions folder, from there, they will appear in the config and can be enabled.
  • Config and config history will be found in the config folder.
  • Translation data is stored in the babel folder.
  • Error and usage logs are stored in the logs folder.
  • Translations, config, and extensions can be overidden in an "overlay" folder.
  • Some extensions may create a "tmp" folder. This contains temporary files which are not needed after restarts.

Extensions

Extension Description Ver. Added
main🔒 Imports extensions, creates some global variables, establishes a log, and runs the main loop N/A
config🔒 Reads configuration data and ensures that the config file is valid 1.0
babel🔒 Provides translated and formatted strings that contributors can easily translate to more languages 1.0
auth🔒 Provides security checks for other commands which need authorization 1.0
utilities🔒 Provides useful functions and other shared code between extensions 1.2.2
error Provides error handling for all other extensions and informs the user 1.0
log Logging to file, or to a text channel in a rich format 1.0
help help, about - Lists featured commands and fetches translated usage instructions 1.0
language language - Allows bot users to change the language 1.0
admin janitor, clean, purge - Power tools for server administrators 1.0
dice dice - A simple dice rolling command with some advanced features 1.0
emoji emoji, thonk - Allows non-nitro users to use a selection of custom emojis 1.0
eventmsg eventmsg, welcome, farewell - Automated messages in response to user actions (replaces greeter) 1.0
poll poll - Adds polls to discord with an interactive poll builder and countdown timers 1.0
reactroles reactrole - Adds reaction role automations to discord with an interactive setup 1.0
system module, migrate, die - Advanced bot controls, deploy patches without restarting 1.2
premium premium - Locks select features behind a paywall, premium roles can bypass 1.0
controlpanel controlpanel - Toggle user and guild settings for all modules in one place 1.2
announce announce - Send an announcement to server owners 1.2.3
download download - Downloads videos from any public url and reuploads them to chat 1.4.0
------ ----------- -----
example echo - Example commands for getting started on writing your own extension 1.0
error_test throw_error - Creates errors intentionally to test error handling 1.2

🔒 = This is a core component and cannot be disabled

About

A Discord.py-based Discord bot framework, adds a reloadable module system, command suggestions, translation support, error handling, and premium features.

Topics

Resources

License

Stars

Watchers

Forks

Contributors 4

  •  
  •  
  •  
  •  

Languages