Forgejo
Forgejo is a fork of Gitea.
Installation
As of 2024-09-18, Forgejo is not provided as a Gentoo package, but is available in the GURU overlay. Alternatively, Forgejo is distributed as a single binary file.
Official binaries
Forgejo
The Forgejo project distributes binaries for AMD64 and ARM64 architectures, which can be downloaded here. The binaries are compatible with musl-based systems.
To download and verify the binary file, follow the instructions provided here.
In case GnuPG fails to retrieve the key, the key can be imported manually:
user $
wget -O - https://keys.openpgp.org/vks/v1/by-fingerprint/EB114F5E6C0DC2BCDD183550A4B61A2DC5923710 | gpg --import
The binary does not require root privileges to run and can be launched from any directory:
user $
./forgejo-*-linux-arm64
If there is a plan to install the binary into the system, follow the steps provided here.
Forgejo Actions (self-hosted)
This section describes a way to run Actions on bare hardware, without virtualization or containers. This means that everything that is uploaded to the repository will run on the same system that the server is running on. This can lead to any number of consequences (data loss, hardware damage, etc.). Only persons with the ultimate level of trust should be able to push data to repositories.
The runner can be downloaded from here.
Once downloaded, create and copy the token via GUI as described here.
Register the runner:
user $
./forgejo-runner-* register --no-interactive --token <OBTAINED TOKEN> --name self-hosted --instance http://[::1]:3001/
http://[::1]:3001/
is Forgejo's address.Once registered, create the minimal configuration file:
log:
level: info
runner:
timeout: 1h
labels:
- self-hosted
cache:
enabled: false
And launch the runner as a daemon:
user $
./forgejo-runner-* --config config.yml daemon
To test that everything works, push the following file to the repository:
on: [push]
jobs:
test:
runs-on: self-hosted
steps:
- run: echo Works
SELinux policy
As of 2024-12-08, there are no official SELinux policies for Forgejo. The policies on this page are written by regular Gentoo Linux users and are provided "as is" without warranty of any kind. Any contribution is welcome.
Current state
The policies are not ready to be used in production.
Almost every action produces a significant number of cosmetic AVC log messages, resulting in a fast-growing /var/log/audit/audit.log file that can lead to a denial of service if /var is not mounted as a separate partition.
Reproducible environment
All tests were performed using official binaries downloaded directly from the Forgejo website.
Once the policies are installed and Forgejo is running, the following features must be configured in the initial setup window:
- Database type: SQLite3
- Git LFS root path: leave empty to disable
- SSH server port: leave empty to disable (almost everything can be done through the REST API)
- Enable OpenID sign-in: disable
- Password hash algorithm: pbkdf2_hi (the default value)
The policies were tested in the following profiles:
Profile name | Status | Forgejo's version | Forgejo runner's version | Notes |
---|---|---|---|---|
default/linux/arm64/23.0/musl/hardened/selinux | Works | 9.0.2 | 5.0.3 |
Forgejo's policy
# License: 0BSD
policy_module(forgejo, 1.0)
gen_require(`
attribute file_type, non_security_file_type, non_auth_file_type;
role user_r;
type user_t;
type user_devpts_t;
type sshd_t;
type bin_t;
type node_t;
type ntop_port_t;
type git_exec_t;
type urandom_device_t;
type shell_exec_t;
type home_root_t;
type ssh_exec_t;
type user_home_dir_t;
type ssh_home_t;
type net_conf_t;
type tmp_t;
')
##
# Type declarations.
#
type forgejo_t;
type forgejo_exec_t;
type forgejo_config_t;
type forgejo_www_t;
domain_type(forgejo_t)
domain_entry_file(forgejo_t, forgejo_exec_t)
typeattribute forgejo_config_t file_type, non_security_file_type, non_auth_file_type;
typeattribute forgejo_www_t file_type, non_security_file_type, non_auth_file_type;
##
# Domain transition (user_t -> forgejo_t).
#
domtrans_pattern(user_t, forgejo_exec_t, forgejo_t)
role user_r types forgejo_t;
# Allow to run the binary file of Forgejo.
allow user_t forgejo_exec_t:file mmap_exec_file_perms;
##
# Data files.
#
allow forgejo_t forgejo_www_t:file { map execute execute_no_trans manage_file_perms };
allow forgejo_t forgejo_www_t:lnk_file { create getattr unlink };
allow forgejo_t forgejo_www_t:dir manage_dir_perms;
allow user_t forgejo_www_t:dir list_dir_perms;
# Self-utilization
allow forgejo_t forgejo_exec_t:file execute_no_trans;
##
# Forgejo requirements (external).
#
allow forgejo_t self:fifo_file { read write getattr ioctl };
allow forgejo_t self:process { setpgid signal signull sigkill };
# External tools
allow forgejo_t bin_t:dir search;
allow forgejo_t bin_t:file { open read execute execute_no_trans map getattr };
allow forgejo_t bin_t:lnk_file read;
# PTY
# FIXME: Optional?
allow forgejo_t sshd_t:fd use;
allow forgejo_t user_devpts_t:chr_file { read write ioctl getattr };
# TCP
allow forgejo_t self:tcp_socket { create bind setopt listen accept getattr read write connect getopt };
allow forgejo_t node_t:tcp_socket node_bind;
allow forgejo_t ntop_port_t:tcp_socket { name_bind name_connect };
# Git
allow forgejo_t git_exec_t:file { getattr execute execute_no_trans open read map };
# Password creation (admin user creation)
allow forgejo_t urandom_device_t:chr_file { open read };
# Shell
allow forgejo_t shell_exec_t:file { getattr execute execute_no_trans open read map };
# SSH keys (always required)
allow forgejo_t home_root_t:dir { getattr search };
allow forgejo_t user_home_dir_t:dir { getattr search };
allow forgejo_t ssh_exec_t:file { getattr execute };
allow forgejo_t ssh_home_t:dir { getattr search write add_name remove_name };
allow forgejo_t ssh_home_t:file { create open read write getattr rename unlink };
# Repo administration
allow forgejo_t net_conf_t:file { getattr read open };
allow forgejo_t tmp_t:dir { search write add_name create getattr read remove_name open rmdir };
allow forgejo_t tmp_t:file { create getattr open read unlink write rename map setattr append ioctl link };
allow forgejo_t tmp_t:lnk_file { create unlink };
/opt/forgejo(/.*)? gen_context(system_u:object_r:forgejo_www_t)
/opt/forgejo/forgejo gen_context(system_u:object_r:forgejo_exec_t)
Forgejo runner's policy
# License: 0BSD
policy_module(forgejo-runner, 1.0)
gen_require(`
attribute file_type, non_security_file_type, non_auth_file_type;
role user_r;
type user_t;
type sshd_t;
type user_devpts_t;
type ntop_port_t;
type home_root_t;
type user_home_dir_t;
type xdg_cache_t;
type xdg_config_t;
type bin_t;
type shell_exec_t;
type git_exec_t;
type urandom_device_t;
')
##
# Type declarations.
#
type forgejo_runner_t;
type forgejo_runner_exec_t;
type forgejo_runner_data_t;
domain_type(forgejo_runner_t)
domain_entry_file(forgejo_runner_t, forgejo_runner_exec_t)
typeattribute forgejo_runner_data_t file_type, non_security_file_type, non_auth_file_type;
##
# Domain transition (user_t -> forgejo_runner_t).
#
domtrans_pattern(user_t, forgejo_runner_exec_t, forgejo_runner_t)
role user_r types forgejo_runner_t;
##
# Data files.
#
allow forgejo_runner_t forgejo_runner_data_t:file { manage_file_perms };
allow forgejo_runner_t forgejo_runner_data_t:dir manage_dir_perms;
allow user_t forgejo_runner_data_t:dir list_dir_perms;
allow user_t forgejo_runner_exec_t:file mmap_exec_file_perms;
##
# Requirements (external)
#
allow forgejo_runner_t self:fifo_file { read write ioctl getattr };
allow forgejo_runner_t self:process { getsched signal setpgid signull };
# PTY
allow forgejo_runner_t user_devpts_t:chr_file { read write ioctl };
# FIXME: Optional?
allow forgejo_runner_t sshd_t:fd use;
# TCP
allow forgejo_runner_t self:tcp_socket { create connect setopt getopt getattr read write };
allow forgejo_runner_t ntop_port_t:tcp_socket name_connect;
allow forgejo_runner_t home_root_t:dir { getattr search };
allow forgejo_runner_t user_home_dir_t:dir { getattr search };
allow forgejo_runner_t xdg_cache_t:dir { getattr search write add_name create read remove_name open rmdir };
allow forgejo_runner_t xdg_cache_t:file { create open write getattr read unlink ioctl rename map setattr append link };
allow forgejo_runner_t xdg_cache_t:lnk_file { create getattr unlink };
allow forgejo_runner_t xdg_config_t:dir search;
allow forgejo_runner_t bin_t:dir search;
allow forgejo_runner_t bin_t:file { getattr execute execute_no_trans read open map };
allow forgejo_runner_t bin_t:lnk_file { read unlink };
allow forgejo_runner_t shell_exec_t:file { getattr execute execute_no_trans open read map };
# Git
allow forgejo_runner_t git_exec_t:file { getattr execute execute_no_trans read open map };
allow forgejo_runner_t urandom_device_t:chr_file { open read };
/opt/forgejo-runner(/.*)? gen_context(system_u:object_r:forgejo_runner_data_t)
/opt/forgejo-runner/forgejo-runner gen_context(system_u:object_r:forgejo_runner_exec_t)
Installation of policies
All .te and .fc files defined above should be in the same directory (forgejo and forgejo-runner can be separated if desired).
root #
make -f /usr/share/selinux/strict/include/Makefile
root #
semodule --install forgejo*.pp
root #
restorecon -R /opt/forgejo
root #
restorecon -R /opt/forgejo-runner
Removal of policies
root #
semodule --remove forgejo
root #
semodule --remove forgejo-runner
root #
restorecon -R /opt/forgejo
root #
restorecon -R /opt/forgejo-runner
Usage of policies
The forgejo.fc file requires the forgejo binary file to be placed in the /opt/forgejo directory.
The forgejo-runner.fc file requires the forgejo-runner binary file to be placed in the /opt/forgejo-runner directory.
The execution must be performed as regular users in the mentioned above directories.
The paths can be modified as desired in the appropriate .fc file.
See also
- Node.js as a reverse proxy for Forgejo
- Gitea — painless self-hosted git service, a fork of gogs