mirror of
https://github.com/GNS3/gns3-server.git
synced 2025-01-18 23:43:48 +02:00
Check for VMware Player version >= 7 and VMware Workstation >= 11. Fixes #286.
This commit is contained in:
parent
bb69f02da6
commit
7bccf9e554
@ -41,7 +41,7 @@ class VMwareHandler:
|
|||||||
def show(request, response):
|
def show(request, response):
|
||||||
|
|
||||||
vmware_manager = VMware.instance()
|
vmware_manager = VMware.instance()
|
||||||
vms = vmware_manager.list_vms()
|
vms = yield from vmware_manager.list_vms()
|
||||||
response.json(vms)
|
response.json(vms)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
|
@ -30,6 +30,7 @@ import codecs
|
|||||||
|
|
||||||
from collections import OrderedDict
|
from collections import OrderedDict
|
||||||
from gns3server.utils.interfaces import interfaces
|
from gns3server.utils.interfaces import interfaces
|
||||||
|
from gns3server.utils.asyncio import subprocess_check_output
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -125,6 +126,72 @@ class VMware(BaseManager):
|
|||||||
self._vmrun_path = vmrun_path
|
self._vmrun_path = vmrun_path
|
||||||
return vmrun_path
|
return vmrun_path
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _find_vmware_version_registry(regkey):
|
||||||
|
|
||||||
|
import winreg
|
||||||
|
version = None
|
||||||
|
try:
|
||||||
|
# default path not used, let's look in the registry
|
||||||
|
hkey = winreg.OpenKey(winreg.HKEY_LOCAL_MACHINE, regkey)
|
||||||
|
version, _ = winreg.QueryValueEx(hkey, "ProductVersion")
|
||||||
|
winreg.CloseKey(hkey)
|
||||||
|
except OSError:
|
||||||
|
pass
|
||||||
|
if version is not None:
|
||||||
|
match = re.search("([0-9]+)\.", version)
|
||||||
|
if match:
|
||||||
|
version = match.group(1)
|
||||||
|
return version
|
||||||
|
|
||||||
|
@asyncio.coroutine
|
||||||
|
def check_vmware_version(self):
|
||||||
|
"""
|
||||||
|
Check VMware version
|
||||||
|
"""
|
||||||
|
|
||||||
|
if sys.platform.startswith("win"):
|
||||||
|
# look for vmrun.exe using the directory listed in the registry
|
||||||
|
ws_version = self._find_vmware_version_registry(r"SOFTWARE\Wow6432Node\VMware, Inc.\VMware Workstation")
|
||||||
|
if ws_version is None:
|
||||||
|
player_version = self._find_vmware_version_registry(r"SOFTWARE\Wow6432Node\VMware, Inc.\VMware Player")
|
||||||
|
if player_version:
|
||||||
|
log.debug("VMware Player version {} detected".format(player_version))
|
||||||
|
if int(player_version) < 7:
|
||||||
|
raise VMwareError("Using VMware Player requires version 7 or above")
|
||||||
|
else:
|
||||||
|
log.warning("Could not find VMware version")
|
||||||
|
else:
|
||||||
|
log.debug("VMware Workstation version {} detected".format(ws_version))
|
||||||
|
if int(ws_version) < 11:
|
||||||
|
raise VMwareError("Using VMware Workstation requires version 11 or above")
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
if sys.platform.startswith("darwin"):
|
||||||
|
return # FIXME: no version checking on Mac OS X
|
||||||
|
else:
|
||||||
|
vmware_path = shutil.which("vmware")
|
||||||
|
|
||||||
|
try:
|
||||||
|
output = yield from subprocess_check_output(vmware_path, "-v")
|
||||||
|
match = re.search("VMware Workstation ([0-9]+)\.", output)
|
||||||
|
version = None
|
||||||
|
if match:
|
||||||
|
version = match.group(1)
|
||||||
|
log.debug("VMware Workstation version {} detected".format(version))
|
||||||
|
if int(version) < 11:
|
||||||
|
raise VMwareError("Using VMware Workstation requires version 11 or above")
|
||||||
|
match = re.search("VMware Player ([0-9]+)\.", output)
|
||||||
|
if match:
|
||||||
|
version = match.group(1)
|
||||||
|
log.debug("VMware Player version {} detected".format(version))
|
||||||
|
if int(version) < 7:
|
||||||
|
raise VMwareError("Using VMware Player requires version 11 or above")
|
||||||
|
if version is None:
|
||||||
|
log.warning("Could not find VMware version")
|
||||||
|
except (OSError, subprocess.SubprocessError) as e:
|
||||||
|
log.error("Error while looking for the VMware version: {}".format(e))
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def get_vmnet_interfaces():
|
def get_vmnet_interfaces():
|
||||||
|
|
||||||
@ -420,11 +487,15 @@ class VMware(BaseManager):
|
|||||||
else:
|
else:
|
||||||
return os.path.expanduser("~/vmware")
|
return os.path.expanduser("~/vmware")
|
||||||
|
|
||||||
|
@asyncio.coroutine
|
||||||
def list_vms(self):
|
def list_vms(self):
|
||||||
"""
|
"""
|
||||||
Gets VMware VM list.
|
Gets VMware VM list.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
# check for the right VMware version
|
||||||
|
yield from self.check_vmware_version()
|
||||||
|
|
||||||
inventory_path = self.get_vmware_inventory_path()
|
inventory_path = self.get_vmware_inventory_path()
|
||||||
if os.path.exists(inventory_path):
|
if os.path.exists(inventory_path):
|
||||||
return self._get_vms_from_inventory(inventory_path)
|
return self._get_vms_from_inventory(inventory_path)
|
||||||
|
Loading…
Reference in New Issue
Block a user