VirtualBox

source: vbox/trunk/src/VBox/Frontends/VBoxManage/VBoxManageGuestProp.cpp@ 13305

Last change on this file since 13305 was 13294, checked in by vboxsync, 16 years ago

FE/VBoxManage: clean up an error handler

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 8.7 KB
Line 
1/** @file
2 *
3 * VBox frontends: VBoxManage (command-line interface), Guest Properties
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22
23/*******************************************************************************
24* Header Files *
25*******************************************************************************/
26
27#include <VBox/com/com.h>
28#include <VBox/com/string.h>
29#include <VBox/com/array.h>
30#include <VBox/com/ErrorInfo.h>
31
32#include <VBox/com/VirtualBox.h>
33
34#include <iprt/stream.h>
35#include <VBox/log.h>
36
37#include "VBoxManage.h"
38
39using namespace com;
40
41void usageGuestProperty(void)
42{
43 RTPrintf("VBoxManage guestproperty get <vmname>|<uuid>\n"
44 " <property> [-verbose]\n"
45 "\n");
46 RTPrintf("VBoxManage guestproperty set <vmname>|<uuid>\n"
47 " <property> [<value> [-flags <flags>]]\n"
48 "\n");
49 RTPrintf("VBoxManage guestproperty enumerate <vmname>|<uuid>\n"
50 " [-patterns <patterns>]\n"
51 "\n");
52}
53
54static int handleGetGuestProperty(int argc, char *argv[],
55 ComPtr<IVirtualBox> aVirtualBox,
56 ComPtr<ISession> aSession)
57{
58 HRESULT rc = S_OK;
59
60 bool verbose = false;
61 if ((3 == argc) && (0 == strcmp(argv[2], "-verbose")))
62 verbose = true;
63 else if (argc != 2)
64 return errorSyntax(USAGE_GUESTPROPERTY, "Incorrect parameters");
65
66 ComPtr<IMachine> machine;
67 /* assume it's a UUID */
68 rc = aVirtualBox->GetMachine(Guid(argv[0]), machine.asOutParam());
69 if (FAILED(rc) || !machine)
70 {
71 /* must be a name */
72 CHECK_ERROR(aVirtualBox, FindMachine(Bstr(argv[0]), machine.asOutParam()));
73 }
74 if (machine)
75 {
76 Guid uuid;
77 machine->COMGETTER(Id)(uuid.asOutParam());
78
79 /* open a session for the VM - new or existing */
80 if (FAILED (aVirtualBox->OpenSession(aSession, uuid)))
81 CHECK_ERROR_RET (aVirtualBox, OpenExistingSession(aSession, uuid), 1);
82
83 /* get the mutable session machine */
84 aSession->COMGETTER(Machine)(machine.asOutParam());
85
86 Bstr value;
87 uint64_t u64Timestamp;
88 Bstr flags;
89 CHECK_ERROR(machine, GetGuestProperty(Bstr(argv[1]), value.asOutParam(),
90 &u64Timestamp, flags.asOutParam()));
91 if (!value)
92 RTPrintf("No value set!\n");
93 if (value)
94 RTPrintf("Value: %lS\n", value.raw());
95 if (value && verbose)
96 {
97 RTPrintf("Timestamp: %lld\n", u64Timestamp);
98 RTPrintf("Flags: %lS\n", flags.raw());
99 }
100 }
101 return SUCCEEDED(rc) ? 0 : 1;
102}
103
104static int handleSetGuestProperty(int argc, char *argv[],
105 ComPtr<IVirtualBox> aVirtualBox,
106 ComPtr<ISession> aSession)
107{
108 HRESULT rc = S_OK;
109
110/*
111 * Check the syntax. We can deduce the correct syntax from the number of
112 * arguments.
113 */
114 bool usageOK = true;
115 const char *pszName = NULL;
116 const char *pszValue = NULL;
117 const char *pszFlags = NULL;
118 if (3 == argc)
119 {
120 pszValue = argv[2];
121 }
122 else if (4 == argc)
123 usageOK = false;
124 else if (5 == argc)
125 {
126 pszValue = argv[2];
127 if (strcmp(argv[3], "-flags") != 0)
128 usageOK = false;
129 pszFlags = argv[4];
130 }
131 else if (argc != 2)
132 usageOK = false;
133 if (!usageOK)
134 return errorSyntax(USAGE_GUESTPROPERTY, "Incorrect parameters");
135 /* This is always needed. */
136 pszName = argv[1];
137
138 ComPtr<IMachine> machine;
139 /* assume it's a UUID */
140 rc = aVirtualBox->GetMachine(Guid(argv[0]), machine.asOutParam());
141 if (FAILED(rc) || !machine)
142 {
143 /* must be a name */
144 CHECK_ERROR(aVirtualBox, FindMachine(Bstr(argv[0]), machine.asOutParam()));
145 }
146 if (machine)
147 {
148 Guid uuid;
149 machine->COMGETTER(Id)(uuid.asOutParam());
150
151 /* open a session for the VM - new or existing */
152 if (FAILED (aVirtualBox->OpenSession(aSession, uuid)))
153 CHECK_ERROR_RET (aVirtualBox, OpenExistingSession(aSession, uuid), 1);
154
155 /* get the mutable session machine */
156 aSession->COMGETTER(Machine)(machine.asOutParam());
157
158 if ((NULL == pszValue) && (NULL == pszFlags))
159 CHECK_ERROR(machine, SetGuestPropertyValue(Bstr(pszName), NULL));
160 else if (NULL == pszFlags)
161 CHECK_ERROR(machine, SetGuestPropertyValue(Bstr(pszName), Bstr(pszValue)));
162 else
163 CHECK_ERROR(machine, SetGuestProperty(Bstr(pszName), Bstr(pszValue), Bstr(pszFlags)));
164
165 if (SUCCEEDED(rc))
166 CHECK_ERROR(machine, SaveSettings());
167
168 aSession->Close();
169 }
170 return SUCCEEDED(rc) ? 0 : 1;
171}
172
173/**
174 * Enumerates the properties in the guest property store.
175 *
176 * @returns 0 on success, 1 on failure
177 * @note see the command line API description for parameters
178 */
179static int handleEnumGuestProperty(int argc, char *argv[],
180 ComPtr<IVirtualBox> aVirtualBox, ComPtr<ISession> aSession)
181{
182/*
183 * Check the syntax. We can deduce the correct syntax from the number of
184 * arguments.
185 */
186 if ((argc < 1) || (2 == argc) ||
187 ((argc > 3) && strcmp(argv[1], "-patterns") != 0))
188 return errorSyntax(USAGE_GUESTPROPERTY, "Incorrect parameters");
189
190/*
191 * Pack the patterns
192 */
193 Utf8Str Utf8Patterns(argc > 2 ? argv[2] : "");
194 for (ssize_t i = 3; i < argc; ++i)
195 Utf8Patterns = Utf8StrFmt ("%s,%s", Utf8Patterns.raw(), argv[i]);
196
197/*
198 * Make the actual call to Main.
199 */
200 ComPtr<IMachine> machine;
201 /* assume it's a UUID */
202 HRESULT rc = aVirtualBox->GetMachine(Guid(argv[0]), machine.asOutParam());
203 if (FAILED(rc) || !machine)
204 {
205 /* must be a name */
206 CHECK_ERROR(aVirtualBox, FindMachine(Bstr(argv[0]), machine.asOutParam()));
207 }
208 if (machine)
209 {
210 Guid uuid;
211 machine->COMGETTER(Id)(uuid.asOutParam());
212
213 /* open a session for the VM - new or existing */
214 if (FAILED (aVirtualBox->OpenSession(aSession, uuid)))
215 CHECK_ERROR_RET (aVirtualBox, OpenExistingSession(aSession, uuid), 1);
216
217 /* get the mutable session machine */
218 aSession->COMGETTER(Machine)(machine.asOutParam());
219
220 com::SafeArray <BSTR> names;
221 com::SafeArray <BSTR> values;
222 com::SafeArray <ULONG64> timestamps;
223 com::SafeArray <BSTR> flags;
224 CHECK_ERROR(machine, EnumerateGuestProperties(Bstr(Utf8Patterns),
225 ComSafeArrayAsOutParam(names),
226 ComSafeArrayAsOutParam(values),
227 ComSafeArrayAsOutParam(timestamps),
228 ComSafeArrayAsOutParam(flags)));
229 if (SUCCEEDED(rc))
230 {
231 if (names.size() == 0)
232 RTPrintf("No properties found.\n");
233 for (unsigned i = 0; i < names.size(); ++i)
234 RTPrintf("Name: %lS, value: %lS, timestamp: %lld, flags: %lS\n",
235 names[i], values[i], timestamps[i], flags[i]);
236 }
237 }
238 return SUCCEEDED(rc) ? 0 : 1;
239}
240
241/**
242 * Access the guest property store.
243 *
244 * @returns 0 on success, 1 on failure
245 * @note see the command line API description for parameters
246 */
247int handleGuestProperty(int argc, char *argv[],
248 ComPtr<IVirtualBox> aVirtualBox, ComPtr<ISession> aSession)
249{
250 if (0 == argc)
251 return errorSyntax(USAGE_GUESTPROPERTY, "Incorrect parameters");
252 if (0 == strcmp(argv[0], "get"))
253 return handleGetGuestProperty(argc - 1, argv + 1, aVirtualBox, aSession);
254 else if (0 == strcmp(argv[0], "set"))
255 return handleSetGuestProperty(argc - 1, argv + 1, aVirtualBox, aSession);
256 else if (0 == strcmp(argv[0], "enumerate"))
257 return handleEnumGuestProperty(argc - 1, argv + 1, aVirtualBox, aSession);
258 /* else */
259 return errorSyntax(USAGE_GUESTPROPERTY, "Incorrect parameters");
260}
261
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