Skip to content

Development - Contributing

Thank you so much for your interest in contributing!. All types of contributions are encouraged and valued. See below for different ways to help, and details about how this project handles them!

Please make sure to read the relevant section before making your contribution! It will make it a lot easier for us maintainers to make the most of it and smooth out the experience for all involved. πŸ’š

Note

Failing to comply with our guidelines may lead to a rejection of the contribution. However, most features that are rejected can be written as a plugin, and used on your modmail, without blocking you from getting updates.

If you are confused by any of these rules, feel free to ask us in the #support channel in our Discord server.

How do I...

Request Support

  • You can either ask your question as issue by opening one at discord-modmail/modmail/issues.

  • Join the Modmail Discord Server

    • Even though Discord is a chat service, sometimes it takes several hours for community members to respond β€” please be patient!
    • Use the #support channel for questions or discussion about writing or contributing to Discord Modmail bot.
    • There are many other channels available, check the channel list

Report an Error or Bug

If you run into an error or bug with the project:

Note

If you find a Closed issue that seems like it is the same thing that you're experiencing, open a new issue and include a link to the original issue in the body of your new one.

  • Open an Issue at discord-modmail/modmail/issues.
  • Explain the problem and include additional details to help maintainers reproduce the problem:
    • Use a clear and descriptive title for the issue to identify the problem.
    • Describe the exact steps which reproduce the problem in as many details as possible. When listing steps, don't just say what you did but explain how you did it.
    • Provide specific examples to demonstrate the steps. Include links to files or GitHub projects, or copy/paste-able snippets, which you use in those examples. If you're providing snippets in the issue, use Markdown code blocks.
    • Describe the behaviour you observed after following the steps and point out what exactly is the problem with that behaviour.
    • Explain which behaviour you expected to see instead and why.
    • Include screenshots and animated GIFs which show you following the described steps and clearly demonstrate the problem. If you use the keyboard while following the steps, record the GIF with the Keybinding Resolver shown. You can use this tool to record GIFs on macOS and Windows, and this tool on Linux (of course there are plenty more).

Request a Feature

If the project doesn't do something you need or want it to do:

  • Open an Issue at discord-modmail/modmail/issues.
  • Provide as much context as you can about what you're running into.

    • Use a clear and descriptive title for the issue to identify the suggestion.
    • Provide a step-by-step description of the suggested enhancement in as many details as possible.
    • Provide specific examples to demonstrate the steps. Include copy/paste-able snippets which you use in those examples, as Markdown code blocks.
    • Explain why this enhancement would be useful to Modmail, and would benefit the community members.
  • Please try and be clear about why existing features and alternatives would not work for you.

Once it's filed:

  • The Maintainers will label the issue.
  • The Maintainers will evaluate the feature request, possibly asking you more questions to understand its purpose and any relevant requirements. If the issue is closed, the team will convey their reasoning and suggest an alternative path forward.
  • If the feature request is accepted, it will be marked for implementation with status: approved, which can then be done either by a core team member or by anyone in the community who wants to contribute code.

Note

The team is unlikely to be able to accept every single feature request that is filed. Please understand if they need to say no. However for most features requested, you can always write a plugin for your modmail bot.

Project Setup

So you want to contribute some code! That's great! This project uses GitHub Pull Requests to manage contributions, so read up on how to fork a GitHub project and file a PR if you've never done it before.

Test Server and Bot Account

You will need your own test server and bot account on Discord to test your changes to the bot.

  1. Create a test server.
  2. Create a bot account and invite it to the server you just created.

Tip

Learn how to obtain the ID of a server, channel or role here.

Fork the Project

You will need your own remote (online) copy of the project repository, known as a fork. You will do all your work in the fork rather than directly in the main repository.

You can click here to fork

And you should be ready to go!

Once you have your fork you will need to clone the repo to your computer.

$ git clone https://github.com/your_username/modmail

---> 100%

$ cd modmail
$ gh repo clone your_username/modmail

---> 100%

$ cd modmail

Tip

You can use the github cli to fork the repo as well, just use gh repo fork discord-modmail/modmail and it will allow you to clone it directly.

Install development dependencies

Make sure you are in the project directory.

$ poetry install

---> 100%

Tip

Run poetry run task precommit to install precommit hooks.

