VirtualBox

source: vbox/trunk/src/VBox/Installer/linux/routines.sh@ 71433

Last change on this file since 71433 was 70930, checked in by vboxsync, 7 years ago

Additions/linux: check for bzip2 and tar before starting installation.
bugref:9117: Linux GA installer failure on minimal OL7

  • Property svn:eol-style set to LF
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 11.6 KB
Line 
1# Oracle VM VirtualBox
2# VirtualBox installer shell routines
3#
4
5#
6# Copyright (C) 2007-2017 Oracle Corporation
7#
8# This file is part of VirtualBox Open Source Edition (OSE), as
9# available from http://www.virtualbox.org. This file is free software;
10# you can redistribute it and/or modify it under the terms of the GNU
11# General Public License (GPL) as published by the Free Software
12# Foundation, in version 2 as it comes in the "COPYING" file of the
13# VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14# hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15#
16
17ro_LOG_FILE=""
18ro_X11_AUTOSTART="/etc/xdg/autostart"
19ro_KDE_AUTOSTART="/usr/share/autostart"
20
21## Aborts the script and prints an error message to stderr.
22#
23# syntax: abort message
24
25abort()
26{
27 echo 1>&2 "$1"
28 exit 1
29}
30
31## Creates an empty log file and remembers the name for future logging
32# operations
33create_log()
34{
35 ## The path of the file to create.
36 ro_LOG_FILE="$1"
37 if [ "$ro_LOG_FILE" = "" ]; then
38 abort "create_log called without an argument! Aborting..."
39 fi
40 # Create an empty file
41 echo > "$ro_LOG_FILE" 2> /dev/null
42 if [ ! -f "$ro_LOG_FILE" -o "`cat "$ro_LOG_FILE"`" != "" ]; then
43 abort "Error creating log file! Aborting..."
44 fi
45}
46
47## Writes text to standard error
48#
49# Syntax: info text
50info()
51{
52 echo 1>&2 "$1"
53}
54
55## Writes text to the log file
56#
57# Syntax: log text
58log()
59{
60 if [ "$ro_LOG_FILE" = "" ]; then
61 abort "Error! Logging has not been set up yet! Aborting..."
62 fi
63 echo "$1" >> $ro_LOG_FILE
64 return 0
65}
66
67## Writes test to standard output and to the log file
68#
69# Syntax: infolog text
70infolog()
71{
72 info "$1"
73 log "$1"
74}
75
76## Checks whether a module is loaded with a given string in its name.
77#
78# syntax: module_loaded string
79module_loaded()
80{
81 if [ "$1" = "" ]; then
82 log "module_loaded called without an argument. Aborting..."
83 abort "Error in installer. Aborting..."
84 fi
85 lsmod | grep -q $1
86}
87
88## Abort if we are not running as root
89check_root()
90{
91 if [ `id -u` -ne 0 ]; then
92 abort "This program must be run with administrator privileges. Aborting"
93 fi
94}
95
96## Abort if dependencies are not found
97check_deps()
98{
99 for i in ${@}; do
100 type "${i}" >/dev/null 2>&1 ||
101 abort "${i} not found. Please install: ${*}; and try again."
102 done
103}
104
105## Abort if a copy of VirtualBox is already running
106check_running()
107{
108 VBOXSVC_PID=`pidof VBoxSVC 2> /dev/null`
109 if [ -n "$VBOXSVC_PID" ]; then
110 if [ -f /etc/init.d/vboxweb-service ]; then
111 kill -USR1 $VBOXSVC_PID
112 fi
113 sleep 1
114 if pidof VBoxSVC > /dev/null 2>&1; then
115 echo 1>&2 "A copy of VirtualBox is currently running. Please close it and try again."
116 abort "Please note that it can take up to ten seconds for VirtualBox to finish running."
117 fi
118 fi
119}
120
121## Creates a systemd wrapper in /lib for an LSB init script
122systemd_wrap_init_script()
123{
124 self="systemd_wrap_init_script"
125 ## The init script to be installed. The file may be copied or referenced.
126 script="$(readlink -f -- "${1}")"
127 ## Name for the service.
128 name="$2"
129 test -x "$script" && test ! "$name" = "" || \
130 { echo "$self: invalid arguments" >&2 && return 1; }
131 test -d /usr/lib/systemd/system && unit_path=/usr/lib/systemd/system
132 test -d /lib/systemd/system && unit_path=/lib/systemd/system
133 test -n "${unit_path}" || \
134 { echo "$self: systemd unit path not found" >&2 && return 1; }
135 conflicts=`sed -n 's/# *X-Conflicts-With: *\(.*\)/\1/p' "${script}" | sed 's/\$[a-z]*//'`
136 description=`sed -n 's/# *Short-Description: *\(.*\)/\1/p' "${script}"`
137 required=`sed -n 's/# *Required-Start: *\(.*\)/\1/p' "${script}" | sed 's/\$[a-z]*//'`
138 startbefore=`sed -n 's/# *X-Start-Before: *\(.*\)/\1/p' "${script}" | sed 's/\$[a-z]*//'`
139 runlevels=`sed -n 's/# *Default-Start: *\(.*\)/\1/p' "${script}"`
140 servicetype=`sed -n 's/# *X-Service-Type: *\(.*\)/\1/p' "${script}"`
141 test -z "${servicetype}" && servicetype="forking"
142 targets=`for i in ${runlevels}; do printf "runlevel${i}.target "; done`
143 before=`for i in ${startbefore}; do printf "${i}.service "; done`
144 after=`for i in ${required}; do printf "${i}.service "; done`
145 cat > "${unit_path}/${name}.service" << EOF
146[Unit]
147SourcePath=${script}
148Description=${description}
149Before=${targets}shutdown.target ${before}
150After=${after}
151Conflicts=shutdown.target ${conflicts}
152
153[Service]
154Type=${servicetype}
155Restart=no
156TimeoutSec=5min
157IgnoreSIGPIPE=no
158KillMode=process
159GuessMainPID=no
160RemainAfterExit=yes
161ExecStart=${script} start
162ExecStop=${script} stop
163
164[Install]
165WantedBy=multi-user.target
166EOF
167 systemctl daemon-reexec
168}
169
170## Installs a file containing a shell script as an init script
171install_init_script()
172{
173 self="install_init_script"
174 ## The init script to be installed. The file may be copied or referenced.
175 script="$1"
176 ## Name for the service.
177 name="$2"
178
179 test -x "${script}" && test ! "${name}" = "" ||
180 { echo "${self}: invalid arguments" >&2; return 1; }
181 # Do not unconditionally silence the following "ln".
182 test -L "/sbin/rc${name}" && rm "/sbin/rc${name}"
183 ln -s "${script}" "/sbin/rc${name}"
184 if test -x "`which systemctl 2>/dev/null`"; then
185 if ! test -f /sbin/init || ls -l /sbin/init | grep -q ">.*systemd"; then
186 { systemd_wrap_init_script "$script" "$name"; return; }
187 fi
188 fi
189 if test -d /etc/rc.d/init.d; then
190 cp "${script}" "/etc/rc.d/init.d/${name}" &&
191 chmod 755 "/etc/rc.d/init.d/${name}"
192 elif test -d /etc/init.d; then
193 cp "${script}" "/etc/init.d/${name}" &&
194 chmod 755 "/etc/init.d/${name}"
195 else
196 { echo "${self}: error: unknown init type" >&2; return 1; }
197 fi
198}
199
200## Remove the init script "name"
201remove_init_script()
202{
203 self="remove_init_script"
204 ## Name of the service to remove.
205 name="$1"
206
207 test -n "${name}" ||
208 { echo "$self: missing argument"; return 1; }
209 rm -f "/sbin/rc${name}"
210 rm -f /lib/systemd/system/"$name".service /usr/lib/systemd/system/"$name".service
211 rm -f "/etc/rc.d/init.d/$name"
212 rm -f "/etc/init.d/$name"
213}
214
215## Did we install a systemd service?
216systemd_service_installed()
217{
218 ## Name of service to test.
219 name="${1}"
220
221 test -f /lib/systemd/system/"${name}".service ||
222 test -f /usr/lib/systemd/system/"${name}".service
223}
224
225## Perform an action on a service
226do_sysvinit_action()
227{
228 self="do_sysvinit_action"
229 ## Name of service to start.
230 name="${1}"
231 ## The action to perform, normally "start", "stop" or "status".
232 action="${2}"
233
234 test ! -z "${name}" && test ! -z "${action}" ||
235 { echo "${self}: missing argument" >&2; return 1; }
236 if systemd_service_installed "${name}"; then
237 systemctl -q ${action} "${name}"
238 elif test -x "/etc/rc.d/init.d/${name}"; then
239 "/etc/rc.d/init.d/${name}" "${action}" quiet
240 elif test -x "/etc/init.d/${name}"; then
241 "/etc/init.d/${name}" "${action}" quiet
242 fi
243}
244
245## Start a service
246start_init_script()
247{
248 do_sysvinit_action "${1}" start
249}
250
251## Stop the init script "name"
252stop_init_script()
253{
254 do_sysvinit_action "${1}" stop
255}
256
257## Extract chkconfig information from a sysvinit script.
258get_chkconfig_info()
259{
260 ## The script to extract the information from.
261 script="${1}"
262
263 set `sed -n 's/# *chkconfig: *\([0-9]*\) *\(.*\)/\1 \2/p' "${script}"`
264 ## Which runlevels should we start in?
265 runlevels="${1}"
266 ## How soon in the boot process will we start, from 00 (first) to 99
267 start_order="${2}"
268 ## How soon in the shutdown process will we stop, from 99 (first) to 00
269 stop_order="${3}"
270 test ! -z "${name}" || \
271 { echo "${self}: missing name" >&2; return 1; }
272 expr "${start_order}" + 0 > /dev/null 2>&1 && \
273 expr 0 \<= "${start_order}" > /dev/null 2>&1 && \
274 test `expr length "${start_order}"` -eq 2 > /dev/null 2>&1 || \
275 { echo "${self}: start sequence number must be between 00 and 99" >&2;
276 return 1; }
277 expr "${stop_order}" + 0 > /dev/null 2>&1 && \
278 expr 0 \<= "${stop_order}" > /dev/null 2>&1 && \
279 test `expr length "${stop_order}"` -eq 2 > /dev/null 2>&1 || \
280 { echo "${self}: stop sequence number must be between 00 and 99" >&2;
281 return 1; }
282}
283
284## Add a service to its default runlevels (annotated inside the script, see get_chkconfig_info).
285addrunlevel()
286{
287 self="addrunlevel"
288 ## Service name.
289 name="${1}"
290
291 test -n "${name}" || \
292 { echo "${self}: missing argument" >&2; return 1; }
293 systemd_service_installed "${name}" && \
294 { systemctl -q enable "${name}"; return; }
295 if test -x "/etc/rc.d/init.d/${name}"; then
296 init_d_path=/etc/rc.d
297 elif test -x "/etc/init.d/${name}"; then
298 init_d_path=/etc
299 else
300 { echo "${self}: error: unknown init type" >&2; return 1; }
301 fi
302 get_chkconfig_info "${init_d_path}/init.d/${name}" || return 1
303 # Redhat based sysvinit systems
304 if test -x "`which chkconfig 2>/dev/null`"; then
305 chkconfig --add "${name}"
306 # SUSE-based sysvinit systems
307 elif test -x "`which insserv 2>/dev/null`"; then
308 insserv "${name}"
309 # Debian/Ubuntu-based systems
310 elif test -x "`which update-rc.d 2>/dev/null`"; then
311 # Old Debians did not support dependencies
312 update-rc.d "${name}" defaults "${start_order}" "${stop_order}"
313 # Gentoo Linux
314 elif test -x "`which rc-update 2>/dev/null`"; then
315 rc-update add "${name}" default
316 # Generic sysvinit
317 elif test -n "${init_d_path}/rc0.d"
318 then
319 for locali in 0 1 2 3 4 5 6
320 do
321 target="${init_d_path}/rc${locali}.d/K${stop_order}${name}"
322 expr "${runlevels}" : ".*${locali}" >/dev/null && \
323 target="${init_d_path}/rc${locali}.d/S${start_order}${name}"
324 test -e "${init_d_path}/rc${locali}.d/"[KS][0-9]*"${name}" || \
325 ln -fs "${init_d_path}/init.d/${name}" "${target}"
326 done
327 else
328 { echo "${self}: error: unknown init type" >&2; return 1; }
329 fi
330}
331
332
333## Delete a service from a runlevel
334delrunlevel()
335{
336 self="delrunlevel"
337 ## Service name.
338 name="${1}"
339
340 test -n "${name}" ||
341 { echo "${self}: missing argument" >&2; return 1; }
342 systemctl -q disable "${name}" >/dev/null 2>&1
343 # Redhat-based systems
344 chkconfig --del "${name}" >/dev/null 2>&1
345 # SUSE-based sysvinit systems
346 insserv -r "${name}" >/dev/null 2>&1
347 # Debian/Ubuntu-based systems
348 update-rc.d -f "${name}" remove >/dev/null 2>&1
349 # Gentoo Linux
350 rc-update del "${name}" >/dev/null 2>&1
351 # Generic sysvinit
352 rm -f /etc/rc.d/rc?.d/[SK]??"${name}"
353 rm -f /etc/rc?.d/[SK]??"${name}"
354}
355
356
357terminate_proc() {
358 PROC_NAME="${1}"
359 SERVER_PID=`pidof $PROC_NAME 2> /dev/null`
360 if [ "$SERVER_PID" != "" ]; then
361 killall -TERM $PROC_NAME > /dev/null 2>&1
362 sleep 2
363 fi
364}
365
366
367maybe_run_python_bindings_installer() {
368 VBOX_INSTALL_PATH="${1}"
369
370 PYTHON=python
371 if [ "`python -c 'import sys
372if sys.version_info >= (2, 6):
373 print \"test\"' 2> /dev/null`" != "test" ]; then
374 echo 1>&2 "Python 2.6 or later not available, skipping bindings installation."
375 return 1
376 fi
377
378 echo 1>&2 "Python found: $PYTHON, installing bindings..."
379 # Pass install path via environment
380 export VBOX_INSTALL_PATH
381 $SHELL -c "cd $VBOX_INSTALL_PATH/sdk/installer && $PYTHON vboxapisetup.py install \
382 --record $CONFIG_DIR/python-$CONFIG_FILES"
383 cat $CONFIG_DIR/python-$CONFIG_FILES >> $CONFIG_DIR/$CONFIG_FILES
384 rm $CONFIG_DIR/python-$CONFIG_FILES
385 # remove files created during build
386 rm -rf $VBOX_INSTALL_PATH/sdk/installer/build
387
388 return 0
389}
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette