# Release management ## Shared user: release-team The [release-team](https://codeberg.org/release-team) user publishes and signs all releases. The associated email is mailto:release@forgejo.org. The public GPG key used to sign the releases is [EB114F5E6C0DC2BCDD183550A4B61A2DC5923710](https://codeberg.org/release-team.gpg) `Forgejo Releases ` ## Release numbering The Forgejo release numbers are composed of the Gitea release number followed by a dash and a serial number. For instance: * Gitea **v1.18.0** will be Forgejo **v1.18.0-0**, **v1.18.0-1**, etc The Gitea release candidates are suffixed with **-rcN** which is handled as a special case for packaging: although **X.Y.Z** is lexicographically lower than **X.Y.Z-rc1** is is considered greater. The Forgejo serial number must therefore be inserted before the **-rcN** suffix to preserve the expected version ordering. * Gitea **v1.18.0-rc0** will be Forgejo **v1.18.0-0-rc0**, **v1.18.0-1-rc0** * Gitea **v1.18.0-rc1** will be Forgejo **v1.18.0-2-rc1**, **v1.18.0-3-rc1**, **v1.18.0-4-rc1** * Gitea **v1.18.0** will be Forgejo **v1.18.0-5**, **v1.18.0-6**, **v1.18.0-7** * etc. ## Release process * Reset the vX.Y/forgejo-integration branch to the Gitea tag vX.Y.Z * Merge all feature branches into the vX.Y/forgejo-integration branch * If the CI passes reset the vX.Y/forgejo branch to the tip of vX.Y/forgejo-integration * Set the vX.Y.Z-N tag to the tip of the vX.Y/forgejo branch * [Binaries](https://codeberg.org/forgejo/forgejo/releases) are built, signed and uploaded by the CI. * [Container images](https://codeberg.org/forgejo/-/packages/container/forgejo/versions) are built and uploaded by the CI. ## Release signing keys management A GPG master key with no expiration date is created and shared with members of the Owners team via encrypted email. A subkey with a one year expiration date is created and stored in the secrets repository, to be used by the CI pipeline. The public master key is stored in the secrets repository and published where relevant. ### Master key creation * gpg --expert --full-generate-key * key type: ECC and ECC option with Curve 25519 as curve * no expiration * id: Forgejo Releases * gpg --export-secret-keys --armor EB114F5E6C0DC2BCDD183550A4B61A2DC5923710 and send via encrypted email to Owners * gpg --export --armor EB114F5E6C0DC2BCDD183550A4B61A2DC5923710 > release-team-gpg.pub * commit to the secret repository ### Subkey creation and renewal * gpg --expert --edit-key EB114F5E6C0DC2BCDD183550A4B61A2DC5923710 * addkey * key type: ECC (signature only) * key validity: one year * create [an issue](https://codeberg.org/forgejo/forgejo/issues) to schedule the renewal #### 2023 * gpg --export --armor F7CBF02094E7665E17ED6C44E381BF3E50D53707 > 2023-release-team-gpg.pub * gpg --export-secret-keys --armor F7CBF02094E7665E17ED6C44E381BF3E50D53707 > 2023-release-team-gpg * commit to the secrets repository * renewal issue https://codeberg.org/forgejo/forgejo/issues/58 ### CI configuration The `releaseteamgpg` secret in the Woodpecker CI configuration is set with the subkey.