This runs our register pre-commit hooks on every commit to automatically point out issues in code such as missing semicolons, trailing whitespace, and debug statements. By pointing these issues out before code review, this allows a code reviewer to focus on the architecture of a change while not wasting time with trivial style nitpicks.

Set up modmail config

  1. Create a copy of config-default.yml named config.yml in the the modmail/ directory.
$ cp -v modmail/config-default.toml modmail/config.toml
$  xcopy /f modmail/config-default.toml modmail/config.toml
  1. Set the modmail bot prefix in bot.prefix.
  2. In case you are a contributor set dev.mode.plugin_dev and dev.mode.develop to true. The develop variable enables the developer bot extensions and plugin_dev enables plugin-developer friendly bot extensions.
  3. Create a text file named .env in your project root (that's the base folder of your repository):
    • You can also copy the .env.template file to .env

Note

The entire file name is literally .env

  1. Open the file with any text editor and write the bot token to the files in this format: TOKEN="my_token".

Run The Project

To run the project, use the (below) in the project root.

$ poetry run task start

---> 100%

Contribute Code

We like code commits a lot! They're super handy, and they keep the project going and doing the work it needs to do to be useful to others.

Code contributions of just about any size are acceptable!

To contribute code:

  • Set up the project.
  • Make any necessary changes to the source code.
  • Write clear, concise commit message(s).
  • Run flake8, black and pre-commit against your code before you push. Your commit will be rejected by the build server if it fails to lint. You can run the lint by executing poetry run task lint in your command line.
  • Go to discord-modmail/modmail/pulls and open a new pull request with your changes.
  • If PRing from your own fork, ensure that "Allow edits from maintainers" is checked. This permits maintainers to commit changes directly to your fork, speeding up the review process.
  • If your PR is connected to an open issue, add a line in your PR's description that says Closes #123, where #123 is the number of the issue you're fixing. This will make github link your issue, and make it easier for us (and other contributers) to find and understand the context behind your PR.

Technical Details

Pull requests (or PRs for short) are the primary mechanism we use to change modmail. GitHub itself has some great documentation on using the Pull Request feature. We use the "fork and pull" model described here, where contributors push changes to their personal fork and create pull requests to bring those changes into the source repository.

Once you've filed the PR:

  • Barring special circumstances, maintainers will not review PRs until lint checks pass (poetry run task lint).
  • One or more contributors will use GitHub's review feature to review your PR.
  • If the maintainer asks for any changes, edit your changes, push, and ask for another review.
  • If the maintainer decides to pass on your PR, they will thank you for the contribution and explain why they won't be accepting the changes. That's ok! We still really appreciate you taking the time to do it, and we don't take that lightly. πŸ’š
  • If your PR gets accepted, it will be marked as such, and merged into the main branch soon after.

Git Commit Messages

Commit messages must start with a short summary (max. 50 chars) written in the imperative, followed by an optional, more detailed explanatory text which is separated from the summary by an empty line.

Commit messages should follow best practices, including explaining the context of the problem and how it was solved, including caveats or follow up changes required. They should tell the story of the change and provide readers understanding of what led to it.

Check out Conventional commits for more information.

If you're lost about what this even means, please see How to Write a Git Commit Message for a start.

In practice, the best approach to maintaining a nice commit message is to leverage a git add -p and git commit --amend to formulate a solid changeset. This allows one to piece together a change, as information becomes available.

If you squash a series of commits, don't just submit that. Re-write the commit message, as if the series of commits was a single stroke of brilliance.

That said, there is no requirement to have a single commit for a PR, as long as each commit tells the story. For example, if there is a feature that requires a package, it might make sense to have the package in a separate commit then have a subsequent commit that uses it.

Remember, you're telling part of the story with the commit message. Don't make your chapter weird.

Python Styleguide

Changelog Requirement

Modmail has CI that will check for an entry corresponding to your PR in CHANGES.md. If you feel this PR does not require a changelog entry please state that in a comment and a maintainer can add a skip changelog label to make the CI pass. Otherwise, please ensure you have a line in the following format:

- `Modmail` is now more awesome (#X)

Note

X should be your PR number, not issue number! This is not perfect but saves a lot of release overhead as now the releaser does not need to go back and workout what to add to the CHANGES.md for each release.

Attribution

This contributing guide is inspired by the Moby's and Atom Text Editor's contributing guide.

Back to top