/* $Id: clienttest.java $ */ /*!file * Sample client for the VirtualBox web service, written in Java (raw web service variant). * * Run the VirtualBox web service server first; see the VirtualBox * SDK reference for details. * * The following license applies to this file only: */ /* * Copyright (C) 2008-2022 Oracle and/or its affiliates. * * Permission is hereby granted, free of charge, to any person * obtaining a copy of this software and associated documentation * files (the "Software"), to deal in the Software without * restriction, including without limitation the rights to use, * copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following * conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR * OTHER DEALINGS IN THE SOFTWARE. */ import org.virtualbox.www.Service.VboxService; import org.virtualbox.www.Service.VboxServiceLocator; import org.virtualbox.www.VboxPortType; public class clienttest { private VboxService _service; private VboxPortType _port; private String _oVbox; public clienttest() { try { // instantiate the webservice in instance data; the classes // VboxServiceLocator and VboxPortType have been created // by the WSDL2Java helper that you should have run prior // to compiling this example, as described in the User Manual. _service = new VboxServiceLocator(); _port = _service.getvboxServicePort(); // From now on, we can call any method in the webservice by // prefixing it with "port." // First step is always to log on to the webservice. This // returns a managed object reference to the webservice's // global instance of IVirtualBox, which in turn contains // the most important methods provided by the Main API. _oVbox = _port.IWebsessionManager_logon("", ""); // Call IVirtualBox::getVersion and print out the result String version = _port.IVirtualBox_getVersion(_oVbox); System.out.println("Initialized connection to VirtualBox version " + version); } catch (Exception e) { e.printStackTrace(); } } public void showVMs() { try { // Call IVirtualBox::getMachines, which yields an array // of managed object references to all machines which have // been registered: String[] aMachines = _port.IVirtualBox_getMachines2(_oVbox); // Walk through this array and, for each machine, call // IMachine::getName (accessor method to the "name" attribute) for (int i = 0; i < aMachines.length; i++) { String oMachine = aMachines[i]; String machinename = _port.IMachine_getName(oMachine); System.out.println("Machine " + i + ": " + oMachine + " - " + machinename); // release managed object reference _port.IManagedObjectRef_release(oMachine); } } catch (Exception e) { e.printStackTrace(); } } public void listHostInfo() { try { String oHost = _port.IVirtualBox_getHost(_oVbox); org.apache.axis.types.UnsignedInt uProcCount = _port.IHost_getProcessorCount(oHost); System.out.println("Processor count: " + uProcCount); String oCollector = _port.IVirtualBox_getPerformanceCollector(_oVbox); String aobj[] = {oHost}; String astrMetrics[] = {"*"}; String aMetrics[] = {}; aMetrics = _port.IPerformanceCollector_getMetrics(oCollector, astrMetrics, aobj); // String astrMetricNames[] = { "*" }; // String aObjects[]; // String aRetNames[]; // int aRetIndices[]; // int aRetLengths[]; // int aRetData[]; // int rc = _port.ICollector_queryMetricsData(oCollector, // aObjects, // aRetNames, // aRetObjects, // aRetIndices, // aRetLengths, // aRetData); // /* Bstr metricNames[] = { L"*" }; com::SafeArray metrics (1); metricNames[0].cloneTo (&metrics [0]); com::SafeArray retNames; com::SafeIfaceArray retObjects; com::SafeArray retIndices; com::SafeArray retLengths; com::SafeArray retData; CHECK_ERROR (collector, QueryMetricsData(ComSafeArrayAsInParam(metrics), ComSafeArrayInArg(objects), ComSafeArrayAsOutParam(retNames), ComSafeArrayAsOutParam(retObjects), ComSafeArrayAsOutParam(retIndices), ComSafeArrayAsOutParam(retLengths), ComSafeArrayAsOutParam(retData)) ); */ } catch (Exception e) { e.printStackTrace(); } } public void startVM(String strVM) { String oSession = ""; Boolean fSessionOpen = false; try { // this is pretty much what VBoxManage does to start a VM String oMachine = ""; Boolean fOK = false; oSession = _port.IWebsessionManager_getSessionObject(_oVbox); // first assume we were given a UUID try { oMachine = _port.IVirtualBox_getMachine(_oVbox, strVM); fOK = true; } catch (Exception e) { } if (!fOK) { try { // or try by name oMachine = _port.IVirtualBox_findMachine(_oVbox, strVM); fOK = true; } catch (Exception e) { } } if (!fOK) { System.out.println("Error: can't find VM \"" + strVM + "\""); } else { String uuid = _port.IMachine_getId(oMachine); String sessionType = "gui"; String env = "DISPLAY=:0.0"; String oProgress = _port.IVirtualBox_openRemoteSession(_oVbox, oSession, uuid, sessionType, env); fSessionOpen = true; System.out.println("Session for VM " + uuid + " is opening..."); _port.IProgress_waitForCompletion(oProgress, 10000); int rc = _port.IProgress_getResultCode(oProgress).intValue(); if (rc != 0) { System.out.println("Session failed!"); } } } catch (Exception e) { e.printStackTrace(); } if (fSessionOpen) { try { _port.ISession_close(oSession); } catch (Exception e) { } } } public void cleanup() { try { if (_oVbox.length() > 0) { // log off _port.IWebsessionManager_logoff(_oVbox); _oVbox = null; System.out.println("Logged off."); } } catch (Exception e) { e.printStackTrace(); } } public static void printArgs() { System.out.println( "Usage: java clienttest ..." + "\nwith being:" + "\n show vms list installed virtual machines" + "\n list hostinfo list host info" + "\n startvm start the given virtual machine"); } public static void main(String[] args) { if (args.length < 1) { System.out.println("Error: Must specify at least one argument."); printArgs(); } else { clienttest c = new clienttest(); if (args[0].equals("show")) { if (args.length == 2) { if (args[1].equals("vms")) c.showVMs(); else System.out.println("Error: Unknown argument to \"show\": \"" + args[1] + "\"."); } else System.out.println("Error: Missing argument to \"show\" command"); } else if (args[0].equals("list")) { if (args.length == 2) { if (args[1].equals("hostinfo")) c.listHostInfo(); else System.out.println("Error: Unknown argument to \"show\": \"" + args[1] + "\"."); } else System.out.println("Error: Missing argument to \"show\" command"); } else if (args[0].equals("startvm")) { if (args.length == 2) { c.startVM(args[1]); } else System.out.println("Error: Missing argument to \"startvm\" command"); } else System.out.println("Error: Unknown command: \"" + args[0] + "\"."); c.cleanup(); } } }