commit:     a383790f3422c86b327d382eb6ff462e4db288fa
Author:     freetolga <freetolga <AT> protonmail <DOT> com>
AuthorDate: Sun Oct 26 18:25:47 2025 +0000
Commit:     Tolga Uçar <freetolga <AT> protonmail <DOT> com>
CommitDate: Mon Oct 27 16:43:09 2025 +0000
URL:        https://gitweb.gentoo.org/repo/proj/guru.git/commit/?id=a383790f

www-apps/forgejo: reintroduce 13.0.2 properly

* add migration advice from 12.0.4 and 11.0.7 using
* eapi9-ver.eclass

* enforce minimum required dependencies for 13.0.2

Signed-off-by: freetolga <freetolga <AT> protonmail.com>

 www-apps/forgejo/Manifest              |   1 +
 www-apps/forgejo/forgejo-13.0.2.ebuild | 141 +++++++++++++++++++++++++++++++++
 2 files changed, 142 insertions(+)

diff --git a/www-apps/forgejo/Manifest b/www-apps/forgejo/Manifest
index 93c19b7cf8..05a24e0a93 100644
--- a/www-apps/forgejo/Manifest
+++ b/www-apps/forgejo/Manifest
@@ -1,2 +1,3 @@
 DIST forgejo-11.0.7.tar.gz 55672879 BLAKE2B 
794e15a406612ef08e325820f60548c9181cf1766459fea41f793537bd454281c475b14a4e262e4f5a4b486ad1d8db677dd7f199f1ebe497de6e5a8e51ed4d46
 SHA512 
dcd97e15b2b556160442742ae76954eadece51ab0e561f7de83346960aeb9f51608f8e4f90c1110b7c01136861a5114d39c66d52507668e0945798e2d63543cd
 DIST forgejo-12.0.4.tar.gz 54124346 BLAKE2B 
5aa50c5af5c58513ccfd628631c43004a269e13190b0e82dad934141fed8554e8fe1ee0b61d1795d45434cffa23a2a791921eff9b61e6a8a71b901e827c060d8
 SHA512 
16fd7e0c1b3c329641f74158a7a733d337bb83dbd9b81032392681eb20c6f7e435dd0cbe42fb35c223de3127ef618f975b72cf5eb5e24603178da44aadb6af88
+DIST forgejo-13.0.2.tar.gz 55481937 BLAKE2B 
39824b59730d957f20c8d0aa30f5e7a08b89ba6d215c66a01caff66ad082ca542300e192be7366aba5dee78ae29ab349150bfa6b0b919aba2db3dd87f0efb38a
 SHA512 
51c044a04568bd14f826a334c02e11689326b27f3cf4aaac99d652ae93b5a35f9ee1529b235ea894832b39ea012bcfd996419b4d666927ca3e74dd889a867161

diff --git a/www-apps/forgejo/forgejo-13.0.2.ebuild 
b/www-apps/forgejo/forgejo-13.0.2.ebuild
new file mode 100644
index 0000000000..07779fd277
--- /dev/null
+++ b/www-apps/forgejo/forgejo-13.0.2.ebuild
@@ -0,0 +1,141 @@
+# Copyright 2016-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit fcaps go-module tmpfiles systemd flag-o-matic eapi9-ver
+
+DESCRIPTION="A self-hosted lightweight software forge"
+HOMEPAGE="https://forgejo.org/ https://codeberg.org/forgejo/forgejo";
+
+SRC_URI="https://codeberg.org/forgejo/forgejo/releases/download/v${PV}/forgejo-src-${PV}.tar.gz
 -> ${P}.tar.gz"
