1 | #!/usr/bin/python
|
---|
2 | #
|
---|
3 | # Copyright (C) 2012 Oracle Corporation
|
---|
4 | #
|
---|
5 | # This file is part of VirtualBox Open Source Edition (OSE), as
|
---|
6 | # available from http://www.virtualbox.org. This file is free software;
|
---|
7 | # you can redistribute it and/or modify it under the terms of the GNU
|
---|
8 | # General Public License (GPL) as published by the Free Software
|
---|
9 | # Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
10 | # VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
11 | # hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
12 | #
|
---|
13 | # Things needed to be set up before running this sample:
|
---|
14 | # - Install Python and verify it works (2.7.2 will do, 3.x is untested yet)
|
---|
15 | # - On Windows: Install the PyWin32 extensions for your Python version
|
---|
16 | # (see http://sourceforge.net/projects/pywin32/)
|
---|
17 | # - If not already done, set the environment variable "VBOX_INSTALL_PATH"
|
---|
18 | # to point to your VirtualBox installation directory (which in turn must have
|
---|
19 | # the "sdk" subfolder")
|
---|
20 | # - Install the VirtualBox Python bindings by doing a
|
---|
21 | # "[python] vboxapisetup.py install"
|
---|
22 | # - Run this sample with "[python] clienttest.py"
|
---|
23 |
|
---|
24 | import os,sys
|
---|
25 | import traceback
|
---|
26 |
|
---|
27 | #
|
---|
28 | # Converts an enumeration to a printable string.
|
---|
29 | #
|
---|
30 | def enumToString(constants, enum, elem):
|
---|
31 | all = constants.all_values(enum)
|
---|
32 | for e in all.keys():
|
---|
33 | if str(elem) == str(all[e]):
|
---|
34 | return e
|
---|
35 | return "<unknown>"
|
---|
36 |
|
---|
37 | def main(argv):
|
---|
38 |
|
---|
39 | from vboxapi import VirtualBoxManager
|
---|
40 | # This is a VirtualBox COM/XPCOM API client, no data needed.
|
---|
41 | wrapper = VirtualBoxManager(None, None)
|
---|
42 |
|
---|
43 | # Get the VirtualBox manager
|
---|
44 | mgr = wrapper.mgr
|
---|
45 | # Get the global VirtualBox object
|
---|
46 | vbox = wrapper.vbox
|
---|
47 |
|
---|
48 | print "Running VirtualBox version %s" %(vbox.version)
|
---|
49 |
|
---|
50 | # Get all constants through the Python wrapper code
|
---|
51 | vboxConstants = wrapper.constants
|
---|
52 |
|
---|
53 | # Enumerate all defined machines
|
---|
54 | for mach in wrapper.getArray(vbox, 'machines'):
|
---|
55 |
|
---|
56 | try:
|
---|
57 | # Be prepared for failures - the VM can be inaccessible
|
---|
58 | vmname = '<inaccessible>'
|
---|
59 | try:
|
---|
60 | vmname = mach.name
|
---|
61 | except Exception, e:
|
---|
62 | None
|
---|
63 | vmid = '';
|
---|
64 | try:
|
---|
65 | vmid = mach.id
|
---|
66 | except Exception, e:
|
---|
67 | None
|
---|
68 |
|
---|
69 | # Print some basic VM information even if there were errors
|
---|
70 | print "Machine name: %s [%s]" %(vmname,vmid)
|
---|
71 | if vmname == '<inaccessible>' or vmid == '':
|
---|
72 | continue
|
---|
73 |
|
---|
74 | # Print some basic VM information
|
---|
75 | print " State: %s" %(enumToString(vboxConstants, "MachineState", mach.state))
|
---|
76 | print " Session state: %s" %(enumToString(vboxConstants, "SessionState", mach.sessionState))
|
---|
77 |
|
---|
78 | # Do some stuff which requires a running VM
|
---|
79 | if mach.state == vboxConstants.MachineState_Running:
|
---|
80 |
|
---|
81 | # Get the session object
|
---|
82 | session = mgr.getSessionObject(vbox)
|
---|
83 |
|
---|
84 | # Lock the current machine (shared mode, since we won't modify the machine)
|
---|
85 | mach.lockMachine(session, vboxConstants.LockType_Shared)
|
---|
86 |
|
---|
87 | # Acquire the VM's console and guest object
|
---|
88 | console = session.console
|
---|
89 | guest = console.guest
|
---|
90 |
|
---|
91 | # Retrieve the current Guest Additions runlevel and print
|
---|
92 | # the installed Guest Additions version
|
---|
93 | addRunLevel = guest.additionsRunLevel
|
---|
94 | print " Additions State: %s" %(enumToString(vboxConstants, "AdditionsRunLevelType", addRunLevel))
|
---|
95 | if addRunLevel != vboxConstants.AdditionsRunLevelType_None:
|
---|
96 | print " Additions Ver: %s" %(guest.additionsVersion)
|
---|
97 |
|
---|
98 | # Get the VM's display object
|
---|
99 | display = console.display
|
---|
100 |
|
---|
101 | # Get the VM's current display resolution + bit depth + position
|
---|
102 | screenNum = 0 # From first screen
|
---|
103 | (screenW, screenH, screenBPP, screenX, screenY) = display.getScreenResolution(screenNum)
|
---|
104 | print " Display (%d): %dx%d, %d BPP at %d,%d" %(screenNum, screenW, screenH, screenBPP, screenX, screenY)
|
---|
105 |
|
---|
106 | # We're done -- don't forget to unlock the machine!
|
---|
107 | session.unlockMachine()
|
---|
108 |
|
---|
109 | except Exception, e:
|
---|
110 | print "Errror [%s]: %s" %(mach.name, str(e))
|
---|
111 | traceback.print_exc()
|
---|
112 |
|
---|
113 | # Call destructor and delete wrapper
|
---|
114 | del wrapper
|
---|
115 |
|
---|
116 | if __name__ == '__main__':
|
---|
117 | main(sys.argv)
|
---|