1
0
mirror of https://github.com/GNS3/gns3-server synced 2025-01-12 09:00:57 +00:00

Add explicit option to automatically create or not the config disk. Off by default.

This commit is contained in:
grossmj 2020-08-14 17:57:24 +09:30
parent 546982d1ea
commit 56aba96a5f
3 changed files with 47 additions and 4 deletions

View File

@ -121,6 +121,7 @@ class QemuVM(BaseNode):
self._kernel_command_line = "" self._kernel_command_line = ""
self._legacy_networking = False self._legacy_networking = False
self._replicate_network_connection_state = True self._replicate_network_connection_state = True
self._create_config_disk = False
self._on_close = "power_off" self._on_close = "power_off"
self._cpu_throttling = 0 # means no CPU throttling self._cpu_throttling = 0 # means no CPU throttling
self._process_priority = "low" self._process_priority = "low"
@ -138,9 +139,8 @@ class QemuVM(BaseNode):
else: else:
try: try:
self.config_disk_image = self.manager.get_abs_image_path(self.config_disk_name) self.config_disk_image = self.manager.get_abs_image_path(self.config_disk_name)
except (NodeError, ImageMissingError) as e: except (NodeError, ImageMissingError):
log.warning("Config disk: image '{}' missing" log.warning("Config disk: image '{}' missing".format(self.config_disk_name))
.format(self.config_disk_name))
self.config_disk_name = "" self.config_disk_name = ""
log.info('QEMU VM "{name}" [{id}] has been created'.format(name=self._name, id=self._id)) log.info('QEMU VM "{name}" [{id}] has been created'.format(name=self._name, id=self._id))
@ -659,6 +659,30 @@ class QemuVM(BaseNode):
log.info('QEMU VM "{name}" [{id}] has disabled network connection state replication'.format(name=self._name, id=self._id)) log.info('QEMU VM "{name}" [{id}] has disabled network connection state replication'.format(name=self._name, id=self._id))
self._replicate_network_connection_state = replicate_network_connection_state self._replicate_network_connection_state = replicate_network_connection_state
@property
def create_config_disk(self):
"""
Returns whether a config disk is automatically created on HDD disk interface (secondary slave)
:returns: boolean
"""
return self._create_config_disk
@create_config_disk.setter
def create_config_disk(self, create_config_disk):
"""
Sets whether a config disk is automatically created on HDD disk interface (secondary slave)
:param replicate_network_connection_state: boolean
"""
if create_config_disk:
log.info('QEMU VM "{name}" [{id}] has enabled the config disk creation feature'.format(name=self._name, id=self._id))
else:
log.info('QEMU VM "{name}" [{id}] has disabled the config disk creation feature'.format(name=self._name, id=self._id))
self._create_config_disk = create_config_disk
@property @property
def on_close(self): def on_close(self):
""" """
@ -1796,7 +1820,7 @@ class QemuVM(BaseNode):
# config disk # config disk
disk_image = getattr(self, "config_disk_image") disk_image = getattr(self, "config_disk_image")
if disk_image: if disk_image and self._create_config_disk:
if getattr(self, "_hdd_disk_image"): if getattr(self, "_hdd_disk_image"):
log.warning("Config disk: blocked by disk image 'hdd'") log.warning("Config disk: blocked by disk image 'hdd'")
else: else:
@ -1815,6 +1839,7 @@ class QemuVM(BaseNode):
log.warning("Could not create '{}' disk image: {}".format(disk_name, e)) log.warning("Could not create '{}' disk image: {}".format(disk_name, e))
if disk_exists: if disk_exists:
options.extend(self._disk_interface_options(disk, 3, interface, "raw")) options.extend(self._disk_interface_options(disk, 3, interface, "raw"))
self.hdd_disk_image = disk
return options return options

View File

@ -190,6 +190,10 @@ QEMU_CREATE_SCHEMA = {
"description": "Replicate the network connection state for links in Qemu", "description": "Replicate the network connection state for links in Qemu",
"type": ["boolean", "null"], "type": ["boolean", "null"],
}, },
"create_config_disk": {
"description": "Automatically create a config disk on HDD disk interface (secondary slave)",
"type": ["boolean", "null"],
},
"on_close": { "on_close": {
"description": "Action to execute on the VM is closed", "description": "Action to execute on the VM is closed",
"enum": ["power_off", "shutdown_signal", "save_vm_state"], "enum": ["power_off", "shutdown_signal", "save_vm_state"],
@ -380,6 +384,10 @@ QEMU_UPDATE_SCHEMA = {
"description": "Replicate the network connection state for links in Qemu", "description": "Replicate the network connection state for links in Qemu",
"type": ["boolean", "null"], "type": ["boolean", "null"],
}, },
"create_config_disk": {
"description": "Automatically create a config disk on HDD disk interface (secondary slave)",
"type": ["boolean", "null"],
},
"on_close": { "on_close": {
"description": "Action to execute on the VM is closed", "description": "Action to execute on the VM is closed",
"enum": ["power_off", "shutdown_signal", "save_vm_state"], "enum": ["power_off", "shutdown_signal", "save_vm_state"],
@ -583,6 +591,10 @@ QEMU_OBJECT_SCHEMA = {
"description": "Replicate the network connection state for links in Qemu", "description": "Replicate the network connection state for links in Qemu",
"type": "boolean", "type": "boolean",
}, },
"create_config_disk": {
"description": "Automatically create a config disk on HDD disk interface (secondary slave)",
"type": ["boolean", "null"],
},
"on_close": { "on_close": {
"description": "Action to execute on the VM is closed", "description": "Action to execute on the VM is closed",
"enum": ["power_off", "shutdown_signal", "save_vm_state"], "enum": ["power_off", "shutdown_signal", "save_vm_state"],
@ -653,6 +665,7 @@ QEMU_OBJECT_SCHEMA = {
"kernel_command_line", "kernel_command_line",
"legacy_networking", "legacy_networking",
"replicate_network_connection_state", "replicate_network_connection_state",
"create_config_disk",
"on_close", "on_close",
"cpu_throttling", "cpu_throttling",
"process_priority", "process_priority",

View File

@ -178,6 +178,11 @@ QEMU_TEMPLATE_PROPERTIES = {
"type": "boolean", "type": "boolean",
"default": True "default": True
}, },
"create_config_disk": {
"description": "Automatically create a config disk on HDD disk interface (secondary slave)",
"type": "boolean",
"default": True
},
"on_close": { "on_close": {
"description": "Action to execute on the VM is closed", "description": "Action to execute on the VM is closed",
"enum": ["power_off", "shutdown_signal", "save_vm_state"], "enum": ["power_off", "shutdown_signal", "save_vm_state"],