mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-05 22:34:22 +03:00
3bb29d8f97
PR-URL: https://github.com/hasura/graphql-engine-mono/pull/10566 Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Manas Agarwal <5352361+manasag@users.noreply.github.com> GitOrigin-RevId: 7ce38991d7b00250697eec34c7ff94fea5f55d41
186 lines
6.5 KiB
Markdown
186 lines
6.5 KiB
Markdown
# Contributing to Hasura GraphQL Engine
|
|
|
|
_First_: if you feel insecure about how to start contributing, either to V2 or V3, feel free to ask us on our
|
|
[Discord](https://discordapp.com/invite/hasura) in the `#contrib` channel. You can also just go ahead with your
|
|
contribution, and we'll give you feedback. Don't worry - the worst that can happen is that you'll be politely asked to
|
|
change something. We appreciate any contributions, and we don't want a wall of rules to stand in the way of that.
|
|
|
|
However, for those individuals who want a bit more guidance on the best way to contribute to the project, read on. This
|
|
document will cover what we're looking for. By addressing the points below, the chances that we can quickly merge or
|
|
address your contributions will increase.
|
|
|
|
## Table of contents
|
|
|
|
[1. Code of conduct ](#code-of-conduct)
|
|
|
|
[2. Repo overview ](#overview)
|
|
|
|
[3. First time contributors welcome! ](#first-timers)
|
|
|
|
[4. Areas for contributing ](#areas)
|
|
|
|
[5. Ways of contributing ](#ways)
|
|
|
|
[6. Commit messages ](#commit-messages)
|
|
|
|
[7. Translations ](#translations)
|
|
|
|
<a name="code-of-conduct"></a>
|
|
|
|
## 1. Code of conduct
|
|
|
|
Please follow our [Code of conduct](code-of-conduct.md) in the context of any contributions made to Hasura.
|
|
|
|
<a name="overview"></a>
|
|
|
|
## 2. Repo overview
|
|
|
|
[hasura/graphql-engine](https://github.com/hasura/graphql-engine) is a mono-repo for both the open source V2 and V3
|
|
Hasura versions.
|
|
|
|
### V2
|
|
|
|
This V2 portion consists of 3 components and each has their own contributing guide:
|
|
|
|
1. [Server (Haskell)](server/CONTRIBUTING.md)
|
|
|
|
2. [CLI (Go)](cli/CONTRIBUTING.md)
|
|
|
|
3. [Console (JavaScript)](frontend/docs/generic-info.md#contributing-to-hasura-console)
|
|
|
|
All of the three components have a single version, denoted by either the git tag or a combination of branch name and git
|
|
commit SHA.
|
|
|
|
For all contributions, a CLA (Contributor License Agreement) needs to be signed
|
|
[here](https://cla-assistant.io/hasura/graphql-engine) before (or after) the pull request has been submitted. A bot will
|
|
prompt contributors to sign the CLA via a pull request comment, if necessary.
|
|
|
|
### V3
|
|
|
|
The V3 portion is the V3 engine exclusively, the heart of Hasura, which is written in Rust.
|
|
|
|
1. [V3 Engine (Rust)](v3/CONTRIBUTING.md)
|
|
|
|
Check out the [V3 README here](/v3/README.md).
|
|
|
|
<a name="first-timers"></a>
|
|
|
|
## 3. First time contributors welcome!
|
|
|
|
We appreciate first time contributors, and we are happy to assist you in getting started. In case of questions, just
|
|
reach out to us!
|
|
|
|
You find all issues suitable for first time contributors
|
|
[here](https://github.com/hasura/graphql-engine/issues?q=is%3Aopen+is%3Aissue+label%3A%22good+first+issue%22).
|
|
|
|
<a name="areas"></a>
|
|
|
|
## 4. Areas for contributing
|
|
|
|
Of course, we appreciate contributions to all components of Hasura. However, we have identified three areas that are
|
|
particularly suitable for open source contributions.
|
|
|
|
### V2 Docs
|
|
|
|
Our goal is to keep our docs comprehensive and updated. If you would like to help us in doing so, we are grateful for
|
|
any kind of contribution:
|
|
|
|
- Report missing content
|
|
|
|
- Fix errors in existing docs
|
|
|
|
- Help us in adding to the docs
|
|
|
|
The contributing guide for docs can be found at [docs/CONTRIBUTING.md](docs/CONTRIBUTING.md).
|
|
|
|
### V2 Community content
|
|
|
|
Since we launched our [learn page](https://hasura.io/learn/), we are happy about contributions:
|
|
|
|
- Fix errors in existing learn tutorials
|
|
|
|
- Add new tutorials (please reach out to us if you have ideas to avoid duplicate word)
|
|
|
|
The README of the learn repository can be found [here](https://github.com/hasura/learn-graphql).
|
|
|
|
Apart from the learn content, we have identified three other ways of contributing with technical community content:
|
|
|
|
- [Boilerplates](https://github.com/hasura/graphql-engine/tree/master/community/boilerplates)
|
|
|
|
- [Sample apps](https://github.com/hasura/sample-apps/tree/main)
|
|
|
|
- [Tools](community/tools)
|
|
|
|
If you would like to contribute to the community by
|
|
|
|
- writing a technical blogpost
|
|
|
|
- speaking at an event
|
|
|
|
- organizing a workshop
|
|
|
|
check out our [community wiki](https://github.com/hasura/graphql-engine/wiki/Community-Wiki).
|
|
|
|
Feel free to submit a pull request if you have something to add even if it's not related to anything mentioned above.
|
|
|
|
### V2 CLI
|
|
|
|
We have some issues on the CLI that are suitable for open source contributions. If you know Go or if you would like to
|
|
learn it by doing, check out the following
|
|
[issues](https://github.com/hasura/graphql-engine/issues?q=is%3Aopen+is%3Aissue+label%3Ac%2Fcli+label%3A%22help+wanted%22).
|
|
|
|
The README of the CLI repository can be found [here](https://github.com/hasura/graphql-engine/tree/master/cli).
|
|
|
|
<a name="ways"></a>
|
|
|
|
## 5. Ways of contributing
|
|
|
|
### Reporting an Issue
|
|
|
|
- Make sure you test against the latest released version. It is possible that we may have already fixed the bug you're
|
|
experiencing.
|
|
|
|
- Provide steps to reproduce the issue, including Postgres version, graphql-engine version and the provider you are
|
|
running on (Heroku, Docker, etc.).
|
|
|
|
- Please include logs of the server, if relevant.
|
|
|
|
- Create a [issue](https://github.com/hasura/graphql-engine/issues/new/choose).
|
|
|
|
### Working on an issue
|
|
|
|
- We use the [fork-and-branch git workflow](https://blog.scottlowe.org/2015/01/27/using-fork-branch-git-workflow/).
|
|
|
|
- Please make sure there is an issue associated with the work that you're doing.
|
|
|
|
- If you're working on an issue, please comment that you are doing so to prevent duplicate work by others also.
|
|
|
|
- Squash your commits and refer to the issue using `fix #<issue-no>` or `close #<issue-no>` in the commit message, at
|
|
the end. For example: `resolve answers to everything (fix #42)` or `resolve answers to everything, fix #42`
|
|
|
|
- Rebase master with your branch before submitting a pull request.
|
|
|
|
<a name="commit-messages"></a>
|
|
|
|
## 6. Commit messages
|
|
|
|
- The first line should be a summary of the changes, not exceeding 50 characters, followed by an optional body which has
|
|
more details about the changes. Refer to [this link](https://github.com/erlang/otp/wiki/writing-good-commit-messages)
|
|
for more information on writing good commit messages.
|
|
|
|
- Use the imperative present tense: "add/fix/change", not "added/fixed/changed" nor "adds/fixes/changes".
|
|
|
|
- Don't capitalize the first letter of the summary line.
|
|
|
|
- Don't add a period/dot (.) at the end of the summary line.
|
|
|
|
<a name="translations"></a>
|
|
|
|
## 7. Translations
|
|
|
|
This document is available in the following translations:
|
|
|
|
- [French 🇫🇷](translations/CONTRIBUTING.french.md)
|
|
|
|
(Credits: Some sections are adapted from https://github.com/PostgREST/postgrest/blob/master/.github/CONTRIBUTING.md)
|