blob: 9f01f18e572b6dee5964954ef196cd36ef3d2473 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
#!/bin/bash
sd_booted() {
[[ -d run/systemd/system && ! -L run/systemd/system ]]
}
add_journal_acls() {
# ignore errors, since the filesystem might not support ACLs
setfacl -Rnm g:wheel:rx,d:g:wheel:rx,g:adm:rx,d:g:adm:rx var/log/journal/ 2>/dev/null
:
}
post_common() {
systemd-sysusers
journalctl --update-catalog
if ! grep -qe '^/usr/bin/systemd-home-fallback-shell$' etc/shells; then
echo '/usr/bin/systemd-home-fallback-shell' >> etc/shells
fi
}
post_install() {
systemd-machine-id-setup
post_common "$@"
add_journal_acls
# enable some services by default, but don't track them
systemctl enable \
getty@tty1.service \
remote-fs.target \
systemd-userdbd.socket
# group 'systemd-journal-remote' is created by systemd-sysusers
mkdir -m2755 var/log/journal/remote
chgrp systemd-journal-remote var/log/journal/remote
}
post_upgrade() {
post_common "$@"
if sd_booted; then
systemctl --system daemon-reexec
systemctl kill --kill-whom='main' --signal='SIGRTMIN+25' 'user@*.service'
fi
local v upgrades=(
)
for v in "${upgrades[@]}"; do
if [[ $(vercmp "$v" "$2") -eq 1 ]]; then
"_${v//[.-]/_}_changes"
fi
done
}
post_remove() {
sed -i -r '/^\/usr\/bin\/systemd-home-fallback-shell$/d' etc/shells
}
# vim:set ts=2 sw=2 et:
|