Contributing to @node-oauth/oauth2-server
Thank you for your interest in this project and your aims to improving it. This guide will give you the most important info on how to contribute properly in order to get your pull requests accepted.
Disclose security vulnerabilities
First things first: This project has strong security implications, and we appreciate every help to improve security.
However, please read our security policy, before taking actions.
Guiding principles
Before contributing to this project it is important to understand how this project and it's collaborators views itself regarding its scope and purpose.
OAuth2 standard compliance
This project aims full standard compliance. All improvements on functionality, as well as security implications, are done in a way that the standard remains as the highest reference of choice.
If you are not familiar with the OAuth2 standards, please consult at least the following documents:
Extended readings:
- RFC 6819 - OAuth 2.0 Threat Model and Security Considerations
- RFC 7636 - Proof Key for Code Exchange by OAuth Public Clients
- RFC 7591 - OAuth 2.0 Dynamic Client Registration Protocol
Framework-agnostic
Design decisions and implementations are always done with keeping in mind, that there are multiple frameworks out there that use this project.
Development
If you want to fix bugs or add new features, please read this chapter and it's sections carefully!
No PR without issue
Please make sure your commitment will be appreciated by first opening an issue and discuss, whether this is a useful addition to the project.
Work on a bug or a new feature
First, clone and install this project from source via
git clone git@github.com:node-oauth/node-oauth2-server.git
cd node-oauth2-server
git checkout development # important! do not work on master!
npm installFrom here you can run several scripts for development purposes:
npm run test # runs the tests once
npm run test:coverage # runs the tests including coverage
npm run docs # generates the API docsTo work on a new feature or a fix please create a new branch:
git checkout -b feature-xyz # or fix-xyzCoding rules
- Unit-testing: all features or bug fixes must be tested by specs
- Documentation: all public API methods must be documented
Commit message convention
We use a commit convention, inspired by angular commit message format with ticket number at the end of summary:
<type>(<scope>): <short summary> #<issue number>Summary in present tense. Not capitalized. No period at the end. The <type> and <summary> fields are mandatory, the (<scope>) and #<number> fields are optional.
Run the tests before committing
Please always make sure your code is passing linter and tests before committing. By doing so you help to make reviews much easier and don't pollute the history with commits, that are solely targeting lint fixes.
You can run the tests via
npm run testor
npm run test:coverageto see your coverage.
Open a pull request (PR)
Once you have implemented your changes and tested them locally, please open a pull request.
Note: sometimes a pull request (PR) is also referred to as merge request (MR).
Fundamental PR requirements
There are a few basic requirements for your pull request to become accepted:
- Make sure to open your pull request to target the
developmentbranch and notmaster - Make sure you are working on a branch, other than
development; usually you can name the branch after the feature or fix you want to provide - Resolve any merge conflicts (usually by keeping your branch updated with
development) - Have a clear description on what the PR does, including any steps necessary for testing, reviewing, reproduction etc.
- Link to the existing issue
- Added functions or changed functions need to get documented in compliance with JSDoc
- Make sure all CI Tests are passing
Also make sure, to comply with the following list:
- Do not work on
developmentdirectly - Do not implement multiple features in one pull request (this includes bumping versions of dependencies that are not related to the PR/issue)
- Do not bump the release version (unless you are a maintainer)
- Do not edit the Changelog as this will be done after your PR is merged
- Do not introduce tight dependencies to a certain package that has not been approved during the discussion in the issue
Review process
Finally, your PR needs to pass the review process:
- A certain amount of maintainers needs to review and accept your PR
- Please expect change requests! They will occur and are intended to improve the overall code quality.
- If your changes have been updated please re-assign the reviewer who asked for the changes
- Once all reviewers have approved your PR it will be merged by one of the maintainers 🎉
After merge
Please delete your branch after merge.
Documentation
We use Vitepress+Markdown for our documentation. If you want to contribute to the docs, please get familiar with Vitepress: https://vitepress.dev
Setting up docs
You need NPM to set up the docs using the following:
npm install
npm run docs:setupYou can then edit the guide section manually.
API Docs
DO NOT edit the api section, as API docs are automatically generated from our internal JSDoc comments.
Instead, update the comments directly within the code and run npm run docs:api to generate the api docs.
Building the docs
Run npm run docs:build to build the docs.