correction

This commit is contained in:
Mickael BOURNEUF 2024-10-08 20:56:56 +02:00
parent fcd33f4372
commit 038ab7de5c
3 changed files with 89 additions and 95 deletions

151
api/vm.py
View File

@ -5,13 +5,15 @@ from pydantic_xml import element, attr, wrapped
from pydantic import UUID4, Field, field_serializer, ConfigDict, ValidationInfo, field_validator
from pydantic import BaseModel as _BaseModel
from pydantic_core import core_schema as cs
import libvirt
from pydantic_core import core_schema
from pydantic.json_schema import GetJsonSchemaHandler, JsonSchemaValue
from deevirt_common.lib.virt import vm as domain
from deevirt_common.schemas import datacenter_schema, storage_schema, network_schema, libvirt
#from deevirt_common.lib.virt import vm as domain
#from deevirt_common.schemas import datacenter_schema, storage_schema, network_schema, configDom
from deevirt_schema.libvirt.dom import config as configDom
class BaseModel(_BaseModel):
class Config:
@ -25,28 +27,28 @@ class BaseModel(_BaseModel):
""" Common """
class VMResource(BaseModel):
class Resource(BaseModel):
"""Experimental"""
name:Optional[str] = Field(default=None, description="Nom du pool")
class VMVCPU(BaseModel):
class VCPU(BaseModel):
value:int = Field(description="Nombre de VCPU")
dedicated:Optional[bool] = Field(default=False, description="VCPU dédié")
hotplug:Optional[bool] = Field(default=False, description="Ajout de VCPU à chaud.")
class VMMemory(BaseModel):
unit:Optional[libvirt.UnitEnum] = Field(default=libvirt.UnitEnum.GiB, description="Unité de mesure.")
class Memory(BaseModel):
unit:Optional[configDom.UnitEnum] = Field(default=configDom.UnitEnum.GiB, description="Unité de mesure.")
value:int = Field(description="Taille de la mémoire.")
hotplug:Optional[bool] = Field(default=False,description="Ajout à chaud de la mémoire.")
class VMOSBootMenu(BaseModel):
class OSBootMenu(BaseModel):
enable:Optional[bool] = Field(default=False,description="Activation du menu de démarrage.")
delay:Optional[int] = Field(default=0, description="Delai maximal pour entrer dans le menu démarrage en millisecondes")
class VMOSBootOrder(BaseModel):
dev:Optional[libvirt.OSBoot.bootEnum] = Field(default=None, description="Périphérique.")
class OSBootOrder(BaseModel):
dev:Optional[configDom.OSBoot.bootEnum] = Field(default=None, description="Périphérique.")
class VMOSInfo(BaseModel):
class OSInfo(BaseModel):
model_config = ConfigDict(from_attributes=True)
name:str = Field(alias="os.name", serialization_alias="name")
@ -54,24 +56,17 @@ class VMOSInfo(BaseModel):
machine:str = Field(alias="os.machine", serialization_alias="architecture")
kernel:str = Field(alias="os.kernel-release", serialization_alias="kernel")
class VMOS(BaseModel):
firmware:libvirt.OS.firmwareEnum = Field(default=libvirt.OS.firmwareEnum.bios, description="Microprogramme")
class OS(BaseModel):
firmware:configDom.OS.firmwareEnum = Field(default=configDom.OS.firmwareEnum.bios, description="Microprogramme")
enrolled_keys:Optional[bool] = Field(default=None, description="Vérification de la signature du chargeur de démarrage")
secure_boot:Optional[bool] = Field(default=None, description="Démarrage sécurisé")
boot_order:Optional[List[libvirt.OSBoot.bootEnum]] = Field(default=None, description="Ordre de démarrage des périphériques")
boot_menu:VMOSBootMenu = Field(default=VMOSBootMenu(), description="Menu de démarrage")
boot_order:Optional[List[configDom.OSBoot.bootEnum]] = Field(default=None, description="Ordre de démarrage des périphériques")
boot_menu:OSBootMenu = Field(default=OSBootMenu(), description="Menu de démarrage")
class VMClock(BaseModel):
class offsetEnum(str, Enum):
utc = "utc"
localtime = "localtime"
timezone = "timezone"
variable = "variable"
absolute = "absolute"
class Clock(BaseModel):
offset:configDom.Clock.offsetEnum = Field(default=configDom.Clock.offsetEnum.utc, description="Sélection de l'offset ?")
offset:offsetEnum = Field(default=offsetEnum.utc, description="Sélection de l'offset ?")
class VMEvent(BaseModel):
class Event(BaseModel):
class on_poweroffEnum(str, Enum):
destroy = "destroy"
restart = "restart"
@ -92,21 +87,21 @@ class VMEvent(BaseModel):
pause = "pause"
ignore = "ignore"
on_poweroff:on_poweroffEnum = Field(default=on_poweroffEnum.destroy, description="Action lors d'un poweroff")
on_reboot:on_rebootEnum = Field(default=on_rebootEnum.restart, description="Action lors d'un redémarrage")
on_crash:on_crashEnum = Field(default=on_crashEnum.restart, description="Action lors d'un crash de la VM")
on_failurelock:on_failurelockEnum = element(default=on_failurelockEnum.ignore, description="A tester")
on_poweroff:configDom.Dom.on_poweroffEnum = Field(default=configDom.Dom.on_poweroffEnum.destroy, description="Action lors d'un poweroff")
on_reboot:configDom.Dom.on_rebootEnum = Field(default=configDom.Dom.on_rebootEnum.restart, description="Action lors d'un redémarrage")
on_crash:configDom.Dom.on_crashEnum = Field(default=configDom.Dom.on_crashEnum.restart, description="Action lors d'un crash de la VM")
on_failurelock:configDom.Dom.on_failurelockEnum = element(default=configDom.Dom.on_failurelockEnum.ignore, description="A tester")
class VMDevicesDisk(BaseModel):
class DevicesDisk(BaseModel):
model_config = ConfigDict(from_attributes=True)
pool_id:UUID4 = Field()
id:UUID4 = Field()
size:int = Field()
unit:libvirt.UnitEnum = Field(default=libvirt.UnitEnum.GiB)
bus:libvirt.DevicesDiskTarget.busEnum = Field(default=libvirt.DevicesDiskTarget.busEnum.scsi)
unit:configDom.UnitEnum = Field(default=configDom.UnitEnum.GiB)
bus:configDom.DevicesDiskTarget.busEnum = Field(default=configDom.DevicesDiskTarget.busEnum.scsi)
class VMDevicesCDROMSource(BaseModel):
class DevicesCDROMSource(BaseModel):
class protocolEnum(str, Enum):
http = "http"
https = "https"
@ -116,60 +111,60 @@ class VMDevicesCDROMSource(BaseModel):
protocol:protocolEnum = attr(default=protocolEnum.https)
name:str = attr()
class VMDevicesCDROM(BaseModel):
class DevicesCDROM(BaseModel):
model_config = ConfigDict(from_attributes=True)
device:libvirt.DevicesDisk.deviceEnum = Field(default=libvirt.DevicesDisk.deviceEnum.cdrom, json_schema_extra={"hidden": True})
source:VMDevicesCDROMSource = element(default=None)
device:configDom.DevicesDisk.deviceEnum = Field(default=configDom.DevicesDisk.deviceEnum.cdrom, json_schema_extra={"hidden": True})
source:DevicesCDROMSource = element(default=None)
class VMDevicesInterfaceGuest(BaseModel):
class DevicesInterfaceGuest(BaseModel):
model_config = ConfigDict(from_attributes=True)
addr:str = Field()
class VMDevicesInterface(BaseModel):
class DevicesInterface(BaseModel):
model_config = ConfigDict(from_attributes=True)
switch_id:UUID4
id:UUID4
mac_addr:str = Field()
class VMGraphics(BaseModel):
class Graphics(BaseModel):
port:int = Field(default=-1)
autoport:bool = Field(default=False)
websocket:int = Field(default=-1)
password:Optional[str] = Field(default=None)
keymap:libvirt.Graphics.keymapEnum = Field(default=libvirt.Graphics.keymapEnum.fr)
keymap:configDom.Graphics.keymapEnum = Field(default=configDom.Graphics.keymapEnum.fr)
power_control:bool = Field(default=False)
class VMAudio(BaseModel):
class Audio(BaseModel):
pass
class VMVideoModel(BaseModel):
type:libvirt.VideoModel.typeEnum = Field(default=libvirt.VideoModel.typeEnum.cirrus)
class VideoModel(BaseModel):
type:configDom.VideoModel.typeEnum = Field(default=configDom.VideoModel.typeEnum.cirrus)
vram:int = Field(default=16384)
primary:libvirt.YesNoEnum = Field(default=libvirt.YesNoEnum.YES)
primary:configDom.YesNoEnum = Field(default=configDom.YesNoEnum.YES)
class VMVideo(BaseModel):
model:VMVideoModel = element()
class Video(BaseModel):
model:VideoModel = element()
class VMWatchdog(BaseModel):
model:libvirt.Watchdog.modelEnum = Field(default=libvirt.Watchdog.modelEnum.itco)
action:libvirt.Watchdog.actionEnum = Field(default=libvirt.Watchdog.actionEnum.reset)
class Watchdog(BaseModel):
model:configDom.Watchdog.modelEnum = Field(default=configDom.Watchdog.modelEnum.itco)
action:configDom.Watchdog.actionEnum = Field(default=configDom.Watchdog.actionEnum.reset)
class VMTPM(BaseModel):
model:libvirt.TPM.modelEnum = attr(default=libvirt.TPM.modelEnum.tpm_tis)
version:libvirt.TPMBackend.versionEnum = Field(default=libvirt.TPMBackend.versionEnum.v20)
class TPM(BaseModel):
model:configDom.TPM.modelEnum = attr(default=configDom.TPM.modelEnum.tpm_tis)
version:configDom.TPMBackend.versionEnum = Field(default=configDom.TPMBackend.versionEnum.v20)
class VMDevices(BaseModel):
disks:Optional[List[VMDevicesDisk]] = Field(default=None, description="Disques virtuel")
cdrom:VMDevicesCDROM = Field(default=None, description="CDROM virtuel")
interfaces:Optional[List[VMDevicesInterface]] = Field(default=None, description="Interfaces réseau")
graphics:Optional[VMGraphics] = Field(default=None, description="Console VNC")
audio:VMAudio = Field(default=None, description="Carte Audio")
video:VMVideo = Field(default=None, description="Carte Vidéo")
watchdog:VMWatchdog = Field(default=None, description="Chien de garde")
tpm:VMTPM = Field(default=None, description="Puce de sécurité")
class Devices(BaseModel):
disks:Optional[List[DevicesDisk]] = Field(default=None, description="Disques virtuel")
cdrom:DevicesCDROM = Field(default=None, description="CDROM virtuel")
interfaces:Optional[List[DevicesInterface]] = Field(default=None, description="Interfaces réseau")
graphics:Optional[Graphics] = Field(default=None, description="Console VNC")
audio:Audio = Field(default=None, description="Carte Audio")
video:Video = Field(default=None, description="Carte Vidéo")
watchdog:Watchdog = Field(default=None, description="Chien de garde")
tpm:TPM = Field(default=None, description="Puce de sécurité")
class VM(BaseModel):
model_config = ConfigDict(from_attributes=True)
@ -181,25 +176,25 @@ class VM(BaseModel):
description:Optional[str] = Field(default=None)
# CPU Allocation
vcpu:VMVCPU = Field()
vcpu:VCPU = Field()
# Memory Allocation
memory:VMMemory = Field()
memory:Memory = Field()
# Pool of resource (Experimental)
resource:VMResource = Field(default=VMResource(), description="Pool de resources")
resource:Resource = Field(default=Resource(), description="Pool de resources")
# BIOS BootLoader
os:VMOS = Field(default=VMOS(), description="Options VM: Options de démarrage.")
os:OS = Field(default=OS(), description="Options VM: Options de démarrage.")
# Clock configuration
clock:VMClock = Field(default=VMClock(), description="Options VM: Gestion de l'horloge")
clock:Clock = Field(default=Clock(), description="Options VM: Gestion de l'horloge")
# Event configuration
event:VMEvent = Field(default=VMEvent(), description="Options VM: Gestion des évènements")
event:Event = Field(default=Event(), description="Options VM: Gestion des évènements")
# Devices
devices:VMDevices = Field(default=VMDevices(), description="Matériel virtuel: Périphériques")
devices:Devices = Field(default=Devices(), description="Matériel virtuel: Périphériques")
"""VM LIST GET"""
class VMs(BaseModel):
@ -217,19 +212,19 @@ class VMs(BaseModel):
datacenter:Optional[Datacenter] = Field(default=[])
"""VM GET"""
class VMGetVCPU(VMVCPU):
class VMGetVCPU(VCPU):
max:Optional[int] = Field(default=None, description="Maximum de VCPUs")
class VMGetOS(VMOS):
guest_info:Optional[VMOSInfo] = Field(default=None, description="Information de l'OS client")
class VMGetOS(OS):
guest_info:Optional[OSInfo] = Field(default=None, description="Information de l'OS client")
class VMGetDevicesDisk(VMDevicesDisk):
class VMGetDevicesDisk(DevicesDisk):
allocated:float = Field(default=None)
class VMGetDevicesInterface(VMDevicesInterface):
guest_info:Optional[List[VMDevicesInterfaceGuest]] = Field(default=None, description="Information de configuration de la carte réseau.")
class VMGetDevicesInterface(DevicesInterface):
guest_info:Optional[List[DevicesInterfaceGuest]] = Field(default=None, description="Information de configuration de la carte réseau.")
class VMGetDevices(VMDevices):
class VMGetDevices(Devices):
disks:Optional[List[VMGetDevicesDisk]] = Field(default=None, description="Disques virtuel")
interfaces:Optional[List[VMGetDevicesInterface]] = Field(default=None, description="Interfaces réseau")
@ -240,7 +235,7 @@ class VMGet(VM):
devices:VMGetDevices = Field(default=VMGetDevices(), description="Matériel virtuel: Périphériques")
"""VM POST"""
class VMCreate(VM):
class VMPost(VM):
id:UUID4 = Field(default_factory=uuid4)
datacenter_id:UUID4 = Field()
@ -248,8 +243,8 @@ class VMCreate(VM):
class VMDelete(BaseModel):
id:UUID4 = Field()
class VMHardDisk(BaseModel):
class HardDisk(BaseModel):
pass
class VMNetInterfaceCreate(BaseModel):
class NetInterfaceCreate(BaseModel):
pass

