VirtualBox

source: vbox/trunk/src/VBox/Main/include/UnattendedInstaller.h@ 95753

Last change on this file since 95753 was 95436, checked in by vboxsync, 3 years ago

Main/UnattendedInstall: Minimalistic support for FreeBSD >= 10.0 sitting in my tree for too long, bugref:9781

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 35.6 KB
Line 
1/* $Id: UnattendedInstaller.h 95436 2022-06-29 18:18:57Z vboxsync $ */
2/** @file
3 * UnattendedInstaller class header
4 */
5
6/*
7 * Copyright (C) 2006-2022 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef MAIN_INCLUDED_UnattendedInstaller_h
19#define MAIN_INCLUDED_UnattendedInstaller_h
20#ifndef RT_WITHOUT_PRAGMA_ONCE
21# pragma once
22#endif
23
24#include "UnattendedScript.h"
25
26/* Forward declarations */
27class Unattended;
28class UnattendedInstaller;
29class BaseTextScript;
30
31
32/**
33 * The abstract UnattendedInstaller class declaration
34 *
35 * The class is intended to service a new VM that this VM will be able to
36 * execute an unattended installation
37 */
38class UnattendedInstaller : public RTCNonCopyable
39{
40/*data*/
41protected:
42 /** Main unattended installation script. */
43 UnattendedScriptTemplate mMainScript;
44 /** Full path to the main template file (set by initInstaller). */
45 Utf8Str mStrMainScriptTemplate;
46
47 /** Post installation (shell) script. */
48 UnattendedScriptTemplate mPostScript;
49 /** Full path to the post template file (set by initInstaller). */
50 Utf8Str mStrPostScriptTemplate;
51
52 /** Pointer to the parent object.
53 * We use this for setting errors and querying attributes. */
54 Unattended *mpParent;
55 /** The path of the extra ISO image we create (set by initInstaller).
56 * This is only valid when isAdditionsIsoNeeded() returns true. */
57 Utf8Str mStrAuxiliaryIsoFilePath;
58 /** The path of the extra floppy image we create (set by initInstaller)
59 * This is only valid when isAdditionsFloppyNeeded() returns true. */
60 Utf8Str mStrAuxiliaryFloppyFilePath;
61 /** The boot device. */
62 DeviceType_T const meBootDevice;
63 /** Default extra install kernel parameters (set by constructor).
64 * This can be overridden by the extraInstallKernelParameters attribute of
65 * IUnattended. */
66 Utf8Str mStrDefaultExtraInstallKernelParameters;
67 /** The directory of the post install script in the unattended install
68 * environment, i.e. when it gets started by the unattended installer
69 * of the respective guest OS. */
70 Utf8Str mStrAuxiliaryInstallDir;
71
72private:
73 UnattendedInstaller(); /* no default constructors */
74
75public:
76 DECLARE_TRANSLATE_METHODS(UnattendedInstaller)
77
78 /**
79 * Regular constructor.
80 *
81 * @param pParent The parent object. Used for setting
82 * errors and querying attributes.
83 * @param pszMainScriptTemplateName The name of the template file (no path)
84 * for the main unattended installer
85 * script.
86 * @param pszPostScriptTemplateName The name of the template file (no path)
87 * for the post installation script.
88 * @param pszMainScriptFilename The main unattended installer script
89 * filename (on aux media).
90 * @param pszPostScriptFilename The post installation script filename
91 * (on aux media).
92 * @param enmBootDevice The boot device type.
93 */
94 UnattendedInstaller(Unattended *pParent,
95 const char *pszMainScriptTemplateName, const char *pszPostScriptTemplateName,
96 const char *pszMainScriptFilename, const char *pszPostScriptFilename,
97 DeviceType_T enmBootDevice = DeviceType_DVD);
98 virtual ~UnattendedInstaller();
99
100 /**
101 * Instantiates the appropriate child class.
102 *
103 * @returns Pointer to the new instance, NULL if no appropriate installer.
104 * @param enmDetectedOSType The detected guest OS type value.
105 * @param strDetectedOSType The detected guest OS type string
106 * @param strDetectedOSVersion The detected guest OS version.
107 * @param strDetectedOSFlavor The detected guest OS flavor.
108 * @param strDetectedOSHints Hints about the detected guest OS.
109 * @param pParent The parent object. Used for setting errors
110 * and querying attributes.
111 * @throws std::bad_alloc
112 */
113 static UnattendedInstaller *createInstance(VBOXOSTYPE enmDetectedOSType, const Utf8Str &strDetectedOSType,
114 const Utf8Str &strDetectedOSVersion, const Utf8Str &strDetectedOSFlavor,
115 const Utf8Str &strDetectedOSHints, Unattended *pParent);
116
117 /**
118 * Initialize the installer.
119 *
120 * @note This is called immediately after instantiation and the caller will
121 * always destroy the unattended installer instance on failure, so it
122 * is not necessary to keep track of whether this succeeded or not.
123 */
124 virtual HRESULT initInstaller();
125
126#if 0 /* These are now in the AUX VISO. */
127 /**
128 * Whether the VBox Guest Additions ISO is needed or not.
129 *
130 * The default implementation always returns false when a VISO is used, see
131 * UnattendedInstaller::addFilesToAuxVisoVectors.
132 */
133 virtual bool isAdditionsIsoNeeded() const;
134
135 /**
136 * Whether the VBox validation kit ISO is needed or not.
137 *
138 * The default implementation always returns false when a VISO is used, see
139 * UnattendedInstaller::addFilesToAuxVisoVectors.
140 */
141 virtual bool isValidationKitIsoNeeded() const;
142#endif
143
144 /**
145 * Indicates whether an original installation ISO is needed or not.
146 */
147 virtual bool isOriginalIsoNeeded() const { return true; }
148
149 /**
150 * Indicates whether a floppy image is needed or not.
151 */
152 virtual bool isAuxiliaryFloppyNeeded() const { return false; }
153
154 /**
155 * Indicates whether an additional or replacement ISO image is needed or not.
156 */
157 virtual bool isAuxiliaryIsoNeeded() const;
158
159 /**
160 * Indicates whether we should boot from the auxiliary ISO image.
161 *
162 * Will boot from installation ISO if false.
163 */
164 virtual bool bootFromAuxiliaryIso() const { return isAuxiliaryIsoNeeded(); }
165
166 /**
167 * Indicates whether a the auxiliary ISO is a .viso-file rather than an
168 * .iso-file.
169 *
170 * Different worker methods are used depending on the return value. A
171 * .viso-file is generally only used when the installation media needs to
172 * be remastered with small changes and additions.
173 */
174 virtual bool isAuxiliaryIsoIsVISO() const { return true; }
175
176 /*
177 * Getters
178 */
179 DeviceType_T getBootableDeviceType() const { return meBootDevice; }
180 const Utf8Str &getTemplateFilePath() const { return mStrMainScriptTemplate; }
181 const Utf8Str &getPostTemplateFilePath() const { return mStrPostScriptTemplate; }
182 const Utf8Str &getAuxiliaryIsoFilePath() const { return mStrAuxiliaryIsoFilePath; }
183 const Utf8Str &getAuxiliaryFloppyFilePath() const { return mStrAuxiliaryFloppyFilePath; }
184 const Utf8Str &getDefaultExtraInstallKernelParameters() const { return mStrDefaultExtraInstallKernelParameters; }
185 const Utf8Str &getAuxiliaryInstallDir() const { return mStrAuxiliaryInstallDir; }
186
187 /*
188 * Setters
189 */
190 void setTemplatePath(const Utf8Str& data); /**< @todo r=bird: This is confusing as heck. Dir for a while, then it's a file. Not a comment about it. Brilliant. */
191
192 /**
193 * Prepares the unattended scripts, does all but write them to the installation
194 * media.
195 */
196 HRESULT prepareUnattendedScripts();
197
198 /**
199 * Prepares the media - floppy image, ISO image.
200 *
201 * This method calls prepareAuxFloppyImage() and prepareAuxIsoImage(), child
202 * classes may override these methods or methods they call.
203 *
204 * @returns COM status code.
205 * @param fOverwrite Whether to overwrite media files or fail if they
206 * already exist.
207 */
208 HRESULT prepareMedia(bool fOverwrite = true);
209
210protected:
211 /**
212 * Prepares (creates) the auxiliary floppy image.
213 *
214 * This is called by the base class prepareMedia() when
215 * isAuxiliaryFloppyNeeded() is true. The base class implementation puts the
216 * edited unattended script onto it.
217 */
218 HRESULT prepareAuxFloppyImage(bool fOverwrite);
219
220 /**
221 * Creates and formats (FAT12) a floppy image.
222 *
223 * This can be overridden to do more preparation work or/and create a different
224 * sized floppy.
225 *
226 * @returns COM status code.
227 * @param pszFilename The path to the image file.
228 * @param fOverwrite Whether to overwrite the file.
229 * @param phVfsFile Where to return a read-writable handle to the newly
230 * created image.
231 */
232 virtual HRESULT newAuxFloppyImage(const char *pszFilename, bool fOverwrite, PRTVFSFILE phVfsFile);
233
234 /**
235 * Copies files to the auxiliary floppy image.
236 *
237 * The base class implementation copies the main and post scripts to the root of
238 * the floppy using the default script names. Child classes may override this
239 * to add additional or different files.
240 *
241 * @returns COM status code.
242 * @param hVfs The floppy image VFS handle.
243 */
244 virtual HRESULT copyFilesToAuxFloppyImage(RTVFS hVfs);
245
246 /**
247 * Adds the given script to the root of the floppy image under the default
248 * script filename.
249 *
250 * @returns COM status code.
251 * @param pEditor The script to add.
252 * @param hVfs The VFS to add it to.
253 */
254 HRESULT addScriptToFloppyImage(BaseTextScript *pEditor, RTVFS hVfs);
255
256 /**
257 * Copy an arbritrary file onto the floopy image.
258 *
259 * @returns COM status code.
260 * @param hVfs The VFS to add it to.
261 * @param pszSrc The source filename.
262 * @param pszDst The destination filename (on @a hVfs).
263 */
264 HRESULT addFileToFloppyImage(RTVFS hVfs, const char *pszSrc, const char *pszDst);
265
266 /**
267 * Prepares (creates) the auxiliary ISO image.
268 *
269 * This is called by the base class prepareMedia() when isAuxiliaryIsoNeeded()
270 * is true. The base class implementation puts the edited unattended script
271 * onto it.
272 */
273 virtual HRESULT prepareAuxIsoImage(bool fOverwrite);
274
275 /**
276 * Opens the installation ISO image.
277 *
278 * @returns COM status code.
279 * @param phVfsIso Where to return the VFS handle for the ISO.
280 * @param fFlags RTFSISO9660_F_XXX flags to pass to the
281 * RTFsIso9660VolOpen API.
282 */
283 virtual HRESULT openInstallIsoImage(PRTVFS phVfsIso, uint32_t fFlags = 0);
284
285 /**
286 * Creates and configures the ISO maker instance.
287 *
288 * This can be overridden to set configure options.
289 *
290 * @returns COM status code.
291 * @param phIsoMaker Where to return the ISO maker.
292 */
293 virtual HRESULT newAuxIsoImageMaker(PRTFSISOMAKER phIsoMaker);
294
295 /**
296 * Adds files to the auxiliary ISO image maker.
297 *
298 * The base class implementation copies just the mMainScript and mPostScript
299 * files to root directory using the default filenames.
300 *
301 * @returns COM status code.
302 * @param hIsoMaker The ISO maker handle.
303 * @param hVfsOrgIso The VFS handle to the original ISO in case files
304 * needs to be added from it.
305 */
306 virtual HRESULT addFilesToAuxIsoImageMaker(RTFSISOMAKER hIsoMaker, RTVFS hVfsOrgIso);
307
308 /**
309 * Adds the given script to the ISO maker.
310 *
311 * @returns COM status code.
312 * @param pEditor The script to add.
313 * @param hIsoMaker The ISO maker to add it to.
314 * @param pszDstFilename The file name (w/ path) to add it under. If NULL,
315 * the default script filename is used to add it to the
316 * root.
317 */
318 HRESULT addScriptToIsoMaker(BaseTextScript *pEditor, RTFSISOMAKER hIsoMaker, const char *pszDstFilename = NULL);
319
320 /**
321 * Writes the ISO image to disk.
322 *
323 * @returns COM status code.
324 * @param hIsoMaker The ISO maker handle.
325 * @param pszFilename The filename.
326 * @param fOverwrite Whether to overwrite the destination file or not.
327 */
328 HRESULT finalizeAuxIsoImage(RTFSISOMAKER hIsoMaker, const char *pszFilename, bool fOverwrite);
329
330 /**
331 * Adds files to the .viso-file vectors.
332 *
333 * The base class implementation adds the script from mAlg, additions ISO
334 * content to '/vboxadditions', and validation kit ISO to '/vboxvalidationkit'.
335 *
336 * @returns COM status code.
337 * @param rVecArgs The ISO maker argument list that will be turned into
338 * a .viso-file.
339 * @param rVecFiles The list of files we've created. This is for
340 * cleaning up at the end.
341 * @param hVfsOrgIso The VFS handle to the original ISO in case files
342 * needs to be added from it.
343 * @param fOverwrite Whether to overwrite files or not.
344 */
345 virtual HRESULT addFilesToAuxVisoVectors(RTCList<RTCString> &rVecArgs, RTCList<RTCString> &rVecFiles,
346 RTVFS hVfsOrgIso, bool fOverwrite);
347
348 /**
349 * Saves the given script to disk and adds it to the .viso-file vectors.
350 *
351 * @returns COM status code.
352 * @param pEditor The script to add.
353 * @param rVecArgs The ISO maker argument list that will be turned into
354 * a .viso-file.
355 * @param rVecFiles The list of files we've created. This is for
356 * cleaning up at the end.
357 * @param fOverwrite Whether to overwrite files or not.
358 */
359 HRESULT addScriptToVisoVectors(BaseTextScript *pEditor, RTCList<RTCString> &rVecArgs,
360 RTCList<RTCString> &rVecFiles, bool fOverwrite);
361
362 /**
363 * Writes out the .viso-file to disk.
364 *
365 * @returns COM status code.
366 * @param rVecArgs The ISO maker argument list to write out.
367 * @param pszFilename The filename.
368 * @param fOverwrite Whether to overwrite the destination file or not.
369 */
370 HRESULT finalizeAuxVisoFile(RTCList<RTCString> const &rVecArgs, const char *pszFilename, bool fOverwrite);
371
372 /**
373 * Loads @a pszFilename from @a hVfsOrgIso into @a pEditor and parses it.
374 *
375 * @returns COM status code.
376 * @param hVfsOrgIso The handle to the original installation ISO.
377 * @param pszFilename The filename to open and load from the ISO.
378 * @param pEditor The editor instance to load the file into and
379 * do the parseing with.
380 */
381 HRESULT loadAndParseFileFromIso(RTVFS hVfsOrgIso, const char *pszFilename, AbstractScript *pEditor);
382};
383
384
385/**
386 * Windows installer, for versions up to xp 64 / w2k3.
387 */
388class UnattendedWindowsSifInstaller : public UnattendedInstaller
389{
390public:
391 DECLARE_TRANSLATE_METHODS(UnattendedWindowsSifInstaller)
392
393 UnattendedWindowsSifInstaller(Unattended *pParent)
394 : UnattendedInstaller(pParent,
395 "win_nt5_unattended.sif", "win_postinstall.cmd",
396 "WINNT.SIF", "VBOXPOST.CMD")
397 {
398 Assert(isOriginalIsoNeeded()); Assert(isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); Assert(!bootFromAuxiliaryIso());
399 mStrAuxiliaryInstallDir = "A:\\";
400 }
401 ~UnattendedWindowsSifInstaller() {}
402
403 bool isAuxiliaryFloppyNeeded() const { return true; }
404 bool bootFromAuxiliaryIso() const { return false; }
405
406};
407
408/**
409 * Windows installer, for versions starting with Vista.
410 */
411class UnattendedWindowsXmlInstaller : public UnattendedInstaller
412{
413public:
414 DECLARE_TRANSLATE_METHODS(UnattendedWindowsXmlInstaller)
415
416 UnattendedWindowsXmlInstaller(Unattended *pParent)
417 : UnattendedInstaller(pParent,
418 "win_nt6_unattended.xml", "win_postinstall.cmd",
419 "autounattend.xml", "VBOXPOST.CMD")
420 {
421 Assert(isOriginalIsoNeeded()); Assert(isAuxiliaryFloppyNeeded() || isAuxiliaryIsoNeeded()); Assert(isAuxiliaryIsoIsVISO()); Assert(!bootFromAuxiliaryIso());
422 if (isAuxiliaryFloppyNeeded())
423 mStrAuxiliaryInstallDir = "A:\\";
424 else if (bootFromAuxiliaryIso())
425 mStrAuxiliaryInstallDir = "D:\\";
426 else
427 mStrAuxiliaryInstallDir = "E:\\";
428 }
429 ~UnattendedWindowsXmlInstaller() {}
430
431 bool isAuxiliaryFloppyNeeded() const { return !mpParent->i_isFirmwareEFI(); }
432 bool isAuxiliaryIsoNeeded() const { return UnattendedInstaller::isAuxiliaryIsoNeeded() || mpParent->i_isFirmwareEFI(); }
433 bool isAuxiliaryIsoIsVISO() const { return true; }
434 bool bootFromAuxiliaryIso() const { return false; }
435};
436
437
438/**
439 * OS/2 installer.
440 */
441class UnattendedOs2Installer : public UnattendedInstaller
442{
443public:
444 DECLARE_TRANSLATE_METHODS(UnattendedOs2Installer)
445
446 UnattendedOs2Installer(Unattended *pParent, Utf8Str const &rStrHints);
447 ~UnattendedOs2Installer() {}
448
449 /* Remaster original ISO with auxiliary floppy used for el torito floppy emulation: */
450 bool isOriginalIsoNeeded() const RT_OVERRIDE { return false; }
451 bool isAuxiliaryFloppyNeeded() const RT_OVERRIDE { return true; }
452 bool isAuxiliaryIsoNeeded() const RT_OVERRIDE { return true; }
453
454protected:
455 HRESULT replaceAuxFloppyImageBootSector(RTVFSFILE hVfsFile) RT_NOEXCEPT;
456 HRESULT newAuxFloppyImage(const char *pszFilename, bool fOverwrite, PRTVFSFILE phVfsFile) RT_OVERRIDE;
457 HRESULT copyFilesToAuxFloppyImage(RTVFS hVfs) RT_OVERRIDE;
458 HRESULT addFilesToAuxVisoVectors(RTCList<RTCString> &rVecArgs, RTCList<RTCString> &rVecFiles,
459 RTVFS hVfsOrgIso, bool fOverwrite) RT_OVERRIDE;
460
461 HRESULT splitResponseFile() RT_NOEXCEPT;
462
463 /**
464 * Splits up the given file into sub-files and writes them out with the auxilary
465 * path base as prefix.
466 *
467 * The source file contains @@VBOX_SPLITTER_START[filename]@@ and
468 * @@VBOX_SPLITTER_END[filename]@@ markup that is used to split it up. Any
469 * text between END and START tags are ignored and can be used for comments.
470 *
471 * @returns COM status code (error info set).
472 * @param pszFileToSplit The name of the file to split.
473 * @param rVecSplitFiles Vector where names of the sub-files are appended
474 * (without any path or prefix).
475 */
476 HRESULT splitFile(const char *pszFileToSplit, RTCList<RTCString> &rVecSplitFiles) RT_NOEXCEPT;
477
478 /**
479 * Splits up the given editor output into sub-files and writes them out with the
480 * auxilary path base as prefix.
481 *
482 * The source file contains @@VBOX_SPLITTER_START[filename]@@ and
483 * @@VBOX_SPLITTER_END[filename]@@ markup that is used to split it up. Any
484 * text between END and START tags are ignored and can be used for comments.
485 *
486 * @returns COM status code (error info set).
487 * @param pEditor The editor which output should be split.
488 * @param rVecSplitFiles Vector where names of the sub-files are appended
489 * (without any path or prefix).
490 */
491 HRESULT splitFile(BaseTextScript *pEditor, RTCList<RTCString> &rVecSplitFiles) RT_NOEXCEPT;
492
493 HRESULT splitFileInner(const char *pszFileToSplit, RTCList<RTCString> &rVecSplitFiles,
494 const char *pszSrc, size_t cbLeft) RT_NOEXCEPT;
495
496 static int patchTestCfg(uint8_t *pbFile, size_t cbFile, const char *pszFilename, UnattendedOs2Installer *pThis);
497 static int patchOs2Ldr(uint8_t *pbFile, size_t cbFile, const char *pszFilename, UnattendedOs2Installer *pThis);
498
499 /** The OS2SE20.SRC path ("\\OS2IMAGES"). */
500 Utf8Str mStrOs2Images;
501 /** Files split out from os2_response_files.rsp (bare filenames, no paths). */
502 RTCList<RTCString> mVecSplitFiles;
503};
504
505
506
507/**
508 * Base class for the unattended linux installers.
509 */
510class UnattendedLinuxInstaller : public UnattendedInstaller
511{
512protected:
513 /** Array of linux parameter patterns that should be removed by editIsoLinuxCfg.
514 * The patterns are proceed by RTStrSimplePatternNMatch. */
515 RTCList<RTCString, RTCString *> mArrStrRemoveInstallKernelParameters;
516
517public:
518 DECLARE_TRANSLATE_METHODS(UnattendedLinuxInstaller)
519
520 UnattendedLinuxInstaller(Unattended *pParent,
521 const char *pszMainScriptTemplateName, const char *pszPostScriptTemplateName,
522 const char *pszMainScriptFilename, const char *pszPostScriptFilename = "vboxpostinstall.sh")
523 : UnattendedInstaller(pParent,
524 pszMainScriptTemplateName, pszPostScriptTemplateName,
525 pszMainScriptFilename, pszPostScriptFilename) {}
526 ~UnattendedLinuxInstaller() {}
527
528 bool isAuxiliaryIsoNeeded() const { return true; }
529
530protected:
531 /**
532 * Performs basic edits on a isolinux.cfg file.
533 *
534 * @returns COM status code
535 * @param pEditor Editor with the isolinux.cfg file loaded and parsed.
536 */
537 virtual HRESULT editIsoLinuxCfg(GeneralTextScript *pEditor);
538 /**
539 * Performs basic common edits on a isolinux.cfg and menu configuration file(s) (txt.cfg or menu.cfg etc).
540 *
541 * @returns COM status code
542 * @param pEditor Editor with the isolinux.cfg file loaded and parsed.
543 */
544 virtual HRESULT editIsoLinuxCommon(GeneralTextScript *pEditor);
545};
546
547
548/**
549 * Debian installer.
550 *
551 * This will remaster the orignal ISO and therefore be producing a .viso-file.
552 */
553class UnattendedDebianInstaller : public UnattendedLinuxInstaller
554{
555public:
556 DECLARE_TRANSLATE_METHODS(UnattendedDebianInstaller)
557
558 UnattendedDebianInstaller(Unattended *pParent,
559 const char *pszMainScriptTemplateName = "debian_preseed.cfg",
560 const char *pszPostScriptTemplateName = "debian_postinstall.sh",
561 const char *pszMainScriptFilename = "preseed.cfg")
562 : UnattendedLinuxInstaller(pParent, pszMainScriptTemplateName, pszPostScriptTemplateName, pszMainScriptFilename)
563 {
564 Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded());
565 Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO());
566 mStrDefaultExtraInstallKernelParameters.setNull();
567 mStrDefaultExtraInstallKernelParameters += " auto=true";
568 mStrDefaultExtraInstallKernelParameters.append(" preseed/file=/cdrom/").append(pszMainScriptFilename);
569 mStrDefaultExtraInstallKernelParameters += " priority=critical";
570 mStrDefaultExtraInstallKernelParameters += " quiet";
571 mStrDefaultExtraInstallKernelParameters += " splash";
572 mStrDefaultExtraInstallKernelParameters += " noprompt"; /* no questions about things like CD/DVD ejections */
573 mStrDefaultExtraInstallKernelParameters += " noshell"; /* No shells on VT1-3 (debian, not ubuntu). */
574 mStrDefaultExtraInstallKernelParameters += " automatic-ubiquity"; // ubiquity
575 // the following can probably go into the preseed.cfg:
576 mStrDefaultExtraInstallKernelParameters.append(" debian-installer/locale=").append(pParent->i_getLocale());
577 mStrDefaultExtraInstallKernelParameters += " keyboard-configuration/layoutcode=us";
578 mStrDefaultExtraInstallKernelParameters += " languagechooser/language-name=English"; /** @todo fixme */
579 mStrDefaultExtraInstallKernelParameters.append(" localechooser/supported-locales=").append(pParent->i_getLocale()).append(".UTF-8");
580 mStrDefaultExtraInstallKernelParameters.append(" countrychooser/shortlist=").append(pParent->i_getCountry()); // ubiquity?
581 mStrDefaultExtraInstallKernelParameters += " --";
582 }
583 ~UnattendedDebianInstaller() {}
584
585 bool isOriginalIsoNeeded() const { return false; }
586
587protected:
588 HRESULT addFilesToAuxVisoVectors(RTCList<RTCString> &rVecArgs, RTCList<RTCString> &rVecFiles,
589 RTVFS hVfsOrgIso, bool fOverwrite);
590 /**
591 * Performs basic edits on menu configuration file(s) of isolinux (txt.cfg or menu.cfg etc).
592 *
593 * @returns COM status code
594 * @param pEditor Editor with the menu config. file loaded and parsed.
595 */
596 HRESULT editDebianMenuCfg(GeneralTextScript *pEditor);
597 /**
598 * Performs basic edits on grub configuration file (grub.cfg).
599 *
600 * @returns COM status code
601 * @param pEditor Editor with the grub.cfg file loaded and parsed.
602 */
603 HRESULT editDebianGrubCfg(GeneralTextScript *pEditor);
604
605 /**
606 * Performs basic edits on a isolinux.cfg file.
607 *
608 * @returns COM status code
609 * @param pEditor Editor with the isolinux.cfg file loaded and parsed.
610 * @param pszMenuConfigFileName Name of the menu config file to include in isolinux.txt. On Debians (at least)
611 it includes the kernel command line with our preseed file and command line argument.
612 */
613 virtual HRESULT editIsoLinuxCfg(GeneralTextScript *pEditor, const char *pszMenuConfigFileName);
614};
615
616
617/**
618 * Ubuntu installer (same as debian, except for the template).
619 */
620class UnattendedUbuntuInstaller : public UnattendedDebianInstaller
621{
622public:
623 DECLARE_TRANSLATE_METHODS(UnattendedUbuntuInstaller)
624
625 UnattendedUbuntuInstaller(Unattended *pParent)
626 : UnattendedDebianInstaller(pParent, "ubuntu_preseed.cfg")
627 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
628 ~UnattendedUbuntuInstaller() {}
629};
630
631
632/**
633 * RHEL 6 installer.
634 *
635 * This serves as a base for the kickstart based installers.
636 */
637class UnattendedRhel6Installer : public UnattendedLinuxInstaller
638{
639public:
640 DECLARE_TRANSLATE_METHODS(UnattendedRhel6Installer)
641
642 UnattendedRhel6Installer(Unattended *pParent,
643 const char *pszMainScriptTemplateName = "redhat67_ks.cfg",
644 const char *pszPostScriptTemplateName = "redhat_postinstall.sh",
645 const char *pszMainScriptFilename = "ks.cfg")
646 : UnattendedLinuxInstaller(pParent, pszMainScriptTemplateName, pszPostScriptTemplateName, pszMainScriptFilename)
647 {
648 Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded());
649 Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO());
650 mStrDefaultExtraInstallKernelParameters.assign(" ks=cdrom:/").append(pszMainScriptFilename).append(' ');
651 mArrStrRemoveInstallKernelParameters.append("rd.live.check"); /* Disables the checkisomd5 step. Required for VISO. */
652 }
653 ~UnattendedRhel6Installer() {}
654
655 bool isAuxiliaryIsoIsVISO() { return true; }
656 bool isOriginalIsoNeeded() const { return false; }
657
658protected:
659 HRESULT addFilesToAuxVisoVectors(RTCList<RTCString> &rVecArgs, RTCList<RTCString> &rVecFiles,
660 RTVFS hVfsOrgIso, bool fOverwrite);
661};
662
663/**
664 * RHEL 7 installer (same as RHEL 6).
665 * The class was added for better handling any possible subtle difference between RHEL6 and RHEL7.
666 */
667class UnattendedRhel7Installer : public UnattendedRhel6Installer
668{
669public:
670 DECLARE_TRANSLATE_METHODS(UnattendedRhel7Installer)
671
672 UnattendedRhel7Installer(Unattended *pParent)
673 : UnattendedRhel6Installer(pParent)
674 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
675
676 UnattendedRhel7Installer(Unattended *pParent,
677 const char *pszMainScriptTemplateName,
678 const char *pszPostScriptTemplateName,
679 const char *pszMainScriptFilename)
680 : UnattendedRhel6Installer(pParent, pszMainScriptTemplateName, pszPostScriptTemplateName, pszMainScriptFilename)
681 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
682 ~UnattendedRhel7Installer() {}
683};
684
685
686/**
687 * RHEL 8 installer (same as RHEL 7).
688 * The class was added for better handling any possible subtle difference between RHEL7 and RHEL8.
689 */
690class UnattendedRhel8Installer : public UnattendedRhel7Installer
691{
692public:
693 DECLARE_TRANSLATE_METHODS(UnattendedRhel8Installer)
694
695 UnattendedRhel8Installer(Unattended *pParent)
696 : UnattendedRhel7Installer(pParent)
697 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
698
699 UnattendedRhel8Installer(Unattended *pParent,
700 const char *pszMainScriptTemplateName,
701 const char *pszPostScriptTemplateName,
702 const char *pszMainScriptFilename)
703 : UnattendedRhel7Installer(pParent, pszMainScriptTemplateName, pszPostScriptTemplateName, pszMainScriptFilename)
704 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
705 ~UnattendedRhel8Installer() {}
706};
707
708
709/**
710 * RHEL 5 installer (same as RHEL 6, except for the kickstart template).
711 */
712class UnattendedRhel5Installer : public UnattendedRhel6Installer
713{
714public:
715 DECLARE_TRANSLATE_METHODS(UnattendedRhel5Installer)
716
717 UnattendedRhel5Installer(Unattended *pParent) : UnattendedRhel6Installer(pParent, "rhel5_ks.cfg") {}
718 ~UnattendedRhel5Installer() {}
719};
720
721
722/**
723 * RHEL 4 installer (same as RHEL 6, except for the kickstart template).
724 */
725class UnattendedRhel4Installer : public UnattendedRhel6Installer
726{
727public:
728 DECLARE_TRANSLATE_METHODS(UnattendedRhel4Installer)
729
730 UnattendedRhel4Installer(Unattended *pParent) : UnattendedRhel6Installer(pParent, "rhel4_ks.cfg") {}
731 ~UnattendedRhel4Installer() {}
732};
733
734
735/**
736 * RHEL 3 installer (same as RHEL 6, except for the kickstart template).
737 */
738class UnattendedRhel3Installer : public UnattendedRhel6Installer
739{
740public:
741 DECLARE_TRANSLATE_METHODS(UnattendedRhel3Installer)
742
743 UnattendedRhel3Installer(Unattended *pParent) : UnattendedRhel6Installer(pParent, "rhel3_ks.cfg") {}
744 ~UnattendedRhel3Installer() {}
745};
746
747
748/**
749 * Fedora installer (same as RHEL 6, except for the template).
750 */
751class UnattendedFedoraInstaller : public UnattendedRhel6Installer
752{
753public:
754 DECLARE_TRANSLATE_METHODS(UnattendedFedoraInstaller)
755
756 UnattendedFedoraInstaller(Unattended *pParent)
757 : UnattendedRhel6Installer(pParent, "fedora_ks.cfg")
758 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
759 ~UnattendedFedoraInstaller() {}
760};
761
762
763/**
764 * Oracle Linux 6 installer. Same as RHEL 6, except for the templates.
765 * The reason of adding new class is to sepatate the RHEL from OL.
766 */
767class UnattendedOracleLinux6Installer : public UnattendedRhel6Installer
768{
769public:
770 DECLARE_TRANSLATE_METHODS(UnattendedOracleLinux6Installer)
771
772 UnattendedOracleLinux6Installer(Unattended *pParent,
773 const char *pszMainScriptTemplateName = "ol_ks.cfg",
774 const char *pszPostScriptTemplateName = "ol_postinstall.sh",
775 const char *pszMainScriptFilename = "ks.cfg")
776 : UnattendedRhel6Installer(pParent, pszMainScriptTemplateName, pszPostScriptTemplateName, pszMainScriptFilename)
777 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
778 ~UnattendedOracleLinux6Installer() {}
779};
780
781
782/**
783 * Oracle Linux 7 installer. Same as OL 6.
784 * The class was added for better handling any possible subtle difference between OL6 and OL7.
785 */
786class UnattendedOracleLinux7Installer : public UnattendedOracleLinux6Installer
787{
788public:
789 DECLARE_TRANSLATE_METHODS(UnattendedOracleLinux7Installer)
790
791 UnattendedOracleLinux7Installer(Unattended *pParent)
792 : UnattendedOracleLinux6Installer(pParent)
793 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
794
795 UnattendedOracleLinux7Installer(Unattended *pParent,
796 const char *pszMainScriptTemplateName,
797 const char *pszPostScriptTemplateName,
798 const char *pszMainScriptFilename)
799 : UnattendedOracleLinux6Installer(pParent, pszMainScriptTemplateName, pszPostScriptTemplateName, pszMainScriptFilename)
800 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
801 ~UnattendedOracleLinux7Installer() {}
802};
803
804
805/**
806 * Oracle Linux 8 installer. Same as OL 7.
807 * The class was added for better handling any possible subtle difference between OL7 and OL8.
808 */
809class UnattendedOracleLinux8Installer : public UnattendedOracleLinux7Installer
810{
811public:
812 DECLARE_TRANSLATE_METHODS(UnattendedOracleLinux8Installer)
813
814 UnattendedOracleLinux8Installer(Unattended *pParent)
815 : UnattendedOracleLinux7Installer(pParent)
816 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
817
818 UnattendedOracleLinux8Installer(Unattended *pParent,
819 const char *pszMainScriptTemplateName,
820 const char *pszPostScriptTemplateName,
821 const char *pszMainScriptFilename)
822 : UnattendedOracleLinux7Installer(pParent, pszMainScriptTemplateName, pszPostScriptTemplateName, pszMainScriptFilename)
823 { Assert(!isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(isAuxiliaryIsoIsVISO()); }
824 ~UnattendedOracleLinux8Installer() {}
825};
826
827#if 0 /* fixme */
828/**
829 * SUSE linux installer.
830 *
831 * @todo needs fixing.
832 */
833class UnattendedSuseInstaller : public UnattendedLinuxInstaller
834{
835public:
836 DECLARE_TRANSLATE_METHODS(UnattendedSuseInstaller)
837
838 UnattendedSuseInstaller(BaseTextScript *pAlg, Unattended *pParent)
839 : UnattendedLinuxInstaller(pAlg, pParent, "suse_autoinstall.xml")
840 { Assert(isOriginalIsoNeeded()); Assert(isAuxiliaryIsoNeeded()); Assert(!isAuxiliaryFloppyNeeded()); Assert(!isAuxiliaryIsoIsVISO()); }
841 ~UnattendedSuseInstaller() {}
842
843 HRESULT setupScriptOnAuxiliaryCD(const Utf8Str &path);
844};
845#endif
846
847/**
848 * Base class for the unattended FreeBSD installers.
849 */
850class UnattendedFreeBsdInstaller : public UnattendedInstaller
851{
852public:
853 UnattendedFreeBsdInstaller(Unattended *pParent)
854 : UnattendedInstaller(pParent,
855 "freebsd_installer.cfg", "freebsd_postinstall.sh",
856 "installerconfig", "vboxpostinstall.sh") {}
857 ~UnattendedFreeBsdInstaller() {}
858
859 bool isAuxiliaryIsoNeeded() const { return true; }
860 bool isOriginalIsoNeeded() const { return false; }
861
862protected:
863 HRESULT addFilesToAuxVisoVectors(RTCList<RTCString> &rVecArgs, RTCList<RTCString> &rVecFiles,
864 RTVFS hVfsOrgIso, bool fOverwrite);
865};
866
867#endif /* !MAIN_INCLUDED_UnattendedInstaller_h */
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