From 209150771e4669d707939d8d7d2435bb868229f6 Mon Sep 17 00:00:00 2001 From: rob thijssen Date: Thu, 16 Apr 2026 11:18:37 +0300 Subject: [PATCH] fix(rpm): use sysusers.d for cortex user/group creation MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Both packages set %attr(...,cortex) on their config files, which caused RPM's auto-dep-generator to emit Requires: group(cortex) / user(cortex). The %pre scriptlets that actually created the group ran too late — dnf rejected neuron installation on hosts without cortex because nothing Provided group(cortex). Switch to systemd-sysusers declarative user creation: each package ships its own named sysusers.d file (cortex-gateway.conf and cortex-neuron.conf — different names so both packages can coinstall) with identical content defining the cortex user/group. RPM's user/group dep generator now emits Provides: user(cortex) and Provides: group(cortex) automatically from the sysusers.d files, satisfying the auto-generated Requires. Either package installs standalone; both can coinstall on the gateway host if desired. Also added Requires: systemd since %sysusers_create_compat depends on systemd-sysusers being present on the target. Co-Authored-By: Claude Opus 4.6 (1M context) --- cortex.spec | 6 ++++-- data/cortex-sysusers.conf | 3 +++ neuron.spec | 6 ++++-- 3 files changed, 11 insertions(+), 4 deletions(-) create mode 100644 data/cortex-sysusers.conf diff --git a/cortex.spec b/cortex.spec index 5c694a8..faba5a7 100644 --- a/cortex.spec +++ b/cortex.spec @@ -20,6 +20,7 @@ BuildRequires: pkgconfig(openssl) BuildRequires: systemd-rpm-macros Requires(pre): shadow-utils +Requires: systemd %description Cortex is a Rust reverse-proxy that sits in front of multiple inference @@ -45,13 +46,13 @@ cargo build --release -p cortex-cli %install install -Dm755 target/release/cortex %{buildroot}%{_bindir}/cortex install -Dm644 data/cortex.service %{buildroot}%{_unitdir}/cortex.service +install -Dm644 data/cortex-sysusers.conf %{buildroot}%{_sysusersdir}/cortex-gateway.conf install -dm750 %{buildroot}%{_sysconfdir}/cortex install -Dm640 cortex.example.toml %{buildroot}%{_sysconfdir}/cortex/cortex.toml install -Dm640 models.example.toml %{buildroot}%{_sysconfdir}/cortex/models.toml %pre -getent group cortex >/dev/null || groupadd -r cortex -getent passwd cortex >/dev/null || useradd -r -g cortex -d /var/lib/cortex -s /sbin/nologin cortex +%sysusers_create_compat %{_builddir}/%{name}-%{version}/data/cortex-sysusers.conf %post %systemd_post cortex.service @@ -67,6 +68,7 @@ getent passwd cortex >/dev/null || useradd -r -g cortex -d /var/lib/cortex -s /s %doc README.md %{_bindir}/cortex %{_unitdir}/cortex.service +%{_sysusersdir}/cortex-gateway.conf %dir %attr(750,root,cortex) %{_sysconfdir}/cortex %config(noreplace) %attr(640,root,cortex) %{_sysconfdir}/cortex/cortex.toml %config(noreplace) %attr(640,root,cortex) %{_sysconfdir}/cortex/models.toml diff --git a/data/cortex-sysusers.conf b/data/cortex-sysusers.conf new file mode 100644 index 0000000..56b3c0b --- /dev/null +++ b/data/cortex-sysusers.conf @@ -0,0 +1,3 @@ +g cortex - - +u cortex - "Cortex inference cluster" /var/lib/cortex /sbin/nologin +m cortex cortex diff --git a/neuron.spec b/neuron.spec index c781e9b..85f4313 100644 --- a/neuron.spec +++ b/neuron.spec @@ -20,6 +20,7 @@ BuildRequires: pkgconfig(openssl) BuildRequires: systemd-rpm-macros Requires(pre): shadow-utils +Requires: systemd %description Neuron is a per-node daemon for cortex inference clusters. It discovers @@ -44,12 +45,12 @@ cargo build --release -p neuron %install install -Dm755 target/release/neuron %{buildroot}%{_bindir}/neuron install -Dm644 data/neuron.service %{buildroot}%{_unitdir}/neuron.service +install -Dm644 data/cortex-sysusers.conf %{buildroot}%{_sysusersdir}/cortex-neuron.conf install -dm750 %{buildroot}%{_sysconfdir}/cortex install -Dm640 neuron.example.toml %{buildroot}%{_sysconfdir}/cortex/neuron.toml %pre -getent group cortex >/dev/null || groupadd -r cortex -getent passwd cortex >/dev/null || useradd -r -g cortex -d /var/lib/cortex -s /sbin/nologin cortex +%sysusers_create_compat %{_builddir}/%{name}-%{version}/data/cortex-sysusers.conf %post %systemd_post neuron.service @@ -65,6 +66,7 @@ getent passwd cortex >/dev/null || useradd -r -g cortex -d /var/lib/cortex -s /s %doc README.md %{_bindir}/neuron %{_unitdir}/neuron.service +%{_sysusersdir}/cortex-neuron.conf %dir %attr(750,root,cortex) %{_sysconfdir}/cortex %config(noreplace) %attr(640,root,cortex) %{_sysconfdir}/cortex/neuron.toml