658b8ad2bd
- Work around rpmlint complaining about /var/log/journal shipped with setgid bit This setgid bit has been already reviewed in the past and wasn't a concern. However we want the mode/ownership adjusted by tmpfiles and avoid the duplication of these info in rpm. - Don't ghost own any directories created dynamically by tmpfiles Again rpmlint complains but it doesn't seem to make sense to try to track all paths (including theirs perms, ownerships...) created dynamically. And 'rpm -V' is likely to report issues later with these paths anyway. This effectively partially reverts the two previous commits. - Make sure the build process won't create /var/log/journal - /var/log/journal/remote is owned by systemd-journal-remote - systemd.spec: fix a bunch of rpmlint errors/warnings - Drop systemd-logger This sub package was introduced in order to configure persistent journal and also to make sure that another syslog provider (such as rsyslog) couldn't be installed at the same time: each syslog provider conflicts with each others. However this mechanism didn't work since uninstalling systemd-logger wasn't magically turning off persistent logging because /var/log/journal is likely to be populated hence not removed. Moreover using a subpackage to configure the mode of journald was overkill and the usual ways (main conf file or drop-ins) should be preferred. - Import commit 7a5801342fe2f53e5c2a8578d6db132c0eca2d97 8d65ec4a66 test: wc is needed by test/units/testsuite-50.sh OBS-URL: https://build.opensuse.org/request/show/922217 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/systemd?expand=0&rev=337
1862 lines
62 KiB
RPMSpec
1862 lines
62 KiB
RPMSpec
#
|
|
# spec file for package systemd-mini
|
|
#
|
|
# Copyright (c) 2021 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/
|
|
#
|
|
|
|
|
|
#
|
|
# The git repository used to track all Suse specific changes can be
|
|
# found at: https://github.com/openSUSE/systemd.
|
|
#
|
|
|
|
##### WARNING: please do not edit this auto generated spec file. Use the systemd.spec! #####
|
|
%define bootstrap 1
|
|
##### WARNING: please do not edit this auto generated spec file. Use the systemd.spec! #####
|
|
%define mini -mini
|
|
%define min_kernel_version 4.5
|
|
%define suse_version +suse.39.g7a5801342f
|
|
%define _testsuitedir /usr/lib/systemd/tests
|
|
|
|
%bcond_with gnuefi
|
|
%if 0%{?bootstrap}
|
|
%bcond_with coredump
|
|
%bcond_with importd
|
|
%bcond_with journal_remote
|
|
%bcond_with machined
|
|
%bcond_with networkd
|
|
%bcond_with portabled
|
|
%bcond_with resolved
|
|
%bcond_with sysvcompat
|
|
%bcond_with experimental
|
|
%bcond_with testsuite
|
|
%else
|
|
%bcond_without coredump
|
|
%ifarch %{ix86} x86_64
|
|
%bcond_without gnuefi
|
|
%endif
|
|
%bcond_without importd
|
|
%bcond_without journal_remote
|
|
%bcond_without machined
|
|
%bcond_without networkd
|
|
%bcond_without portabled
|
|
%bcond_without resolved
|
|
%bcond_without sysvcompat
|
|
%bcond_without experimental
|
|
%bcond_without testsuite
|
|
%endif
|
|
|
|
Name: systemd-mini
|
|
URL: http://www.freedesktop.org/wiki/Software/systemd
|
|
Version: 249.4
|
|
Release: 0
|
|
Summary: A System and Session Manager
|
|
License: LGPL-2.1-or-later
|
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
|
%if ! 0%{?bootstrap}
|
|
BuildRequires: docbook-xsl-stylesheets
|
|
BuildRequires: kbd
|
|
BuildRequires: libapparmor-devel
|
|
BuildRequires: libgcrypt-devel
|
|
BuildRequires: libxslt-tools
|
|
BuildRequires: polkit
|
|
# python is only required for generating systemd.directives.xml
|
|
BuildRequires: python3-base
|
|
BuildRequires: python3-lxml
|
|
BuildRequires: pkgconfig(audit)
|
|
BuildRequires: pkgconfig(libcryptsetup) >= 1.6.0
|
|
BuildRequires: pkgconfig(libdw)
|
|
BuildRequires: pkgconfig(libfido2)
|
|
BuildRequires: pkgconfig(liblz4)
|
|
BuildRequires: pkgconfig(liblzma)
|
|
BuildRequires: pkgconfig(libpcre2-8)
|
|
BuildRequires: pkgconfig(libqrencode)
|
|
BuildRequires: pkgconfig(libselinux) >= 2.1.9
|
|
BuildRequires: pkgconfig(libzstd)
|
|
BuildRequires: pkgconfig(tss2-esys)
|
|
BuildRequires: pkgconfig(tss2-mu)
|
|
BuildRequires: pkgconfig(tss2-rc)
|
|
%ifarch aarch64 %ix86 x86_64 x32 %arm ppc64le s390x
|
|
BuildRequires: pkgconfig(libseccomp) >= 2.3.1
|
|
%endif
|
|
%endif
|
|
BuildRequires: fdupes
|
|
BuildRequires: gperf
|
|
BuildRequires: libacl-devel
|
|
BuildRequires: libcap-devel
|
|
BuildRequires: libmount-devel >= 2.27.1
|
|
BuildRequires: meson >= 0.43
|
|
BuildRequires: pam-devel
|
|
BuildRequires: python3-jinja2
|
|
# regenerate_initrd_post macro is expanded during build, hence this
|
|
# BR. Also this macro was introduced since version 12.4.
|
|
BuildRequires: suse-module-tools >= 12.4
|
|
BuildRequires: systemd-rpm-macros
|
|
BuildRequires: pkgconfig(blkid) >= 2.26
|
|
BuildRequires: pkgconfig(libkmod) >= 15
|
|
BuildRequires: pkgconfig(libpci) >= 3
|
|
%if %{with importd}
|
|
BuildRequires: pkgconfig(bzip2)
|
|
BuildRequires: pkgconfig(libcurl)
|
|
BuildRequires: pkgconfig(zlib)
|
|
%endif
|
|
%if %{with journal_remote}
|
|
BuildRequires: pkgconfig(libcurl)
|
|
BuildRequires: pkgconfig(libmicrohttpd) >= 0.9.33
|
|
%endif
|
|
%if %{with gnuefi}
|
|
BuildRequires: gnu-efi
|
|
%endif
|
|
|
|
%if 0%{?bootstrap}
|
|
#!BuildIgnore: dbus-1
|
|
Requires: this-is-only-for-build-envs
|
|
Provides: systemd = %{version}-%{release}
|
|
%else
|
|
# the buildignore is important for bootstrapping
|
|
#!BuildIgnore: udev
|
|
Requires: aaa_base >= 13.2
|
|
Requires: dbus-1 >= 1.4.0
|
|
Requires: kbd
|
|
Requires: netcfg >= 11.5
|
|
Requires: systemd-default-settings-branding
|
|
Requires: systemd-presets-branding
|
|
Requires: util-linux >= 2.27.1
|
|
Requires: group(lock)
|
|
# This Recommends because some symbols of libpcre2 are dlopen()ed by journalctl
|
|
Recommends: libpcre2-8-0
|
|
# ditto but dlopen()ed by systemd-cryptenroll
|
|
Recommends: libfido2
|
|
Recommends: libtss2-esys0
|
|
Recommends: libtss2-mu0
|
|
Recommends: libtss2-rc0
|
|
Requires(post): coreutils
|
|
Requires(post): findutils
|
|
Requires(post): systemd-presets-branding
|
|
Requires(post): pam-config >= 0.79-5
|
|
%endif
|
|
|
|
%if 0%{?bootstrap}
|
|
Conflicts: systemd
|
|
Conflicts: kiwi
|
|
%endif
|
|
Conflicts: sysvinit
|
|
Conflicts: filesystem < 11.5
|
|
Conflicts: mkinitrd < 2.7.0
|
|
Provides: systemd-logger = %{version}-%{release}
|
|
Obsoletes: systemd-logger < %{version}-%{release}
|
|
Provides: systemd-analyze = %{version}-%{release}
|
|
Obsoletes: pm-utils <= 1.4.1
|
|
Obsoletes: suspend <= 1.0
|
|
Obsoletes: systemd-analyze < 201
|
|
Source0: systemd-v%{version}%{suse_version}.tar.xz
|
|
Source1: %{name}-rpmlintrc
|
|
Source2: systemd-user
|
|
%if %{with sysvcompat}
|
|
Source3: systemd-sysv-convert
|
|
Source4: systemd-sysv-install
|
|
%endif
|
|
Source5: tmpfiles-suse.conf
|
|
Source6: baselibs.conf
|
|
Source11: after-local.service
|
|
Source14: kbd-model-map.legacy
|
|
|
|
Source100: scripts-systemd-fix-machines-btrfs-subvol.sh
|
|
Source101: scripts-systemd-upgrade-from-pre-210.sh
|
|
Source102: scripts-systemd-migrate-sysconfig-i18n.sh
|
|
|
|
# Patches listed below are SUSE specific and should be kept at its
|
|
# minimum. We try hard to push our changes to upstream but sometimes
|
|
# they are only relevant for SUSE distros. Special rewards for those
|
|
# who will manage to get rid of one of them !
|
|
Patch1: 0001-restore-var-run-and-var-lock-bind-mount-if-they-aren.patch
|
|
Patch2: 0002-rc-local-fix-ordering-startup-for-etc-init.d-boot.lo.patch
|
|
Patch3: 0003-strip-the-domain-part-from-etc-hostname-when-setting.patch
|
|
Patch5: 0005-udev-create-default-symlinks-for-primary-cd_dvd-driv.patch
|
|
Patch6: 0006-sysv-generator-add-back-support-for-SysV-scripts-for.patch
|
|
Patch7: 0007-networkd-make-network.service-an-alias-of-systemd-ne.patch
|
|
Patch8: 0008-sysv-generator-translate-Required-Start-into-a-Wants.patch
|
|
Patch9: 0009-pid1-handle-console-specificities-weirdness-for-s390.patch
|
|
Patch10: 0001-conf-parser-introduce-early-drop-ins.patch
|
|
Patch11: 0011-core-disable-session-keyring-per-system-sevice-entir.patch
|
|
Patch12: 0012-resolved-create-etc-resolv.conf-symlink-at-runtime.patch
|
|
|
|
# Patches listed below are put in quarantine. Normally all changes
|
|
# must go to upstream first and then are cherry-picked in the SUSE git
|
|
# repository. But in very few cases, some stuff might be broken in
|
|
# upstream and need an urgent fix. Even in this case, the patches are
|
|
# temporary and should be removed as soon as a fix is merged by
|
|
# upstream.
|
|
|
|
%description
|
|
Systemd is a system and service manager, compatible with SysV and LSB
|
|
init scripts for Linux. systemd provides aggressive parallelization
|
|
capabilities, uses socket and D-Bus activation for starting services,
|
|
offers on-demand starting of daemons, keeps track of processes using
|
|
Linux cgroups, supports snapshotting and restoring of the system state,
|
|
maintains mount and automount points and implements an elaborate
|
|
transactional dependency-based service control logic. It can work as a
|
|
drop-in replacement for sysvinit.
|
|
|
|
%if !0%{?bootstrap}
|
|
%package doc
|
|
Summary: HTML documentation for systemd
|
|
License: LGPL-2.1-or-later
|
|
Supplements: (systemd and patterns-base-documentation)
|
|
|
|
%description doc
|
|
The HTML documentation for systemd.
|
|
|
|
# /bootstrap
|
|
%endif
|
|
|
|
%package devel
|
|
Summary: Development headers for systemd
|
|
License: LGPL-2.1-or-later
|
|
Requires: libsystemd0%{?mini} = %{version}-%{release}
|
|
Requires: systemd-rpm-macros
|
|
%if 0%{?bootstrap}
|
|
Conflicts: systemd-devel
|
|
%endif
|
|
|
|
%description devel
|
|
Development headers and auxiliary files for developing applications for systemd.
|
|
|
|
%package sysvinit
|
|
Summary: System V init tools
|
|
License: LGPL-2.1-or-later
|
|
Requires: %{name} = %{version}-%{release}
|
|
Provides: sbin_init
|
|
Conflicts: sbin_init
|
|
Provides: systemd-sysvinit = %{version}-%{release}
|
|
Provides: sysvinit:/sbin/init
|
|
|
|
%description sysvinit
|
|
Drop-in replacement of System V init tools.
|
|
|
|
%package -n libsystemd0%{?mini}
|
|
Summary: Component library for systemd
|
|
License: LGPL-2.1-or-later
|
|
%if 0%{?bootstrap}
|
|
Conflicts: libsystemd0
|
|
Requires: this-is-only-for-build-envs
|
|
%endif
|
|
|
|
%description -n libsystemd0%{?mini}
|
|
This library provides several of the systemd C APIs:
|
|
|
|
* sd-bus implements an alternative D-Bus client library that is
|
|
relatively easy to use, very efficient and supports both classic
|
|
D-Bus as well as kdbus as transport backend.
|
|
|
|
* sd-daemon(3): for system services (daemons) to report their status
|
|
to systemd and to make easy use of socket-based activation logic
|
|
|
|
* sd-event is a generic event loop abstraction that is built around
|
|
Linux epoll, but adds features such as event prioritization or
|
|
efficient timer handling.
|
|
|
|
* sd-id128(3): generation and processing of 128-bit IDs
|
|
|
|
* sd-journal(3): API to submit and query journal log entries
|
|
|
|
* sd-login(3): APIs to introspect and monitor seat, login session and
|
|
user status information on the local system.
|
|
|
|
%package -n udev%{?mini}
|
|
Summary: A rule-based device node and kernel event manager
|
|
License: GPL-2.0-only
|
|
URL: http://www.kernel.org/pub/linux/utils/kernel/hotplug/udev.html
|
|
Requires: %{name} = %{version}-%{release}
|
|
%systemd_requires
|
|
Requires: kmod
|
|
Requires: system-group-hardware
|
|
Requires: group(kvm)
|
|
Requires(post): sed
|
|
Requires(post): coreutils
|
|
Requires(postun): coreutils
|
|
|
|
Conflicts: filesystem < 11.5
|
|
Conflicts: mkinitrd < 2.7.0
|
|
Conflicts: dracut < 044.1
|
|
Conflicts: util-linux < 2.16
|
|
Conflicts: ConsoleKit < 0.4.1
|
|
Requires: filesystem
|
|
%if 0%{?bootstrap}
|
|
Provides: udev = %{version}-%{release}
|
|
Conflicts: libudev1
|
|
Conflicts: udev
|
|
# avoid kiwi picking it for bootstrap
|
|
Requires: this-is-only-for-build-envs
|
|
%endif
|
|
|
|
%description -n udev%{?mini}
|
|
Udev creates and removes device nodes in /dev for devices discovered or
|
|
removed from the system. It receives events via kernel netlink messages
|
|
and dispatches them according to rules in %{_udevrulesdir}/. Matching
|
|
rules may name a device node, create additional symlinks to the node,
|
|
call tools to initialize a device, or load needed kernel modules.
|
|
|
|
%package -n libudev%{?mini}1
|
|
Summary: Dynamic library to access udev device information
|
|
License: LGPL-2.1-or-later
|
|
%if 0%{?bootstrap}
|
|
Conflicts: libudev1
|
|
Conflicts: kiwi
|
|
# avoid kiwi picking it for bootstrap
|
|
Requires: this-is-only-for-build-envs
|
|
%endif
|
|
|
|
%description -n libudev%{?mini}1
|
|
This package contains the dynamic library libudev, which provides
|
|
access to udev device information
|
|
|
|
%package -n libudev%{?mini}-devel
|
|
Summary: Development files for libudev
|
|
License: LGPL-2.1-or-later
|
|
Requires: libudev%{?mini}1 = %{version}-%{release}
|
|
%if 0%{?bootstrap}
|
|
Provides: libudev-devel = %{version}-%{version}
|
|
Conflicts: libudev1 = %{version}
|
|
Conflicts: libudev-devel
|
|
%endif
|
|
|
|
%description -n libudev%{?mini}-devel
|
|
This package contains the development files for the library libudev, a
|
|
dynamic library, which provides access to udev device information.
|
|
|
|
%if %{with coredump}
|
|
%package coredump
|
|
Summary: Systemd tools for coredump management
|
|
License: LGPL-2.1-or-later
|
|
Requires: %{name} = %{version}-%{release}
|
|
%systemd_requires
|
|
Provides: systemd:%{_bindir}/coredumpctl
|
|
|
|
%description coredump
|
|
Systemd tools to store and manage coredumps.
|
|
|
|
This package contains systemd-coredump, coredumpctl.
|
|
%endif
|
|
|
|
%package container
|
|
Summary: Systemd tools for container management
|
|
License: LGPL-2.1-or-later
|
|
Requires: %{name} = %{version}-%{release}
|
|
%systemd_requires
|
|
Provides: systemd:%{_bindir}/systemd-nspawn
|
|
%if 0%{?bootstrap}
|
|
Conflicts: systemd-container
|
|
%endif
|
|
|
|
%description container
|
|
Systemd tools to spawn and manage containers and virtual machines.
|
|
|
|
This package contains systemd-nspawn, machinectl, systemd-machined,
|
|
and systemd-importd.
|
|
|
|
%if %{with networkd} || %{with resolved}
|
|
%package network
|
|
Summary: Systemd tools for networkd and resolved
|
|
License: LGPL-2.1-or-later
|
|
Requires: %{name} = %{version}-%{release}
|
|
%systemd_requires
|
|
# This Recommends because some symbols of libidn2 are dlopen()ed by resolved
|
|
Recommends: pkgconfig(libidn2)
|
|
BuildRequires: pkgconfig(libidn2)
|
|
Provides: systemd:/usr/lib/systemd/systemd-networkd
|
|
Provides: systemd:/usr/lib/systemd/systemd-resolved
|
|
|
|
%description network
|
|
Systemd tools to manage network settings using networkd and
|
|
resolver tools for resolved
|
|
|
|
%endif
|
|
|
|
%if %{with portabled}
|
|
%package portable
|
|
Summary: Systemd tools for portable services
|
|
License: LGPL-2.1-or-later
|
|
Requires: %{name} = %{version}-%{release}
|
|
%systemd_requires
|
|
|
|
%description portable
|
|
Systemd tools to manage portable services. The feature is still
|
|
considered experimental so the package might change or vanish.
|
|
Use at own risk.
|
|
|
|
More information can be found online:
|
|
|
|
http://0pointer.net/blog/walkthrough-for-portable-services.html
|
|
https://systemd.io/PORTABLE_SERVICES
|
|
%endif
|
|
|
|
%if ! 0%{?bootstrap}
|
|
%package -n nss-systemd
|
|
Summary: Plugin for local virtual host name resolution
|
|
License: LGPL-2.1-or-later
|
|
|
|
%description -n nss-systemd
|
|
This package contains a plugin for the Name Service Switch (NSS),
|
|
which enables resolution of all dynamically allocated service
|
|
users. (See the DynamicUser= setting in unit files.)
|
|
|
|
To activate this NSS module, you will need to include it in
|
|
/etc/nsswitch.conf, see nss-systemd(8) manpage for more details.
|
|
|
|
%package -n nss-myhostname
|
|
Summary: Plugin for local system host name resolution
|
|
License: LGPL-2.1-or-later
|
|
|
|
%description -n nss-myhostname
|
|
This package contains a plug-in module for the Name Service Switch
|
|
(NSS), primarly providing hostname resolution for the locally
|
|
configured system hostname as returned by gethostname(2). For example,
|
|
it resolves the local hostname to locally configured IP addresses, as
|
|
well as "localhost" to 127.0.0.1/::1.
|
|
|
|
To activate this NSS module, you will need to include it in
|
|
/etc/nsswitch.conf, see nss-hostname(8) manpage for more details.
|
|
%endif
|
|
|
|
%if %{with resolved}
|
|
%package -n nss-resolve
|
|
Summary: Plugin for local hostname resolution via systemd-resolved
|
|
License: LGPL-2.1-or-later
|
|
Requires: %{name}-network = %{version}-%{release}
|
|
|
|
%description -n nss-resolve
|
|
This package contains a plug-in module for the Name Service Switch
|
|
(NSS), which enables host name resolutions via the systemd-resolved(8)
|
|
local network name resolution service. It replaces the nss-dns plug-in
|
|
module that traditionally resolves hostnames via DNS.
|
|
|
|
To activate this NSS module, you will need to include it in
|
|
/etc/nsswitch.conf, see nss-resolve(8) manpage for more details.
|
|
%endif
|
|
|
|
%if %{with machined}
|
|
%package -n nss-mymachines
|
|
Summary: Plugin for local virtual host name resolution
|
|
License: LGPL-2.1-or-later
|
|
|
|
%description -n nss-mymachines
|
|
This package contains a plugin for the Name Service Switch (NSS),
|
|
providing host name resolution for all local containers and virtual
|
|
machines registered with systemd-machined to their respective IP
|
|
addresses. It also maps UID/GIDs ranges used by containers to useful
|
|
names.
|
|
|
|
To activate this NSS module, you will need to include it in
|
|
/etc/nsswitch.conf, see nss-mymachines(8) manpage for more details.
|
|
%endif
|
|
|
|
%if %{with journal_remote}
|
|
%package journal-remote
|
|
Summary: Gateway for serving journal events over the network using HTTP
|
|
License: LGPL-2.1-or-later
|
|
Requires: %{name} = %{version}-%{release}
|
|
%systemd_requires
|
|
|
|
%description journal-remote
|
|
This extends the journal functionality to keep a copy of logs on a
|
|
remote server by providing programs to forward journal entries over
|
|
the network, using encrypted HTTP, and to write journal files from
|
|
serialized journal contents.
|
|
|
|
This package contains systemd-journal-gatewayd,
|
|
systemd-journal-remote, and systemd-journal-upload.
|
|
%endif
|
|
|
|
%if %{with testsuite}
|
|
%package testsuite
|
|
Summary: Testsuite for systemd
|
|
# Unit tests dependencies
|
|
License: LGPL-2.1-or-later
|
|
Recommends: python3
|
|
Recommends: python3-colorama
|
|
# Optional dep for mkfs.vfat needed by test-loop-block (otherwise skipped)
|
|
Recommends: dosfstools
|
|
# The following deps on libs are for test-dlopen-so whereas the
|
|
# pkgconfig ones are used by test-funtions to find the libs on the
|
|
# host and install them in the image, see install_missing_libraries()
|
|
# for details.
|
|
%if %{with resolved}
|
|
Requires: libidn2 pkgconfig(libidn2)
|
|
%endif
|
|
%if %{with experimental}
|
|
Requires: libpwquality1 pkgconfig(pwquality)
|
|
Requires: libqrencode4 pkgconfig(libqrencode)
|
|
%endif
|
|
Requires: %{name} = %{version}-%{release}
|
|
Requires: attr
|
|
Requires: binutils
|
|
Requires: busybox-static
|
|
Requires: cryptsetup
|
|
Requires: dosfstools
|
|
Requires: libcap-progs
|
|
Requires: lz4
|
|
Requires: netcat
|
|
Requires: qemu-kvm
|
|
Requires: quota
|
|
Requires: socat
|
|
Requires: squashfs
|
|
Requires: systemd-container
|
|
Requires: libfido2 pkgconfig(libfido2)
|
|
Requires: libtss2-esys0 pkgconfig(tss2-esys)
|
|
Requires: libtss2-mu0 pkgconfig(tss2-mu)
|
|
Requires: libtss2-rc0 pkgconfig(tss2-rc)
|
|
%if %{with coredump}
|
|
Requires: systemd-coredump
|
|
%endif
|
|
%if %{with experimental}
|
|
Requires: systemd-experimental
|
|
%endif
|
|
%if %{with journal_remote}
|
|
Requires: systemd-journal-remote
|
|
%endif
|
|
%if %{with portabled}
|
|
Requires: systemd-portable
|
|
%endif
|
|
Requires: xz
|
|
|
|
%description testsuite
|
|
This package contains the unit tests as well as the extended
|
|
testsuite. The unit tests are used to check various internal functions
|
|
used by systemd whereas the extended testsuite is used to test various
|
|
functionalities of systemd and all its components.
|
|
|
|
Note that the extended testsuite only works with UID=0.
|
|
|
|
Run the following python script to run all unit tests at once:
|
|
$ %{_testsuitedir}/run-unit-tests.py
|
|
|
|
To run the full extended testsuite do the following:
|
|
$ NO_BUILD=1 %{_testsuitedir}/test/run-integration-tests.sh
|
|
|
|
Or to run one specific integration test:
|
|
$ NO_BUILD=1 make -C %{_testsuitedir}/test/TEST-01-BASIC clean setup run
|
|
|
|
For more details on the available options to run the extended
|
|
testsuite, please refer to %{_testsuitedir}/test/README.testsuite.
|
|
%endif
|
|
|
|
%if %{with experimental}
|
|
%package experimental
|
|
Summary: Experimental systemd features
|
|
License: LGPL-2.1-or-later
|
|
Requires: %{name} = %{version}-%{release}
|
|
%systemd_requires
|
|
# These Recommends because some symbols of these libs are dlopen()ed by home stuff
|
|
Recommends: libfido2
|
|
Recommends: libpwquality1
|
|
Recommends: libqrencode4
|
|
# libfido2, libpwquality1 and libqrencode4 are build requirements for home stuff
|
|
BuildRequires: pkgconfig(libfido2)
|
|
BuildRequires: pkgconfig(libqrencode)
|
|
BuildRequires: pkgconfig(pwquality)
|
|
# fdisk and openssl are build requirements for home stuff and repart
|
|
BuildRequires: pkgconfig(fdisk)
|
|
BuildRequires: pkgconfig(openssl)
|
|
|
|
%description experimental
|
|
This package contains optional extra services that are considered as
|
|
previews and are provided so users can do early experiments with the
|
|
new features or technologies without waiting for them to be fully
|
|
supported by either upstream and openSUSE.
|
|
|
|
Please note that all services should be considered in development
|
|
phase and as such their behaviors details, unit files, option names,
|
|
etc... are subject to change without the usual backwards-compatibility
|
|
promises.
|
|
|
|
Components that turn out to be stable and considered as fully
|
|
supported will be merged into the main package or moved into a
|
|
dedicated package.
|
|
|
|
The package contains: homed, pstore, repart, userdbd.
|
|
|
|
Have fun with these services at your own risk.
|
|
%endif
|
|
|
|
%if ! 0%{?bootstrap}
|
|
%lang_package
|
|
%endif
|
|
|
|
%prep
|
|
%setup -q -n systemd-v%{version}%{suse_version}
|
|
%autopatch -p1
|
|
|
|
%build
|
|
# keep split-usr until all packages have moved their systemd rules to /usr
|
|
%meson \
|
|
-Dmode=release \
|
|
-Dversion-tag=%{version}%{suse_version} \
|
|
-Ddocdir=%{_docdir}/systemd \
|
|
-Drootprefix=/usr \
|
|
%if !0%{?usrmerged}
|
|
-Dsplit-usr=true \
|
|
%endif
|
|
-Dsplit-bin=true \
|
|
-Dsystem-uid-max=499 \
|
|
-Dsystem-gid-max=499 \
|
|
-Dpamconfdir=%{_pam_vendordir} \
|
|
-Dpamlibdir=%{_pam_moduledir} \
|
|
-Dxinitrcdir=%{_distconfdir}/X11/xinit/xinitrc.d \
|
|
-Drpmmacrosdir=no \
|
|
-Dcertificate-root=%{_sysconfdir}/pki/systemd \
|
|
-Ddefault-hierarchy=unified \
|
|
-Ddefault-kill-user-processes=false \
|
|
-Drc-local=/etc/init.d/boot.local \
|
|
-Dcreate-log-dirs=false \
|
|
-Dbump-proc-sys-fs-nr-open=false \
|
|
-Ddebug-shell=/bin/bash \
|
|
-Dseccomp=auto \
|
|
-Dselinux=auto \
|
|
-Dapparmor=auto \
|
|
-Dsmack=false \
|
|
-Dima=false \
|
|
-Delfutils=auto \
|
|
-Doomd=false \
|
|
%if %{with experimental}
|
|
-Dpstore=true \
|
|
-Drepart=true \
|
|
-Dhomed=true \
|
|
-Duserdb=true \
|
|
%else
|
|
-Dpstore=false \
|
|
-Drepart=false \
|
|
-Dhomed=false \
|
|
-Duserdb=false \
|
|
%endif
|
|
%if 0%{?bootstrap}
|
|
-Dnss-myhostname=false \
|
|
%else
|
|
-Dtpm2=true \
|
|
-Dman=true \
|
|
-Dhtml=true \
|
|
%endif
|
|
%if %{without coredump}
|
|
-Dcoredump=false \
|
|
%endif
|
|
%if %{without gnuefi}
|
|
-Dgnu-efi=false \
|
|
%endif
|
|
%if %{without importd}
|
|
-Dimportd=false \
|
|
%endif
|
|
%if %{without journal_remote}
|
|
-Dremote=false \
|
|
%endif
|
|
%if %{without portabled}
|
|
-Dportabled=false \
|
|
%endif
|
|
%if %{without machined}
|
|
-Dmachined=false \
|
|
%endif
|
|
%if %{without networkd}
|
|
-Dnetworkd=false \
|
|
%endif
|
|
%if %{without resolved}
|
|
-Dresolve=false \
|
|
%endif
|
|
%if %{without sysvcompat}
|
|
-Dsysvinit-path= \
|
|
-Dsysvrcnd-path= \
|
|
%endif
|
|
%if %{with testsuite}
|
|
-Dtests=unsafe \
|
|
-Dinstall-tests=true \
|
|
%else
|
|
-Dtests=false \
|
|
-Dinstall-tests=false \
|
|
%endif
|
|
-Dadm-group=false \
|
|
-Dwheel-group=false \
|
|
-Dgshadow=false \
|
|
-Dldconfig=false
|
|
|
|
%meson_build
|
|
|
|
%install
|
|
%meson_install
|
|
|
|
%if 0%{?bootstrap}
|
|
rm %{buildroot}%{_libdir}/libnss_systemd.so*
|
|
rm -r %{buildroot}%{_datadir}/locale
|
|
%endif
|
|
|
|
# Don't ship resolvconf symlink for now as it conflicts with the
|
|
# binary shipped by openresolv and provides limited compatibility
|
|
# only
|
|
%if %{with resolved}
|
|
rm %{buildroot}%{_sbindir}/resolvconf
|
|
rm %{buildroot}%{_mandir}/man1/resolvconf.1*
|
|
%endif
|
|
|
|
%if %{with sysvcompat}
|
|
mkdir -p %{buildroot}%{_localstatedir}/lib/systemd/sysv-convert
|
|
mkdir -p %{buildroot}%{_localstatedir}/lib/systemd/migrated
|
|
|
|
install -m0755 -D %{S:3} %{buildroot}/%{_prefix}/lib/systemd/systemd-sysv-convert
|
|
install -m0755 -D %{S:4} %{buildroot}/%{_prefix}/lib/systemd/systemd-sysv-install
|
|
%endif
|
|
|
|
mkdir -p % %{buildroot}%{_sysconfdir}/systemd/network
|
|
mkdir -p % %{buildroot}%{_sysconfdir}/systemd/nspawn
|
|
|
|
# Package the scripts used to fix all packaging issues. Also drop the
|
|
# "scripts-{systemd/udev}" prefix which is used because osc doesn't
|
|
# allow directory structure...
|
|
for s in %{S:100} %{S:101} %{S:102}; do
|
|
install -m0755 -D $s %{buildroot}%{_prefix}/lib/systemd/scripts/${s#*/scripts-systemd-}
|
|
done
|
|
|
|
%if !0%{?usrmerged}
|
|
# Legacy sysvinit tools
|
|
mkdir -p %{buildroot}/sbin
|
|
ln -s ../usr/lib/systemd/systemd %{buildroot}/sbin/init
|
|
ln -s ../usr/bin/systemctl %{buildroot}/sbin/reboot
|
|
ln -s ../usr/bin/systemctl %{buildroot}/sbin/halt
|
|
ln -s ../usr/bin/systemctl %{buildroot}/sbin/shutdown
|
|
ln -s ../usr/bin/systemctl %{buildroot}/sbin/poweroff
|
|
%if %{with sysvcompat}
|
|
ln -s ../usr/bin/systemctl %{buildroot}/sbin/telinit
|
|
ln -s ../usr/bin/systemctl %{buildroot}/sbin/runlevel
|
|
%endif
|
|
%endif
|
|
|
|
# Make sure we don't ship static enablement symlinks in /etc during
|
|
# installation, presets should be honoured instead.
|
|
rm -rf %{buildroot}/etc/systemd/system/*.target.{requires,wants}
|
|
rm -f %{buildroot}/etc/systemd/system/default.target
|
|
|
|
# Replace upstream systemd-user with the openSUSE one.
|
|
install -m0644 %{S:2} %{buildroot}%{_pam_vendordir}
|
|
|
|
# don't enable wall ask password service, it spams every console (bnc#747783)
|
|
rm %{buildroot}%{_unitdir}/multi-user.target.wants/systemd-ask-password-wall.path
|
|
|
|
# do not ship sysctl defaults in systemd package, will be part of
|
|
# aaa_base (in procps for now)
|
|
rm -f %{buildroot}%{_sysctldir}/50-default.conf
|
|
rm -f %{buildroot}%{_sysctldir}/50-pid-max.conf
|
|
|
|
# Make sure systemd-network polkit rules file starts with a suitable
|
|
# number prefix so it takes precedence over our polkit-default-privs.
|
|
%if %{with networkd}
|
|
mv %{buildroot}%{_datadir}/polkit-1/rules.d/systemd-networkd.rules \
|
|
%{buildroot}%{_datadir}/polkit-1/rules.d/60-systemd-networkd.rules
|
|
%endif
|
|
|
|
# since v207 /etc/sysctl.conf is no longer parsed (commit
|
|
# 04bf3c1a60d82791), however backward compatibility is provided by
|
|
# /usr/lib/sysctl.d/99-sysctl.conf.
|
|
ln -s ../../../etc/sysctl.conf %{buildroot}%{_sysctldir}/99-sysctl.conf
|
|
|
|
# The definition of the basic users/groups are defined by system-user
|
|
# on SUSE (bsc#1006978).
|
|
rm -f %{buildroot}%{_sysusersdir}/basic.conf
|
|
|
|
# Remove README file in init.d as (SUSE) rpm requires executable files
|
|
# in this directory... oh well.
|
|
rm -f %{buildroot}/etc/init.d/README
|
|
|
|
# This dir must be owned (and thus created) by systemd otherwise the
|
|
# build system will complain. This is odd since we simply own a ghost
|
|
# file in it...
|
|
mkdir -p %{buildroot}%{_sysconfdir}/X11/xorg.conf.d
|
|
|
|
# Make sure directories in /var exist
|
|
mkdir -p %{buildroot}%{_localstatedir}/lib/systemd/coredump
|
|
mkdir -p %{buildroot}%{_localstatedir}/lib/systemd/catalog
|
|
|
|
# Make sure the NTP units dir exists
|
|
mkdir -p %{buildroot}%{_ntpunitsdir}
|
|
|
|
# Make sure the shutdown/sleep drop-in dirs exist
|
|
mkdir -p %{buildroot}%{_prefix}/lib/systemd/system-shutdown/
|
|
mkdir -p %{buildroot}%{_prefix}/lib/systemd/system-sleep/
|
|
|
|
# Make sure these directories are properly owned
|
|
mkdir -p %{buildroot}%{_unitdir}/basic.target.wants
|
|
mkdir -p %{buildroot}%{_unitdir}/default.target.wants
|
|
mkdir -p %{buildroot}%{_unitdir}/dbus.target.wants
|
|
mkdir -p %{buildroot}%{_unitdir}/halt.target.wants
|
|
mkdir -p %{buildroot}%{_unitdir}/kexec.target.wants
|
|
mkdir -p %{buildroot}%{_unitdir}/poweroff.target.wants
|
|
mkdir -p %{buildroot}%{_unitdir}/reboot.target.wants
|
|
mkdir -p %{buildroot}%{_unitdir}/shutdown.target.wants
|
|
|
|
# Make sure the generator directories are created and properly owned.
|
|
mkdir -p %{buildroot}%{_systemdgeneratordir}
|
|
mkdir -p %{buildroot}%{_systemdusergeneratordir}
|
|
mkdir -p %{buildroot}%{_presetdir}
|
|
mkdir -p %{buildroot}%{_userpresetdir}
|
|
mkdir -p %{buildroot}%{_systemd_system_env_generator_dir}
|
|
mkdir -p %{buildroot}%{_systemd_user_env_generator_dir}
|
|
|
|
# ensure after.local wrapper is called
|
|
install -m 644 %{S:11} %{buildroot}%{_unitdir}/
|
|
ln -s ../after-local.service %{buildroot}%{_unitdir}/multi-user.target.wants/
|
|
|
|
# ghost directories with default permissions.
|
|
mkdir -p %{buildroot}%{_localstatedir}/lib/systemd/backlight
|
|
|
|
# ghost files with default permisssions.
|
|
touch %{buildroot}%{_sysconfdir}/X11/xorg.conf.d/00-keyboard.conf
|
|
touch %{buildroot}%{_sysconfdir}/vconsole.conf
|
|
touch %{buildroot}%{_sysconfdir}/locale.conf
|
|
touch %{buildroot}%{_sysconfdir}/machine-info
|
|
touch %{buildroot}%{_localstatedir}/lib/systemd/catalog/database
|
|
touch %{buildroot}%{_localstatedir}/lib/systemd/i18n-migrated
|
|
|
|
%fdupes -s %{buildroot}%{_mandir}
|
|
|
|
# Make sure to disable all services by default. The Suse branding
|
|
# presets package takes care of defining the right policies.
|
|
rm -f %{buildroot}%{_presetdir}/*.preset
|
|
echo 'disable *' >%{buildroot}%{_presetdir}/99-default.preset
|
|
echo 'disable *' >%{buildroot}%{_userpresetdir}/99-default.preset
|
|
|
|
# The tmpfiles dealing with the generic paths is pretty messy
|
|
# currently because:
|
|
#
|
|
# 1. filesystem package wants to define the generic paths and some of
|
|
# them conflict with the definition given by systemd in var.conf,
|
|
# see bsc#1078466.
|
|
#
|
|
# 2. /tmp and /var/tmp are not cleaned by default on SUSE distros
|
|
# (fate#314974) which conflict with tmp.conf.
|
|
#
|
|
# 3. There're also legacy.conf which defines various legacy paths
|
|
# which either don't match the SUSE defaults or don't look needed
|
|
# at all.
|
|
#
|
|
# 4. And to finish, we don't want the part in etc.conf which imports
|
|
# default upstream files in empty /etc, see below.
|
|
#
|
|
# To keep things simple, we remove all these tmpfiles config files but
|
|
# still keep the remaining paths that still don't have a better home
|
|
# in suse.conf.
|
|
rm -f %{buildroot}%{_tmpfilesdir}/{etc,home,legacy,tmp,var}.conf
|
|
install -m 644 %{S:5} %{buildroot}%{_tmpfilesdir}/suse.conf
|
|
|
|
# The content of the files shipped by systemd doesn't match the
|
|
# defaults used by SUSE. Don't ship those files but leave the decision
|
|
# to use the mechanism to the individual packages that actually
|
|
# consume those configs (like glibc or pam), see bsc#1170146.
|
|
rm -fr %{buildroot}%{_datadir}/factory/*
|
|
|
|
# Add entries for xkeyboard-config converted keymaps; mappings, which
|
|
# already exist in original systemd mapping table are being ignored
|
|
# though, i.e. not overwritten; needed as long as YaST uses console
|
|
# keymaps internally and calls localectl to convert from vconsole to
|
|
# X11 keymaps. Ideally YaST should switch to X11 layout names (the
|
|
# mapping table wouldn't be needed since each X11 keymap has a
|
|
# generated xkbd keymap) and let localectl initialize
|
|
# /etc/vconsole.conf and /etc/X11/xorg.conf.d/00-keyboard.conf
|
|
# (FATE#319454).
|
|
if [ -f /usr/share/systemd/kbd-model-map.xkb-generated ]; then
|
|
cat /usr/share/systemd/kbd-model-map.xkb-generated \
|
|
>>%{buildroot}%{_datarootdir}/systemd/kbd-model-map
|
|
fi
|
|
|
|
# kbd-model-map.legacy is used to provide mapping for legacy keymaps,
|
|
# which may still be used by yast.
|
|
cat %{S:14} >>%{buildroot}%{_datarootdir}/systemd/kbd-model-map
|
|
|
|
# Don't ship systemd-journald-audit.socket as there's no other way for
|
|
# us to prevent journald from recording audit messages in the journal
|
|
# by default (bsc#1109252).
|
|
rm -f %{buildroot}%{_unitdir}/systemd-journald-audit.socket
|
|
rm -f %{buildroot}%{_unitdir}/sockets.target.wants/systemd-journald-audit.socket
|
|
|
|
%if %{with testsuite}
|
|
cp -a test %{buildroot}%{_testsuitedir}/
|
|
find %{buildroot}%{_testsuitedir}/ -name .git\* -exec rm -fr {} \;
|
|
%endif
|
|
|
|
%if ! 0%{?bootstrap}
|
|
%find_lang systemd
|
|
%endif
|
|
|
|
# Build of installation images uses a hard coded list of packages with
|
|
# a %%pre that needs to be run during the build. systemd is one of them
|
|
# so keep the section even if it's empty.
|
|
%pre
|
|
:
|
|
|
|
%post
|
|
# Make /etc/machine-id an empty file during package installation. On
|
|
# the first boot, machine-id is initialized and either committed (if
|
|
# /etc/ is writable) or the system/image runs with a transient machine
|
|
# ID, that changes on each boot (if the image is read-only). This is
|
|
# especially important for appliance builds to avoid an identical
|
|
# machine ID in all images.
|
|
if [ $1 -eq 1 ]; then
|
|
touch %{_sysconfdir}/machine-id
|
|
chmod 444 %{_sysconfdir}/machine-id
|
|
fi
|
|
|
|
# /etc/machine-id might have been created writeable incorrectly
|
|
# (boo#1092269).
|
|
if [ "$(stat -c%a %{_sysconfdir}/machine-id)" != 444 ]; then
|
|
echo "Incorrect file mode bits for /etc/machine-id which should be 0444, fixing..."
|
|
chmod 444 %{_sysconfdir}/machine-id
|
|
fi
|
|
|
|
%if ! 0%{?bootstrap}
|
|
pam-config --add --systemd || :
|
|
%endif
|
|
|
|
# systemd-sysusers is not available in %pre so this needs to be done
|
|
# in %%post. However this shouldn't be an issue since all files the
|
|
# main package ships are owned by root.
|
|
%sysusers_create systemd.conf
|
|
|
|
[ -e %{_localstatedir}/lib/random-seed ] && mv %{_localstatedir}/lib/random-seed %{_localstatedir}/lib/systemd/ || :
|
|
/usr/lib/systemd/systemd-random-seed save || :
|
|
|
|
systemctl daemon-reexec || :
|
|
|
|
# Reexecute user manager instances (if any). It is asynchronous but it
|
|
# shouldn't be a problem in practice: a problem would arise only if
|
|
# the new version of a user service has a brand new option that is
|
|
# only understood by the latest version of the user manager and the
|
|
# user service is started before the user manager get reexecuted. But
|
|
# this case is very unlikely especially since we don't restart any
|
|
# user service for now on.
|
|
#
|
|
# Before doing this, we unfortunately have to wait until users will
|
|
# reexec their user manager (by either rebooting or restarting their
|
|
# session) to a version that supports SIGRTMIN+25 otherwise sending
|
|
# the signal to an old version will kill the manager which means
|
|
# tearing down the user session.
|
|
#
|
|
# systemctl kill --kill-who=main --signal=SIGRTMIN+25 "user@*.service" || :
|
|
|
|
if [ "$1" -eq 1 ]; then
|
|
# Persistent journal is the default
|
|
mkdir -p %{_localstatedir}/log/journal
|
|
fi
|
|
|
|
%journal_catalog_update
|
|
%tmpfiles_create
|
|
|
|
# Create default config in /etc at first install.
|
|
# Later package updates should not overwrite these settings.
|
|
%systemd_post remote-cryptsetup.target
|
|
%systemd_post getty@.service
|
|
%systemd_post machines.target
|
|
%systemd_post remote-fs.target
|
|
%systemd_post systemd-timesyncd.service
|
|
|
|
# v228 wrongly set world writable suid root permissions on timestamp
|
|
# files used by permanent timers. Fix the timestamps that might have
|
|
# been created by the affected versions of systemd (bsc#1020601).
|
|
for stamp in $(ls /var/lib/systemd/timers/stamp-*.timer 2>/dev/null); do
|
|
chmod 0644 $stamp
|
|
done
|
|
|
|
# Same for user lingering created by logind.
|
|
for username in $(ls /var/lib/systemd/linger/* 2>/dev/null); do
|
|
chmod 0644 $username
|
|
done
|
|
|
|
# Due to the fact that DynamicUser= was turned ON during v235 and then
|
|
# switched back to off in v240, /var/lib/systemd/timesync might be a
|
|
# symlink pointing to /var/lib/private/systemd/timesync, which is
|
|
# inaccessible for systemd-timesync user as /var/lib/private is 0700
|
|
# root:root, see https://github.com/systemd/systemd/issues/11329 for
|
|
# details. Note: only TW users might be affected by this bug.
|
|
if [ -L %{_localstatedir}/lib/systemd/timesync ]; then
|
|
rm %{_localstatedir}/lib/systemd/timesync
|
|
mv %{_localstatedir}/lib/private/systemd/timesync %{_localstatedir}/lib/systemd/timesync
|
|
fi
|
|
|
|
# This includes all hacks needed when upgrading from SysV.
|
|
%{_prefix}/lib/systemd/scripts/upgrade-from-pre-210.sh || :
|
|
|
|
# Migrate old i18n settings previously configured in /etc/sysconfig to
|
|
# the new locations used by systemd (/etc/locale.conf,
|
|
# /etc/vconsole.conf, ...). Recent versions of systemd parse the new
|
|
# locations only.
|
|
#
|
|
# This is needed both at package updates and package installations
|
|
# because we might be upgrading from a system which was running SysV
|
|
# init (systemd package is being installed).
|
|
#
|
|
# It's run only once.
|
|
%{_prefix}/lib/systemd/scripts/migrate-sysconfig-i18n.sh || :
|
|
|
|
# During the migration to tmpfs for /tmp, a bug was introduced that
|
|
# affected users using tmpfs for /tmp and happened during the _second_
|
|
# update following the one that introduced tmpfs on /tmp. It consisted
|
|
# in creating a dangling symlink /etc/systemd/system/tmp.mount
|
|
# pointing to the old copy that previous versions shipped in
|
|
# /usr/share/systemd, which doesn't exist anymore. So we migrate the
|
|
# link to the new location.
|
|
#
|
|
# Users have been exposed to this bug during a short period of time as
|
|
# it was present only in one release and was fixed shortly after by
|
|
# the next update. So we can assume that it's safe to drop it in 6
|
|
# months (ie March 2021).
|
|
if [ "$(readlink -f %{_sysconfdir}/systemd/system/tmp.mount)" = "%{_datadir}/systemd/tmp.mount" ] ; then
|
|
ln -sf %{_unitdir}/tmp.mount %{_sysconfdir}/systemd/system/tmp.mount
|
|
fi
|
|
|
|
%postun
|
|
# daemon-reload is implied by %%systemd_postun_with_restart
|
|
%systemd_postun_with_restart systemd-journald.service
|
|
%systemd_postun_with_restart systemd-timesyncd.service
|
|
# Avoid restarting logind until fixed upstream (issue #1163)
|
|
|
|
%pre -n udev%{?mini}
|
|
# New installations uses the last compat symlink generation number
|
|
# (currently at 2), which basically disables all compat symlinks. On
|
|
# old systems, the file doesn't exist. This is equivalent to
|
|
# generation #1, which enables the creation of all compat symlinks.
|
|
if [ $1 -eq 1 ]; then
|
|
echo "COMPAT_SYMLINK_GENERATION=2" >/usr/lib/udev/compat-symlink-generation
|
|
fi
|
|
|
|
%post -n udev%{?mini}
|
|
%regenerate_initrd_post
|
|
%udev_hwdb_update
|
|
|
|
# add KERNEL name match to existing persistent net rules
|
|
sed -ri '/KERNEL/ ! { s/NAME="(eth|wlan|ath)([0-9]+)"/KERNEL=="\1*", NAME="\1\2"/}' \
|
|
/etc/udev/rules.d/70-persistent-net.rules 2>/dev/null || :
|
|
|
|
# cleanup old stuff
|
|
rm -f /etc/sysconfig/udev
|
|
rm -f /etc/udev/rules.d/{20,55,65}-cdrom.rules
|
|
|
|
%postun -n udev%{?mini}
|
|
%regenerate_initrd_post
|
|
|
|
# The order of the units being restarted is important here because there's currently no
|
|
# way to queue multiple jobs into a single transaction atomically. Therefore systemctl
|
|
# will create 3 restart jobs that can be handled by PID1 separately and if the jobs for
|
|
# the sockets are being handled first then starting them again will fail as the service
|
|
# is still active hence the sockets held by udevd. However if the restart job for udevd
|
|
# is handled first, there should be enough time to queue the socket jobs before the stop
|
|
# job for udevd is processed. Hence PID1 will automatically sort the restart jobs
|
|
# correctly by stopping the service then the sockets and then by starting the sockets and
|
|
# the unit.
|
|
#
|
|
# Note that when systemd-udevd is restarted, there will always be a short time
|
|
# frame where no socket will be listening to the events sent by the kernel, no
|
|
# matter if the socket unit is restarted in first or not.
|
|
%service_del_postun_with_restart systemd-udevd.service systemd-udevd-{control,kernel}.socket
|
|
|
|
%posttrans -n udev%{?mini}
|
|
%regenerate_initrd_posttrans
|
|
|
|
%post -n libudev%{?mini}1 -p /sbin/ldconfig
|
|
%post -n libsystemd0%{?mini} -p /sbin/ldconfig
|
|
|
|
%postun -n libudev%{?mini}1 -p /sbin/ldconfig
|
|
%postun -n libsystemd0%{?mini} -p /sbin/ldconfig
|
|
|
|
%post container
|
|
%tmpfiles_create systemd-nspawn.conf
|
|
%if %{with machined}
|
|
if [ $1 -gt 1 ]; then
|
|
# Convert /var/lib/machines subvolume to make it suitable for
|
|
# rollbacks, if needed. See bsc#992573. The installer has been fixed
|
|
# to create it at installation time.
|
|
#
|
|
# The convertion might only be problematic for openSUSE distros
|
|
# (TW/Factory) where previous versions had already created the
|
|
# subvolume at the wrong place (via tmpfiles for example) and user
|
|
# started to populate and use it. In this case we'll let the user fix
|
|
# it manually.
|
|
#
|
|
# For SLE12 this subvolume was only introduced during the upgrade from
|
|
# v210 to v228 when we added this workaround. Note that the subvolume
|
|
# is still created at the wrong place due to the call to
|
|
# tmpfiles_create macro previously however it's empty so there
|
|
# shouldn't be any issues.
|
|
%{_prefix}/lib/systemd/scripts/fix-machines-btrfs-subvol.sh || :
|
|
fi
|
|
%endif
|
|
|
|
%if ! 0%{?bootstrap}
|
|
%post -n nss-myhostname -p /sbin/ldconfig
|
|
%postun -n nss-myhostname -p /sbin/ldconfig
|
|
|
|
%post -n nss-systemd -p /sbin/ldconfig
|
|
%postun -n nss-systemd -p /sbin/ldconfig
|
|
%endif
|
|
|
|
%if %{with resolved}
|
|
%post -n nss-resolve -p /sbin/ldconfig
|
|
%postun -n nss-resolve -p /sbin/ldconfig
|
|
%endif
|
|
|
|
%if %{with machined}
|
|
%post -n nss-mymachines -p /sbin/ldconfig
|
|
%postun -n nss-mymachines -p /sbin/ldconfig
|
|
%endif
|
|
|
|
%if %{with journal_remote}
|
|
%pre journal-remote
|
|
%service_add_pre systemd-journal-gatewayd.socket systemd-journal-gatewayd.service
|
|
%service_add_pre systemd-journal-remote.socket systemd-journal-remote.service
|
|
%service_add_pre systemd-journal-upload.service
|
|
|
|
%post journal-remote
|
|
# Assume that all files shipped by systemd-journal-remove are owned by root.
|
|
%sysusers_create systemd-remote.conf
|
|
%service_add_post systemd-journal-gatewayd.socket systemd-journal-gatewayd.service
|
|
%service_add_post systemd-journal-remote.socket systemd-journal-remote.service
|
|
%service_add_post systemd-journal-upload.service
|
|
|
|
%preun journal-remote
|
|
%service_del_preun systemd-journal-gatewayd.socket systemd-journal-gatewayd.service
|
|
%service_del_preun systemd-journal-remote.socket systemd-journal-remote.service
|
|
%service_del_preun systemd-journal-upload.service
|
|
|
|
%postun journal-remote
|
|
%service_del_postun systemd-journal-gatewayd.socket systemd-journal-gatewayd.service
|
|
%service_del_postun systemd-journal-remote.socket systemd-journal-remote.service
|
|
%service_del_postun systemd-journal-upload.service
|
|
%endif
|
|
|
|
%if %{with networkd} || %{with resolved}
|
|
%pre network
|
|
%if %{with networkd}
|
|
%service_add_pre systemd-networkd.service
|
|
%service_add_pre systemd-networkd-wait-online.service
|
|
%endif
|
|
%if %{with resolved}
|
|
%service_add_pre systemd-resolved.service
|
|
%endif
|
|
|
|
%post network
|
|
%if %{with networkd}
|
|
%service_add_post systemd-networkd.service
|
|
%service_add_post systemd-networkd-wait-online.service
|
|
%endif
|
|
%if %{with resolved}
|
|
%service_add_post systemd-resolved.service
|
|
%endif
|
|
|
|
%preun network
|
|
%if %{with networkd}
|
|
%service_del_preun systemd-networkd.service
|
|
%service_del_preun systemd-networkd-wait-online.service
|
|
%endif
|
|
%if %{with resolved}
|
|
%service_del_preun systemd-resolved.service
|
|
%endif
|
|
|
|
%postun network
|
|
%if %{with networkd}
|
|
%service_del_postun systemd-networkd.service
|
|
%service_del_postun systemd-networkd-wait-online.service
|
|
%endif
|
|
%if %{with resolved}
|
|
%service_del_postun systemd-resolved.service
|
|
%endif
|
|
%endif
|
|
|
|
%if %{with portabled}
|
|
%pre portable
|
|
%service_add_pre systemd-portabled.service
|
|
|
|
%post portable
|
|
%tmpfiles_create portables.conf
|
|
%service_add_post systemd-portabled.service
|
|
|
|
%preun portable
|
|
%service_del_preun systemd-portabled.service
|
|
|
|
%postun portable
|
|
%service_del_postun systemd-portabled.service
|
|
%endif
|
|
|
|
%if %{with experimental}
|
|
%pre experimental
|
|
%service_add_pre systemd-pstore.service
|
|
%service_add_pre systemd-userdbd.service systemd-userdbd.socket
|
|
%service_add_pre systemd-homed.service
|
|
|
|
%post experimental
|
|
%tmpfiles_create systemd-pstore.conf
|
|
%service_add_post systemd-pstore.service
|
|
%service_add_post systemd-userdbd.service systemd-userdbd.socket
|
|
%service_add_post systemd-homed.service
|
|
|
|
%preun experimental
|
|
%service_del_preun systemd-pstore.service
|
|
%service_del_preun systemd-userdbd.service systemd-userdbd.socket
|
|
%service_del_preun systemd-homed.service
|
|
|
|
%postun experimental
|
|
%service_del_postun systemd-pstore.service
|
|
%service_del_postun systemd-userdbd.service systemd-userdbd.socket
|
|
%service_del_postun systemd-homed.service
|
|
%endif
|
|
|
|
%files
|
|
%defattr(-,root,root)
|
|
%license LICENSE*
|
|
%{_bindir}/busctl
|
|
%{_bindir}/bootctl
|
|
%{_bindir}/hostnamectl
|
|
%{_bindir}/kernel-install
|
|
%{_bindir}/localectl
|
|
%{_bindir}/systemctl
|
|
%{_bindir}/systemd-analyze
|
|
%if ! 0%{?bootstrap}
|
|
%{_bindir}/systemd-cryptenroll
|
|
%endif
|
|
%{_bindir}/systemd-delta
|
|
%{_bindir}/systemd-dissect
|
|
%{_bindir}/systemd-escape
|
|
%{_bindir}/systemd-firstboot
|
|
%{_bindir}/systemd-id128
|
|
%{_bindir}/systemd-path
|
|
%{_bindir}/systemd-sysusers
|
|
%{_bindir}/systemd-mount
|
|
%{_bindir}/systemd-umount
|
|
%{_bindir}/systemd-notify
|
|
%{_bindir}/systemd-run
|
|
%{_bindir}/systemd-sysext
|
|
%{_bindir}/journalctl
|
|
%{_bindir}/systemd-ask-password
|
|
%{_bindir}/loginctl
|
|
%{_bindir}/systemd-inhibit
|
|
%{_bindir}/systemd-tty-ask-password-agent
|
|
%{_bindir}/systemd-tmpfiles
|
|
%{_bindir}/systemd-machine-id-setup
|
|
%{_bindir}/systemd-socket-activate
|
|
%{_bindir}/systemd-stdio-bridge
|
|
%{_bindir}/systemd-detect-virt
|
|
%{_bindir}/timedatectl
|
|
%{_bindir}/systemd-cgls
|
|
%{_bindir}/systemd-cgtop
|
|
%{_bindir}/systemd-cat
|
|
%dir %{_prefix}/lib/kernel
|
|
%dir %{_prefix}/lib/kernel/install.d
|
|
%{_prefix}/lib/kernel/install.d/00-entry-directory.install
|
|
%{_prefix}/lib/kernel/install.d/50-depmod.install
|
|
%{_prefix}/lib/kernel/install.d/90-loaderentry.install
|
|
%dir %{_prefix}/lib/systemd
|
|
%dir %{_prefix}/lib/systemd/network
|
|
%dir %{_unitdir}
|
|
%{_userunitdir}
|
|
%if %{with coredump}
|
|
%exclude %{_prefix}/lib/systemd/systemd-coredump
|
|
%exclude %{_unitdir}/systemd-coredump*
|
|
%exclude %{_unitdir}/sockets.target.wants/systemd-coredump.socket
|
|
%endif
|
|
%if %{with journal_remote}
|
|
%exclude %{_unitdir}/systemd-journal-gatewayd.*
|
|
%exclude %{_unitdir}/systemd-journal-remote.*
|
|
%exclude %{_unitdir}/systemd-journal-upload.*
|
|
%exclude %{_prefix}/lib/systemd/systemd-journal-gatewayd
|
|
%exclude %{_prefix}/lib/systemd/systemd-journal-remote
|
|
%exclude %{_prefix}/lib/systemd/systemd-journal-upload
|
|
%endif
|
|
%exclude %{_prefix}/lib/systemd/systemd-udevd
|
|
%exclude %{_unitdir}/systemd-udev*.*
|
|
%exclude %{_unitdir}/systemd-hwdb*.*
|
|
%exclude %{_unitdir}/*.target.wants/systemd-udev*.*
|
|
%exclude %{_unitdir}/*.target.wants/systemd-hwdb*.*
|
|
%exclude %{_unitdir}/initrd-udevadm-cleanup-db.service
|
|
%exclude %{_unitdir}/kmod-static-nodes.service
|
|
%exclude %{_unitdir}/systemd-nspawn@.service
|
|
%if %{with machined}
|
|
%exclude %{_prefix}/lib/systemd/systemd-machined
|
|
%exclude %{_unitdir}/systemd-machined.service
|
|
%exclude %{_unitdir}/dbus-org.freedesktop.machine1.service
|
|
%exclude %{_unitdir}/var-lib-machines.mount
|
|
%exclude %{_unitdir}/machine.slice
|
|
%exclude %{_unitdir}/machines.target.wants
|
|
%exclude %{_unitdir}/*.target.wants/var-lib-machines.mount
|
|
%endif
|
|
%if %{with importd}
|
|
%exclude %{_prefix}/lib/systemd/systemd-import*
|
|
%exclude %{_prefix}/lib/systemd/systemd-pull
|
|
%exclude %{_prefix}/lib/systemd/import-pubring.gpg
|
|
%exclude %{_unitdir}/systemd-importd.service
|
|
%exclude %{_unitdir}/dbus-org.freedesktop.import1.service
|
|
%endif
|
|
%if %{with networkd}
|
|
%exclude %{_prefix}/lib/systemd/systemd-network-generator
|
|
%exclude %{_prefix}/lib/systemd/systemd-networkd
|
|
%exclude %{_prefix}/lib/systemd/systemd-networkd-wait-online
|
|
%exclude %{_unitdir}/systemd-network-generator.service
|
|
%exclude %{_unitdir}/systemd-networkd.service
|
|
%exclude %{_unitdir}/systemd-networkd.socket
|
|
%exclude %{_unitdir}/systemd-networkd-wait-online.service
|
|
%exclude %{_prefix}/lib/systemd/systemd-resolved
|
|
%exclude %{_unitdir}/systemd-resolved.service
|
|
%endif
|
|
%if %{with portabled}
|
|
%exclude %{_prefix}/lib/systemd/systemd-portabled
|
|
%exclude %{_prefix}/lib/systemd/portable
|
|
%exclude %{_unitdir}/systemd-portabled.service
|
|
%exclude %{_unitdir}/dbus-org.freedesktop.portable1.service
|
|
%exclude %{_tmpfilesdir}/portables.conf
|
|
%endif
|
|
%if %{with experimental}
|
|
%exclude %{_prefix}/lib/systemd/systemd-pstore
|
|
%exclude %{_unitdir}/systemd-pstore.service
|
|
%exclude %{_tmpfilesdir}/systemd-pstore.conf
|
|
%exclude %{_unitdir}/systemd-repart.service
|
|
%exclude %{_unitdir}/initrd-root-fs.target.wants/systemd-repart.service
|
|
%exclude %{_unitdir}/sysinit.target.wants/systemd-repart.service
|
|
%exclude %{_prefix}/lib/systemd/systemd-userwork
|
|
%exclude %{_prefix}/lib/systemd/systemd-userdbd
|
|
%exclude %{_unitdir}/systemd-userdbd.service
|
|
%exclude %{_unitdir}/systemd-userdbd.socket
|
|
%exclude %{_prefix}/lib/systemd/systemd-homed
|
|
%exclude %{_prefix}/lib/systemd/systemd-homework
|
|
%exclude %{_unitdir}/systemd-homed-activate.service
|
|
%exclude %{_unitdir}/systemd-homed.service
|
|
%endif
|
|
|
|
%{_unitdir}/*.automount
|
|
%{_unitdir}/*.service
|
|
%{_unitdir}/*.slice
|
|
%{_unitdir}/*.target
|
|
%{_unitdir}/*.mount
|
|
%{_unitdir}/*.timer
|
|
%{_unitdir}/*.socket
|
|
%{_unitdir}/*.wants
|
|
%{_unitdir}/*.path
|
|
|
|
%{_unitdir}/user-.slice.d/
|
|
|
|
%{_prefix}/lib/systemd/systemd-*
|
|
%{_prefix}/lib/systemd/systemd
|
|
%{_prefix}/lib/systemd/libsystemd-shared-*.so
|
|
%{_prefix}/lib/systemd/scripts
|
|
%exclude %{_prefix}/lib/systemd/scripts/fix-machines-btrfs-subvol.sh
|
|
%dir %{_journalcatalogdir}
|
|
%{_journalcatalogdir}/systemd.catalog
|
|
%{_journalcatalogdir}/systemd.*.catalog
|
|
%{_presetdir}
|
|
%{_userpresetdir}
|
|
%{_systemdgeneratordir}
|
|
%{_systemdusergeneratordir}
|
|
%{_systemd_system_env_generator_dir}
|
|
%{_systemd_user_env_generator_dir}
|
|
%dir %{_ntpunitsdir}
|
|
%{_ntpunitsdir}/80-systemd-timesync.list
|
|
%dir %{_prefix}/lib/systemd/system-shutdown/
|
|
%dir %{_prefix}/lib/systemd/system-sleep/
|
|
|
|
%{_pam_moduledir}/pam_systemd.so
|
|
|
|
%if %{with gnuefi}
|
|
%dir %{_prefix}/lib/systemd/boot
|
|
%dir %{_prefix}/lib/systemd/boot/efi
|
|
%{_prefix}/lib/systemd/boot/efi/*.efi
|
|
%{_prefix}/lib/systemd/boot/efi/*.stub
|
|
%endif
|
|
|
|
%dir %{_sysconfdir}/modules-load.d
|
|
%{_modulesloaddir}
|
|
|
|
%dir %{_sysusersdir}
|
|
%doc %{_sysusersdir}/README
|
|
%{_sysusersdir}/systemd.conf
|
|
|
|
%dir %{_sysconfdir}/tmpfiles.d
|
|
%{_tmpfilesdir}/
|
|
%exclude %{_tmpfilesdir}/systemd-nspawn.conf
|
|
|
|
%{_environmentdir}/
|
|
|
|
%dir %{_binfmtdir}
|
|
%dir %{_sysconfdir}/binfmt.d
|
|
|
|
%dir %{_sysctldir}
|
|
%dir %{_sysconfdir}/sysctl.d
|
|
%doc %{_sysctldir}/README
|
|
%{_sysctldir}/99-sysctl.conf
|
|
|
|
%dir %{_sysconfdir}/X11/xorg.conf.d
|
|
%dir %{_sysconfdir}/systemd
|
|
%dir %{_sysconfdir}/systemd/network
|
|
%dir %{_sysconfdir}/systemd/system
|
|
%dir %{_sysconfdir}/systemd/user
|
|
%dir %{_sysconfdir}/xdg/systemd
|
|
%{_sysconfdir}/xdg/systemd/user
|
|
|
|
%dir %{_distconfdir}/X11/xinit
|
|
%dir %{_distconfdir}/X11/xinit/xinitrc.d
|
|
%{_distconfdir}/X11/xinit/xinitrc.d/50-systemd-user.sh
|
|
|
|
%{_pam_vendordir}/systemd-user
|
|
|
|
%config(noreplace) %{_sysconfdir}/systemd/journald.conf
|
|
%config(noreplace) %{_sysconfdir}/systemd/logind.conf
|
|
%config(noreplace) %{_sysconfdir}/systemd/sleep.conf
|
|
%config(noreplace) %{_sysconfdir}/systemd/system.conf
|
|
%config(noreplace) %{_sysconfdir}/systemd/timesyncd.conf
|
|
%config(noreplace) %{_sysconfdir}/systemd/user.conf
|
|
|
|
%dir %{_datadir}/dbus-1
|
|
%dir %{_datadir}/dbus-1/services
|
|
%dir %{_datadir}/dbus-1/system.d
|
|
%dir %{_datadir}/dbus-1/system-services
|
|
|
|
%{_datadir}/dbus-1/services/org.freedesktop.systemd1.service
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.locale1.conf
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.login1.conf
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.systemd1.conf
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.hostname1.conf
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.timedate1.conf
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.timesync1.conf
|
|
|
|
# FIXME: why do we have to own this dir ?
|
|
%dir %{_modprobedir}
|
|
%doc %{_modprobedir}/README
|
|
%{_modprobedir}/systemd.conf
|
|
|
|
# Some files created at runtime.
|
|
%ghost %config(noreplace) %{_sysconfdir}/X11/xorg.conf.d/00-keyboard.conf
|
|
%ghost %config(noreplace) %{_sysconfdir}/vconsole.conf
|
|
%ghost %config(noreplace) %{_sysconfdir}/locale.conf
|
|
%ghost %config(noreplace) %{_sysconfdir}/machine-info
|
|
%ghost %attr(0444,root,root) %config(noreplace) %{_sysconfdir}/machine-id
|
|
|
|
%{_datadir}/systemd
|
|
%{_datadir}/factory
|
|
|
|
%if %{with journal_remote}
|
|
%exclude %{_datadir}/systemd/gatewayd
|
|
%endif
|
|
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.systemd1.service
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.locale1.service
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.login1.service
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.hostname1.service
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.timedate1.service
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.timesync1.service
|
|
|
|
%dir %{_datadir}/polkit-1
|
|
%dir %{_datadir}/polkit-1/actions
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.systemd1.policy
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.hostname1.policy
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.locale1.policy
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.timedate1.policy
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.login1.policy
|
|
|
|
%if ! 0%{?bootstrap}
|
|
%{_mandir}/man1/[a-rt-z]*ctl.1*
|
|
%{_mandir}/man1/systemc*.1*
|
|
%{_mandir}/man1/systemd*.1*
|
|
%{_mandir}/man5/[a-tv-z]*
|
|
%{_mandir}/man5/user*
|
|
%{_mandir}/man7/[bdfks]*
|
|
%{_mandir}/man8/kern*
|
|
%{_mandir}/man8/pam_*
|
|
%{_mandir}/man8//rc-local.*
|
|
%{_mandir}/man8/systemd-[a-gik-tvx]*
|
|
%{_mandir}/man8/systemd-h[aioy]*
|
|
%{_mandir}/man8/systemd-journald*
|
|
%{_mandir}/man8/systemd-u[ps]*
|
|
%{_mandir}/man8/30-systemd-environment-d-generator.*
|
|
%if %{with coredump}
|
|
%exclude %{_mandir}/man1/coredumpctl*
|
|
%exclude %{_mandir}/man5/coredump.conf*
|
|
%exclude %{_mandir}/man8/systemd-coredump*
|
|
%endif
|
|
%exclude %{_mandir}/man*/*nspawn*
|
|
%if %{with machined}
|
|
%exclude %{_mandir}/man*/machinectl*
|
|
%exclude %{_mandir}/man*/systemd-machined*
|
|
%endif
|
|
%if %{with importd}
|
|
%exclude %{_mandir}/man*/systemd-importd*
|
|
%endif
|
|
%if %{with journal_remote}
|
|
%exclude %{_mandir}/man5/journal-remote.conf*
|
|
%exclude %{_mandir}/man5/journal-upload.conf*
|
|
%endif
|
|
%if %{with portabled}
|
|
%exclude %{_mandir}/man*/portablectl*
|
|
%exclude %{_mandir}/man*/systemd-portabled*
|
|
%endif
|
|
%if %{with experimental}
|
|
%exclude %{_mandir}/man*/*pstore*
|
|
%exclude %{_mandir}/man*/*repart*
|
|
%exclude %{_mandir}/man*/userdbctl*
|
|
%exclude %{_mandir}/man*/systemd-userdbd*
|
|
%exclude %{_mandir}/man*/*homectl*
|
|
%exclude %{_mandir}/man*/*homed*
|
|
%exclude %{_mandir}/man*/org.freedesktop.home1*
|
|
%exclude %{_mandir}/man*/pam_systemd_home*
|
|
%exclude %{_datadir}/bash-completion/completions/homectl
|
|
%endif
|
|
%endif
|
|
|
|
%{_docdir}/systemd
|
|
%exclude %{_docdir}/systemd/html
|
|
|
|
%{_udevrulesdir}/70-uaccess.rules
|
|
%{_udevrulesdir}/71-seat.rules
|
|
%{_udevrulesdir}/73-seat-late.rules
|
|
%{_udevrulesdir}/99-systemd.rules
|
|
%dir %{_localstatedir}/lib/systemd
|
|
%dir %{_localstatedir}/lib/systemd/catalog
|
|
%if %{with sysvcompat}
|
|
%dir %{_localstatedir}/lib/systemd/sysv-convert
|
|
%dir %{_localstatedir}/lib/systemd/migrated
|
|
%endif
|
|
%ghost %{_localstatedir}/lib/systemd/catalog/database
|
|
%ghost %{_localstatedir}/lib/systemd/backlight
|
|
%ghost %{_localstatedir}/lib/systemd/i18n-migrated
|
|
%ghost %attr(0600,root,root) %{_localstatedir}/lib/systemd/random-seed
|
|
|
|
%dir %{_datadir}/bash-completion
|
|
%dir %{_datadir}/bash-completion/completions
|
|
%{_datadir}/bash-completion/completions/*
|
|
|
|
%dir %{_datadir}/zsh
|
|
%dir %{_datadir}/zsh/site-functions
|
|
%{_datadir}/zsh/site-functions/*
|
|
%{_datadir}/pkgconfig/systemd.pc
|
|
|
|
%if ! 0%{?bootstrap}
|
|
%files doc
|
|
%defattr(-,root,root,-)
|
|
%dir %{_docdir}/systemd
|
|
%{_docdir}/systemd/html
|
|
# /bootstrap
|
|
%endif
|
|
|
|
%files devel
|
|
%defattr(-,root,root,-)
|
|
%{_libdir}/libsystemd.so
|
|
%{_libdir}/pkgconfig/libsystemd.pc
|
|
%{_includedir}/systemd/
|
|
%if ! 0%{?bootstrap}
|
|
%{_mandir}/man3/SD*.3*
|
|
%{_mandir}/man3/sd*.3*
|
|
%endif
|
|
|
|
%files sysvinit
|
|
%defattr(-,root,root,-)
|
|
%if !0%{?usrmerged}
|
|
/sbin/init
|
|
/sbin/reboot
|
|
/sbin/halt
|
|
/sbin/shutdown
|
|
/sbin/poweroff
|
|
%if %{with sysvcompat}
|
|
/sbin/telinit
|
|
/sbin/runlevel
|
|
%endif
|
|
%endif
|
|
%{_sbindir}/init
|
|
%{_sbindir}/reboot
|
|
%{_sbindir}/halt
|
|
%{_sbindir}/shutdown
|
|
%{_sbindir}/poweroff
|
|
%if %{with sysvcompat}
|
|
%{_sbindir}/telinit
|
|
%{_sbindir}/runlevel
|
|
%endif
|
|
%if ! 0%{?bootstrap}
|
|
%{_mandir}/man1/init.1*
|
|
%{_mandir}/man8/halt.8*
|
|
%{_mandir}/man8/reboot.8*
|
|
%{_mandir}/man8/shutdown.8*
|
|
%{_mandir}/man8/poweroff.8*
|
|
%{_mandir}/man8/telinit.8*
|
|
%{_mandir}/man8/runlevel.8*
|
|
%endif
|
|
|
|
%files -n udev%{?mini}
|
|
%defattr(-,root,root)
|
|
%{_bindir}/udevadm
|
|
%{_bindir}/systemd-hwdb
|
|
%dir %{_prefix}/lib/udev/
|
|
%{_prefix}/lib/udev/ata_id
|
|
%{_prefix}/lib/udev/cdrom_id
|
|
# dmi_memory_id is only relevant on arches with DMI
|
|
%ifarch %{arm} aarch64 %{ix86} x86_64 ia64 mips
|
|
%{_prefix}/lib/udev/dmi_memory_id
|
|
%endif
|
|
%{_prefix}/lib/udev/fido_id
|
|
%{_prefix}/lib/udev/mtd_probe
|
|
%{_prefix}/lib/udev/path_id_compat
|
|
%{_prefix}/lib/udev/scsi_id
|
|
%{_prefix}/lib/udev/v4l_id
|
|
%ghost %attr(644, root, root) %{_prefix}/lib/udev/compat-symlink-generation
|
|
%dir %{_udevrulesdir}/
|
|
%doc %{_udevrulesdir}/README
|
|
%exclude %{_udevrulesdir}/70-uaccess.rules
|
|
%exclude %{_udevrulesdir}/71-seat.rules
|
|
%exclude %{_udevrulesdir}/73-seat-late.rules
|
|
%exclude %{_udevrulesdir}/99-systemd.rules
|
|
%{_udevrulesdir}/*.rules
|
|
%{_udevhwdbdir}/
|
|
%dir %{_sysconfdir}/udev/
|
|
%dir %{_sysconfdir}/udev/rules.d/
|
|
%ghost %attr(444, root, root) %{_sysconfdir}/udev/hwdb.bin
|
|
%config(noreplace) %{_sysconfdir}/udev/udev.conf
|
|
%if ! 0%{?bootstrap}
|
|
%{_mandir}/man5/udev*
|
|
%{_mandir}/man7/hwdb*
|
|
%{_mandir}/man7/udev*
|
|
%{_mandir}/man8/systemd-hwdb*
|
|
%{_mandir}/man8/systemd-udev*
|
|
%{_mandir}/man8/udev*
|
|
%endif
|
|
%dir %{_unitdir}
|
|
%{_prefix}/lib/systemd/systemd-udevd
|
|
%{_unitdir}/kmod-static-nodes.service
|
|
%{_unitdir}/systemd-udev*.service
|
|
%{_unitdir}/systemd-udevd*.socket
|
|
%{_unitdir}/systemd-hwdb*.*
|
|
%{_unitdir}/initrd-udevadm-cleanup-db.service
|
|
%dir %{_unitdir}/sysinit.target.wants
|
|
%{_unitdir}/sysinit.target.wants/systemd-udev*.service
|
|
%dir %{_unitdir}/sockets.target.wants
|
|
%{_unitdir}/sockets.target.wants/systemd-udev*.socket
|
|
%{_unitdir}/*.target.wants/systemd-hwdb*.*
|
|
%{_prefix}/lib/systemd/network/99-default.link
|
|
%{_datadir}/pkgconfig/udev.pc
|
|
|
|
%files -n libsystemd0%{?mini}
|
|
%defattr(-,root,root)
|
|
%{_libdir}/libsystemd.so.*
|
|
|
|
%files -n libudev%{?mini}1
|
|
%defattr(-,root,root)
|
|
%{_libdir}/libudev.so.*
|
|
|
|
%files -n libudev%{?mini}-devel
|
|
%defattr(-,root,root)
|
|
%{_includedir}/libudev.h
|
|
%{_libdir}/libudev.so
|
|
%{_libdir}/pkgconfig/libudev.pc
|
|
%if ! 0%{?bootstrap}
|
|
%{_mandir}/man3/*udev*.3*
|
|
%endif
|
|
|
|
%if %{with coredump}
|
|
%files coredump
|
|
%defattr(-,root,root)
|
|
%{_bindir}/coredumpctl
|
|
%{_prefix}/lib/systemd/systemd-coredump
|
|
%{_unitdir}/systemd-coredump*
|
|
%{_unitdir}/sockets.target.wants/systemd-coredump.socket
|
|
%{_sysctldir}/50-coredump.conf
|
|
%config(noreplace) %{_sysconfdir}/systemd/coredump.conf
|
|
%dir %{_localstatedir}/lib/systemd/coredump
|
|
%if ! 0%{?bootstrap}
|
|
%{_mandir}/man1/coredumpctl*
|
|
%{_mandir}/man5/coredump.conf*
|
|
%{_mandir}/man8/systemd-coredump*
|
|
%endif
|
|
%endif
|
|
|
|
%files container
|
|
%defattr(-,root,root)
|
|
%dir %{_sysconfdir}/systemd/nspawn
|
|
%{_bindir}/systemd-nspawn
|
|
%{_unitdir}/systemd-nspawn@.service
|
|
%if %{with machined}
|
|
%{_bindir}/machinectl
|
|
%{_prefix}/lib/systemd/systemd-machined
|
|
%{_unitdir}/systemd-machined.service
|
|
%{_unitdir}/dbus-org.freedesktop.machine1.service
|
|
%{_unitdir}/var-lib-machines.mount
|
|
%{_unitdir}/machine.slice
|
|
%{_unitdir}/machines.target.wants
|
|
%{_unitdir}/*.target.wants/var-lib-machines.mount
|
|
%{_prefix}/lib/systemd/scripts/fix-machines-btrfs-subvol.sh
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.machine1.conf
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.machine1.service
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.machine1.policy
|
|
%{_tmpfilesdir}/systemd-nspawn.conf
|
|
%endif
|
|
%if %{with importd}
|
|
%{_prefix}/lib/systemd/systemd-import*
|
|
%{_prefix}/lib/systemd/systemd-pull
|
|
%{_prefix}/lib/systemd/import-pubring.gpg
|
|
%{_unitdir}/systemd-importd.service
|
|
%{_unitdir}/dbus-org.freedesktop.import1.service
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.import1.conf
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.import1.service
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.import1.policy
|
|
%endif
|
|
%if ! 0%{?bootstrap}
|
|
%{_mandir}/man*/*nspawn*
|
|
%if %{with machined}
|
|
%{_mandir}/man*/machinectl*
|
|
%{_mandir}/man*/systemd-machined*
|
|
%endif
|
|
%if %{with importd}
|
|
%{_mandir}/man*/systemd-importd*
|
|
%endif
|
|
%endif
|
|
|
|
%if ! 0%{?bootstrap}
|
|
%files lang -f systemd.lang
|
|
|
|
%files -n nss-myhostname
|
|
%defattr(-, root, root)
|
|
%{_libdir}/*nss_myhostname*
|
|
%{_mandir}/man8/libnss_myhostname.*
|
|
%{_mandir}/man8/nss-myhostname.*
|
|
|
|
%files -n nss-systemd
|
|
%defattr(-, root, root)
|
|
%{_libdir}/libnss_systemd.so*
|
|
%{_mandir}/man8/libnss_systemd.so.*
|
|
%{_mandir}/man8/nss-systemd.*
|
|
%endif
|
|
|
|
%if %{with resolved}
|
|
%files -n nss-resolve
|
|
%defattr(-, root, root)
|
|
%{_libdir}/libnss_resolve.so.2
|
|
%{_mandir}/man8/libnss_resolve.*
|
|
%{_mandir}/man8/nss-resolve.*
|
|
%endif
|
|
|
|
%if %{with machined}
|
|
%files -n nss-mymachines
|
|
%defattr(-,root,root)
|
|
%{_libdir}/libnss_mymachines.so*
|
|
%{_mandir}/man8/libnss_mymachines.*
|
|
%{_mandir}/man8/nss-mymachines.*
|
|
%endif
|
|
|
|
%if %{with journal_remote}
|
|
%files journal-remote
|
|
%defattr(-, root, root)
|
|
%config(noreplace) %{_sysconfdir}/systemd/journal-remote.conf
|
|
%config(noreplace) %{_sysconfdir}/systemd/journal-upload.conf
|
|
%{_unitdir}/systemd-journal-gatewayd.*
|
|
%{_unitdir}/systemd-journal-remote.*
|
|
%{_unitdir}/systemd-journal-upload.*
|
|
%{_prefix}/lib/systemd/systemd-journal-gatewayd
|
|
%{_prefix}/lib/systemd/systemd-journal-remote
|
|
%{_prefix}/lib/systemd/systemd-journal-upload
|
|
%{_sysusersdir}/systemd-remote.conf
|
|
%{_mandir}/man5/journal-remote.conf*
|
|
%{_mandir}/man5/journal-upload.conf*
|
|
%{_mandir}/man8/systemd-journal-gatewayd.*
|
|
%{_mandir}/man8/systemd-journal-remote.*
|
|
%{_mandir}/man8/systemd-journal-upload.*
|
|
%{_datadir}/systemd/gatewayd
|
|
%endif
|
|
|
|
%if %{with networkd} || %{with resolved}
|
|
%files network
|
|
%defattr(-,root,root)
|
|
%if %{with networkd}
|
|
%config(noreplace) %{_sysconfdir}/systemd/networkd.conf
|
|
%{_bindir}/networkctl
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.network1.conf
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.network1.service
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.network1.policy
|
|
%{_datadir}/polkit-1/rules.d/60-systemd-networkd.rules
|
|
%{_prefix}/lib/systemd/network/*.network
|
|
%{_prefix}/lib/systemd/network/*.network.example
|
|
%{_prefix}/lib/systemd/systemd-network-generator
|
|
%{_prefix}/lib/systemd/systemd-networkd
|
|
%{_prefix}/lib/systemd/systemd-networkd-wait-online
|
|
%{_unitdir}/systemd-network-generator.service
|
|
%{_unitdir}/systemd-networkd.service
|
|
%{_unitdir}/systemd-networkd.socket
|
|
%{_unitdir}/systemd-networkd-wait-online.service
|
|
# Some files created at runtime
|
|
%endif
|
|
%if %{with resolved}
|
|
%{_bindir}/resolvectl
|
|
%{_bindir}/systemd-resolve
|
|
%config(noreplace) %{_sysconfdir}/systemd/resolved.conf
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.resolve1.conf
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.resolve1.service
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.resolve1.policy
|
|
%{_prefix}/lib/systemd/resolv.conf
|
|
%{_prefix}/lib/systemd/systemd-resolved
|
|
%{_unitdir}/systemd-resolved.service
|
|
%endif
|
|
%endif
|
|
|
|
%if %{with portabled}
|
|
%files portable
|
|
%defattr(-,root,root)
|
|
%{_bindir}/portablectl
|
|
%{_prefix}/lib/systemd/systemd-portabled
|
|
%{_prefix}/lib/systemd/portable
|
|
%{_unitdir}/systemd-portabled.service
|
|
%{_unitdir}/dbus-org.freedesktop.portable1.service
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.portable1.conf
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.portable1.service
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.portable1.policy
|
|
%{_tmpfilesdir}/portables.conf
|
|
%{_mandir}/man*/portablectl*
|
|
%{_mandir}/man*/systemd-portabled*
|
|
%endif
|
|
|
|
%if %{with testsuite}
|
|
%files testsuite
|
|
%defattr(-,root,root)
|
|
%{_testsuitedir}
|
|
%doc %{_testsuitedir}/test/README.testsuite
|
|
%endif
|
|
|
|
%if %{with experimental}
|
|
%files experimental
|
|
%defattr(-,root,root)
|
|
%config(noreplace) %{_sysconfdir}/systemd/pstore.conf
|
|
%{_prefix}/lib/systemd/systemd-pstore
|
|
%{_unitdir}/systemd-pstore.service
|
|
%{_tmpfilesdir}/systemd-pstore.conf
|
|
%{_mandir}/man*/*pstore*
|
|
%{_bindir}/systemd-repart
|
|
%{_unitdir}/systemd-repart.service
|
|
%{_mandir}/man*/*repart*
|
|
%{_bindir}/userdbctl
|
|
%{_prefix}/lib/systemd/systemd-userwork
|
|
%{_prefix}/lib/systemd/systemd-userdbd
|
|
%{_unitdir}/systemd-userdbd.service
|
|
%{_unitdir}/systemd-userdbd.socket
|
|
%{_mandir}/man*/userdbctl*
|
|
%{_mandir}/man*/systemd-userdbd*
|
|
%config(noreplace) %{_sysconfdir}/systemd/homed.conf
|
|
%{_bindir}/homectl
|
|
%{_prefix}/lib/systemd/systemd-homed
|
|
%{_prefix}/lib/systemd/systemd-homework
|
|
%{_unitdir}/systemd-homed.service
|
|
%{_unitdir}/systemd-homed-activate.service
|
|
%{_pam_moduledir}/pam_systemd_home.so
|
|
%{_datadir}/dbus-1/system-services/org.freedesktop.home1.service
|
|
%{_datadir}/dbus-1/system.d/org.freedesktop.home1.conf
|
|
%{_datadir}/polkit-1/actions/org.freedesktop.home1.policy
|
|
%{_datadir}/bash-completion/completions/homectl
|
|
%{_mandir}/man*/*homectl*
|
|
%{_mandir}/man*/*homed*
|
|
%{_mandir}/man*/org.freedesktop.home1*
|
|
%{_mandir}/man*/pam_systemd_home*
|
|
%endif
|
|
|
|
%changelog
|