Hey! Thank you for your interest in contributing to Twake, we really appreciate it.
Following these guidelines helps to communicate that you respect the time of the developers managing and developing this open source project. In return, they should reciprocate that respect in addressing your issue, assessing changes, and helping you finalize your pull requests.
We are an open-source project and we love to receive contributions from our community! There are many ways to contribute - writing tutorials or blog posts, improving the documentation, submitting bug reports and feature requests, fixing bugs, submitting pull requests for enhancements, or reviewing other's pull requests.
Please adhere to the following responsibilities:
- Ensure cross-platform compatibility for every change that's accepted. For example, Windows, Mac, Debian & Ubuntu Linux.
- Any change must be done using Pull Requests incoming from a fork of original Twake repository.
- Create issues for any major changes and enhancements that you wish to make. Discuss things transparently and get community feedback.
- Don't add any classes to the codebase unless absolutely needed. Err on the side of using functions.
- Keep feature versions as small as possible, preferably one new feature per version.
- Be welcoming to newcomers and encourage diverse new contributions from all backgrounds. See the Code of Conduct
Our Code of Conduct means that you are responsible for treating everyone on the project with respect and courtesy regardless of their identity. If you are the victim of any inappropriate behavior or comments as described in our Code of Conduct, we are here for you. Please follow the guidelines on our website to report the issue and we will do the best to ensure that the abuser is reprimanded appropriately per our code.
Unsure where to begin contributing to Twake? You can start by looking at these good first issues and help wanted issues. Good first issues - issues which should require only a few lines of code, and a test or two. Help wanted issues - issues which should be a bit more involved than beginner issues. While not perfect, number of comments is a reasonable proxy for impact a given change will have.
Working on your first Pull Request? You can learn how from these free resources: Course - How to Contribute to an Open Source Project on GitHub from @kentcdodds on @eggheadio and Make a Pull Request.
At this point, you are ready to make your changes! Feel free to ask for help; everyone is a beginner at first. 😃
If a maintainer asks you to "rebase" your PR, they are saying that a lot of code has changed, and that you need to update your branch so it's easier to merge.
When contributing to this repository, please first discuss the change you wish to make via issue, email, or any other method with the owners of this repository before making a change.
It's important to break your feature down into small pieces first, each piece should become it's own pull request. Once you know, what the first small piece of your feature will be, follow this general process while working:
-
Create your own fork of the code and do changes in your own fork.
-
Make your first commit: any will do even if empty or trivial, but we need something in order to create the initial pull request. Create the pull request and use the pull request naming convention.
-
Make sure that the titles of your pull requests and commits respect this format - Commit & Pull Request Format
-
Write a detailed description of the problem you are solving, the part of Twake it affects, and how you plan on fixing it.
-
If you have write access, add the [Status] In Progress label or wait until somebody adds it. This indicates that the pull request is not ready for a review and may still be incomplete. On the other hand, it welcomes early feedback and encourages collaboration during the development process.
-
-
Start developing and pushing out commits to your new branch.
- Push your changes out frequently and try to avoid getting stuck in a long-running branch or a merge nightmare. Smaller changes are much easier to review and to deal with potential conflicts.
- Note that you can automate some of these tasks by setting up githooks and they will run whenever you
git commit
. - Please feel free to change, squash, and rearrange commits or to force push. Keep in mind, however, that if other people are committing on the same branch then you can mess up their history. You are perfectly safe if you are the only one pushing commits to that branch.
- Squash minor commits such as typo fixes or fixes to previous commits in the pull request.
-
If you end up needing more than a few commits, consider splitting the pull request into separate components. Discuss in the new pull request and in the comments why the branch was broken apart and any changes that may have taken place that necessitated the split. Our goal is to catch early in the review process those pull requests that attempt to do too much.
-
When you feel that you are ready for a formal review or for merging into
trunk
make sure you check this list.- Make sure your branch merges cleanly and consider rebasing against
trunk
to keep the branch history short and clean. - If there are visual changes, add before and after screenshots in the pull request comments.
- Add unit tests, or at a minimum, provide helpful instructions for the reviewer so they can test your changes. This will help speed up the review process.
- Ensure that your commit messages are meaningful.
- Mention that the PR is ready for review or if you have write access remove the [Status] In Progress label from the pull request and add the [Status] Needs Review label - someone will provide feedback on the latest unreviewed changes. The reviewer will also mark the pull request as [Status] Needs Author Reply if they think you need to change anything.
- Make sure your branch merges cleanly and consider rebasing against
-
If you get a 👍 and the status has been changed to [Status] Ready to Merge - this is great - the pull request is ready to be merged.
If you feel yourself waiting for someone to review a PR, don't hesitate to personally ask for someone to review it or to mention them on Github. Remember, the PR author is responsible for pushing the change through.
We use the Developer Certificate of Origin (DCO) as an additional safeguard for the Linagora/Twake projects. This is a well established and widely used mechanism to assure contributors have confirmed their right to license their contributions under the project's license. Please read Developer Certificate of Origin. If you can certify it, then just add a line to every git commit message:
Signed-Off by: Unicorn John <[email protected]>
Use your real name (sorry, no pseudonyms or anonymous contributions). If you set your user.name
and user.email
git configs, you can sign your commit automatically with git commit-s
.
Code Reviews are an important part of the Twake workflow. They help to keep code quality consistent, and they help every person working on Twake learn and improve over time. We want to make you the best Twake contributor you can be.
Every PR should be reviewed and approved by someone other than the author, even if the author has write access. Fresh eyes can find problems that can hide in the open if you have been working on the code for a while.
The recommended way of finding an appropriate person to review your code is by blaming one of the files you are updating and looking at who was responsible for previous commits on that file.
Then, you may ask that person to review your code by mentioning their Github username on the PR comments like this:
cc @username
Everyone is encouraged to review PRs and add feedback and ask questions. Reading other people's code is a great way to learn new techniques, and seeing code outside of your own feature helps you to see patterns across the project. It's also helpful to see the feedback other contributors are getting on their PRs.
In case you are not sure about how to apply our license correctly, please have a look at How to Apply Licence.
If you find a security vulnerability, do NOT open an issue. Email [email protected] instead.
In order to determine whether you are dealing with a security issue, ask yourself these two questions:
-
Can I access something that's not mine, or something I should not have access to?
-
Can I disable something for other people?
If the answer to either of those two questions are "yes", then you are probably dealing with a security issue. Note that even if you answer "no" to both questions, you may still be dealing with a security issue, so if you're unsure, just email us at [email protected].
For reporting any other bug, just file a Github issue.
If you find yourself wishing for a feature that doesn't exist in Twake, you are probably not alone. There are bound to be others out there with similar needs. Many of the features that Twake has today have been added because our users saw the need. Open an issues on our issues list on Github which describes the feature you would like to see, why you need it.
You can chat with the core team at - Gitter and we will try our best to reply to you as soon as possible.