forked from QubesOS/qubes-mgmt-salt
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathqubes.SaltLinuxVM
executable file
·54 lines (48 loc) · 1.58 KB
/
qubes.SaltLinuxVM
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
#!/usr/bin/env bash
#
# The Qubes OS Project, https://www.qubes-os.org/
#
# Copyright (C) 2016 Marek Marczykowski-Górecki
#
# q program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
set -e
if [ "`id -u`" -ne 0 ]; then
exec sudo "$0" "$@"
fi
read target_vm
read salt_command
rm -rf /srv
user=$(qubesdb-read /default-user)
eval "dir=~$user/QubesIncoming/dom0/srv"
if [[ "${dir:0:1}" = '/' ]]; then
mv "$dir" /srv
else
echo "User $user does not exist" >&2
exit 1
fi
mkdir -p /etc/salt
if [ -f /srv/master ]; then
mv /srv/master /etc/salt/
fi
# do not fail if 'salt' user doesn't exit, we run as root
echo 'verify_env: False' >> /etc/salt/master
(cd /srv/salt; find _tops -type f -o -type l| sed -e 's/^/- /' > tops.yaml)
cat > /etc/salt/roster <<EOF
$target_vm:
host: $target_vm
EOF
export PATH="/usr/lib/qubes-vm-connector/ssh-wrapper:$PATH"
salt-ssh -w "$target_vm" $salt_command