VirtualBox

source: vbox/trunk/src/VBox/Main/include/ApplianceImpl.h@ 82820

Last change on this file since 82820 was 81369, checked in by vboxsync, 5 years ago

*: doxygen fixes

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 13.8 KB
Line 
1/* $Id: ApplianceImpl.h 81369 2019-10-18 21:13:03Z vboxsync $ */
2/** @file
3 * VirtualBox COM class implementation
4 */
5
6/*
7 * Copyright (C) 2006-2019 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_ApplianceImpl_h
19#define MAIN_INCLUDED_ApplianceImpl_h
20#ifndef RT_WITHOUT_PRAGMA_ONCE
21# pragma once
22#endif
23
24/* VBox includes */
25#include "VirtualSystemDescriptionWrap.h"
26#include "ApplianceWrap.h"
27#include "MediumFormatImpl.h"
28
29/** @todo This file needs massive cleanup. Split IAppliance in a public and
30 * private classes. */
31#include <iprt/tar.h>
32#include "ovfreader.h"
33#include <set>
34
35/* VBox forward declarations */
36class Certificate;
37class Progress;
38class VirtualSystemDescription;
39struct VirtualSystemDescriptionEntry;
40struct LocationInfo;
41typedef struct VDINTERFACE *PVDINTERFACE;
42typedef struct VDINTERFACEIO *PVDINTERFACEIO;
43typedef struct SHASTORAGE *PSHASTORAGE;
44
45namespace ovf
46{
47 struct HardDiskController;
48 struct VirtualSystem;
49 class OVFReader;
50 struct DiskImage;
51 struct EnvelopeData;
52}
53
54namespace xml
55{
56 class Document;
57 class ElementNode;
58}
59
60namespace settings
61{
62 class MachineConfigFile;
63}
64
65class ATL_NO_VTABLE Appliance :
66 public ApplianceWrap
67{
68public:
69
70 DECLARE_EMPTY_CTOR_DTOR(Appliance)
71
72 HRESULT FinalConstruct();
73 void FinalRelease();
74
75
76 HRESULT init(VirtualBox *aVirtualBox);
77 void uninit();
78
79 /* public methods only for internal purposes */
80
81 static HRESULT i_setErrorStatic(HRESULT aResultCode,
82 const Utf8Str &aText)
83 {
84 return setErrorInternal(aResultCode, getStaticClassIID(), getStaticComponentName(), aText, false, true);
85 }
86
87 /* private instance data */
88private:
89 // wrapped IAppliance properties
90 HRESULT getPath(com::Utf8Str &aPath);
91 HRESULT getDisks(std::vector<com::Utf8Str> &aDisks);
92 HRESULT getCertificate(ComPtr<ICertificate> &aCertificateInfo);
93 HRESULT getVirtualSystemDescriptions(std::vector<ComPtr<IVirtualSystemDescription> > &aVirtualSystemDescriptions);
94 HRESULT getMachines(std::vector<com::Utf8Str> &aMachines);
95
96 // wrapped IAppliance methods
97 HRESULT read(const com::Utf8Str &aFile,
98 ComPtr<IProgress> &aProgress);
99 HRESULT interpret();
100 HRESULT importMachines(const std::vector<ImportOptions_T> &aOptions,
101 ComPtr<IProgress> &aProgress);
102 HRESULT createVFSExplorer(const com::Utf8Str &aURI,
103 ComPtr<IVFSExplorer> &aExplorer);
104 HRESULT write(const com::Utf8Str &aFormat,
105 const std::vector<ExportOptions_T> &aOptions,
106 const com::Utf8Str &aPath,
107 ComPtr<IProgress> &aProgress);
108 HRESULT getWarnings(std::vector<com::Utf8Str> &aWarnings);
109 HRESULT getPasswordIds(std::vector<com::Utf8Str> &aIdentifiers);
110 HRESULT getMediumIdsForPasswordId(const com::Utf8Str &aPasswordId, std::vector<com::Guid> &aIdentifiers);
111 HRESULT addPasswords(const std::vector<com::Utf8Str> &aIdentifiers,
112 const std::vector<com::Utf8Str> &aPasswords);
113 HRESULT createVirtualSystemDescriptions(ULONG aRequested, ULONG *aCreated);
114 /** weak VirtualBox parent */
115 VirtualBox* const mVirtualBox;
116
117 struct ImportStack;
118 class TaskOVF;
119 class TaskOPC;
120 class TaskCloud;
121
122 struct Data; // opaque, defined in ApplianceImpl.cpp
123 Data *m;
124
125 enum SetUpProgressMode { ImportFile, ImportS3, WriteFile, WriteS3, ExportCloud, ImportCloud };
126
127 enum ApplianceState { ApplianceIdle, ApplianceImporting, ApplianceExporting };
128 void i_setApplianceState(const ApplianceState &state);
129 /** @name General stuff
130 * @{
131 */
132 bool i_isApplianceIdle();
133 HRESULT i_searchUniqueVMName(Utf8Str& aName) const;
134 HRESULT i_searchUniqueImageFilePath(const Utf8Str &aMachineFolder,
135 DeviceType_T aDeviceType,
136 Utf8Str &aName) const;
137 HRESULT i_setUpProgress(ComObjPtr<Progress> &pProgress,
138 const Utf8Str &strDescription,
139 SetUpProgressMode mode);
140 void i_addWarning(const char* aWarning, ...);
141 void i_disksWeight();
142 void i_parseBucket(Utf8Str &aPath, Utf8Str &aBucket);
143
144 static void i_importOrExportThreadTask(TaskOVF *pTask);
145 static void i_exportOPCThreadTask(TaskOPC *pTask);
146 static void i_importOrExportCloudThreadTask(TaskCloud *pTask);
147
148 HRESULT i_initBackendNames();
149
150 Utf8Str i_typeOfVirtualDiskFormatFromURI(Utf8Str type) const;
151
152#if 0 /* unused */
153 std::set<Utf8Str> i_URIFromTypeOfVirtualDiskFormat(Utf8Str type);
154#endif
155
156 HRESULT i_findMediumFormatFromDiskImage(const ovf::DiskImage &di, ComObjPtr<MediumFormat>& mf);
157
158 RTVFSIOSTREAM i_manifestSetupDigestCalculationForGivenIoStream(RTVFSIOSTREAM hVfsIos, const char *pszManifestEntry,
159 bool fRead = true);
160 /** @} */
161
162 /** @name Read stuff
163 * @{
164 */
165 HRESULT i_readImpl(const LocationInfo &aLocInfo, ComObjPtr<Progress> &aProgress);
166
167 HRESULT i_readFS(TaskOVF *pTask);
168 HRESULT i_readFSOVF(TaskOVF *pTask);
169 HRESULT i_readFSOVA(TaskOVF *pTask);
170 HRESULT i_readOVFFile(TaskOVF *pTask, RTVFSIOSTREAM hIosOvf, const char *pszManifestEntry);
171 HRESULT i_readManifestFile(TaskOVF *pTask, RTVFSIOSTREAM hIosMf, const char *pszSubFileNm);
172 HRESULT i_readSignatureFile(TaskOVF *pTask, RTVFSIOSTREAM hIosCert, const char *pszSubFileNm);
173 HRESULT i_readTailProcessing(TaskOVF *pTask);
174 HRESULT i_gettingCloudData(TaskCloud *pTask);
175
176 /** @} */
177
178 /** @name Import stuff
179 * @{
180 */
181 HRESULT i_importImpl(const LocationInfo &aLocInfo, ComObjPtr<Progress> &aProgress);
182
183 HRESULT i_importFS(TaskOVF *pTask);
184 HRESULT i_importFSOVF(TaskOVF *pTask, AutoWriteLockBase &rWriteLock);
185 HRESULT i_importFSOVA(TaskOVF *pTask, AutoWriteLockBase &rWriteLock);
186 HRESULT i_importDoIt(TaskOVF *pTask, AutoWriteLockBase &rWriteLock, RTVFSFSSTREAM hVfsFssOva = NIL_RTVFSFSSTREAM);
187
188 HRESULT i_verifyManifestFile(ImportStack &stack);
189
190 void i_convertDiskAttachmentValues(const ovf::HardDiskController &hdc,
191 uint32_t ulAddressOnParent,
192 Utf8Str &controllerName,
193 int32_t &lControllerPort,
194 int32_t &lDevice);
195
196 void i_importOneDiskImage(const ovf::DiskImage &di,
197 const Utf8Str &strDstPath,
198 ComObjPtr<Medium> &pTargetMedium,
199 ImportStack &stack);
200
201 void i_importMachineGeneric(const ovf::VirtualSystem &vsysThis,
202 ComObjPtr<VirtualSystemDescription> &vsdescThis,
203 ComPtr<IMachine> &pNewMachine,
204 ImportStack &stack);
205 void i_importVBoxMachine(ComObjPtr<VirtualSystemDescription> &vsdescThis,
206 ComPtr<IMachine> &pNewMachine,
207 ImportStack &stack);
208 void i_importMachines(ImportStack &stack);
209
210 HRESULT i_preCheckImageAvailability(ImportStack &stack);
211 bool i_importEnsureOvaLookAhead(ImportStack &stack);
212 RTVFSIOSTREAM i_importOpenSourceFile(ImportStack &stack, Utf8Str const &rstrSrcPath, const char *pszManifestEntry);
213 HRESULT i_importCreateAndWriteDestinationFile(Utf8Str const &rstrDstPath,
214 RTVFSIOSTREAM hVfsIosSrc, Utf8Str const &rstrSrcLogNm);
215
216 void i_importCopyFile(ImportStack &stack, Utf8Str const &rstrSrcPath, Utf8Str const &rstrDstPath,
217 const char *pszManifestEntry);
218 void i_importDecompressFile(ImportStack &stack, Utf8Str const &rstrSrcPath, Utf8Str const &rstrDstPath,
219 const char *pszManifestEntry);
220 HRESULT i_importCloudImpl(TaskCloud *pTask);
221 /** @} */
222
223 /** @name Write stuff
224 * @{
225 */
226 HRESULT i_writeImpl(ovf::OVFVersion_T aFormat, const LocationInfo &aLocInfo, ComObjPtr<Progress> &aProgress);
227 HRESULT i_writeOPCImpl(ovf::OVFVersion_T aFormat, const LocationInfo &aLocInfo, ComObjPtr<Progress> &aProgress);
228 HRESULT i_writeCloudImpl(const LocationInfo &aLocInfo, ComObjPtr<Progress> &aProgress);
229
230 HRESULT i_writeFS(TaskOVF *pTask);
231 HRESULT i_writeFSOVF(TaskOVF *pTask, AutoWriteLockBase& writeLock);
232 HRESULT i_writeFSOVA(TaskOVF *pTask, AutoWriteLockBase& writeLock);
233 HRESULT i_writeFSOPC(TaskOPC *pTask);
234 HRESULT i_exportCloudImpl(TaskCloud *pTask);
235 HRESULT i_writeFSImpl(TaskOVF *pTask, AutoWriteLockBase &writeLock, RTVFSFSSTREAM hVfsFssDst);
236 HRESULT i_writeBufferToFile(RTVFSFSSTREAM hVfsFssDst, const char *pszFilename, const void *pvContent, size_t cbContent);
237
238 struct XMLStack;
239
240 void i_buildXML(AutoWriteLockBase& writeLock,
241 xml::Document &doc,
242 XMLStack &stack,
243 const Utf8Str &strPath,
244 ovf::OVFVersion_T enFormat);
245 void i_buildXMLForOneVirtualSystem(AutoWriteLockBase& writeLock,
246 xml::ElementNode &elmToAddVirtualSystemsTo,
247 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes,
248 ComObjPtr<VirtualSystemDescription> &vsdescThis,
249 ovf::OVFVersion_T enFormat,
250 XMLStack &stack);
251 /** @} */
252
253 friend class Machine;
254 friend class Certificate;
255};
256
257void i_parseURI(Utf8Str strUri, LocationInfo &locInfo);
258
259struct VirtualSystemDescriptionEntry
260{
261 uint32_t ulIndex; ///< zero-based index of this entry within array
262 VirtualSystemDescriptionType_T type; ///< type of this entry
263 Utf8Str strRef; ///< reference number (hard disk controllers only)
264 Utf8Str strOvf; ///< original OVF value (type-dependent)
265 Utf8Str strVBoxSuggested; ///< configuration value (type-dependent); original value suggested by interpret()
266 Utf8Str strVBoxCurrent; ///< configuration value (type-dependent); current value, either from interpret() or setFinalValue()
267 Utf8Str strExtraConfigSuggested; ///< extra configuration key=value strings (type-dependent); original value suggested by interpret()
268 Utf8Str strExtraConfigCurrent; ///< extra configuration key=value strings (type-dependent); current value, either from interpret() or setFinalValue()
269
270 uint32_t ulSizeMB; ///< hard disk images only: a copy of ovf::DiskImage::ulSuggestedSizeMB
271 bool skipIt; ///< used during export to skip some parts if it's needed
272};
273
274class ATL_NO_VTABLE VirtualSystemDescription :
275 public VirtualSystemDescriptionWrap
276{
277 friend class Appliance;
278
279public:
280
281 DECLARE_EMPTY_CTOR_DTOR(VirtualSystemDescription)
282
283 HRESULT FinalConstruct();
284 void FinalRelease();
285
286 HRESULT init();
287 void uninit();
288
289 /* public methods only for internal purposes */
290 void i_addEntry(VirtualSystemDescriptionType_T aType,
291 const Utf8Str &strRef,
292 const Utf8Str &aOvfValue,
293 const Utf8Str &aVBoxValue,
294 uint32_t ulSizeMB = 0,
295 const Utf8Str &strExtraConfig = "");
296
297 std::list<VirtualSystemDescriptionEntry*> i_findByType(VirtualSystemDescriptionType_T aType);
298 const VirtualSystemDescriptionEntry* i_findControllerFromID(uint32_t id);
299
300 void i_importVBoxMachineXML(const xml::ElementNode &elmMachine);
301 const settings::MachineConfigFile* i_getMachineConfig() const;
302
303 /* private instance data */
304private:
305
306 // wrapped IVirtualSystemDescription properties
307 HRESULT getCount(ULONG *aCount);
308
309 // wrapped IVirtualSystemDescription methods
310 HRESULT getDescription(std::vector<VirtualSystemDescriptionType_T> &aTypes,
311 std::vector<com::Utf8Str> &aRefs,
312 std::vector<com::Utf8Str> &aOVFValues,
313 std::vector<com::Utf8Str> &aVBoxValues,
314 std::vector<com::Utf8Str> &aExtraConfigValues);
315 HRESULT getDescriptionByType(VirtualSystemDescriptionType_T aType,
316 std::vector<VirtualSystemDescriptionType_T> &aTypes,
317 std::vector<com::Utf8Str> &aRefs,
318 std::vector<com::Utf8Str> &aOVFValues,
319 std::vector<com::Utf8Str> &aVBoxValues,
320 std::vector<com::Utf8Str> &aExtraConfigValues);
321 HRESULT getValuesByType(VirtualSystemDescriptionType_T aType,
322 VirtualSystemDescriptionValueType_T aWhich,
323 std::vector<com::Utf8Str> &aValues);
324 HRESULT setFinalValues(const std::vector<BOOL> &aEnabled,
325 const std::vector<com::Utf8Str> &aVBoxValues,
326 const std::vector<com::Utf8Str> &aExtraConfigValues);
327 HRESULT addDescription(VirtualSystemDescriptionType_T aType,
328 const com::Utf8Str &aVBoxValue,
329 const com::Utf8Str &aExtraConfigValue);
330 HRESULT removeDescriptionByType(VirtualSystemDescriptionType_T aType);
331 void i_removeByType(VirtualSystemDescriptionType_T aType);
332
333 struct Data;
334 Data *m;
335
336 friend class Machine;
337};
338
339#endif /* !MAIN_INCLUDED_ApplianceImpl_h */
340/* vi: set tabstop=4 shiftwidth=4 expandtab: */
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