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
|