diff options
Diffstat (limited to 'sys-apps/openrc/openrc-0.44.10-r2.ebuild')
-rw-r--r-- | sys-apps/openrc/openrc-0.44.10-r2.ebuild | 217 |
1 files changed, 217 insertions, 0 deletions
diff --git a/sys-apps/openrc/openrc-0.44.10-r2.ebuild b/sys-apps/openrc/openrc-0.44.10-r2.ebuild new file mode 100644 index 00000000..9411236e --- /dev/null +++ b/sys-apps/openrc/openrc-0.44.10-r2.ebuild @@ -0,0 +1,217 @@ +# Copyright 1999-2022 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +inherit flag-o-matic meson pam toolchain-funcs + +DESCRIPTION="OpenRC manages the services, startup and shutdown of a host" +HOMEPAGE="https://github.com/openrc/openrc/" + +if [[ ${PV} =~ ^9{4,}$ ]]; then + EGIT_REPO_URI="https://github.com/OpenRC/${PN}.git" + inherit git-r3 +else + SRC_URI="https://github.com/OpenRC/openrc/archive/${PV}.tar.gz -> ${P}.tar.gz" +KEYWORDS="~alpha amd64 arm arm64 hppa ~ia64 ~loong ~m68k ~mips ppc ppc64 ~riscv ~s390 sparc x86" +fi + +LICENSE="BSD-2" +SLOT="0" +IUSE="+apparmor audit bash debug +dkms elogind +havege ncurses pam newnet +netifrc selinux +settingsd +splash sysv-utils unicode" + +COMMON_DEPEND=" + apparmor? ( + sys-apps/apparmor + sys-apps/apparmor-utils + sec-policy/apparmor-profiles + ) + ncurses? ( sys-libs/ncurses:0= ) + pam? ( sys-libs/pam ) + audit? ( sys-process/audit ) + dkms? ( sys-kernel/dkms ) + elogind? ( sys-auth/elogind ) + havege? ( sys-apps/haveged ) + sys-process/psmisc + !<sys-process/procps-3.3.9-r2 + selinux? ( + sys-apps/policycoreutils + >=sys-libs/libselinux-2.6 + ) + settingsd? ( app-admin/openrc-settingsd ) + amd64? ( splash? ( sys-boot/plymouth-openrc-plugin ) ) + !<sys-apps/baselayout-2.1-r1 + !<sys-fs/udev-init-scripts-27" +DEPEND="${COMMON_DEPEND} + virtual/os-headers + ncurses? ( virtual/pkgconfig )" +RDEPEND="${COMMON_DEPEND} + bash? ( app-shells/bash ) + !prefix? ( + sysv-utils? ( + !sys-apps/systemd[sysv-utils(-)] + !sys-apps/sysvinit + ) + !sysv-utils? ( >=sys-apps/sysvinit-2.86-r6[selinux?] ) + virtual/tmpfiles + ) + selinux? ( + >=sec-policy/selinux-base-policy-2.20170204-r4 + >=sec-policy/selinux-openrc-2.20170204-r4 + ) + !<app-shells/gentoo-bashcomp-20180302 + !<app-shells/gentoo-zsh-completions-20180228 +" + +PDEPEND="netifrc? ( net-misc/netifrc )" + +src_prepare() { + default + if use dkms; then + eapply "${FILESDIR}"/${PN}-dkms.patch + fi + eapply "${FILESDIR}"/${PN}-enable-rclogger.patch +} + +src_configure() { + local emesonargs=( + $(meson_feature audit) + "-Dbranding=\"Redcore Linux Hardened\"" + $(meson_use newnet) + -Dos=Linux + $(meson_use pam) + $(meson_feature selinux) + -Drootprefix="${EPREFIX}" + -Dshell=$(usex bash /bin/bash /bin/sh) + $(meson_use sysv-utils sysvinit) + -Dtermcap=$(usev ncurses) + ) + # export DEBUG=$(usev debug) + meson_src_configure +} + +# set_config <file> <option name> <yes value> <no value> test +# a value of "#" will just comment out the option +set_config() { + local file="${ED}/$1" var=$2 val com + eval "${@:5}" && val=$3 || val=$4 + [[ ${val} == "#" ]] && com="#" && val='\2' + sed -i -r -e "/^#?${var}=/{s:=([\"'])?([^ ]*)\1?:=\1${val}\1:;s:^#?:${com}:}" "${file}" +} + +set_config_yes_no() { + set_config "$1" "$2" YES NO "${@:3}" +} + +src_install() { + meson_install + + keepdir /lib/rc/tmp + + # Setup unicode defaults for silly unicode users + set_config_yes_no /etc/rc.conf unicode use unicode + + # Cater to the norm + set_config_yes_no /etc/conf.d/keymaps windowkeys '(' use x86 '||' use amd64 ')' + + # On HPPA, do not run consolefont by default (bug #222889) + if use hppa; then + rm -f "${ED}"/etc/runlevels/boot/consolefont + fi + + # Support for logfile rotation + insinto /etc/logrotate.d + newins "${FILESDIR}"/openrc.logrotate openrc + + if use pam; then + # install gentoo pam.d files + newpamd "${FILESDIR}"/start-stop-daemon.pam start-stop-daemon + newpamd "${FILESDIR}"/start-stop-daemon.pam supervise-daemon + fi + + # install documentation + dodoc ChangeLog *.md +} + +pkg_preinst() { + # avoid default thrashing in conf.d files when possible #295406 + if [[ -e "${EROOT}"/etc/conf.d/hostname ]] ; then + ( + unset hostname HOSTNAME + source "${EROOT}"/etc/conf.d/hostname + : ${hostname:=${HOSTNAME}} + [[ -n ${hostname} ]] && set_config /etc/conf.d/hostname hostname "${hostname}" + ) + fi + + # set default interactive shell to sulogin if it exists + set_config /etc/rc.conf rc_shell /sbin/sulogin "#" test -e /sbin/sulogin + return 0 +} + +pkg_postinst() { + # add dkms to boot runlevel + if [ -e "${ROOT}"/etc/init.d/dkms ] && use dkms; then + if [ "$(rc-config list boot | grep dkms)" != "" ]; then + einfo > /dev/null 2>&1 + else + "${ROOT}"/sbin/rc-update add dkms boot > /dev/null 2>&1 + fi + fi + # move dbus to boot runlevel + if [ -e "${ROOT}"/etc/init.d/dbus ] && use elogind; then + if [ "$(rc-config list boot | grep dbus)" != "" ]; then + einfo > /dev/null 2>&1 + elif [ "$(rc-config list default | grep dbus)" != "" ]; then + "${ROOT}"/sbin/rc-update del dbus default > /dev/null 2>&1 + "${ROOT}"/sbin/rc-update add dbus boot > /dev/null 2>&1 + else + "${ROOT}"/sbin/rc-update add dbus boot > /dev/null 2>&1 + fi + fi + # add elogind to boot runlevel, disable consolekit && cgmanager + if [ -e "${ROOT}"/etc/init.d/elogind ] && use elogind; then + if [ "$(rc-config list boot | grep elogind)" != "" ]; then + einfo > /dev/null 2>&1 + else + "${ROOT}"/sbin/rc-update add elogind boot > /dev/null 2>&1 + fi + + if [ "$(rc-config list default | grep consolekit)" != "" ]; then + "${ROOT}"/sbin/rc-update del consolekit default > /dev/null 2>&1 + fi + + if [ "$(rc-config list default | grep cgmanager)" != "" ]; then + "${ROOT}"/sbin/rc-update del cgmanager default > /dev/null 2>&1 + fi + fi + # add apparmor to boot runlevel + if [ -e "${ROOT}"/etc/init.d/apparmor ] && use apparmor; then + if [ "$(rc-config list boot | grep apparmor)" != "" ]; then + einfo > /dev/null 2>&1 + else + "${ROOT}"/sbin/rc-update add apparmor boot > /dev/null 2>&1 + fi + fi + # add haveged to default runlevel + if [ -e "${ROOT}"/etc/init.d/haveged ] && use havege; then + if [ "$(rc-config list default | grep haveged)" != "" ]; then + einfo > /dev/null 2>&1 + else + "${ROOT}"/sbin/rc-update add haveged default > /dev/null 2>&1 + fi + fi + # add openrc-settingsd to default level, disable ntpd + # this allows time & date to be set to network time zone in various desktop environments + if [ -e "${ROOT}"/etc/init.d/openrc-settingsd ] && use settingsd; then + if [ "$(rc-config list default | grep openrc-settingsd)" != "" ]; then + einfo > /dev/null 2>&1 + else + "${ROOT}"/sbin/rc-update add openrc-settingsd default > /dev/null 2>&1 + fi + + if [ "$(rc-config list default | grep ntpd)" != "" ]; then + "${ROOT}"/sbin/rc-update del ntpd default > /dev/null 2>&1 + fi + fi +} |