2021-06-21 11:51:14 +02:00
<!--
Thank you for contributing changes to this document! Because we use a central repository
to synchronize this file across all our repositories, make sure to make your edits
in the correct file, which you can find here:
https://github.com/ory/meta/blob/master/templates/repository/common/CONTRIBUTING.md
-->
2022-06-16 19:31:32 +00:00
# Contributing to Ory Ory Oathkeeper Maester
2021-06-21 11:51:14 +02:00
<!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE - RUN doctoc TO UPDATE -->
- [Introduction ](#introduction )
- [FAQ ](#faq )
- [How can I contribute? ](#how-can-i-contribute )
- [Communication ](#communication )
- [Contributing Code ](#contributing-code )
- [Documentation ](#documentation )
- [Disclosing vulnerabilities ](#disclosing-vulnerabilities )
- [Code Style ](#code-style )
- [Working with Forks ](#working-with-forks )
- [Conduct ](#conduct )
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
## Introduction
2022-06-16 19:31:28 +00:00
There are many ways in which you can contribute, beyond writing code. The goal of this document is to provide a high-level
overview of how you can get involved.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:32 +00:00
_Please note_: We take Ory Ory Oathkeeper Maester's security and our users' trust very seriously. If you believe you have found a security issue
in Ory Ory Oathkeeper Maester, please responsibly disclose by contacting us at security@ory .sh.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
First: As a potential contributor, your changes and ideas are welcome at any hour of the day or night, weekdays, weekends, and
holidays. Please do not ever hesitate to ask a question or send a pull request.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
If you are unsure, just ask or submit the issue or pull request anyways. You won't be yelled at for giving it your best effort.
The worst that can happen is that you'll be politely asked to change something. We appreciate any sort of contributions, and don't
want a wall of rules to get in the way of that.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
That said, if you want to ensure that a pull request is likely to be merged, talk to us! You can find out our thoughts and ensure
that your contribution won't clash or be obviated by Ory
2022-06-16 19:31:32 +00:00
Ory Oathkeeper Maester's normal direction. A great way to
2021-06-21 11:51:14 +02:00
do this is via
2022-06-16 19:31:32 +00:00
[Ory Ory Oathkeeper Maester Discussions ](https://github.com/orgs/ory/discussions ) or the
2022-06-16 19:31:28 +00:00
[Ory Chat ](https://www.ory.sh/chat ).
2021-06-21 11:51:14 +02:00
## FAQ
- I am new to the community. Where can I find the
[Ory Community Code of Conduct? ](https://github.com/ory/hydra-maester/blob/master/CODE_OF_CONDUCT.md )
2022-06-16 19:31:32 +00:00
- I have a question. Where can I get [answers to questions regarding Ory Ory Oathkeeper Maester? ](#communication )
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
- I would like to contribute but I am not sure how. Are there [easy ways to contribute? ](#how-can-i-contribute )
2021-06-21 11:51:14 +02:00
[Or good first issues? ](https://github.com/search?l=&o=desc&q=label%3A%22help+wanted%22+label%3A%22good+first+issue%22+is%3Aopen+user%3Aory+user%3Aory-corp&s=updated&type=Issues )
2022-06-16 19:31:32 +00:00
- I want to talk to other Ory Ory Oathkeeper Maester users. [How can I become a part of the community? ](#communication )
2021-06-21 11:51:14 +02:00
- I would like to know what I am agreeing to when I contribute to Ory
2022-06-16 19:31:32 +00:00
Ory Oathkeeper Maester.
2021-06-21 11:51:14 +02:00
Does Ory have
[a Contributors License Agreement? ](https://cla-assistant.io/ory/hydra-maester )
2022-06-16 19:31:32 +00:00
- I would like updates about new versions of Ory Ory Oathkeeper Maester.
2021-06-21 11:51:14 +02:00
[How are new releases announced? ](https://ory.us10.list-manage.com/subscribe?u=ffb1a878e4ec6c0ed312a3480&id=f605a41b53 )
## How can I contribute?
If you want to start contributing code right away, we have a
[list of good first issues ](https://github.com/ory/hydra-maester/labels/good%20first%20issue ).
2022-06-16 19:31:28 +00:00
There are many other ways you can contribute without writing any code. Here are a few things you can do to help out:
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
- **Give us a star.** It may not seem like much, but it really makes a difference. This is something that everyone can do to help
2022-06-16 19:31:32 +00:00
out Ory Ory Oathkeeper Maester. Github stars help the project gain visibility and stand out.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
- **Join the community.** Sometimes helping people can be as easy as listening to their problems and offering a different
perspective. Join our Slack, have a look at discussions in the forum and take part in our weekly hangout. More info on this in
[Communication ](#communication ).
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:32 +00:00
- **Helping with open issues.** We have a lot of open issues for Ory Ory Oathkeeper Maester and some of them may lack necessary information,
2022-06-16 19:31:28 +00:00
some are duplicates of older issues. You can help out by guiding people through the process of filling out the issue template,
asking for clarifying information, or pointing them to existing issues that match their description of the problem.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
- **Reviewing documentation changes.** Most documentation just needs a review for proper spelling and grammar. If you think a
document can be improved in any way, feel free to hit the `edit` button at the top of the page. More info on contributing to
documentation [here ](#documentation ).
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
- **Help with tests.** Some pull requests may lack proper tests or test plans. These are needed for the change to be implemented
safely.
2021-06-21 11:51:14 +02:00
## Communication
2022-06-16 19:31:28 +00:00
We use [Slack ](https://www.ory.sh/chat ). You are welcome to drop in and ask questions, discuss bugs and feature requests, talk to
other users of Ory, etc.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:32 +00:00
Check out [Ory Ory Oathkeeper Maester Discussions ](https://github.com/orgs/ory/discussions ). This is a great place for in-depth discussions and lots of code examples, logs
2022-06-16 19:31:28 +00:00
and similar data.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
You can also join our community hangout, if you want to speak to the Ory team directly or ask some questions. You can find more
info on the hangouts in [Slack ](https://www.ory.sh/chat ).
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:32 +00:00
If you want to receive regular notifications about updates to Ory Ory Oathkeeper Maester, consider joining the mailing list. We will _only_ send
2022-06-16 19:31:28 +00:00
you vital information on the projects that you are interested in.
2021-06-21 11:51:14 +02:00
Also [follow us on twitter ](https://twitter.com/orycorp ).
## Contributing Code
2022-06-16 19:31:28 +00:00
Unless you are fixing a known bug, we **strongly** recommend discussing it with the core team via a GitHub issue or
2022-06-16 19:31:32 +00:00
[in our chat ](https://www.ory.sh/chat ) before getting started to ensure your work is consistent with Ory Ory Oathkeeper Maester's roadmap and
2022-06-16 19:31:28 +00:00
architecture.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
All contributions are made via pull requests. To make a pull request, you will need a GitHub account; if you are unclear on this
process, see GitHub's documentation on [forking ](https://help.github.com/articles/fork-a-repo ) and
[pull requests ](https://help.github.com/articles/using-pull-requests ). Pull requests should be targeted at the `master` branch.
Before creating a pull request, go through this checklist:
2021-07-12 21:45:42 +02:00
1. Create a feature branch off of `master` so that changes do not get mixed up.
2022-06-16 19:31:28 +00:00
1. [Rebase ](http://git-scm.com/book/en/Git-Branching-Rebasing ) your local changes against the `master` branch.
1. Run the full project test suite with the `go test -tags sqlite ./...` (or equivalent) command and confirm that it passes.
1. Run `make format` if a `Makefile` is available, `gofmt -s` if the project is written in Go, `npm run format` if the project is
written for NodeJS.
1. Ensure that each commit has a descriptive prefix. This ensures a uniform commit history and helps structure the changelog.
2022-06-16 19:31:32 +00:00
Please refer to this [list of prefixes for Ory Oathkeeper Maester ](https://github.com/ory/hydra-maester/blob/master/.github/semantic.yml ) for an
2022-06-16 19:31:28 +00:00
overview.
1. Sign-up with CircleCI so that it has access to your repository with the branch containing your PR. Simply creating a CircleCI
account is sufficient for the CI jobs to run, you do not need to setup a CircleCI project for the branch.
2021-06-21 11:51:14 +02:00
2021-07-12 21:45:42 +02:00
If a pull request is not ready to be reviewed yet
[it should be marked as a "Draft" ](https://docs.github.com/en/github/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/changing-the-stage-of-a-pull-request ).
2021-06-21 11:51:14 +02:00
2021-07-12 21:45:42 +02:00
Before your contributions can be reviewed you need to sign our
2021-06-21 11:51:14 +02:00
[Contributor License Agreement ](https://cla-assistant.io/ory/hydra-maester ).
2022-06-16 19:31:28 +00:00
This agreement defines the terms under which your code is contributed to Ory. More specifically it declares that you have the
right to, and actually do, grant us the rights to use your contribution. You can see the Apache 2.0 license under which our
projects are published [here ](https://github.com/ory/meta/blob/master/LICENSE ).
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
When pull requests fail testing, authors are expected to update their pull requests to address the failures until the tests pass.
2021-07-12 21:45:42 +02:00
Pull requests eligible for review
1. follow the repository's code formatting conventions;
2022-06-16 19:31:28 +00:00
2. include tests which prove that the change works as intended and does not add regressions;
2021-07-12 21:45:42 +02:00
3. document the changes in the code and/or the project's documentation;
4. pass the CI pipeline;
2022-06-16 19:31:28 +00:00
5. have signed our [Contributor License Agreement ](https://cla-assistant.io/ory/hydra-maester );
2021-07-12 21:45:42 +02:00
6. include a proper git commit message following the
[Conventional Commit Specification ](https://www.conventionalcommits.org/en/v1.0.0/ ).
2022-06-16 19:31:28 +00:00
If all of these items are checked, the pull request is ready to be reviewed and you should change the status to "Ready for review"
and
2021-07-12 21:45:42 +02:00
[request review from a maintainer ](https://docs.github.com/en/github/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/requesting-a-pull-request-review ).
Reviewers will approve the pull request once they are satisfied with the patch.
2021-06-21 11:51:14 +02:00
## Documentation
2022-06-16 19:31:28 +00:00
Please provide documentation when changing, removing, or adding features. Documentation resides in the project's
[docs ](https://github.com/ory/hydra-maester/tree/master/docs ) folder. Generate API and configuration reference documentation using
`cd docs; npm run gen` .
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
For further instructions please head over to [docs/README.md ](https://github.com/ory/hydra-maester/blob/master/README.md ).
2021-06-21 11:51:14 +02:00
## Disclosing vulnerabilities
2022-06-16 19:31:28 +00:00
Please disclose vulnerabilities exclusively to [security@ory.sh ](mailto:security@ory.sh ). Do not use GitHub issues.
2021-06-21 11:51:14 +02:00
## Code Style
Please follow these guidelines when formatting source code:
- Go code should match the output of `gofmt -s` and pass `golangci-lint run` .
2022-06-16 19:31:28 +00:00
- NodeJS and JavaScript code should be prettified using `npm run format` where appropriate.
2021-06-21 11:51:14 +02:00
### Working with Forks
```
# First you clone the original repository
git clone git@github .com:ory/ory/hydra-maester.git
# Next you add a git remote that is your fork:
git remote add fork git@github .com:< YOUR-GITHUB-USERNAME-HERE > /ory/hydra-maester.git
# Next you fetch the latest changes from origin for master:
git fetch origin
git checkout master
git pull --rebase
# Next you create a new feature branch off of master:
git checkout my-feature-branch
# Now you do your work and commit your changes:
git add -A
git commit -a -m "fix: this is the subject line" -m "This is the body line. Closes #123 "
# And the last step is pushing this to your fork
git push -u fork my-feature-branch
```
Now go to the project's GitHub Pull Request page and click "New pull request"
## Conduct
2022-06-16 19:31:28 +00:00
Whether you are a regular contributor or a newcomer, we care about making this community a safe place for you and we've got your
back.
2021-06-21 11:51:14 +02:00
2022-06-16 19:31:28 +00:00
- We are committed to providing a friendly, safe and welcoming environment for all, regardless of gender, sexual orientation,
disability, ethnicity, religion, or similar personal characteristic.
- Please avoid using nicknames that might detract from a friendly, safe and welcoming environment for all.
2021-06-21 11:51:14 +02:00
- Be kind and courteous. There is no need to be mean or rude.
2022-06-16 19:31:28 +00:00
- We will exclude you from interaction if you insult, demean or harass anyone. In particular, we do not tolerate behavior that
excludes people in socially marginalized groups.
- Private harassment is also unacceptable. No matter who you are, if you feel you have been or are being harassed or made
2022-06-16 19:31:32 +00:00
uncomfortable by a community member, please contact one of the channel ops or a member of the Ory Ory Oathkeeper Maester core team
2022-06-16 19:31:28 +00:00
immediately.
- Likewise any spamming, trolling, flaming, baiting or other attention-stealing behaviour is not welcome.
We welcome discussion about creating a welcoming, safe, and productive environment for the community. If you have any questions,
feedback, or concerns [please let us know ](https://www.ory.sh/chat ).