+S="${WORKDIR}/${PN}-src-${PV}"
+LICENSE="Apache-2.0 BSD BSD-2 ISC MIT MPL-2.0"
+SLOT="0"
+
+KEYWORDS="~amd64 ~arm ~arm64 ~riscv ~x86"
+
+IUSE="+acct pam sqlite pie"
+
+DEPEND="
+       acct? (
+               acct-group/git
+               acct-user/git[gitea] )
+       pam? ( sys-libs/pam )"
+RDEPEND="${DEPEND}
+       >=dev-vcs/git-2.34.1
+       !www-apps/gitea" # until acct-user/git[forgejo]
+
+BDEPEND="
+>=dev-lang/go-1.25.0"
+
+DOCS=(
+       custom/conf/app.example.ini CONTRIBUTING.md README.md
+)
+FILECAPS=(
+       -m 711 cap_net_bind_service+ep usr/bin/forgejo
+)
+
+RESTRICT="test"
+
+src_prepare() {
+       default
+
+       local sedcmds=(
+               -e "s#^ROOT =#ROOT = 
${EPREFIX}/var/lib/gitea/gitea-repositories#"
+               -e "s#^ROOT_PATH =#ROOT_PATH = ${EPREFIX}/var/log/forgejo#"
+               -e "s#^APP_DATA_PATH = data#APP_DATA_PATH = 
${EPREFIX}/var/lib/gitea/data#"
+               -e "s#^HTTP_ADDR = 0.0.0.0#HTTP_ADDR = 127.0.0.1#"
+               -e "s#^MODE = console#MODE = file#"
+               -e "s#^LEVEL = Trace#LEVEL = Info#"
+               -e "s#^LOG_SQL = true#LOG_SQL = false#"
+               -e "s#^DISABLE_ROUTER_LOG = false#DISABLE_ROUTER_LOG = true#"
+       )
+
+       sed -i "${sedcmds[@]}" custom/conf/app.example.ini || die
+       if use sqlite ; then
+               sed -i -e "s#^DB_TYPE = .*#DB_TYPE = sqlite3#" 
custom/conf/app.example.ini || die
+       fi
+}
+
+src_configure() {
+       # bug 832756 - PIE build issues
+       filter-flags -fPIE
+       filter-ldflags -fPIE -pie
+}
+
+src_compile() {
+       local forgejo_tags=(
+               bindata
+               $(usev pam)
+               $(usex sqlite 'sqlite sqlite_unlock_notify' '')
+       )
+       local forgejo_settings=(
+               "-X 
forgejo.org/modules/setting.CustomConf=${EPREFIX}/etc/forgejo/app.ini"
+               "-X 
forgejo.org/modules/setting.CustomPath=${EPREFIX}/var/lib/gitea/custom"
+               "-X 
forgejo.org/modules/setting.AppWorkPath=${EPREFIX}/var/lib/gitea"
+       )
+       local makeenv=(
+               DRONE_TAG="${PV}"
+               LDFLAGS="-extldflags \"${LDFLAGS}\" ${forgejo_settings[*]}"
+               TAGS="${forgejo_tags[*]}"
+       )
+
+       GOFLAGS=""
+       if use pie ; then
+               GOFLAGS+="-buildmode=pie"
+       fi
+
+       # need to set -j1 or build fails due to a race condition between MAKE 
jobs.
+       # this does not actually impact build parallelism, because the go 
compiler
+       # will still build everything in parallel when it's invoked.
+       env "${makeenv[@]}" emake -j1 EXTRA_GOFLAGS="${GOFLAGS}" backend
+}
+
+src_install() {
+       cp gitea forgejo
+       dobin forgejo
+
+       einstalldocs
+
+       newconfd "${FILESDIR}/forgejo.confd-r1" forgejo
+       newinitd "${FILESDIR}/forgejo.initd-r3" forgejo
+       newtmpfiles - forgejo.conf <<-EOF
+               d /run/forgejo 0755 git git
+       EOF
+       systemd_newunit "${FILESDIR}"/forgejo.service-r3 forgejo.service
+
+       insinto /etc/forgejo
+       newins custom/conf/app.example.ini app.ini
+       if use acct; then
+               fowners root:git /etc/forgejo/{,app.ini}
+               fperms g+w,o-rwx /etc/forgejo/{,app.ini}
+
+               diropts -m0750 -o git -g git
+               keepdir /var/lib/gitea /var/lib/gitea/custom /var/lib/gitea/data
+               keepdir /var/log/forgejo
+       fi
+}
+
+pkg_postinst() {
+       fcaps_pkg_postinst
+       tmpfiles_process forgejo.conf
+
+       ewarn "${PN} ${PV} will continue to use /var/lib/gitea as the default 
home,"
+       ewarn "as acct-user/git[gitea] depends on it, and acct-user[forgejo] 
does not"
+       ewarn "exist yet."
+
+       if ver_replacing -lt 13.0.0; then
+               ewarn "Make sure your runners are verified before migrating to 
Forgejo 13"
+               ewarn "More information at: 
https://code.forgejo.org/forgejo/runner/releases/tag/v9.0.0";
+               ewarn "Warning: the migration will invalidate existing actions 
artifacts"
+               ewarn "More information at: 
https://codeberg.org/forgejo/forgejo/pulls/9023";
+       fi
+
+       if ver_replacing -lt 12.0.0; then
+               ewarn "Warning: upgrade from 11.0.x LTS detected, carefully 
consider this nontrivial migration!"
+               ewarn "Once upgraded a database cannot be downgraded!"
+               ewarn "11.0.x to 12.0.0 release notes can be found at"
+               ewarn 
"https://codeberg.org/forgejo/forgejo/src/branch/forgejo/release-notes-published/12.0.0.md";
+       fi
+}

Reply via email to