Project Code Repository Policy
Each Apache project can have a directory in the Apache Subversion repository, or Git repositories, for their product code and assets. The majority of projects now use Git.
- Each project can have a public directory in the Subversion repository, or as many public Git repositories as their work requires.
- Each project can request (using a Jira ticket) that Infra set up a temporary private Git repository fork for use with tasks, such as fixing security issues in project code, that should not be publicly available. The PMC must explain its need of a private fork in the Jira ticket. Forks will be tied to Jira tickets or CVEs such that upon completion of the work, the private fork can be decommissioned by Infra.
- Private repos must have commit/PR/issues emails sent to the project's
private@
list. - To follow the Infra convention, name project repos in the pattern
$project-$reponame
in order to map the project LDAP group to the permissions scheme.
Git repositories
- We recommend using GitHub for your interactions with writable Git repositories.
- Those who have reservations about GitHub's terms and conditions can use Apache's GitBox, which also gives full access to Apache's writable Git repositories.
- To link your GitHub and Apache IDs, follow these instructions.
- Projects can request new, blank, public repositories through selfserve.
- Apache does not support custom commits or other hooks. All projects get the same hooks. Setting up gitpubsub should provide sufficient flexibility without impacting the core Git setup.
Git customizations
Git offers a number of customizations for committing code to a repository. Apache does not support all of them for its projects. For instance:
- supported
- Head branches automatically deleted after pull requests are merged.
- Commit squashing for pull requests.
- Default to pull request titles for squash commits.
- Commit merging for pull requests.
- Commit rebasing for pull requests.
- Always update a pull request branch when it is not up to date with the base branch.
To deploy one of these customizations for your project's repository, ask Infra for help via a Jira ticket.
- not supported
- Auto-merge of pull requests.
- Merge queues. This feature is in limited beta.
Subversion directories
Typically, the Incubator PMC makes a Jira request to Infra to create an SVN directory for a graduating project, or for a project joining the ASF with an existing SVN directory. If a project needs a subdirectory for a specific purpose, it requests its creation in a Jira ticket to Infra.
You can find a list of ASF Subversion directories at svn.apache.org/viewvc.
Repository access
- ASF projects must house their project code in ASF supported services (Subversion, GitBox).
- Only people with an ICLA on file with Apache can create, edit, or update code housed within the ASF. There is no third-party access to create, edit, or delete files.
- Apache software projects are open-source, so everyone has read access to all public code housed within the ASF.
- Documentation is not code. Projects can host their documentation anywhere (such as on platforms like readthedocs and gitlab) and, if they choose, make them available to the world to create and edit pages.
- However, if projects create and house their documentation inside the ASF, statement 2 applies to it.
Since the primary presence of an Apache project must be within Apache, there is an argument for storing project documentation in its own repository alongside the project's code repository. This practice also makes it easier for project committers to move from committing new features, or updates to existing features, to writing about them for the project's users.
Copyright 2024, The Apache Software Foundation, Licensed under the Apache License, Version 2.0.
Apache® and the Apache feather logo are trademarks of The Apache Software Foundation.