From ef54367bf79900b8ae1fc4218925f9fd374fbb70 Mon Sep 17 00:00:00 2001 From: Julien Duponchelle Date: Wed, 21 Dec 2016 14:39:44 +0100 Subject: [PATCH] Fix crash when converting topology with broken link Fix #845 --- gns3server/controller/topology.py | 29 ++++++++++++++++------------- 1 file changed, 16 insertions(+), 13 deletions(-) diff --git a/gns3server/controller/topology.py b/gns3server/controller/topology.py index 02840672..ae8f7165 100644 --- a/gns3server/controller/topology.py +++ b/gns3server/controller/topology.py @@ -310,20 +310,23 @@ def _convert_1_3_later(topo, topo_path): # Create links for old_link in topo.get("links", []): - nodes = [] - source_node = { - "adapter_number": ports[old_link["source_port_id"]].get("adapter_number", 0), - "port_number": ports[old_link["source_port_id"]].get("port_number", 0), - "node_id": node_id_to_node_uuid[old_link["source_node_id"]] - } - nodes.append(source_node) + try: + nodes = [] + source_node = { + "adapter_number": ports[old_link["source_port_id"]].get("adapter_number", 0), + "port_number": ports[old_link["source_port_id"]].get("port_number", 0), + "node_id": node_id_to_node_uuid[old_link["source_node_id"]] + } + nodes.append(source_node) - destination_node = { - "adapter_number": ports[old_link["destination_port_id"]].get("adapter_number", 0), - "port_number": ports[old_link["destination_port_id"]].get("port_number", 0), - "node_id": node_id_to_node_uuid[old_link["destination_node_id"]] - } - nodes.append(destination_node) + destination_node = { + "adapter_number": ports[old_link["destination_port_id"]].get("adapter_number", 0), + "port_number": ports[old_link["destination_port_id"]].get("port_number", 0), + "node_id": node_id_to_node_uuid[old_link["destination_node_id"]] + } + nodes.append(destination_node) + except KeyError: + continue link = { "link_id": str(uuid.uuid4()),