Table of Contents generated with DocToc
- Contributing to the Brimstone Repo
Whether you're a member of the CyberArk team, or are just getting involved with our community, these general-purpose guidelines are meant to help you familiarize yourself with our processes. You can use them when working on any of our public projects, including this one!
As you visit the various guides and documents throughout this repository, you may notice something that you feel is missing, or perhaps you feel it could be improved in some way. This documentation is used by a wide variety of community members, it's important to us that we are as clear and thorough as possible, so your perspective is important! Your feedback can help countless others, so don't be afraid to be the change you want to see!
Your first step should be checking the Issues
tab to see if someone else has already created the
issue. If it has been created, check out the working on issues section, or
feel free to add additional context or information about the topic. If it hasn't been created, read
about how to report a new issue!
-
After confirming that the topic doesn't already exist, you'll need to click
New Issue
to create it. -
Select a template, as this will automatically add an appropriate tag and provide additional guidelines for what information is required.
-
Create a descriptive title for the issue, using present-tense verbage, e.g.
Secretless Broker does not have emoji support
-
Add the appropriate tag for your issue, if one was not added by the template, e.g.
kind/documenation kind/enhancement
-
Continue to monitor the issue for responses and engage in conversation until resolved
-
Click the
Issues
tab on Github to see open issues -
Select an existing issue and provide the following information in a comment:
- State your intention to work on the issue
- Provide an outline for your implementation plan
This is important to avoid the overlapping of work!
-
If the issue is already in progress, feel free to ask questions or engage in conversation about the implementation. Otherwise, review the repository license requirements before starting work and continue on to working on issues.
To contribute to any CyberArk open source project, you must make sure you've met our contributor license requirements.
To find out what the project you're interested in requires, refer to the
CONTRIBUTING.md
file in the repository.
If the CONTRIBUTING.md
document indicates that you need to sign the CLA, for example:
"Thanks for your interest in Conjur. Before contributing, please take a moment to read and sign our Contributor Agreement. This provides patent protection for all Conjur users and allows CyberArk to enforce its license terms. Please email a signed copy to oss@cyberark.com."
Then you must submit a signed copy of the CLA to oss@cyberark.com in order for your contribution to be merged.
A copy of the CLA can be found here.
If the repo does not ask you to sign the CLA, then you may do one of the following:
- Follow the above instructions for signing the CLA.
OR
- Sign your commits using the
--signoff
flag in thegit
CLI (more info here) to certify that you have the rights to submit the work under the same license as the project and you agree to a Developer Certificate of Origin (see http://developercertificate.org/ for more information).
When signing, every commit must be signed, and your PR will not be approved until this is the case.
To sign-off, use:
git commit --signoff
or
git commit -s
Alternatively, if you have already made the commit, you may use:
git commit --amend --signoff
or
git commit --amend -s
After amending a commit, you will need to force-push (git push -f <branch_name>
)
to your branch for this to take effect.
Note: Only repositories licensed under MIT, BSD, or Apache 2.0 are eligible to use the DCO instead of the CLA for community contributions!! If the repo does not meet this criterion, you must sign the CLA.
To determine if you have signed a commit, look at the commit history in the branch to ensure each commit includes a line like:
Signed-off-by: Jane A Doe <jane@developer.example.org>
This line should include your real name and contact email.
-
After receiving confirmation that the issue is not already in progress, add the
Implementing
label to the issue as you begin to work on it. -
Make local changes to your fork by editing files.
-
Run tests as described in the
CONTRIBUTING.md
or as outlined in the test stage(s) in theJenkinsfile
, ensuring they pass. -
Commit your changes, making sure to sign off on your commits.
-
Once you have wrapped up your work, you should verify that your commit history is clean and organized.
-
Sync your fork with the upstream repository and resolve any conflicts.
-
Navigate to GitHub and open a
Pull Request
("PR
"). -
Make sure you're requesting a merge into the main (or default) branch of the upstream project from your fork.
-
Add a PR title and description.
-
Add a title to the PR that describes what the set of changes included in the PR accomplishes, as well as a reference to the issue it addresses, if an issue exists. The PR title should be clear, specific, and succinct.
-
Examples of bad PR titles:
Component refactor Minor fixes Add tests
-
Examples of good PR titles:
#40 - Improved logs for default authenticator Bump special-gem version to 1.3.2 #1645 - Add support for configuring connector plugin via environment
-
-
Add a description to the PR that details the changes you made, filling out any categories listed by a template, and linking the original issue in the description, e.g.
Connected to #[Issue Number]
-
-
Add the
Implemented
label to the issue. -
Tag a reviewer if any are recommended in the righthand menu.
-
Submit the Pull-Request.
Once your pull-request has been submitted for review, a reviewer will look for a few things.
-
A maintainer will verify that any contributor license agreements have been met. Required contributor license agreements (if any) are usually documented in the repo's CONTRIBUTING.md.
-
A maintainer will review your code, and verify that it addresses the issue sufficiently while meeting the contribution guidelines or style patterns for the project.
Here are a few things a reviewer may look for.
- Has the branch author done a good job cleaning up the commit history?
- Has the branch been rebased against the main or default branch?
- Has the code been thoroughly tested?
- Have you ran any unit or integration tests, and made note of it in the pull-request description?
- Have you performed any manual or non-standard tests, and made note of them in the pull-request description?
- Does this pull-request require an update to any existing documentation?
- If so, does an issue need to be made for updating the documentation?
- Is the code written in a way that is consistent with the existing code base?
-
The maintainer will finalize their review
- If a reviewer notices an issue with your pull-request, such as those listed above, they will request changes be made. You may need to go back and fix a thing or two before it can be approved.
- If any of the reviewer's feedback is optional, it will be clearly marked "Not required" or "nit". It might still be worth addressing, if you can.
-
Respond directly to any comments with any of your questions or concerns.
-
After making any changes, required or otherwise, make sure your commit history is still organized, and make sure you have recently rebased off of main or default branch.
-
If changes were requested, you can prompt for a re-review at the bottom of your pull-request's page in Github. Otherwise, you can click the 're-review' icon beside the reviewers name on the righthand side of your pull-request page.
-
From here you will engage in conversation with the reviewer(s) until they are satisfied with the branch state, and confirm that it is ready to merge into main or default branch. Once the PR is approved (Marked as "Approved" in Github), you are ready to merge your changes!
We want to provide our community with the best possible experience when they choose to contribute to one of our projects. That means constant improvements to this project and the documentation therein.
Looking through issues for this project is a great way to see what we're doing to improve the community experience, and to see what we're planning for the future.
If you have an idea for something that could be added or improved, feel free to submit an issue yourself!
Since standards for contribution can vary from project to project, it's beneficial to use the following tips to make that information easy to find, and easy to use.
-
The project should be listed in the dropdown-list in the Brimstone README.md, under its respective team
-
Within the project's own repository, a CONTRIBUTING.md file should be the standard entry-point for a contributor, whether internal or external. If it does not exists, it's recommended that one is created, and pointed to by the top-level README.md of the project.
A good CONTRIBUTING.md has the following:- A reference to this community repo for general guidelines
- Where to find issues
- How to report new issues
- How to work on issues
- Standards for writing in the project-specific language
- How to build, run, and test the project
- Any relevant forums for discussion and collaboration
- Any project-specific best practices
-
Templates for issues can improve the information gathered for a new issue, and provide helpful organization, while reducing the amount of domain knowledge required for filing an issue, and should be created and wherever possible. For example, templates for common cases like
bugs
orfeature requests
can save time and cut down on requests for additional information.