2019-11-18 17:39:57 +00:00
|
|
|
import json
|
|
|
|
from os.path import join
|
|
|
|
from uuid import uuid4
|
|
|
|
|
2019-12-14 15:23:31 +00:00
|
|
|
from .etcd_wrapper import PsuedoEtcdEntry
|
2019-11-18 17:39:57 +00:00
|
|
|
from .classes import SpecificEtcdEntryBase
|
|
|
|
|
|
|
|
|
|
|
|
class RequestType:
|
|
|
|
CreateVM = "CreateVM"
|
|
|
|
ScheduleVM = "ScheduleVM"
|
|
|
|
StartVM = "StartVM"
|
|
|
|
StopVM = "StopVM"
|
|
|
|
InitVMMigration = "InitVMMigration"
|
|
|
|
TransferVM = "TransferVM"
|
|
|
|
DeleteVM = "DeleteVM"
|
|
|
|
|
|
|
|
|
|
|
|
class RequestEntry(SpecificEtcdEntryBase):
|
|
|
|
def __init__(self, e):
|
2019-12-29 18:48:04 +00:00
|
|
|
self.destination_sock_path = None
|
2019-12-28 10:39:11 +00:00
|
|
|
self.destination_host_key = None
|
2019-11-18 17:39:57 +00:00
|
|
|
self.type = None # type: str
|
|
|
|
self.migration = None # type: bool
|
|
|
|
self.destination = None # type: str
|
|
|
|
self.uuid = None # type: str
|
|
|
|
self.hostname = None # type: str
|
|
|
|
super().__init__(e)
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def from_scratch(cls, request_prefix, **kwargs):
|
2019-12-30 09:35:07 +00:00
|
|
|
e = PsuedoEtcdEntry(
|
|
|
|
join(request_prefix, uuid4().hex),
|
|
|
|
value=json.dumps(kwargs).encode("utf-8"),
|
|
|
|
value_in_json=True,
|
|
|
|
)
|
2019-11-18 17:39:57 +00:00
|
|
|
return cls(e)
|
|
|
|
|
|
|
|
|
|
|
|
class RequestPool:
|
|
|
|
def __init__(self, etcd_client, request_prefix):
|
|
|
|
self.client = etcd_client
|
|
|
|
self.prefix = request_prefix
|
|
|
|
|
|
|
|
def put(self, obj: RequestEntry):
|
|
|
|
if not obj.key.startswith(self.prefix):
|
|
|
|
obj.key = join(self.prefix, obj.key)
|
|
|
|
|
|
|
|
self.client.put(obj.key, obj.value, value_in_json=True)
|