PKGBUILD 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455
  1. # Maintainer (Arch): Christian Hesse <mail@eworm.de>
  2. # Maintainer (Arch): Dave Reisner <dreisner@archlinux.org>
  3. # Maintainer (Arch): Tom Gundersen <teg@jklm.no>
  4. # Maintainer: Luke Shumaker <lukeshu@parabola.nu>
  5. # Contributor: Omar Vega Ramos <ovruni@gnu.org.pe>
  6. # Contributor: Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
  7. pkgbase=systemd
  8. pkgname=('systemd' 'systemd-libs' 'systemd-resolvconf' 'systemd-sysvcompat')
  9. pkgname+=('systemd-common' 'systemd-udev')
  10. # We split Arch's systemd-libs into systemd-$X, for the following $X:
  11. _systemd_libs=('libsystemd' 'libudev' 'nss-systemd' 'nss-myhostname' 'nss-mymachines' 'nss-resolve')
  12. pkgname+=("${_systemd_libs[@]/#/systemd-}")
  13. _tag='5ca6cc7f6e95bd98bb014126040d4a5fae541511' # git rev-parse v${pkgver}
  14. pkgver=247.3
  15. pkgrel=1
  16. pkgrel+=.parabola1
  17. arch=('x86_64')
  18. arch+=('i686' 'armv7h' 'ppc64le')
  19. url='https://www.github.com/systemd/systemd'
  20. makedepends=('acl' 'cryptsetup' 'docbook-xsl' 'gperf' 'lz4' 'xz' 'pam' 'libelf'
  21. 'intltool' 'iptables' 'kmod' 'libcap' 'libidn2' 'libgcrypt'
  22. 'libmicrohttpd' 'libxcrypt' 'libxslt' 'util-linux' 'linux-api-headers'
  23. 'python-lxml' 'quota-tools' 'shadow' 'git'
  24. 'meson' 'libseccomp' 'pcre2' 'audit' 'kexec-tools' 'libxkbcommon'
  25. 'bash-completion' 'p11-kit' 'systemd')
  26. makedepends_i686=('gnu-efi-libs' 'pkgconf')
  27. makedepends_x86_64=('gnu-efi-libs')
  28. options=('strip')
  29. validpgpkeys=('63CDA1E5D3FC22B998D20DD6327F26951A015CC4' # Lennart Poettering <lennart@poettering.net>
  30. '5C251B5FC54EB2F80F407AAAC54CA336CFEB557E') # Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
  31. source=("git+https://github.com/systemd/systemd-stable#tag=${_tag}?signed"
  32. "git+https://github.com/systemd/systemd#tag=v${pkgver%.*}?signed"
  33. '0001-Use-Arch-Linux-device-access-groups.patch'
  34. 'initcpio-hook-udev'
  35. 'initcpio-install-systemd'
  36. 'initcpio-install-udev'
  37. 'parabola.conf'
  38. 'loader.conf'
  39. 'splash-parabola.bmp'
  40. 'systemd-user.pam'
  41. 'systemd-hook'
  42. '20-systemd-sysusers.hook'
  43. 'udev-hook'
  44. '30-systemd-binfmt.hook'
  45. '30-systemd-catalog.hook'
  46. '30-systemd-daemon-reload.hook'
  47. '30-systemd-hwdb.hook'
  48. '30-systemd-sysctl.hook'
  49. '30-systemd-tmpfiles.hook'
  50. '30-systemd-udev-reload.hook'
  51. '30-systemd-update.hook'
  52. '0001-FSDG-man-Refer-to-the-operating-system-as-GNU-Linux.patch'
  53. '0002-FSDG-os-release-Default-PRETTY_NAME-to-GNU-Linux-ins.patch'
  54. '0003-FSDG-os-release-Default-NAME-to-GNU-Linux-instead-of.patch'
  55. '0004-FSDG-os-release-Default-ID-to-gnu-linux-instead-of-l.patch'
  56. '0005-FSDG-systemd-resolved-Fallback-hostname-to-gnu-linux.patch'
  57. '0006-FSDG-man-Use-FSDG-operating-systems-as-examples.patch'
  58. '0007-FSDG-bootctl-Say-Systemd-Boot-Manager-instead-of-Lin.patch')
  59. sha512sums=('SKIP'
  60. 'SKIP'
  61. 'e38c7c422c82953f9c2476a5ab8009d614cbec839e4088bff5db7698ddc84e3d8ed64f32ed323f57b1913c5c9703546f794996cb415ed7cdda930b627962a3c4'
  62. 'f0d933e8c6064ed830dec54049b0a01e27be87203208f6ae982f10fb4eddc7258cb2919d594cbfb9a33e74c3510cfd682f3416ba8e804387ab87d1a217eb4b73'
  63. '8e76f8334b95ce7fee9190f4a1016b16109f3a75b68635fc227b2b4791cf8179ef09b532b66b4ed885ddf98ed76befed3106f3c3088f1819ed8cdf4c13e0805a'
  64. 'a25b28af2e8c516c3a2eec4e64b8c7f70c21f974af4a955a4a9d45fd3e3ff0d2a98b4419fe425d47152d5acae77d64e69d8d014a7209524b75a81b0edb10bf3a'
  65. '70b3f1d6aaa9cd4b6b34055a587554770c34194100b17b2ef3aaf4f16f68da0865f6b3ae443b3252d395e80efabd412b763259ffb76c902b60e23b6b522e3cc8'
  66. '6c6f579644ea2ebb6b46ee274ab15110718b0de40def8c30173ba8480b045d403f2aedd15b50ad9b96453f4ad56920d1350ff76563755bb9a80b10fa7f64f1d9'
  67. 'a50bc85061a9a16d776235099867bc1a17c17dddb74c1ecf5614c849735a9779c5e34e5ddca8ca6af4b59a40f57c08ecf219b98cab09476ddb0f110e6a35e45c'
  68. 'b90c99d768dc2a4f020ba854edf45ccf1b86a09d2f66e475de21fe589ff7e32c33ef4aa0876d7f1864491488fd7edb2682fc0d68e83a6d4890a0778dc2d6fe19'
  69. 'd8ed2e26a6562ed7835a861a7a534842befec22475db0442cd26350ac54446bc9fec6b4c8429ed6d983cc600564446ab2827ea10cacef7e950220d01f0961214'
  70. '299dcc7094ce53474521356647bdd2fb069731c08d14a872a425412fcd72da840727a23664b12d95465bf313e8e8297da31259508d1c62cc2dcea596160e21c5'
  71. 'b7ee4f212c910df62c3472103a64a3cdf0d31292bc2f8fa839e5c86f34faa3ef1a3693601f5716779c4552a0d2b1d57538d45610f4c2e1c80e155ffbf0af187d'
  72. '0d6bc3d928cfafe4e4e0bc04dbb95c5d2b078573e4f9e0576e7f53a8fab08a7077202f575d74a3960248c4904b5f7f0661bf17dbe163c524ab51dd30e3cb80f7'
  73. '2b50b25e8680878f7974fa9d519df7e141ca11c4bfe84a92a5d01bb193f034b1726ea05b3c0030bad1fbda8dbb78bf1dc7b73859053581b55ba813c39b27d9dc'
  74. '63e55b3acd14bc54320b6f2310b43398651ad4e262d4f4a0135e05d34a993e56ed673cc46e57f15b418371df5c4cef6f54486db96325e4abb1d33fb1a3946254'
  75. 'cee9240dac5888d1dde916429ac25c022e30b5d7c53ba9e699e281021d2224bfd6e4cc4ac1c71c15f768b720d524cac0dabaae06d026a68759f6fe84b4c62751'
  76. '9426829605bbb9e65002437e02ed54e35c20fdf94706770a3dc1049da634147906d6b98bf7f5e7516c84068396a12c6feaf72f92b51bdf19715e0f64620319de'
  77. 'da7a97d5d3701c70dd5388b0440da39006ee4991ce174777931fea2aa8c90846a622b2b911f02ae4d5fffb92680d9a7e211c308f0f99c04896278e2ee0d9a4dc'
  78. '5aa475f37d35752a95e73417c38c4d3bc4d15d5f1052e95d75b4c4144b74c79af94da1d1e954be536339f9829a1ceb3a1bc5c6adceb187df7a8e5f5a83e4a850'
  79. '825b9dd0167c072ba62cabe0677e7cd20f2b4b850328022540f122689d8b25315005fa98ce867cf6e7460b2b26df16b88bb3b5c9ebf721746dce4e2271af7b97'
  80. 'e963859d9958e527802f118a5ac5f2051343a2ee987f60cae256fc4e8c71f5fe16439375a5d1caf0338f1156775ad087eaab9e8bf9d18633e62ea4d32e713e7f'
  81. '3536a497e4d6cfae76296be7bf903c7645d6a85f96f57256196282f91d3845876d74ca121efeb81df8d524ec3c53f614157a90d213a5d3c4bb14958be701fff9'
  82. 'fd0df3d365892d4d461a78bb0b728201e81c1269af07a38e134fadfc0ffb29aade7642142d128abcf88803b86494d7629ff5990359ef067feea3d476c7238a67'
  83. 'e9e884015a40dc796fd8cbd8f79b3b9eebc7e48a332b22d52104c21c492be9982b35b7dd30bc29f2c2d274707ffd043eda059659844a4cd50eb433b8a3f7648c'
  84. '0d6b894149ec8d0612d1be1dee5daa1768345232e450435ddc750e36a8309dd96782a92f0220169c69103b1c4632af708e4a737cb7ba817944c92dcb61379a30'
  85. '34acbb7c47b5ccd14adb6982b734cd718d478e3caf3b7f4e15795c3ba39f3c3f03b0a3f8f5a0c29b4342cd923f892daf55dd22598392900946ea8d185c706c78'
  86. '28a5b3fc9e2c5cec9267bb96725c73ee77788514f140c0cf8df765af64bc8130dd02f4863d9128ac45d54256b2ab4f2b06d1a3f65660ce1dfba5727618cd1839')
  87. _backports=(
  88. )
  89. _reverts=(
  90. )
  91. prepare() {
  92. cd "$pkgbase-stable"
  93. # add upstream repository for cherry-picking
  94. git remote add -f upstream ../systemd
  95. local _c
  96. for _c in "${_backports[@]}"; do
  97. git log --oneline -1 "${_c}"
  98. git cherry-pick -n "${_c}"
  99. done
  100. for _c in "${_reverts[@]}"; do
  101. git log --oneline -1 "${_c}"
  102. git revert -n "${_c}"
  103. done
  104. # Replace cdrom/dialout/tape groups with optical/uucp/storage
  105. patch -Np1 -i ../0001-Use-Arch-Linux-device-access-groups.patch
  106. # apply FSDG patches
  107. local _patch
  108. for _patch in "$srcdir"/????-FSDG-*.patch; do
  109. patch -Np1 -i "$_patch"
  110. done
  111. }
  112. build() {
  113. local _timeservers=({0..3}.arch.pool.ntp.org)
  114. local _nameservers=(
  115. # We use these public name services, ordered by their
  116. # privacy policy (hopefully):
  117. # * Cloudflare (https://1.1.1.1/)
  118. # * Quad9 without filtering (https://www.quad9.net/)
  119. # * Google (https://developers.google.com/speed/public-dns/)
  120. 1.1.1.1
  121. 9.9.9.10
  122. 8.8.8.8
  123. 2606:4700:4700::1111
  124. 2620:fe::10
  125. 2001:4860:4860::8888
  126. )
  127. if [ "$CARCH" = "armv7h" ]; then
  128. LDFLAGS+=" -Wl,-fuse-ld=bfd"
  129. CFLAGS+=" -fno-lto"
  130. CXXFLAGS+=" -fno-lto"
  131. fi
  132. local _meson_options=(
  133. -Dversion-tag="${pkgver}-${pkgrel}-parabola"
  134. -Dmode=release
  135. -Dima=false
  136. -Dlibidn2=true
  137. -Dlz4=true
  138. -Dman=true
  139. # We disable DNSSEC by default, it still causes trouble:
  140. # https://github.com/systemd/systemd/issues/10579
  141. -Ddbuspolicydir=/usr/share/dbus-1/system.d
  142. -Ddefault-dnssec=no
  143. -Ddefault-hierarchy=hybrid
  144. -Ddefault-kill-user-processes=false
  145. -Ddefault-locale=C
  146. -Ddns-over-tls=openssl
  147. -Dfallback-hostname='parabola'
  148. -Dnologin-path=/usr/bin/nologin
  149. -Dntp-servers="${_timeservers[*]}"
  150. -Ddns-servers="${_nameservers[*]}"
  151. -Drpmmacrosdir=no
  152. -Dsysvinit-path=
  153. -Dsysvrcnd-path=
  154. )
  155. if [ "$CARCH" != "armv7h" ]; then
  156. _meson_options+=(-Dgnu-efi=true)
  157. fi
  158. arch-meson "$pkgbase-stable" build "${_meson_options[@]}"
  159. ninja -C build
  160. # Go ahead and split the package now. It's easier this way, because
  161. # we can use mv instead of awkward, error-prone rm/cp pairs.
  162. rm -rf "$srcdir/dest"
  163. # Put things in the main systemd package by default
  164. DESTDIR="$srcdir/dest/systemd" meson install -C build
  165. install -dm755 "$srcdir/dest/common"/usr/lib/systemd
  166. mv -T "$srcdir/dest"/{systemd,common}/usr/lib/systemd/libsystemd-shared-${pkgver%%.*}.so
  167. install -dm755 "$srcdir/dest/libsystemd"/usr/{lib/pkgconfig,share/man/man3,include}
  168. mv -T "$srcdir/dest"/{systemd,libsystemd}/usr/include/systemd
  169. mv -T "$srcdir/dest"/{systemd,libsystemd}/usr/lib/pkgconfig/libsystemd.pc
  170. mv "$srcdir/dest"/systemd/usr/lib/libsystemd.so* -t "$srcdir/dest"/libsystemd/usr/lib/
  171. mv "$srcdir/dest"/systemd/usr/share/man/man3/{SD,sd}* -t "$srcdir/dest"/libsystemd/usr/share/man/man3/
  172. install -dm755 "$srcdir/dest/libudev"/usr/{lib/pkgconfig,share/man/man3,include}
  173. mv -T "$srcdir/dest"/{systemd,libudev}/usr/include/libudev.h
  174. mv -T "$srcdir/dest"/{systemd,libudev}/usr/lib/pkgconfig/libudev.pc
  175. mv "$srcdir/dest"/systemd/usr/lib/libudev.so* -t "$srcdir/dest"/libudev/usr/lib/
  176. mv "$srcdir/dest"/systemd/usr/share/man/man3/*udev* -t "$srcdir/dest"/libudev/usr/share/man/man3/
  177. install -dm755 "$srcdir/dest/udev"/{etc,usr/lib}
  178. mv -T "$srcdir/dest"/{systemd,udev}/etc/udev/
  179. mv -T "$srcdir/dest"/{systemd,udev}/usr/lib/udev/
  180. while read -d '' -r file; do
  181. install -dm755 "$srcdir/dest/udev/${file%/*}"
  182. mv -T "$srcdir/dest/systemd/$file" "$srcdir/dest/udev/$file"
  183. done < <(find "$srcdir/dest/systemd" \( -name '*udev*' -o -name '*hwdb*' \) -printf '%P\0')
  184. local nssmodule
  185. for nssmodule in systemd myhostname mymachines resolve; do
  186. install -dm755 "$srcdir/dest/nss-$nssmodule"/usr/{lib,share/man/man8}
  187. mv -t "$srcdir/dest"/nss-$nssmodule/usr/share/man/man8/ -- \
  188. "$srcdir/dest"/systemd/usr/share/man/man8/nss-$nssmodule.8 \
  189. "$srcdir/dest"/systemd/usr/share/man/man8/libnss_$nssmodule.*.8
  190. mv "$srcdir/dest"/systemd/usr/lib/libnss_$nssmodule.so* -t "$srcdir/dest"/nss-$nssmodule/usr/lib/
  191. done
  192. install -dm755 "$srcdir/dest/systemd-sysvcompat"/usr/share/man/man8
  193. mv "$srcdir/dest/systemd"/usr/share/man/man8/{halt,poweroff,reboot,shutdown}.8 \
  194. -t "$srcdir/dest/systemd-sysvcompat"/usr/share/man/man8
  195. rmdir "$srcdir/dest"/systemd/usr/{share/man/man3,lib/pkgconfig,include}
  196. }
  197. check() {
  198. meson test -C build
  199. }
  200. package_systemd() {
  201. pkgdesc='system and service manager'
  202. license=('LGPL2.1')
  203. depends=('bash' 'dbus' 'kbd' 'kmod' 'libkmod.so'
  204. 'systemd-libs' 'pam' 'libelf'
  205. 'util-linux' 'pcre2')
  206. depends+=("systemd-common=$pkgver-$pkgrel" 'udev')
  207. provides=("systemd-tools=$pkgver")
  208. replaces=('systemd-tools')
  209. conflicts=('systemd-tools')
  210. optdepends=('libmicrohttpd: remote journald capabilities'
  211. 'quota-tools: kernel-level quota management'
  212. 'systemd-sysvcompat: symlink package to provide sysvinit binaries'
  213. 'polkit: allow administration as unprivileged user'
  214. 'curl: machinectl pull-tar and pull-raw')
  215. backup=(etc/pam.d/systemd-user
  216. etc/systemd/coredump.conf
  217. etc/systemd/homed.conf
  218. etc/systemd/journald.conf
  219. etc/systemd/journal-remote.conf
  220. etc/systemd/journal-upload.conf
  221. etc/systemd/logind.conf
  222. etc/systemd/networkd.conf
  223. etc/systemd/pstore.conf
  224. etc/systemd/resolved.conf
  225. etc/systemd/sleep.conf
  226. etc/systemd/system.conf
  227. etc/systemd/timesyncd.conf
  228. etc/systemd/user.conf)
  229. install=systemd.install
  230. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/$pkgname" "$pkgdir"
  231. # we'll create this on installation
  232. rmdir "$pkgdir"/var/log/journal/remote
  233. # executable (symlinks) shipped with systemd-sysvcompat
  234. rm "$pkgdir"/usr/bin/{halt,init,poweroff,reboot,shutdown}
  235. # files shipped with systemd-resolvconf
  236. rm "$pkgdir"/usr/{bin/resolvconf,share/man/man1/resolvconf.1}
  237. # avoid a potential conflict with [core]/filesystem
  238. rm "$pkgdir"/usr/share/factory/etc/{issue,nsswitch.conf}
  239. sed -i -e '/^C \/etc\/nsswitch\.conf/d' \
  240. -e '/^C \/etc\/issue/d' "$pkgdir"/usr/lib/tmpfiles.d/etc.conf
  241. # add back tmpfiles.d/legacy.conf, normally omitted without sysv-compat
  242. install -m0644 $pkgbase-stable/tmpfiles.d/legacy.conf "$pkgdir"/usr/lib/tmpfiles.d
  243. # ship default policy to leave services disabled
  244. echo 'disable *' >"$pkgdir"/usr/lib/systemd/system-preset/99-default.preset
  245. # add mkinitcpio hooks
  246. install -D -m0644 initcpio-install-systemd "$pkgdir"/usr/lib/initcpio/install/systemd
  247. # The group 'systemd-journal' is allocated dynamically and may have varying
  248. # gid on different systems. Let's install with gid 0 (root), systemd-tmpfiles
  249. # will fix the permissions for us. (see /usr/lib/tmpfiles.d/systemd.conf)
  250. install -d -o root -g root -m 2755 "$pkgdir"/var/log/journal
  251. # match directory owner/group and mode from [extra]/polkit
  252. install -d -o root -g 102 -m 0750 "$pkgdir"/usr/share/polkit-1/rules.d
  253. # add example bootctl configuration
  254. install -D -m0644 parabola.conf "$pkgdir"/usr/share/systemd/bootctl/parabola.conf
  255. install -D -m0644 loader.conf "$pkgdir"/usr/share/systemd/bootctl/loader.conf
  256. install -D -m0644 splash-parabola.bmp "$pkgdir"/usr/share/systemd/bootctl/splash-parabola.bmp
  257. # pacman hooks
  258. install -D -m0755 systemd-hook "$pkgdir"/usr/share/libalpm/scripts/systemd-hook
  259. install -D -m0644 -t "$pkgdir"/usr/share/libalpm/hooks *.hook
  260. rm -- "$pkgdir"/usr/share/libalpm/hooks/*{udev,hwdb}*
  261. # overwrite the systemd-user PAM configuration with our own
  262. install -D -m0644 systemd-user.pam "$pkgdir"/etc/pam.d/systemd-user
  263. }
  264. package_systemd-common() {
  265. pkgdesc='systemd files shared between split packages'
  266. license=('LGPL2.1')
  267. depends=('acl' 'libacl.so' 'cryptsetup' 'libcryptsetup.so' 'libdbus'
  268. 'glibc' 'iptables' 'libcap' 'libcap.so'
  269. 'libgcrypt' 'libxcrypt' 'libcrypt.so' 'libidn2' 'libseccomp' 'libseccomp.so' 'libsystemd.so'
  270. 'libudev.so' 'libblkid.so' 'libmount.so' 'libuuid.so' 'lz4'
  271. 'xz' 'audit' 'libaudit.so' 'libp11-kit' 'libp11-kit.so' 'openssl')
  272. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/${pkgname#systemd-}" "$pkgdir"
  273. }
  274. package_systemd-udev() {
  275. pkgdesc='Userspace device file manager'
  276. license=('GPL2') # NB: different than the rest
  277. depends=("systemd-common=$pkgver-$pkgrel" 'systemd-libudev'
  278. 'hwids' 'kmod' 'libkmod.so' 'util-linux' 'zlib')
  279. backup=(etc/udev/udev.conf)
  280. provides+=("${pkgname#systemd-}=$pkgver")
  281. conflicts+=("${pkgname#systemd-}")
  282. replaces+=("${pkgname#systemd-}")
  283. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/${pkgname#systemd-}" "$pkgdir"
  284. # add mkinitcpio hooks
  285. install -D -m0644 initcpio-install-udev "$pkgdir"/usr/lib/initcpio/install/udev
  286. install -D -m0644 initcpio-hook-udev "$pkgdir"/usr/lib/initcpio/hooks/udev
  287. # pacman hooks
  288. install -D -m0755 udev-hook "$pkgdir"/usr/share/libalpm/scripts/udev-hook
  289. install -D -m0644 -t "$pkgdir"/usr/share/libalpm/hooks *{udev,hwdb}*.hook
  290. }
  291. package_systemd-libs() {
  292. pkgdesc='systemd client libraries metapackage'
  293. depends=("${_systemd_libs[@]}")
  294. license=('LGPL2.1')
  295. provides=('libsystemd')
  296. conflicts=('libsystemd')
  297. replaces=('libsystemd')
  298. }
  299. package_systemd-libsystemd() {
  300. pkgdesc='systemd client library'
  301. depends=('glibc' 'libcap' 'libcap.so' 'libgcrypt' 'lz4' 'xz' 'zstd')
  302. license=('LGPL2.1')
  303. provides=('libsystemd.so')
  304. provides+=("libsystemd-standalone=$pkgver")
  305. conflicts+=('libsystemd-standalone')
  306. replaces+=('libsystemd-standalone')
  307. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/${pkgname#systemd-}" "$pkgdir"
  308. }
  309. package_systemd-libudev() {
  310. pkgdesc='systemd library for enumerating and introspecting local devices'
  311. depends=('glibc' 'libcap' 'libcap.so')
  312. license=('LGPL2.1')
  313. provides=('libudev.so')
  314. provides+=("${pkgname#systemd-}=$pkgver")
  315. conflicts+=("${pkgname#systemd-}")
  316. replaces+=("${pkgname#systemd-}")
  317. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/${pkgname#systemd-}" "$pkgdir"
  318. }
  319. package_systemd-nss-systemd() {
  320. pkgdesc='NSS module providing user and group resolution for dynamic users and groups'
  321. depends=('glibc' 'libcap' 'libcap.so')
  322. license=('LGPL2.1')
  323. provides+=("${pkgname#systemd-}=$pkgver")
  324. conflicts+=("${pkgname#systemd-}")
  325. replaces+=("${pkgname#systemd-}")
  326. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/${pkgname#systemd-}" "$pkgdir"
  327. }
  328. package_systemd-nss-myhostname() {
  329. pkgdesc='NSS module providing hostname resolution for the locally configured system hostname'
  330. depends=('glibc' 'libcap' 'libcap.so')
  331. license=('LGPL2.1')
  332. provides+=("${pkgname#systemd-}=$pkgver")
  333. conflicts+=("${pkgname#systemd-}")
  334. replaces+=("${pkgname#systemd-}")
  335. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/${pkgname#systemd-}" "$pkgdir"
  336. }
  337. package_systemd-nss-mymachines() {
  338. pkgdesc='NSS module providing hostname resolution for local systemd-machined container instances'
  339. depends=('glibc' 'libcap' 'libcap.so')
  340. license=('LGPL2.1')
  341. provides+=("${pkgname#systemd-}=$pkgver")
  342. conflicts+=("${pkgname#systemd-}")
  343. replaces+=("${pkgname#systemd-}")
  344. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/${pkgname#systemd-}" "$pkgdir"
  345. }
  346. package_systemd-nss-resolve() {
  347. pkgdesc='NSS module providing hostname resolution via systemd-resolved'
  348. depends=('glibc' 'libcap' 'libcap.so')
  349. license=('LGPL2.1')
  350. provides+=("${pkgname#systemd-}=$pkgver")
  351. conflicts+=("${pkgname#systemd-}")
  352. replaces+=("${pkgname#systemd-}")
  353. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/${pkgname#systemd-}" "$pkgdir"
  354. }
  355. package_systemd-resolvconf() {
  356. pkgdesc='systemd resolvconf replacement (for use with systemd-resolved)'
  357. license=('LGPL2.1')
  358. depends=('systemd')
  359. provides=('openresolv' 'resolvconf')
  360. conflicts=('openresolv')
  361. replaces+=('notsystemd-resolvconf') # notsystemd-resolvconf should have never existed
  362. install -d -m0755 "$pkgdir"/usr/bin
  363. ln -s resolvectl "$pkgdir"/usr/bin/resolvconf
  364. install -d -m0755 "$pkgdir"/usr/share/man/man1
  365. ln -s resolvectl.1.gz "$pkgdir"/usr/share/man/man1/resolvconf.1.gz
  366. }
  367. package_systemd-sysvcompat() {
  368. pkgdesc='sysvinit compat for systemd'
  369. license=('LGPL2.1')
  370. provides=('init')
  371. conflicts=('init' 'sysvinit')
  372. depends=('systemd')
  373. cp -rT -d --no-preserve=ownership,timestamp "$srcdir/dest/$pkgname" "$pkgdir"
  374. install -d -m0755 "$pkgdir"/usr/bin
  375. ln -s ../lib/systemd/systemd "$pkgdir"/usr/bin/init
  376. for tool in halt poweroff reboot shutdown; do
  377. ln -s systemctl "$pkgdir"/usr/bin/$tool
  378. done
  379. }
  380. # vim:ft=sh syn=sh et sw=2: