For support and general questions and discussions, please visit the support Discord server! Please do not use the issue tracker for general support questions. Please also remember that unless explicitly stated otherwise/you have hired services to that end, all support is free and offered on a volunteer basis, and there is no guarantee or obligation upon maintainers and/or community members to provide support.
The following are accepted uses for the issue tracker:
- Bug reports
- Feature or enhancement requests (within reason)-- note that these may be denied if they are deemed out of scope of the project and/or are not feasible to implement for any reason.
File bugs in the issue tracker. Please follow these guidelines:
- Search existing issues first! Make sure your issue hasn't already been reported.
- Stay on topic, but describe the issue in detail so that others can reproduce it.
- Provide screenshot(s) if possible.
It's recommended, but not required, to discuss potential new features in the support Discord before creating an issue, as this helps check that it is valid for a feature request and if it would be useful to others-- something which increases its likelihood of the issue being accepted and consequently the feature being implemented. Please also check that your request has not already been posted on the issue tracker.
Avoid listing multiple requests in one issue. One issue per request makes it easier to track and discuss it. If need be, you may make multiple issues (within reason), but do not spam. Do not make multiple issues for the same request.
If you want to start contributing to the project's code, please follow these guidelines before creating a pull request:
- Bugfixes are always welcome. Start by reviewing the list of bugs!
- A good way to easily start contributing is to pick and work on a good first issue. We try to make these issues as clear as possible and provide basic info on how the code should be changed, and if something is unclear feel free to ask for more information on the issue.
- Before adding a new feature, ask about it in the issue tracker or the support Discord, or check if there is an existing issue to make sure the new functionality is desired.
- Changes that will consist of more than 50 lines of code should be discussed via an issue or the support Discord, so that you don't spend too much time implementing something that might not be accepted.
- Pull requests that make many changes using an automated tool, like for spell fixing, styling, etc. will not be accepted. An exception would be if the changes have been discussed and someone has agreed to review and test the pull request.
- It's recommended to run tests for at minimum the general area(s) you are modifying! While all tests are run by default on creation of a pull request, these tests must pass, and running them locally first can help catch issues before making a pull request. Note that if your changes require tests to be added and/or updated, you must do so. For more information on working with tests, see here.
- Be sure to include any instructions, such as running
php artisan migrate
, in your pull request! - If in doubt, provide more information, not less. It can sometimes be difficult to tell from code alone what the purpose of a change is, so you should explain as best you can.
Note that while the project is primarily located at https://code.itinerare.net/itinerare/Mundialis, contributions are accepted via GitHub for convenience.
Generally speaking, Mundialis and its branches are structured and maintained in keeping with GitFlow. Loosely, this means that there are two persistent branches:
- The default/primary branch--
main
, in this case-- which always contains the current release/the current stable version, and - The development branch--
develop
, in this case-- which always contains the latest work-- features, fixes, and so on. It is by definition unstable.
There are additionally three types of impermanent branches. Each branch of these types is destined to be merged into another.
- Feature Branches
- These follow the naming scheme
feature/FEATURE-NAME-HERE
- While these are called feature branches, they can contain new features and/or non-emergency bugfixes!
- New features are always merged into
develop
anddevelop
only. - These branches are created branched off of develop (if they contain features or there is no current release branch) or the current release branch (if there is one, and the feature branch contains only bugfixes for the current content within it).
- These follow the naming scheme
- Release Branches
- These follow the naming scheme
release/UPCOMING-VERSION-HERE
. - These are created by a maintainer of the repo when an upcoming release is feature-complete or otherwise ready, and are branched off of
develop
. - Once they are created, no additional features or work from
develop
will be merged into these branches, only bugfixes for the features already in them. - Conversely, bugfixes for features contained in a release branch are merged directly into the release branch and the release branch only. In the event that a release branch receives bugfixes, said release branch is periodically merged back into
develop
to incorporate them. - In essence, the purpose of a release branch is to isolate, test, and if necessary fix a static set of features.
- When a release branch is sufficiently stable and any necessary preparations complete, the branch will be merged into master and become the new current release.
- These follow the naming scheme
- Hotfix branches
- These follow the naming scheme
hotfix/HOTFIX-NAME-HERE
. - These contain emergency bugfixes, e.g. fixes for critical issues or security vulnerabilities.
- These are directly branched off of
main
/the current release and merged back into main when complete. - In such an event,
main
is merged back intodevelop
as well to incorporate fixes.
- These follow the naming scheme
In summary:
- When contributing to Mundialis, you will create either a feature or (more rarely) a hotfix branch.
- If you are creating a new feature, it must be isolated in its own feature branch and merged via pull request into
develop
.
If you are fixing bug(s), there are a few possibilities depending on the circumstances:
- If there is currently a release branch, make a feature branch off of the release branch or check out the release branch itself.
- Once you have done so, fix bug(s) with the current content of the release branch, then push the branch to your fork and make a PR to the release branch.
- Prioritize fixing bugs in the release branch first and foremost. This allows the branch to better achieve stability and move toward full release.
- If there is not currently a release branch, or if your fix(es) concern content that is only present in
develop
, make a feature branch off ofdevelop
or check outdevelop
itself.- Alternately put: do not PR bugfixes that apply to an extant release branch to
develop
. Isolate them from any changes relevant only todevelop
on a branch created from the release branch and PR them to the release branch. This helps the release branch achieve stability and move toward full release.
- Alternately put: do not PR bugfixes that apply to an extant release branch to
- As a general rule, making feature branches for bugfixes vs. checking out
develop
or the release branch and committing them directly is recommended, but not required, as you will need to push the relevant branch to your fork and make a PR regardless. - If you are making a hotfix for a critical issue present in the current release, create a new hotfix branch off of
main
, make the necessary changes, and PR it back intomain
.
Contributions are recommended to follow the style of the project's existing code. However, PHP styling and view formatting will automatically be adjusted for contributions on creation of a pull request.
If you wish to apply these changes locally, you can run or dry-run them via:
- Fix PHP styling with
composer lint
or dry run withcomposer sniff
- Format views with
npm run format
Commits to this project follow Conventional Commits formatting. Contributors are highly recommended to follow this formatting when making pull requests (it also makes it very easy to make pull requests!). It is also recommended to focus on atomic commits (commit each fix or task as a separate change, and only commit when a block of work is complete)-- this makes it much easier both to review and manage changes.
In the case where a pull request is started but not finished and the contributor is nonresponsive despite efforts to contact them, the pull request will be closed regardless of its status. It is up to contributors to finish work, make any requested changes, etc., not maintainers.
However, knowledge from the issue and/or pull request may be used to create a new pull request, potentially based on the changes from the closed pull request.