2020-02-23 10:55:57 +00:00
|
|
|
import uuid
|
2020-02-21 15:33:37 +00:00
|
|
|
from django.db import models
|
|
|
|
from django.contrib.auth import get_user_model
|
|
|
|
|
2020-02-23 10:42:03 +00:00
|
|
|
from django.contrib.postgres.fields import JSONField
|
2020-02-21 15:33:37 +00:00
|
|
|
|
|
|
|
class VM(models.Model):
|
2020-02-23 10:42:03 +00:00
|
|
|
vmid = models.IntegerField(primary_key=True)
|
2020-02-23 10:59:09 +00:00
|
|
|
uuid = models.UUIDField(default=uuid.uuid4, editable=False, unique=True)
|
2020-02-21 15:33:37 +00:00
|
|
|
owner = models.ForeignKey(get_user_model(), on_delete=models.CASCADE)
|
2020-02-23 10:42:03 +00:00
|
|
|
data = JSONField()
|
|
|
|
|
|
|
|
|
2020-02-23 10:55:57 +00:00
|
|
|
@property
|
2020-02-23 10:42:03 +00:00
|
|
|
def cores(self):
|
2020-02-23 10:55:57 +00:00
|
|
|
return int(self.data['TEMPLATE']['VCPU'])
|
2020-02-23 10:42:03 +00:00
|
|
|
|
2020-02-23 14:09:58 +00:00
|
|
|
@property
|
2020-02-23 10:42:03 +00:00
|
|
|
def ram_in_gb(self):
|
|
|
|
return (int(self.data['TEMPLATE']['MEMORY'])/1024.)
|
|
|
|
|
2020-02-23 10:55:57 +00:00
|
|
|
@property
|
2020-02-23 10:42:03 +00:00
|
|
|
def disks(self):
|
|
|
|
"""
|
|
|
|
If there is no disk then the key DISK does not exist.
|
|
|
|
|
|
|
|
If there is only one disk, we have a dictionary in the database.
|
|
|
|
|
|
|
|
If there are multiple disks, we have a list of dictionaries in the database.
|
|
|
|
"""
|
|
|
|
|
|
|
|
if not 'DISK' in self.data['TEMPLATE']['DISK']:
|
|
|
|
return []
|
|
|
|
elif type(self.data['TEMPLATE']['DISK']) is dict:
|
|
|
|
return [ self.data['TEMPLATE']['DISK'] ]
|
|
|
|
else:
|
|
|
|
return self.data['TEMPLATE']['DISK']
|