blob: 0637d2eb66ff00e969a87f43b44e06cff11767bb (
plain) (
blame)
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
#!/bin/sh
#
# $FreeBSD$
#
# PROVIDE: hald
# REQUIRE: DAEMON devd dbus moused webcamd
#
# Add the following line to /etc/rc.conf to enable the HAL daemon:
#
# hald_enable="YES"
#
. /etc/rc.subr
. %%GNOME_SUBR%%
hald_enable=${hald_enable-${gnome_enable}}
hald_flags=${hald_flags-""}
name=hald
rcvar=hald_enable
command="%%PREFIX%%/sbin/hald"
pidfile="/var/run/${name}/${name}.pid"
stop_postcmd="hald_postcmd"
start_precmd="hald_precmd"
start_cmd="hald_start"
local_force_depend()
{
_depend="$1"
if [ -f %%LOCALBASE%%/etc/rc.d/${_depend}.sh ]; then
_depend="${_depend}.sh"
fi
if ! %%LOCALBASE%%/etc/rc.d/${_depend} forcestatus 1>/dev/null 2>&1 &&
! %%LOCALBASE%%/etc/rc.d/${_depend} forcestart; then
return 1
fi
return 0
}
init_var_policykit()
{
local USER=polkit
local GROUP=${USER}
local PREFIX=/usr/local
/usr/bin/install -d -o root -m 0770 -g ${GROUP} /var/run/PolicyKit
/usr/bin/install -d -o root -m 0770 -g ${GROUP} /var/lib/PolicyKit
/usr/bin/install -d -o ${USER} -m 0755 -g wheel /var/lib/PolicyKit-public
/bin/mkdir -p /var/lib/misc
/usr/bin/touch -f /var/lib/misc/PolicyKit.reload
/usr/sbin/chown ${USER}:${GROUP} /var/lib/misc/PolicyKit.reload
/bin/chmod 0664 /var/lib/misc/PolicyKit.reload
}
init_var_polkit()
{
mkdir -p /var/lib/polkit-1/localauthority
for i in 10-vendor.d 20-org.d 30-site.d 50-local.d 90-mandatory.d
do
mkdir -p /var/lib/polkit-1/localauthority/${i}
done
chmod 0700 /var/lib/polkit-1
}
init_var_hal()
{
local USER=haldaemon
local GROUP=${USER}
/usr/bin/install -d -o ${USER} -g ${GROUP} /var/run/hald
/usr/bin/install -d -o ${USER} -g ${GROUP} /var/cache/hald
/usr/bin/install -d -o ${USER} -g ${GROUP} /var/lib/hal
/usr/local/bin/polkit-auth --user ${USER} --grant \
org.freedesktop.policykit.read 1> /dev/null 2>&1
}
hald_precmd()
{
if ! checkyesno dbus_enable
then
local_force_depend dbus || return 1
fi
init_var_policykit
init_var_polkit
init_var_hal
chmod 0755 /var/cache
mkdir -p $(dirname $pidfile)
}
hald_postcmd()
{
rm -f $pidfile
}
hald_start()
{
if ! checkyesno hald_enable ; then
return 0
fi
echo "Starting ${name}."
( iter=0
while ! ps -axoargs | grep "^/usr/libexec/getty " | grep -qv grep >/dev/null 2>&1; do
if [ ${iter} -eq 60 ]; then
break
fi
sleep 1
iter=$(expr ${iter} + 1)
done
${command} ${hald_flags} ) &
}
load_rc_config ${name}
run_rc_command "$1"
|