mirror of
https://github.com/GNS3/gns3-server.git
synced 2025-02-07 08:43:48 +02:00
Support listing images in subdirectories
It's a part of the OVA support: https://github.com/GNS3/gns3-gui/issues/700
This commit is contained in:
parent
dd7f6eb021
commit
034ac392b7
@ -20,12 +20,12 @@ import base64
|
|||||||
|
|
||||||
from ...web.route import Route
|
from ...web.route import Route
|
||||||
from ...schemas.nio import NIO_SCHEMA
|
from ...schemas.nio import NIO_SCHEMA
|
||||||
|
from ...schemas.vm import VM_LIST_IMAGES_SCHEMA
|
||||||
from ...schemas.dynamips_vm import VM_CREATE_SCHEMA
|
from ...schemas.dynamips_vm import VM_CREATE_SCHEMA
|
||||||
from ...schemas.dynamips_vm import VM_UPDATE_SCHEMA
|
from ...schemas.dynamips_vm import VM_UPDATE_SCHEMA
|
||||||
from ...schemas.dynamips_vm import VM_CAPTURE_SCHEMA
|
from ...schemas.dynamips_vm import VM_CAPTURE_SCHEMA
|
||||||
from ...schemas.dynamips_vm import VM_OBJECT_SCHEMA
|
from ...schemas.dynamips_vm import VM_OBJECT_SCHEMA
|
||||||
from ...schemas.dynamips_vm import VM_CONFIGS_SCHEMA
|
from ...schemas.dynamips_vm import VM_CONFIGS_SCHEMA
|
||||||
from ...schemas.dynamips_vm import VMS_LIST_SCHEMA
|
|
||||||
from ...modules.dynamips import Dynamips
|
from ...modules.dynamips import Dynamips
|
||||||
from ...modules.dynamips.dynamips_error import DynamipsError
|
from ...modules.dynamips.dynamips_error import DynamipsError
|
||||||
from ...modules.project_manager import ProjectManager
|
from ...modules.project_manager import ProjectManager
|
||||||
@ -460,7 +460,7 @@ class DynamipsVMHandler:
|
|||||||
200: "List of Dynamips VM retrieved",
|
200: "List of Dynamips VM retrieved",
|
||||||
},
|
},
|
||||||
description="Retrieve the list of Dynamips VMS",
|
description="Retrieve the list of Dynamips VMS",
|
||||||
output=VMS_LIST_SCHEMA)
|
output=VM_LIST_IMAGES_SCHEMA)
|
||||||
def list_vms(request, response):
|
def list_vms(request, response):
|
||||||
|
|
||||||
dynamips_manager = Dynamips.instance()
|
dynamips_manager = Dynamips.instance()
|
||||||
@ -469,7 +469,7 @@ class DynamipsVMHandler:
|
|||||||
response.json(vms)
|
response.json(vms)
|
||||||
|
|
||||||
@Route.post(
|
@Route.post(
|
||||||
r"/dynamips/vms/{filename}",
|
r"/dynamips/vms/{path}",
|
||||||
status_codes={
|
status_codes={
|
||||||
204: "Image uploaded",
|
204: "Image uploaded",
|
||||||
},
|
},
|
||||||
@ -478,5 +478,5 @@ class DynamipsVMHandler:
|
|||||||
def upload_vm(request, response):
|
def upload_vm(request, response):
|
||||||
|
|
||||||
dynamips_manager = Dynamips.instance()
|
dynamips_manager = Dynamips.instance()
|
||||||
yield from dynamips_manager.write_image(request.match_info["filename"], request.content)
|
yield from dynamips_manager.write_image(request.match_info["path"], request.content)
|
||||||
response.set_status(204)
|
response.set_status(204)
|
||||||
|
@ -26,7 +26,7 @@ from ...schemas.iou import IOU_UPDATE_SCHEMA
|
|||||||
from ...schemas.iou import IOU_OBJECT_SCHEMA
|
from ...schemas.iou import IOU_OBJECT_SCHEMA
|
||||||
from ...schemas.iou import IOU_CAPTURE_SCHEMA
|
from ...schemas.iou import IOU_CAPTURE_SCHEMA
|
||||||
from ...schemas.iou import IOU_CONFIGS_SCHEMA
|
from ...schemas.iou import IOU_CONFIGS_SCHEMA
|
||||||
from ...schemas.iou import IOU_LIST_VMS_SCHEMA
|
from ...schemas.vm import VM_LIST_IMAGES_SCHEMA
|
||||||
from ...modules.iou import IOU
|
from ...modules.iou import IOU
|
||||||
|
|
||||||
|
|
||||||
@ -373,7 +373,7 @@ class IOUHandler:
|
|||||||
200: "List of IOU VM retrieved",
|
200: "List of IOU VM retrieved",
|
||||||
},
|
},
|
||||||
description="Retrieve the list of IOU VMS",
|
description="Retrieve the list of IOU VMS",
|
||||||
output=IOU_LIST_VMS_SCHEMA)
|
output=VM_LIST_IMAGES_SCHEMA)
|
||||||
def list_vms(request, response):
|
def list_vms(request, response):
|
||||||
|
|
||||||
iou_manager = IOU.instance()
|
iou_manager = IOU.instance()
|
||||||
@ -382,7 +382,7 @@ class IOUHandler:
|
|||||||
response.json(vms)
|
response.json(vms)
|
||||||
|
|
||||||
@Route.post(
|
@Route.post(
|
||||||
r"/iou/vms/{filename}",
|
r"/iou/vms/{path}",
|
||||||
status_codes={
|
status_codes={
|
||||||
204: "Image uploaded",
|
204: "Image uploaded",
|
||||||
},
|
},
|
||||||
@ -391,5 +391,5 @@ class IOUHandler:
|
|||||||
def upload_vm(request, response):
|
def upload_vm(request, response):
|
||||||
|
|
||||||
iou_manager = IOU.instance()
|
iou_manager = IOU.instance()
|
||||||
yield from iou_manager.write_image(request.match_info["filename"], request.content)
|
yield from iou_manager.write_image(request.match_info["path"], request.content)
|
||||||
response.set_status(204)
|
response.set_status(204)
|
||||||
|
@ -26,8 +26,8 @@ from ...schemas.qemu import QEMU_CREATE_SCHEMA
|
|||||||
from ...schemas.qemu import QEMU_UPDATE_SCHEMA
|
from ...schemas.qemu import QEMU_UPDATE_SCHEMA
|
||||||
from ...schemas.qemu import QEMU_OBJECT_SCHEMA
|
from ...schemas.qemu import QEMU_OBJECT_SCHEMA
|
||||||
from ...schemas.qemu import QEMU_BINARY_LIST_SCHEMA
|
from ...schemas.qemu import QEMU_BINARY_LIST_SCHEMA
|
||||||
from ...schemas.qemu import QEMU_LIST_IMAGES_SCHEMA
|
|
||||||
from ...schemas.qemu import QEMU_IMAGE_CREATE_SCHEMA
|
from ...schemas.qemu import QEMU_IMAGE_CREATE_SCHEMA
|
||||||
|
from ...schemas.vm import VM_LIST_IMAGES_SCHEMA
|
||||||
from ...modules.qemu import Qemu
|
from ...modules.qemu import Qemu
|
||||||
from ...config import Config
|
from ...config import Config
|
||||||
|
|
||||||
@ -348,7 +348,7 @@ class QEMUHandler:
|
|||||||
200: "List of Qemu images retrieved",
|
200: "List of Qemu images retrieved",
|
||||||
},
|
},
|
||||||
description="Retrieve the list of Qemu images",
|
description="Retrieve the list of Qemu images",
|
||||||
output=QEMU_LIST_IMAGES_SCHEMA)
|
output=VM_LIST_IMAGES_SCHEMA)
|
||||||
def list_vms(request, response):
|
def list_vms(request, response):
|
||||||
|
|
||||||
qemu_manager = Qemu.instance()
|
qemu_manager = Qemu.instance()
|
||||||
@ -357,7 +357,7 @@ class QEMUHandler:
|
|||||||
response.json(vms)
|
response.json(vms)
|
||||||
|
|
||||||
@Route.post(
|
@Route.post(
|
||||||
r"/qemu/vms/{filename}",
|
r"/qemu/vms/{path}",
|
||||||
status_codes={
|
status_codes={
|
||||||
204: "Image uploaded",
|
204: "Image uploaded",
|
||||||
},
|
},
|
||||||
@ -366,5 +366,5 @@ class QEMUHandler:
|
|||||||
def upload_vm(request, response):
|
def upload_vm(request, response):
|
||||||
|
|
||||||
qemu_manager = Qemu.instance()
|
qemu_manager = Qemu.instance()
|
||||||
yield from qemu_manager.write_image(request.match_info["filename"], request.content)
|
yield from qemu_manager.write_image(request.match_info["path"], request.content)
|
||||||
response.set_status(204)
|
response.set_status(204)
|
||||||
|
@ -439,15 +439,15 @@ class BaseManager:
|
|||||||
:returns: Array of hash
|
:returns: Array of hash
|
||||||
"""
|
"""
|
||||||
|
|
||||||
try:
|
|
||||||
files = os.listdir(self.get_images_directory())
|
|
||||||
except FileNotFoundError:
|
|
||||||
return []
|
|
||||||
files.sort()
|
|
||||||
images = []
|
images = []
|
||||||
for filename in files:
|
img_dir = self.get_images_directory()
|
||||||
if filename[0] != "." and not filename.endswith(".md5sum"):
|
for root, dirs, files in os.walk(img_dir):
|
||||||
images.append({"filename": filename})
|
for filename in files:
|
||||||
|
if filename[0] != "." and not filename.endswith(".md5sum"):
|
||||||
|
path = os.path.relpath(os.path.join(root, filename), img_dir)
|
||||||
|
images.append({
|
||||||
|
"filename": filename,
|
||||||
|
"path": path})
|
||||||
return images
|
return images
|
||||||
|
|
||||||
def get_images_directory(self):
|
def get_images_directory(self):
|
||||||
|
@ -777,21 +777,3 @@ VM_CONFIGS_SCHEMA = {
|
|||||||
},
|
},
|
||||||
"additionalProperties": False,
|
"additionalProperties": False,
|
||||||
}
|
}
|
||||||
|
|
||||||
VMS_LIST_SCHEMA = {
|
|
||||||
"$schema": "http://json-schema.org/draft-04/schema#",
|
|
||||||
"description": "List available Dynamips images",
|
|
||||||
"type": "array",
|
|
||||||
"items": [
|
|
||||||
{
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"filename": {
|
|
||||||
"description": "Image filename",
|
|
||||||
"type": ["string"]
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"additionalProperties": False,
|
|
||||||
}
|
|
||||||
|
@ -299,21 +299,3 @@ IOU_CONFIGS_SCHEMA = {
|
|||||||
},
|
},
|
||||||
"additionalProperties": False,
|
"additionalProperties": False,
|
||||||
}
|
}
|
||||||
|
|
||||||
IOU_LIST_VMS_SCHEMA = {
|
|
||||||
"$schema": "http://json-schema.org/draft-04/schema#",
|
|
||||||
"description": "List available IOU images",
|
|
||||||
"type": "array",
|
|
||||||
"items": [
|
|
||||||
{
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"filename": {
|
|
||||||
"description": "Image filename",
|
|
||||||
"type": ["string"]
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"additionalProperties": False,
|
|
||||||
}
|
|
||||||
|
@ -577,25 +577,6 @@ QEMU_BINARY_LIST_SCHEMA = {
|
|||||||
"additionalProperties": False,
|
"additionalProperties": False,
|
||||||
}
|
}
|
||||||
|
|
||||||
QEMU_LIST_IMAGES_SCHEMA = {
|
|
||||||
"$schema": "http://json-schema.org/draft-04/schema#",
|
|
||||||
"description": "List available QEMU images",
|
|
||||||
"type": "array",
|
|
||||||
"items": [
|
|
||||||
{
|
|
||||||
"type": "object",
|
|
||||||
"properties": {
|
|
||||||
"filename": {
|
|
||||||
"description": "Image filename",
|
|
||||||
"type": "string"
|
|
||||||
},
|
|
||||||
},
|
|
||||||
"additionalProperties": False
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"additionalProperties": False,
|
|
||||||
}
|
|
||||||
|
|
||||||
QEMU_IMAGE_CREATE_SCHEMA = {
|
QEMU_IMAGE_CREATE_SCHEMA = {
|
||||||
"$schema": "http://json-schema.org/draft-04/schema#",
|
"$schema": "http://json-schema.org/draft-04/schema#",
|
||||||
"description": "Create a new qemu image. Options can be specific to a format. Read qemu-img manual for more information",
|
"description": "Create a new qemu image. Options can be specific to a format. Read qemu-img manual for more information",
|
||||||
|
40
gns3server/schemas/vm.py
Normal file
40
gns3server/schemas/vm.py
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
#
|
||||||
|
# Copyright (C) 2015 GNS3 Technologies Inc.
|
||||||
|
#
|
||||||
|
# This program is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
|
||||||
|
VM_LIST_IMAGES_SCHEMA = {
|
||||||
|
"$schema": "http://json-schema.org/draft-04/schema#",
|
||||||
|
"description": "List of disk images",
|
||||||
|
"type": "array",
|
||||||
|
"items": [
|
||||||
|
{
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"filename": {
|
||||||
|
"description": "Image filename",
|
||||||
|
"type": "string"
|
||||||
|
},
|
||||||
|
"path": {
|
||||||
|
"description": "Image path",
|
||||||
|
"type": "string"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"additionalProperties": False
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"additionalProperties": False,
|
||||||
|
}
|
@ -332,7 +332,7 @@ def test_vms(server, tmpdir, fake_iou_bin):
|
|||||||
with patch("gns3server.modules.IOU.get_images_directory", return_value=str(tmpdir)):
|
with patch("gns3server.modules.IOU.get_images_directory", return_value=str(tmpdir)):
|
||||||
response = server.get("/iou/vms", example=True)
|
response = server.get("/iou/vms", example=True)
|
||||||
assert response.status == 200
|
assert response.status == 200
|
||||||
assert response.json == [{"filename": "iou.bin"}]
|
assert response.json == [{"filename": "iou.bin", "path": "iou.bin"}]
|
||||||
|
|
||||||
|
|
||||||
def test_upload_vm(server, tmpdir):
|
def test_upload_vm(server, tmpdir):
|
||||||
|
@ -216,7 +216,7 @@ def test_vms(server, tmpdir, fake_qemu_vm):
|
|||||||
with patch("gns3server.modules.Qemu.get_images_directory", return_value=str(tmpdir), example=True):
|
with patch("gns3server.modules.Qemu.get_images_directory", return_value=str(tmpdir), example=True):
|
||||||
response = server.get("/qemu/vms")
|
response = server.get("/qemu/vms")
|
||||||
assert response.status == 200
|
assert response.status == 200
|
||||||
assert response.json == [{"filename": "linux.img"}]
|
assert response.json == [{"filename": "linux.img", "path": "linux.img"}]
|
||||||
|
|
||||||
|
|
||||||
def test_upload_vm(server, tmpdir):
|
def test_upload_vm(server, tmpdir):
|
||||||
|
@ -132,8 +132,28 @@ def test_list_images(loop, qemu, tmpdir):
|
|||||||
|
|
||||||
with patch("gns3server.modules.Qemu.get_images_directory", return_value=str(tmpdir)):
|
with patch("gns3server.modules.Qemu.get_images_directory", return_value=str(tmpdir)):
|
||||||
assert loop.run_until_complete(qemu.list_images()) == [
|
assert loop.run_until_complete(qemu.list_images()) == [
|
||||||
{"filename": "a.bin"},
|
{"filename": "a.bin", "path": "a.bin"},
|
||||||
{"filename": "b.bin"}
|
{"filename": "b.bin", "path": "b.bin"}
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
def test_list_images_recursives(loop, qemu, tmpdir):
|
||||||
|
|
||||||
|
fake_images = ["a.bin", "b.bin", ".blu.bin", "a.bin.md5sum"]
|
||||||
|
for image in fake_images:
|
||||||
|
with open(str(tmpdir / image), "w+") as f:
|
||||||
|
f.write("1")
|
||||||
|
os.makedirs(str(tmpdir / "c"))
|
||||||
|
fake_images = ["c.bin", "c.bin.md5sum"]
|
||||||
|
for image in fake_images:
|
||||||
|
with open(str(tmpdir / "c" / image), "w+") as f:
|
||||||
|
f.write("1")
|
||||||
|
|
||||||
|
with patch("gns3server.modules.Qemu.get_images_directory", return_value=str(tmpdir)):
|
||||||
|
assert loop.run_until_complete(qemu.list_images()) == [
|
||||||
|
{"filename": "a.bin", "path": "a.bin"},
|
||||||
|
{"filename": "b.bin", "path": "b.bin"},
|
||||||
|
{"filename": "c.bin", "path": os.path.sep.join(["c", "c.bin"])}
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user