* allow for tracked time to be removed again * correct image source for quoted reply * prevent render failure on faulty org settings post * Revert "remove API authentication methods that uses the URL query" * upgrade fails or hang at migration[31]: Migrate maven package name concatenation * make the action feed resilient to database inconsistencies * make sure to use unaltered fields when saving a shadow copy for updated profiles or comments * follow symlinks for local assets * use correct ACME default - remove get-sources.sh, use obs tooling - include apparmor in Leap 16 - update to version 12.0.0: * remove API authentication methods that uses the URL query * relax email requirements * consider WebAuthn & SSH for instance signing * add SSH signing support for instances * forgejo docs command is deprecated * remove the legacy TEST_CONFLICTING_PATCHES_WITH_GIT_APPLY setting * fail if sha is not provided to the POST /repos/{owner}/{repo}/contents API endpoint * transform fediverse handles * add user visibility description in the settings page * add model viewer for .glb (GLTF) model in file view * show size constraints of custom avatar * add links to milestones and projects in issue comments * global styling for the kbd tag OBS-URL: https://build.opensuse.org/package/show/devel:tools:scm/forgejo?expand=0&rev=78
278 lines
9.2 KiB
RPMSpec
278 lines
9.2 KiB
RPMSpec
#
|
||
# spec file for package forgejo
|
||
#
|
||
# Copyright (c) 2025 SUSE LLC
|
||
#
|
||
# All modifications and additions to the file contributed by third parties
|
||
# remain the property of their copyright owners, unless otherwise agreed
|
||
# upon. The license for this file, and modifications and additions to the
|
||
# file, is the same license as for the pristine package itself (unless the
|
||
# license for the pristine package is not an Open Source License, in which
|
||
# case the license is the MIT License). An "Open Source License" is a
|
||
# license that conforms to the Open Source Definition (Version 1.9)
|
||
# published by the Open Source Initiative.
|
||
|
||
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||
#
|
||
|
||
|
||
%if 0%{?suse_version} >= 1600
|
||
%bcond_without selinux
|
||
%bcond_without apparmor
|
||
%else
|
||
# Leap & SLE 15.X
|
||
%bcond_with selinux
|
||
%bcond_without apparmor
|
||
%endif
|
||
Name: forgejo
|
||
Version: 12.0.1
|
||
Release: 0
|
||
Summary: Self-hostable forge
|
||
License: GPL-3.0-or-later
|
||
Group: Development/Tools/Version Control
|
||
URL: https://forgejo.org
|
||
Source0: https://codeberg.org/forgejo/forgejo/releases/download/v%{version}/forgejo-src-%{version}.tar.gz
|
||
Source1: https://codeberg.org/forgejo/forgejo/releases/download/v%{version}/forgejo-src-%{version}.tar.gz.asc
|
||
Source2: https://keys.openpgp.org/vks/v1/by-fingerprint/EB114F5E6C0DC2BCDD183550A4B61A2DC5923710#/forgejo.keyring
|
||
Source3: package-lock.json
|
||
Source4: node_modules.spec.inc
|
||
%include %{_sourcedir}/node_modules.spec.inc
|
||
Source5: forgejo.service
|
||
Source6: forgejo.sysusers
|
||
Source7: forgejo.fc
|
||
Source8: forgejo.if
|
||
Source9: forgejo.te
|
||
Source10: forgejo.apparmor
|
||
Source11: forgejo.firewalld
|
||
Source12: forgejo-abstraction.apparmor
|
||
Source13: forgejo-hooks-abstraction.apparmor
|
||
Source14: node_modules.sums
|
||
Source99: README.SUSE
|
||
Patch0: custom-app.ini.patch
|
||
BuildRequires: golang(API) >= 1.24
|
||
## node >= 20
|
||
%if 0%{?suse_version} == 1500
|
||
BuildRequires: nodejs-devel-default
|
||
BuildRequires: npm-default
|
||
%else
|
||
BuildRequires: nodejs-packaging
|
||
%endif
|
||
BuildRequires: fdupes
|
||
BuildRequires: firewall-macros
|
||
BuildRequires: firewalld
|
||
BuildRequires: local-npm-registry
|
||
BuildRequires: make
|
||
BuildRequires: systemd-rpm-macros
|
||
BuildRequires: sysuser-tools
|
||
Requires: git-core
|
||
Requires: git-lfs
|
||
Requires: (forgejo-apparmor if apparmor-abstractions)
|
||
Requires: (forgejo-firewalld if firewalld)
|
||
Requires: (forgejo-selinux if selinux-policy-targeted)
|
||
Conflicts: forgejo-longterm
|
||
%if %{with apparmor}
|
||
BuildRequires: apparmor-abstractions
|
||
BuildRequires: apparmor-rpm-macros
|
||
BuildRequires: libapparmor-devel
|
||
%endif
|
||
%if %{with selinux}
|
||
BuildRequires: checkpolicy
|
||
BuildRequires: selinux-policy-devel
|
||
%endif
|
||
%{systemd_requires}
|
||
%{sysusers_requires}
|
||
|
||
%package firewalld
|
||
Summary: Firewalld profile for %{name}
|
||
BuildArch: noarch
|
||
Conflicts: forgejo-longterm-firewalld
|
||
|
||
%description firewalld
|
||
This package adds a firewalld service profile to %{name}
|
||
|
||
%if %{with apparmor}
|
||
%package apparmor
|
||
Summary: Apparmor profile for %{name}
|
||
BuildArch: noarch
|
||
Conflicts: forgejo-longterm-apparmor
|
||
Requires: %{name} = %{version}-%{release}
|
||
|
||
%description apparmor
|
||
This package adds the Apparmor profile to %{name}
|
||
%endif
|
||
|
||
%if %{with selinux}
|
||
%package selinux
|
||
Summary: Selinux support for %{name}
|
||
BuildArch: noarch
|
||
Conflicts: forgejo-longterm-selinux
|
||
Requires: %{name} = %{version}-%{release}
|
||
Requires: selinux-policy-targeted
|
||
|
||
%description selinux
|
||
This package adds SELinux enforcement to %{name}.
|
||
%endif
|
||
|
||
%package environment-to-ini
|
||
Summary: Configuration params via environment variables for %{name}
|
||
Conflicts: forgejo-longterm-environment-to-ini
|
||
Requires: %{name} = %{version}-%{release}
|
||
|
||
%description environment-to-ini
|
||
OCI Container users can change arbitrary configuration
|
||
via environment variables with this tool
|
||
|
||
Forgejo needs to use an ini file for configuration because the running
|
||
environment that starts the OCI container may not be the same as that used
|
||
by the hooks. An ini file also gives a good default and means that
|
||
users do not have to completely provide a full environment.
|
||
|
||
%description
|
||
Providing Git hosting for your project, friends, company or community? Forgejo
|
||
(/for'd͡ʒe.jo/ inspired by forĝejo – the Esperanto word for forge) has you
|
||
covered with its intuitive interface, light and easy hosting and a lot of
|
||
builtin functionality.
|
||
|
||
%prep
|
||
%autosetup -p1 -n forgejo-src-%{version}
|
||
local-npm-registry %{_sourcedir} install --include=dev --legacy-peer-deps
|
||
cp %{SOURCE99} .
|
||
|
||
%build
|
||
%sysusers_generate_pre %{SOURCE6} forgejo forgejo.conf
|
||
export TAGS="timetzdata sqlite sqlite_unlock_notify"
|
||
export EXTRA_GOFLAGS="-buildmode=pie -mod=vendor"
|
||
STRIP=0 %make_build build
|
||
go build ${EXTRA_GOFLAGS} -o contrib/environment-to-ini/environment-to-ini contrib/environment-to-ini/environment-to-ini.go
|
||
|
||
%install
|
||
install -d -D \
|
||
%{buildroot}%{_bindir} %{buildroot}%{_datadir}/forgejo/{conf,https,mailer}
|
||
|
||
cp -r options %{buildroot}%{_datadir}/forgejo/
|
||
cp -r public %{buildroot}%{_datadir}/forgejo/
|
||
cp -r templates %{buildroot}%{_datadir}/forgejo/
|
||
|
||
install -d -m 0750 \
|
||
%{buildroot}%{_sharedstatedir}/forgejo/{data,https,indexers,queues,repositories} \
|
||
%{buildroot}%{_sharedstatedir}/forgejo/data/home/.ssh \
|
||
%{buildroot}%{_sysconfdir}/forgejo \
|
||
%{buildroot}%{_localstatedir}/log/forgejo
|
||
|
||
install -D -m 0755 contrib/environment-to-ini/environment-to-ini %{buildroot}%{_bindir}
|
||
install -D -m 0755 %{_builddir}/forgejo-src-%{version}/gitea %{buildroot}%{_bindir}/forgejo
|
||
ln -s forgejo %{buildroot}%{_bindir}/gitea
|
||
|
||
install -D -m 0640 %{_builddir}/forgejo-src-%{version}/custom/conf/app.example.ini %{buildroot}%{_sysconfdir}/forgejo/conf/app.ini
|
||
|
||
install -D -m 0644 %{SOURCE5} %{buildroot}%{_unitdir}/forgejo.service
|
||
install -D -m 0644 %{SOURCE6} %{buildroot}%{_sysusersdir}/forgejo.conf
|
||
|
||
%if %{with apparmor}
|
||
install -D -d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/abstractions \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d/forgejo-session-exec.d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d/forgejo-hooks.d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d/git.d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d/hooks-pre-receive.d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d/hooks-post-receive.d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d/hooks-proc-receive.d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d/hooks-update.d \
|
||
%{buildroot}%{_sysconfdir}/apparmor.d/forgejo.d/forgejo.d
|
||
|
||
install -Dm0644 %{SOURCE10} %{buildroot}%{_sysconfdir}/apparmor.d/forgejo
|
||
install -Dm0644 %{SOURCE12} %{buildroot}%{_sysconfdir}/apparmor.d/abstractions/forgejo
|
||
install -Dm0644 %{SOURCE13} %{buildroot}%{_sysconfdir}/apparmor.d/abstractions/forgejo-hooks
|
||
%endif
|
||
|
||
%if %{with selinux}
|
||
cd %{_sourcedir}
|
||
make -f %{_datadir}/selinux/devel/Makefile forgejo.pp
|
||
install -Dm0644 forgejo.pp %{buildroot}%{_datadir}/selinux/packages/forgejo/forgejo.pp
|
||
install -Dm0644 forgejo.if %{buildroot}%{_datadir}/selinux/devel/include/distributed/forgejo.if
|
||
%endif
|
||
|
||
#firewalld service file
|
||
install -D -m 0644 %{SOURCE11} %{buildroot}%{_prefix}/lib/firewalld/services/forgejo.xml
|
||
|
||
%fdupes %{buildroot}
|
||
|
||
%pre -f forgejo.pre
|
||
%service_add_pre forgejo.service
|
||
|
||
%post
|
||
if [ -e %{_datadir}/forgejo/.ssh/authorized_keys ] ; then
|
||
mv %{_datadir}/forgejo/.ssh/authorized_keys %{_sharedstatedir}/forgejo/data/home/.ssh/authorized_keys
|
||
fi
|
||
%service_add_post forgejo.service
|
||
|
||
%post firewalld
|
||
%firewalld_reload
|
||
|
||
%if %{with apparmor}
|
||
%post apparmor
|
||
%apparmor_reload %{_sysconfdir}/apparmor.d/forgejo
|
||
%endif
|
||
|
||
%if %{with selinux}
|
||
%post selinux
|
||
semodule -i %{_datadir}/selinux/packages/forgejo/forgejo.pp 2>/dev/null || :
|
||
|
||
%preun selinux
|
||
semodule -r forgejo 2>/dev/null || :
|
||
%endif
|
||
|
||
%preun
|
||
%service_del_preun forgejo.service
|
||
|
||
%postun
|
||
%service_del_postun forgejo.service
|
||
|
||
%files
|
||
%license LICENSE
|
||
%doc README.md RELEASE-NOTES.md CONTRIBUTING.md README.SUSE
|
||
%{_bindir}/forgejo
|
||
%{_bindir}/gitea
|
||
%{_datadir}/forgejo
|
||
%{_sysusersdir}/forgejo.conf
|
||
%{_unitdir}/forgejo.service
|
||
%defattr(0640,root,forgejo,750)
|
||
%config(noreplace) %{_sysconfdir}/forgejo/conf/app.ini
|
||
%dir %{_sysconfdir}/forgejo
|
||
%dir %{_sysconfdir}/forgejo/conf
|
||
%defattr(0640,forgejo,forgejo,750)
|
||
%{_localstatedir}/log/forgejo
|
||
%{_sharedstatedir}/forgejo
|
||
|
||
%if %{with apparmor}
|
||
%files apparmor
|
||
%config %{_sysconfdir}/apparmor.d/abstractions/forgejo*
|
||
%config %{_sysconfdir}/apparmor.d/forgejo
|
||
%dir %{_sysconfdir}/apparmor.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d/forgejo-hooks.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d/forgejo-session-exec.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d/forgejo.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d/git.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d/hooks-post-receive.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d/hooks-pre-receive.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d/hooks-proc-receive.d
|
||
%dir %{_sysconfdir}/apparmor.d/forgejo.d/hooks-update.d
|
||
%endif
|
||
|
||
%if %{with selinux}
|
||
%files selinux
|
||
%dir %{_datadir}/selinux/devel/include/distributed
|
||
%{_datadir}/selinux/devel/include/distributed/forgejo.if
|
||
%{_datadir}/selinux/packages/forgejo
|
||
%endif
|
||
|
||
%files firewalld
|
||
%{_prefix}/lib/firewalld/services/forgejo.xml
|
||
|
||
%files environment-to-ini
|
||
%{_bindir}/environment-to-ini
|
||
|
||
%changelog
|