Thanks for being willing to contribute to the Flight! The goal of Flight is to keep the implementation of things simple and free of outside dependencies. You should only bring in the depedencies you want in your project right? Right.
Flight aims to be simple and fast. Anything that compromises either of those two things will be heavily scrutinized and/or rejected. Other things to consider when making a contribution:
-
Dependencies - We strive to be dependency free in Flight. Yes even polyfills, yes even
Interface
only repos likepsr/container
. The fewer dependencies, the fewer your exposed attack vectors. -
Coding Standards - We use PSR1 coding standards enforced by PHPCS. Some standards that either need additional configuration or need to be manually done are:
- PHPStan is at level 6.
===
instead of truthy or falsey statements like==
or!is_array()
.
-
PHP 7.4 Focused - We do not make PHP 8+ focused enhancements on the framework as the focus is maintaining PHP 7.4.
-
Core functionality vs Plugin - Have a conversation with us in the chatroom to know if your idea is worth makes sense in the framework or in a plugin.
-
Testing - Until automated testing is put into place, any PRs must pass unit testing in PHP 7.4 and PHP 8.2+. Additionally you need to run
composer test-server
andcomposer test-server-v2
and ensure all the header links work correctly.
-
Do not open up a GitHub issue if the bug is a security vulnerability. Instead contact maintainers directly via email to safely pass in the information related to the security vuln.
-
Ensure the bug was not already reported by searching on GitHub under Issues.
-
If you're unable to find an open issue addressing the problem, open a new one. Be sure to include a title and clear description, as much relevant information as possible, and a code sample or an executable test case demonstrating the expected behavior that is not occurring.
-
Open a new GitHub pull request with the patch.
-
Ensure the PR description clearly describes the problem and solution. Include the relevant issue number if applicable.
Changes that are cosmetic in nature and do not add anything substantial to the stability, functionality, or testability of Flight will generally not be accepted.
-
Hop into the chatroom for Flight and let's have a conversation about the feature you want to add. It could be amazing, or it might make more sense as an extension/plugin. If you create a PR without having a conversation with maintainers, it likely will be closed without review.
-
Do not open an issue on GitHub until you have collected positive feedback about the change. GitHub issues are primarily intended for bug reports and fixes.
- Ask any question about how to use Flight in the in the Flight Matrix chat room.
- Please see the Flight Documentation repo on GitHub.
Flight is a volunteer effort. We encourage you to pitch in and join!
Thanks! ❤️ ❤️ ❤️
Flight Team