mirror of
https://github.com/GNS3/gns3-server
synced 2025-01-26 07:51:13 +00:00
parent
50a922f83e
commit
3b94484914
@ -199,7 +199,6 @@ def _patch_project_file(project, path, zstream, include_images, keep_compute_id,
|
|||||||
yield from _export_remote_images(project, compute_id, image_type, image, zstream, temporary_dir)
|
yield from _export_remote_images(project, compute_id, image_type, image, zstream, temporary_dir)
|
||||||
|
|
||||||
zstream.writestr("project.gns3", json.dumps(topology).encode())
|
zstream.writestr("project.gns3", json.dumps(topology).encode())
|
||||||
|
|
||||||
return images
|
return images
|
||||||
|
|
||||||
def _export_local_image(image, zstream):
|
def _export_local_image(image, zstream):
|
||||||
|
@ -57,7 +57,9 @@ def import_project(controller, project_id, stream, location=None, name=None, kee
|
|||||||
with zipfile.ZipFile(stream) as zip_file:
|
with zipfile.ZipFile(stream) as zip_file:
|
||||||
project_file = zip_file.read("project.gns3").decode()
|
project_file = zip_file.read("project.gns3").decode()
|
||||||
except zipfile.BadZipFile:
|
except zipfile.BadZipFile:
|
||||||
raise aiohttp.web.HTTPConflict(text="Cannot import project, not a GNS3 project (invalid zip) or project.gns3 file could not be found")
|
raise aiohttp.web.HTTPConflict(text="Cannot import project, not a GNS3 project (invalid zip)")
|
||||||
|
except KeyError:
|
||||||
|
raise aiohttp.web.HTTPConflict(text="Cannot import project, project.gns3 file could not be found")
|
||||||
|
|
||||||
try:
|
try:
|
||||||
topology = json.loads(project_file)
|
topology = json.loads(project_file)
|
||||||
|
@ -123,8 +123,8 @@ class Snapshot:
|
|||||||
project = yield from import_project(self._project.controller, self._project.id, f, location=self._project.path)
|
project = yield from import_project(self._project.controller, self._project.id, f, location=self._project.path)
|
||||||
except (OSError, PermissionError) as e:
|
except (OSError, PermissionError) as e:
|
||||||
raise aiohttp.web.HTTPConflict(text=str(e))
|
raise aiohttp.web.HTTPConflict(text=str(e))
|
||||||
self._project.controller.notification.emit("snapshot.restored", self.__json__())
|
|
||||||
yield from project.open()
|
yield from project.open()
|
||||||
|
self._project.controller.notification.emit("snapshot.restored", self.__json__())
|
||||||
return self._project
|
return self._project
|
||||||
|
|
||||||
def __json__(self):
|
def __json__(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user