blob: c6d61a4485d5ecb1b379e6dd07da07e633d9e435 (
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
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
|
post_install() {
_go_automate_configure_user_bridge
}
post_upgrade() {
_go_automate_configure_user_bridge
}
pre_remove() {
_go_automate_disable_user_bridge
}
_go_automate_configure_user_bridge() {
local unit="go-automate-home-assistant-bridge.service"
if command -v systemctl >/dev/null 2>&1; then
systemctl --global enable "$unit" >/dev/null 2>&1 || true
fi
if [ -n "${SUDO_USER:-}" ] && [ "$SUDO_USER" != "root" ]; then
_go_automate_enable_for_user "$SUDO_USER" "$unit"
fi
cat <<'EOF'
go-automate: installed user service go-automate-home-assistant-bridge.service
- Enabled globally for future logins with systemd user sessions.
- If the installing user has an active user systemd session, the service was started for that user as well.
- Home Assistant config is read from ~/.config/go-automate/config.yml for each user.
If the service is not running yet for your current session, run:
systemctl --user daemon-reload
systemctl --user enable --now go-automate-home-assistant-bridge.service
EOF
}
_go_automate_enable_for_user() {
local user="$1"
local unit="$2"
local uid
local runtime_dir
local bus_path
uid="$(id -u "$user" 2>/dev/null)" || return 0
runtime_dir="/run/user/$uid"
bus_path="$runtime_dir/bus"
if [ ! -S "$bus_path" ]; then
return 0
fi
runuser -u "$user" -- env \
XDG_RUNTIME_DIR="$runtime_dir" \
DBUS_SESSION_BUS_ADDRESS="unix:path=$bus_path" \
systemctl --user daemon-reload >/dev/null 2>&1 || return 0
runuser -u "$user" -- env \
XDG_RUNTIME_DIR="$runtime_dir" \
DBUS_SESSION_BUS_ADDRESS="unix:path=$bus_path" \
systemctl --user enable --now "$unit" >/dev/null 2>&1 || return 0
}
_go_automate_disable_user_bridge() {
local unit="go-automate-home-assistant-bridge.service"
if command -v systemctl >/dev/null 2>&1; then
systemctl --global disable "$unit" >/dev/null 2>&1 || true
fi
if [ -n "${SUDO_USER:-}" ] && [ "$SUDO_USER" != "root" ]; then
_go_automate_disable_for_user "$SUDO_USER" "$unit"
fi
}
_go_automate_disable_for_user() {
local user="$1"
local unit="$2"
local uid
local runtime_dir
local bus_path
uid="$(id -u "$user" 2>/dev/null)" || return 0
runtime_dir="/run/user/$uid"
bus_path="$runtime_dir/bus"
if [ ! -S "$bus_path" ]; then
return 0
fi
runuser -u "$user" -- env \
XDG_RUNTIME_DIR="$runtime_dir" \
DBUS_SESSION_BUS_ADDRESS="unix:path=$bus_path" \
systemctl --user disable --now "$unit" >/dev/null 2>&1 || return 0
}
|