Thank you for contributing to the Stanford Spezi open-source project! We value the time and effort you invest in the open-source project!
The keywords "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119.
We REQUIRED using GitHub Discussions at https://github.com/orgs/StanfordSpezi/discussions for any discussions about the project. You MUST follow our Code of Conduct.
We REQUIRED using the Github Flow for all code-related contributions. GitHub discussions SHALL be the best way to brainstorm your suggestions. GitHub issues SHALL be the best way to document decisions or bugs. Pull requests SHALL be the best way to propose changes to the codebase.
Each contribution to a Spezi repository REQUIRES a GitHub account. We RECOMMEND to add your full name, a representative profile picture, and your preferred pronoums to your GitHub Account to make it easier to address you and recognize you across commits.
In addition, all commits to Spezi repositories MUST be signed. You can learn more about commit signature verification and how to set it up in the GitHub documentation..
Important
Be sure to set up commit signature verification before you make your first commit to a Stanford Spezi repository or a fork you plan to use to contribute to a Stanford Spezi repository.
The Stanford Spezi open-source project follows the Github Flow to enable everyone to easily contribute to a repositiry using forks and pull requests.
As a contributor who is not part of the core team, you MUST create a fork to contribute to a Stanford Spezi repository. "Forks let you make changes to a project without affecting the original repository"[About forks - GitHub Documentation]. We RECOMMEND to follow the "Fork a repository" instructions to create a new fork of the Stanford Spezi repository you want to contribute to.
Once you have created a fork of the repository, you can start to make any changes in conformance with this contributing guide to your repository. Once you have properly tested, documented, and validated all the changes, you MUST use a pull request to contribute your changes back to the upstream repository. "A pull request is a proposal to merge a set of changes from one branch into another."[About pull requests - GitHub Documentation]. We RECOMMEND to follow the "Creating a pull request from a fork" instructions to create a PR based on the fork that you have created. We RECOMMEND to request a PR review from one of the core team members. Each PR MUST provide a proper description based on the PR template displayed when you create a PR and SHOULD be tagged with the appropriate labels and linked to any related GitHub issues or discussions.
Every new contribution MUST be properly documented. All documentation MUST conform to our Documentation Guide
Every new contribution MUST be properly tested and automatically verified using unit tests, user interface (UI) tests, and our continuous integration (CI) setup using GitHub Actions.
Your submissions MUST be published and conform to the license currently used in the respective repository.
We use the REUSE Software Conventions to structure our attributions and contributor lists.
Each file MUST contain the following header information with Spezi
being replaced with the project name and MIT
with the SPDX License Identifier.
This source file is part of the Stanford Spezi open-source project
SPDX-FileCopyrightText: 2022 Stanford University and the project authors (see CONTRIBUTORS.md)
SPDX-License-Identifier: MIT
As referenced in the copyright text, we list all contributors in the CONTRIBUTORS.md at the root of every repository. Each contributor SHOULD add themselves to the CONTRIBUTORS.md in a pull request with a sizable and meaningful contribution to the project. The addition and final decision to be added to the CONTRIBUTORS.md is up to the Spezi core team.
If your code is based on another source, you MUST add a reference to the original source code to the specific code (e.g., using a comment) and make sure that the license of the original source allows the usage under the license used in the project.
We use GitHub issues to track work items. Report a bug SHALL be done by opening a new issue using the bug issue template.
Please refer to our Support Policy for information about getting support.
For security and vulnerability-related issues, please refer to our Support Policy.
Stanford Spezi consists of a wide variety of projects in different programming languages. While many things are common to all the different programming languages and setups, some specific subsystems have dedicated setups to make contributing, testing, and documenting easier.
Spezi has a great collection of Swift Package-based modules: https://swiftpackageindex.com/StanfordSpezi. You MUST conform to the Swift-specific Contributing Guideleines if you make a contribution to a Swift-based Stanford Spezi project.