1 | # $Id: setup-routines.sh 98103 2023-01-17 14:15:46Z vboxsync $
|
---|
2 | ## @file
|
---|
3 | # VirtualBox Validation Kit - TestBoxScript Service Setup on Solaris.
|
---|
4 | #
|
---|
5 |
|
---|
6 | #
|
---|
7 | # Copyright (C) 2006-2023 Oracle and/or its affiliates.
|
---|
8 | #
|
---|
9 | # This file is part of VirtualBox base platform packages, as
|
---|
10 | # available from https://www.virtualbox.org.
|
---|
11 | #
|
---|
12 | # This program is free software; you can redistribute it and/or
|
---|
13 | # modify it under the terms of the GNU General Public License
|
---|
14 | # as published by the Free Software Foundation, in version 3 of the
|
---|
15 | # License.
|
---|
16 | #
|
---|
17 | # This program is distributed in the hope that it will be useful, but
|
---|
18 | # WITHOUT ANY WARRANTY; without even the implied warranty of
|
---|
19 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
---|
20 | # General Public License for more details.
|
---|
21 | #
|
---|
22 | # You should have received a copy of the GNU General Public License
|
---|
23 | # along with this program; if not, see <https://www.gnu.org/licenses>.
|
---|
24 | #
|
---|
25 | # The contents of this file may alternatively be used under the terms
|
---|
26 | # of the Common Development and Distribution License Version 1.0
|
---|
27 | # (CDDL), a copy of it is provided in the "COPYING.CDDL" file included
|
---|
28 | # in the VirtualBox distribution, in which case the provisions of the
|
---|
29 | # CDDL are applicable instead of those of the GPL.
|
---|
30 | #
|
---|
31 | # You may elect to license modified versions of this file under the
|
---|
32 | # terms and conditions of either the GPL or the CDDL or both.
|
---|
33 | #
|
---|
34 | # SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
|
---|
35 | #
|
---|
36 |
|
---|
37 | #
|
---|
38 | # Detect solaris version.
|
---|
39 | #
|
---|
40 | MY_SOLARIS_VER=`uname -r`
|
---|
41 | case "${MY_SOLARIS_VER}" in
|
---|
42 | 5.10) MY_SOLARIS_VER=10;;
|
---|
43 | 5.11) MY_SOLARIS_VER=11;;
|
---|
44 | 5.12) MY_SOLARIS_VER=12;;
|
---|
45 | *)
|
---|
46 | echo "Your solaris version (${MY_SOLARIS_VER}) is not supported." >&2
|
---|
47 | exit 1;;
|
---|
48 | esac
|
---|
49 |
|
---|
50 | #
|
---|
51 | # Overriding setup.sh bits.
|
---|
52 | #
|
---|
53 | MY_FGREP="/usr/xpg4/bin/fgrep" # The other one does grok -q.
|
---|
54 | if [ ! -f "${MY_ETC_SUDOERS}" ]; then # sudo isn't standard on S10.
|
---|
55 | if [ -f "/opt/csw/etc/sudoers" ]; then
|
---|
56 | MY_ETC_SUDOERS=/opt/csw/etc/sudoers
|
---|
57 | fi
|
---|
58 | if [ -f "/etc/opt/csw/sudoers" ]; then
|
---|
59 | MY_ETC_SUDOERS=/etc/opt/csw/sudoers
|
---|
60 | fi
|
---|
61 | fi
|
---|
62 |
|
---|
63 | #
|
---|
64 | # Solaris variables.
|
---|
65 | #
|
---|
66 | MY_SVC_FMRI="svc:/system/virtualbox/testboxscript"
|
---|
67 | MY_SVCCFG="/usr/sbin/svccfg"
|
---|
68 | MY_SVCADM="/usr/sbin/svcadm"
|
---|
69 | MY_CHGRP="/usr/bin/chgrp"
|
---|
70 | MY_TR="/usr/bin/tr"
|
---|
71 | MY_TAB=`printf "\t"`
|
---|
72 |
|
---|
73 | if test "${MY_SOLARIS_VER}" -lt 11; then
|
---|
74 | # solaris 10 service import
|
---|
75 | MY_SVC="/tmp/testboxscript.xml"
|
---|
76 | else
|
---|
77 | # use propper manifest directory
|
---|
78 | # /lib/svc/manifest/system for solaris 11 and higher for testboxscript.xml file
|
---|
79 |
|
---|
80 | # Since sol 11.4 the solaris testboxscript service
|
---|
81 | # generates Warnings in /var/svc/log/system-manifest-import:default.log
|
---|
82 | # -------- Warning!!
|
---|
83 | # Configuring services...
|
---|
84 | # * Warning!! Importing Zone access service ...FAILED.
|
---|
85 |
|
---|
86 | MY_SVC="/lib/svc/manifest/system/testboxscript.xml"
|
---|
87 | fi
|
---|
88 | if test "${MY_SOLARIS_VER}" -lt 11; then ## No gsed on S10?? ARG!
|
---|
89 | MY_SED="/usr/xpg4/bin/sed"
|
---|
90 | else
|
---|
91 | MY_SED="/usr/bin/gsed"
|
---|
92 | fi
|
---|
93 | if test "${MY_SOLARIS_VER}" -lt 11; then
|
---|
94 | MY_SCREEN="/opt/csw/bin/screen"
|
---|
95 | else
|
---|
96 | MY_SCREEN="screen"
|
---|
97 | fi
|
---|
98 |
|
---|
99 |
|
---|
100 | check_for_cifs() {
|
---|
101 | if [ ! -f /usr/kernel/fs/amd64/smbfs -a ! -f /usr/kernel/fs/smbfs -a "${MY_SOLARIS_VER}" -ge 11 ]; then
|
---|
102 | echo "error: smbfs client not installed?" >&2
|
---|
103 | echo "Please install smbfs client support:" >&2
|
---|
104 | echo " pkg install system/file-system/smb" >&2
|
---|
105 | echo " svcadm enable svc:/system/idmap" >&2
|
---|
106 | echo " svcadm enable svc:/network/smb/client" >&2
|
---|
107 | echo " svcs svc:/system/idmap" >&2
|
---|
108 | return 1;
|
---|
109 | fi
|
---|
110 | return 0;
|
---|
111 | }
|
---|
112 |
|
---|
113 | ##
|
---|
114 | # Loads config values from the current installation.
|
---|
115 | #
|
---|
116 | os_load_config() {
|
---|
117 | #
|
---|
118 | # Adjust defaults.
|
---|
119 | #
|
---|
120 | # - Use NFS instead of CIFS because S10 doesn't have smbfs and S11 has
|
---|
121 | # problems getting the password.
|
---|
122 | # - Pass the PATH along so we'll find sudo and other stuff later.
|
---|
123 | #
|
---|
124 | TESTBOXSCRIPT_BUILDS_TYPE="nfs"
|
---|
125 | TESTBOXSCRIPT_TESTRSRC_TYPE="nfs"
|
---|
126 | TESTBOXSCRIPT_DEFAULT_BUILDS_TYPE="nfs"
|
---|
127 | TESTBOXSCRIPT_DEFAULT_TESTRSRC_TYPE="nfs"
|
---|
128 | TESTBOXSCRIPT_ENVVARS[${#TESTBOXSCRIPT_ENVVARS[@]}]="PATH=${PATH}";
|
---|
129 |
|
---|
130 | # Load old current.
|
---|
131 | if "${MY_SVCCFG}" "export" "${MY_SVC_FMRI}" > /dev/null 2>&1; then
|
---|
132 | # User. ASSUMES single quoted attribs.
|
---|
133 | MY_TMP=`"${MY_SVCCFG}" "export" "${MY_SVC_FMRI}" \
|
---|
134 | | ${MY_TR} '\n' ' ' \
|
---|
135 | `;
|
---|
136 | MY_TMP=`echo "${MY_TMP} " \
|
---|
137 | | ${MY_SED} \
|
---|
138 | -e 's/> */> /g' \
|
---|
139 | -e 's/ *\/>/ \/>/g' \
|
---|
140 | -e 's/^.*<method_credential \([^>]*\) \/>.*$/\1/' \
|
---|
141 | -e "s/^.*user='\([^']*\)'.*\$/\1/" \
|
---|
142 | `;
|
---|
143 | if [ -n "${MY_TMP}" ]; then
|
---|
144 | TESTBOXSCRIPT_USER="${MY_TMP}";
|
---|
145 | fi
|
---|
146 |
|
---|
147 | # Arguments. ASSUMES sub-elements. ASSUMES single quoted attribs.
|
---|
148 | XMLARGS=`"${MY_SVCCFG}" "export" "${MY_SVC_FMRI}" \
|
---|
149 | | ${MY_TR} '\n' ' ' \
|
---|
150 | `;
|
---|
151 | case "${XMLARGS}" in
|
---|
152 | *exec_method*)
|
---|
153 | XMLARGS=`echo "${XMLARGS} " \
|
---|
154 | | ${MY_SED} \
|
---|
155 | -e 's/> */> /g' \
|
---|
156 | -e 's/ *\/>/ \/>/g' \
|
---|
157 | -e "s/^.*<exec_method \([^>]*\)name='start'\([^>]*\)>.*\$/\1 \2/" \
|
---|
158 | -e "s/^.*exec='\([^']*\)'.*\$/\1/" \
|
---|
159 | -e 's/"/"/g' \
|
---|
160 | -e 's/</</g' \
|
---|
161 | -e 's/>/>/g' \
|
---|
162 | -e 's/&/&/g' \
|
---|
163 | | ${MY_SED} \
|
---|
164 | -e 's/^.*testboxscript -d -m *//' \
|
---|
165 | `;
|
---|
166 | eval common_testboxscript_args_to_config ${XMLARGS}
|
---|
167 | ;;
|
---|
168 | *)
|
---|
169 | echo "error: ${MY_SVCCFG}" "export" "${MY_SVC_FMRI} contains no exec_method element." >&2
|
---|
170 | echo " Please delete the service manually and restart setup.sh" >&2
|
---|
171 | exit 2
|
---|
172 | ;;
|
---|
173 | esac
|
---|
174 | fi
|
---|
175 | }
|
---|
176 |
|
---|
177 | ##
|
---|
178 | # Adds one or more arguments to MY_ARGV after checking them for conformity.
|
---|
179 | #
|
---|
180 | os_add_args() {
|
---|
181 | while [ $# -gt 0 ];
|
---|
182 | do
|
---|
183 | case "$1" in
|
---|
184 | *\ *)
|
---|
185 | echo "error: Space in option value is not allowed ($1)" >&2
|
---|
186 | exit 1;
|
---|
187 | ;;
|
---|
188 | *${MY_TAB}*)
|
---|
189 | echo "error: Tab in option value is not allowed ($1)" >&2
|
---|
190 | exit 1;
|
---|
191 | ;;
|
---|
192 | *\&*)
|
---|
193 | echo "error: Ampersand in option value is not allowed ($1)" >&2
|
---|
194 | exit 1;
|
---|
195 | ;;
|
---|
196 | *\<*)
|
---|
197 | echo "error: Greater-than in option value is not allowed ($1)" >&2
|
---|
198 | exit 1;
|
---|
199 | ;;
|
---|
200 | *\>*)
|
---|
201 | echo "error: Less-than in option value is not allowed ($1)" >&2
|
---|
202 | exit 1;
|
---|
203 | ;;
|
---|
204 | *)
|
---|
205 | MY_ARGV="${MY_ARGV} $1";
|
---|
206 | ;;
|
---|
207 | esac
|
---|
208 | shift;
|
---|
209 | done
|
---|
210 | return 0;
|
---|
211 | }
|
---|
212 |
|
---|
213 | ##
|
---|
214 | # Installs, configures and starts the service.
|
---|
215 | #
|
---|
216 | os_install_service() {
|
---|
217 | # Only NFS for S10.
|
---|
218 | if [ "${MY_SOLARIS_VER}" -lt 11 ]; then
|
---|
219 | if [ "${TESTBOXSCRIPT_BUILDS_TYPE}" != "nfs" -o "${TESTBOXSCRIPT_TESTRSRC_TYPE}" != "nfs" ]; then
|
---|
220 | echo "On solaris 10 both share types must be 'nfs', cifs (smbfs) is not supported." >&2
|
---|
221 | return 1;
|
---|
222 | fi
|
---|
223 | fi
|
---|
224 |
|
---|
225 | # Calc the command line.
|
---|
226 | MY_ARGV=""
|
---|
227 | common_compile_testboxscript_command_line
|
---|
228 |
|
---|
229 | # Create the service xml config file.
|
---|
230 | cat > "${MY_SVC}" <<EOF
|
---|
231 | <?xml version='1.0'?>
|
---|
232 | <!DOCTYPE service_bundle SYSTEM "/usr/share/lib/xml/dtd/service_bundle.dtd.1">
|
---|
233 | <service_bundle type='manifest' name='export'>
|
---|
234 | <service name='system/virtualbox/testboxscript' type='service' version='1'>
|
---|
235 | <create_default_instance enabled='false' />
|
---|
236 | <single_instance/>
|
---|
237 |
|
---|
238 | <!-- Wait for the network to start up -->
|
---|
239 | <dependency name='milestone-network' grouping='require_all' restart_on='none' type='service'>
|
---|
240 | <service_fmri value='svc:/milestone/network:default' />
|
---|
241 | </dependency>
|
---|
242 |
|
---|
243 | <!-- We wish to be started as late as possible... so go crazy with deps. -->
|
---|
244 | <dependency name='milestone-devices' grouping='require_all' restart_on='none' type='service'>
|
---|
245 | <service_fmri value='svc:/milestone/devices:default' />
|
---|
246 | </dependency>
|
---|
247 | <dependency name='multi-user' grouping='require_all' restart_on='none' type='service'>
|
---|
248 | <service_fmri value='svc:/milestone/multi-user:default' />
|
---|
249 | </dependency>
|
---|
250 | <dependency name='multi-user-server' grouping='require_all' restart_on='none' type='service'>
|
---|
251 | <service_fmri value='svc:/milestone/multi-user-server:default' />
|
---|
252 | </dependency>
|
---|
253 | <dependency name='filesystem-local' grouping='require_all' restart_on='none' type='service'>
|
---|
254 | <service_fmri value='svc:/system/filesystem/local:default' />
|
---|
255 | </dependency>
|
---|
256 | <dependency name='filesystem-autofs' grouping='require_all' restart_on='none' type='service'>
|
---|
257 | <service_fmri value='svc:/system/filesystem/autofs:default' />
|
---|
258 | </dependency>
|
---|
259 | EOF
|
---|
260 | if [ "`uname -r`" = "5.10" ]; then # Seems to be gone in S11?
|
---|
261 | cat >> "${MY_SVC}" <<EOF
|
---|
262 | <dependency name='filesystem-volfs' grouping='require_all' restart_on='none' type='service'>
|
---|
263 | <service_fmri value='svc:/system/filesystem/volfs:default' />
|
---|
264 | </dependency>
|
---|
265 | EOF
|
---|
266 | fi
|
---|
267 | cat >> "${MY_SVC}" <<EOF
|
---|
268 | <!-- start + stop methods -->
|
---|
269 | <exec_method type='method' name='start' exec='${MY_SCREEN} -S testboxscript -d -m ${MY_ARGV}'
|
---|
270 | timeout_seconds='30'>
|
---|
271 | <method_context working_directory='${TESTBOXSCRIPT_DIR}'>
|
---|
272 | <method_credential user='${TESTBOXSCRIPT_USER}' />
|
---|
273 | <method_environment>
|
---|
274 | <envvar name='PATH' value='${PATH}' />
|
---|
275 | </method_environment>
|
---|
276 | </method_context>
|
---|
277 | </exec_method>
|
---|
278 |
|
---|
279 | <exec_method type='method' name='stop' exec=':kill' timeout_seconds='60' />
|
---|
280 |
|
---|
281 | <property_group name='startd' type='framework'>
|
---|
282 | <!-- sub-process core dumps/signals should not restart session -->
|
---|
283 | <propval name='ignore_error' type='astring' value='core,signal' />
|
---|
284 | </property_group>
|
---|
285 |
|
---|
286 | <!-- Description -->
|
---|
287 | <template>
|
---|
288 | <common_name>
|
---|
289 | <loctext xml:lang='C'>VirtualBox TestBox Script</loctext>
|
---|
290 | </common_name>
|
---|
291 | </template>
|
---|
292 | </service>
|
---|
293 | </service_bundle>
|
---|
294 | EOF
|
---|
295 |
|
---|
296 | if test "${MY_SOLARIS_VER}" -lt 11; then
|
---|
297 | # Install the service, replacing old stuff.
|
---|
298 | if "${MY_SVCCFG}" "export" "${MY_SVC_FMRI}" > /dev/null 2>&1; then
|
---|
299 | "${MY_SVCCFG}" "delete" "${MY_SVC_FMRI}"
|
---|
300 | fi
|
---|
301 | "${MY_SVCCFG}" "import" "${MY_SVC}"
|
---|
302 |
|
---|
303 | # only for solaris version less than 11
|
---|
304 | rm -f "${MY_SVC}"
|
---|
305 | else
|
---|
306 | "${MY_CHGRP}" "sys" "${MY_SVC}"
|
---|
307 | "${MY_SVCADM}" "restart" "manifest-import"
|
---|
308 |
|
---|
309 | # Do not remove the xml file in Solaris versions 11 and higher.
|
---|
310 | # The service will be removed automatically, if the command
|
---|
311 | # svcadm restart manifest-import
|
---|
312 | # will be executed
|
---|
313 |
|
---|
314 | fi
|
---|
315 | return 0;
|
---|
316 | }
|
---|
317 |
|
---|
318 | os_enable_service() {
|
---|
319 | "${MY_SVCADM}" "enable" "${MY_SVC_FMRI}"
|
---|
320 | return 0;
|
---|
321 | }
|
---|
322 |
|
---|
323 | os_disable_service() {
|
---|
324 | if "${MY_SVCCFG}" "export" "${MY_SVC_FMRI}" > /dev/null 2>&1; then
|
---|
325 | "${MY_SVCADM}" "disable" "${MY_SVC_FMRI}"
|
---|
326 | sleep 1
|
---|
327 | fi
|
---|
328 | return 0;
|
---|
329 | }
|
---|
330 |
|
---|
331 | os_add_user() {
|
---|
332 | useradd -m -s /usr/bin/bash -G staff "${TESTBOXSCRIPT_USER}"
|
---|
333 | passwd "${TESTBOXSCRIPT_USER}" # This sucker prompts, seemingly no way around that.
|
---|
334 | return 0;
|
---|
335 | }
|
---|
336 |
|
---|
337 |
|
---|
338 | maybe_hush_up_root_login() {
|
---|
339 | # We don't want /etc/profile to display /etc/motd, quotas and mail status
|
---|
340 | # every time we do sudo -i... It may screw up serious if we parse the
|
---|
341 | # output of the command we sudid.
|
---|
342 | > ~root/.hushlogin
|
---|
343 | return 0;
|
---|
344 | }
|
---|
345 |
|
---|
346 | os_final_message() {
|
---|
347 | cat <<EOF
|
---|
348 |
|
---|
349 | Additional things to do:"
|
---|
350 | 1. Configure NTP:
|
---|
351 | a) echo "server wei01-time.de.oracle.com" > /etc/inet/ntp.conf
|
---|
352 | echo "driftfile /var/ntp/ntp.drift" >> /etc/inet/ntp.conf
|
---|
353 | b) Enable the service: svcadm enable ntp
|
---|
354 | c) Sync once in case of big diff: ntpdate wei01-time.de.oracle.com
|
---|
355 | d) Check that it works: ntpq -p
|
---|
356 |
|
---|
357 | Enjoy!
|
---|
358 | EOF
|
---|
359 | }
|
---|
360 |
|
---|