# -*- coding: utf-8 -*- # # 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 . from ..web.route import Route from ..schemas.virtualbox import VBOX_CREATE_SCHEMA from ..schemas.virtualbox import VBOX_OBJECT_SCHEMA from ..modules.virtualbox import VirtualBox class VirtualBoxHandler: """ API entry points for VirtualBox. """ @classmethod @Route.post( r"/virtualbox", status_codes={ 201: "VirtualBox VM instance created", 400: "Invalid project UUID", 409: "Conflict" }, description="Create a new VirtualBox VM instance", input=VBOX_CREATE_SCHEMA, output=VBOX_OBJECT_SCHEMA) def create(request, response): vbox_manager = VirtualBox.instance() vm = yield from vbox_manager.create_vm(request.json["name"], request.json["project_uuid"], request.json.get("uuid"), request.json["vmname"], request.json.get("linked_clone", False)) response.set_status(201) response.json({"name": vm.name, "uuid": vm.uuid, "project_uuid": vm.project.uuid}) @classmethod @Route.post( r"/virtualbox/{uuid}/start", parameters={ "uuid": "VirtualBox VM instance UUID" }, status_codes={ 204: "VirtualBox VM instance started", 400: "Invalid VirtualBox VM instance UUID", 404: "VirtualBox VM instance doesn't exist" }, description="Start a VirtualBox VM instance") def create(request, response): vbox_manager = VirtualBox.instance() yield from vbox_manager.start_vm(request.match_info["uuid"]) response.set_status(204) @classmethod @Route.post( r"/virtualbox/{uuid}/stop", parameters={ "uuid": "VirtualBox VM instance UUID" }, status_codes={ 204: "VirtualBox VM instance stopped", 400: "Invalid VirtualBox VM instance UUID", 404: "VirtualBox VM instance doesn't exist" }, description="Stop a VirtualBox VM instance") def create(request, response): vbox_manager = VirtualBox.instance() yield from vbox_manager.stop_vm(request.match_info["uuid"]) response.set_status(204)