View File

@ -4,7 +4,21 @@ from uuid import uuid4
from pydantic import UUID4
from pydantic_xml import BaseXmlModel, attr, element, wrapped
from deevirt_schema.libvirt.enum import YesNoEnum, OnOffEnum, UnitEnum
from enum import Enum
class YesNoEnum(str, Enum):
YES = "yes"
NO = "no"
class OnOffEnum(str, Enum):
ON = "on"
OFF = "off"
class UnitEnum(str, Enum):
KiB = "KiB"
MiB = "MiB"
GiB = "GiB"
TiB = "TiB"
class Metadata(BaseXmlModel, search_mode='ordered'):
# wrapped("metadata", element(default=None, ns="deevirt", nsmap={'deevirt': 'https://deevirt.com/'}))
@ -613,7 +627,7 @@ class Devices(BaseXmlModel, search_mode='ordered'):
watchdog:Optional[Watchdog] = element(default=None)
tpm:Optional[TPM] = element(default=None)
class VM(BaseXmlModel, tag='domain', search_mode='ordered'):
class Dom(BaseXmlModel, tag='domain', search_mode='ordered'):
class on_poweroffEnum(str, Enum):
destroy = "destroy"
restart = "restart"

View File

@ -1,15 +0,0 @@
from enum import Enum
class YesNoEnum(str, Enum):
YES = "yes"
NO = "no"
class OnOffEnum(str, Enum):
ON = "on"
OFF = "off"
class UnitEnum(str, Enum):
KiB = "KiB"
MiB = "MiB"
GiB = "GiB"
TiB = "TiB"