mirror of
https://github.com/GNS3/gns3-server
synced 2025-01-12 09:00:57 +00:00
Fixes unicode decode error when saving IOS router configs. Fixes #115.
This commit is contained in:
parent
3c917c59fb
commit
056ff14437
@ -356,13 +356,13 @@ class DynamipsVMHandler:
|
|||||||
vm = dynamips_manager.get_vm(request.match_info["vm_id"],
|
vm = dynamips_manager.get_vm(request.match_info["vm_id"],
|
||||||
project_id=request.match_info["project_id"])
|
project_id=request.match_info["project_id"])
|
||||||
|
|
||||||
startup_config, private_config = yield from vm.extract_config()
|
startup_config_base64, private_config_base64 = yield from vm.extract_config()
|
||||||
result = {}
|
result = {}
|
||||||
if startup_config:
|
if startup_config_base64:
|
||||||
startup_config_content = base64.decodebytes(startup_config.encode("utf-8")).decode("utf-8")
|
startup_config_content = base64.b64decode(startup_config_base64).decode(errors='replace')
|
||||||
result["startup_config_content"] = startup_config_content
|
result["startup_config_content"] = startup_config_content
|
||||||
if private_config:
|
if private_config_base64:
|
||||||
private_config_content = base64.decodebytes(private_config.encode("utf-8")).decode("utf-8")
|
private_config_content = base64.b64decode(private_config_base64).decode(errors='replace')
|
||||||
result["private_config_content"] = private_config_content
|
result["private_config_content"] = private_config_content
|
||||||
|
|
||||||
response.set_status(200)
|
response.set_status(200)
|
||||||
|
@ -26,6 +26,7 @@ import sys
|
|||||||
import os
|
import os
|
||||||
import glob
|
import glob
|
||||||
import base64
|
import base64
|
||||||
|
import binascii
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -1183,8 +1184,7 @@ class Router(BaseVM):
|
|||||||
slot_number=slot_number))
|
slot_number=slot_number))
|
||||||
|
|
||||||
if adapter is None:
|
if adapter is None:
|
||||||
raise DynamipsError("Adapter is missing in {slot_number}".format( slot_number=slot_number))
|
raise DynamipsError("Adapter is missing in slot {slot_number}".format(slot_number=slot_number))
|
||||||
|
|
||||||
|
|
||||||
if not adapter.port_exists(port_number):
|
if not adapter.port_exists(port_number):
|
||||||
raise DynamipsError("Port {port_number} does not exist in adapter {adapter}".format(adapter=adapter,
|
raise DynamipsError("Port {port_number} does not exist in adapter {adapter}".format(adapter=adapter,
|
||||||
@ -1221,7 +1221,8 @@ class Router(BaseVM):
|
|||||||
raise DynamipsError('Slot {slot_number} does not exist on router "{name}"'.format(name=self._name,
|
raise DynamipsError('Slot {slot_number} does not exist on router "{name}"'.format(name=self._name,
|
||||||
slot_number=slot_number))
|
slot_number=slot_number))
|
||||||
|
|
||||||
|
if adapter is None:
|
||||||
|
raise DynamipsError("Adapter is missing in slot {slot_number}".format(slot_number=slot_number))
|
||||||
|
|
||||||
if not adapter.port_exists(port_number):
|
if not adapter.port_exists(port_number):
|
||||||
raise DynamipsError("Port {port_number} does not exist in adapter {adapter}".format(adapter=adapter,
|
raise DynamipsError("Port {port_number} does not exist in adapter {adapter}".format(adapter=adapter,
|
||||||
@ -1494,24 +1495,24 @@ class Router(BaseVM):
|
|||||||
startup_config_base64, private_config_base64 = yield from self.extract_config()
|
startup_config_base64, private_config_base64 = yield from self.extract_config()
|
||||||
if startup_config_base64:
|
if startup_config_base64:
|
||||||
try:
|
try:
|
||||||
config = base64.decodebytes(startup_config_base64.encode("utf-8")).decode("utf-8")
|
config = base64.b64decode(startup_config_base64).decode(errors='replace')
|
||||||
config = "!\n" + config.replace("\r", "")
|
config = "!\n" + config.replace("\r", "")
|
||||||
config_path = os.path.join(module_workdir, self.startup_config)
|
config_path = os.path.join(module_workdir, self.startup_config)
|
||||||
with open(config_path, "w") as f:
|
with open(config_path, "w") as f:
|
||||||
log.info("saving startup-config to {}".format(self.startup_config))
|
log.info("saving startup-config to {}".format(self.startup_config))
|
||||||
f.write(config)
|
f.write(config)
|
||||||
except OSError as e:
|
except (binascii.Error, OSError) as e:
|
||||||
raise DynamipsError("Could not save the startup configuration {}: {}".format(config_path, e))
|
raise DynamipsError("Could not save the startup configuration {}: {}".format(config_path, e))
|
||||||
|
|
||||||
if private_config_base64:
|
if private_config_base64:
|
||||||
try:
|
try:
|
||||||
config = base64.decodebytes(private_config_base64.encode("utf-8")).decode("utf-8")
|
config = base64.b64decode(private_config_base64).decode(errors='replace')
|
||||||
config = "!\n" + config.replace("\r", "")
|
config = "!\n" + config.replace("\r", "")
|
||||||
config_path = os.path.join(module_workdir, self.private_config)
|
config_path = os.path.join(module_workdir, self.private_config)
|
||||||
with open(config_path, "w") as f:
|
with open(config_path, "w") as f:
|
||||||
log.info("saving private-config to {}".format(self.private_config))
|
log.info("saving private-config to {}".format(self.private_config))
|
||||||
f.write(config)
|
f.write(config)
|
||||||
except OSError as e:
|
except (binascii.Error, OSError) as e:
|
||||||
raise DynamipsError("Could not save the private configuration {}: {}".format(config_path, e))
|
raise DynamipsError("Could not save the private configuration {}: {}".format(config_path, e))
|
||||||
|
|
||||||
def delete(self):
|
def delete(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user