blob: f1253602247aaa2970430824566076d2748b5828 (
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
|
#!/bin/bash
# Needs full bash
#
# Script to be called by systemd
#
# Downloads and appends addons per sqfs/aufs.
#
######################################################################################
#
# Two modes for this script:
# - without any arguments, it will just go through the list of addons to
# setup as given through the OpenSLX configuration file
# - with an argument, it will setup the addon given as $1
#
#
######################################################################################
# read global OpenSLX config
. /opt/openslx/config || { echo "Could not source config!"; exit 23; }
[ -z "${SLX_ADDONS}" ] && { echo "No addons configured. Nothing to do :-)."; exit 0; }
# source functions.inc for the download function
. /opt/openslx/etc/functions.inc || { echo "functions.inc not found!"; exit 1337; }
# quick fix for the missing FUTURE_ROOT needed by /opt/openslx/etc/functions.inc
export FUTURE_ROOT="/"
# read openslx config, especially servers given by SLX_KCL_SERVERS and SLX_CONFIG_SERVERS
if [ -z "${SLX_CONFIG_SERVERS}" ]; then
echo "SLX_CONFIG_SERVERS is not set in /opt/openslx/config. Will only try the base servers from the cmdline."
[ -z "${SLX_KCL_SERVERS}" ] && SLX_KCL_SERVERS=$(read_from_cmdline "slxsrv")
fi
# read base slx servers from cmdline
HTTP_BASE_PATH=$(read_from_cmdline "slxbase")
BASE_MOUNT_POINT="/opt/openslx/mnt"
DOWNLOAD_DEST="/tmp/addons"
mkdir -p "$DOWNLOAD_DEST" || { echo "Failed to create $DOWNLOAD_DEST"; exit 1; }
######################################################################################
#
# NO ARGUMENTS -> LOOP OVER ALL ADDONS
#
if [ $# -eq 0 ]; then
for ADDON in ${SLX_ADDONS}; do
systemctl start "setup-slx-addon@$ADDON" &
done
fi
######################################################################################
#
# WITH ARGUMENTS -> SETUP ADDON
#
if [ $# -eq 1 ]; then
ADDON="$1"
# sanity check
[[ ! "$SLX_ADDONS" == *"$ADDON"* ]] && \
{ echo "$ADDON is not listed in SLX_ADDONS of your config file. Skipping it."; exit 1; }
# download the addon from the given URL
ADDON_TARGET_PATH="${DOWNLOAD_DEST}/$(basename "$ADDON").sqfs"
if ! download "${HTTP_BASE_PATH}/${ADDON}.sqfs" "${ADDON_TARGET_PATH}"; then
slxlog --echo "addon-download" "Download of '${HTTP_BASE_PATH}/${ADDON}.sqfs' failed."
exit 1
fi
# now mount it to $BASE_MOUNT_POINT/<addon-name>
ADDON_MOUNT_POINT="${BASE_MOUNT_POINT}/$(basename "$ADDON")"
mkdir -p "$ADDON_MOUNT_POINT"
mount -t squashfs "$ADDON_TARGET_PATH" "$ADDON_MOUNT_POINT" || \
{ slxlog --echo "addon-mount" "Failed to mount $ADDON_TARGET_PATH."; exit 1; }
# now append it to /
echo "Appending ${ADDON_MOUNT_POINT} to /"
if ! mount -o "remount,append:${ADDON_MOUNT_POINT}=ro" / ; then
slxlog --echo "Failed to append ${ADDON_MOUNT_POINT} to the aufs. Cleaning up..."
umount -l ${ADDON_MOUNT_POINT} || echo "Could not unmount ${ADDON_MOUNT_POINT}!"
exit 1
fi
# Run post-hook if available
if [ -x "$ADDON_MOUNT_POINT/addon-init" ]; then
"$ADDON_MOUNT_POINT/addon-init" || \
slxlog --echo "addon-init" "Warning: Could not execute addon-init of $ADDON"
fi
fi
[ $# -gt 1 ] && { echo "Error - $0 only takes no or one argument. $# given." && exit 1; }
exit 0
|