blob: afd319433ac95af20aa48b4b7aa62e6d78b1ed5b [file] [log] [blame]
Omar Abdelkader392239a2017-08-03 14:53:26 -07001from core.models.plcorebase import *
2from models_decl import VMMService_decl
Omar Abdelkader2b9c3d42017-09-06 19:21:12 -05003from models_decl import VMMVendor_decl
Omar Abdelkader392239a2017-08-03 14:53:26 -07004from models_decl import VMMTenant_decl
5
Omar Abdelkadereef4b2d2017-08-07 19:31:43 -06006from django.db import models
7from core.models import Service, PlCoreBase, Slice, Instance, Tenant, TenantWithContainer, Node, Image, User, Flavor, NetworkParameter, NetworkParameterType, Port, AddressPool
8from core.models.plcorebase import StrippedCharField
9import os
10from django.db import models, transaction
11from django.forms.models import model_to_dict
12from django.db.models import *
13from operator import itemgetter, attrgetter, methodcaller
14from core.models import Tag
15from core.models.service import LeastLoadedNodeScheduler
16import traceback
17from xos.exceptions import *
18from xos.config import Config
Omar Abdelkadereef4b2d2017-08-07 19:31:43 -060019
Omar Abdelkader392239a2017-08-03 14:53:26 -070020class VMMService(VMMService_decl):
21 class Meta:
22 proxy = True
23
Omar Abdelkader10e37d22017-08-30 10:41:29 -060024 def create_tenant(self, **kwargs):
25 t = VMMTenant(kind="vEPC", provider_service=self, connect_method="na", **kwargs)
26 t.save()
27 return t
28
Omar Abdelkader2b9c3d42017-09-06 19:21:12 -050029class VMMVendor(VMMVendor_decl):
30 class Meta:
31 proxy = True
32
Omar Abdelkader392239a2017-08-03 14:53:26 -070033class VMMTenant(VMMTenant_decl):
34 class Meta:
35 proxy = True
36
37 def __init__(self, *args, **kwargs):
38 vmmservice = VMMService.get_service_objects().all()
39 if vmmservice:
40 self._meta.get_field(
41 "provider_service").default = vmmservice[0].id
42 super(VMMTenant, self).__init__(*args, **kwargs)
43
Omar Abdelkader2b9c3d42017-09-06 19:21:12 -050044 @property
45 def image(self):
46 if not self.vmm_vendor:
47 return super(VMMTenant, self).image
48 return self.vmm_vendor.image
49
50 def save_instance(self, instance):
51 if self.vmm_vendor:
52 instance.flavor = self.vmm_vendor.flavor
53 super(VMMTenant, self).save_instance(instance)
54
Omar Abdelkader392239a2017-08-03 14:53:26 -070055 def save(self, *args, **kwargs):
Omar Abdelkader10e37d22017-08-30 10:41:29 -060056 if not self.creator:
57 if not getattr(self, "caller", None):
58 raise XOSProgrammingError("VMMTenant's self.caller was not set")
59 self.creator = self.caller
60 if not self.creator:
61 raise XOSProgrammingError("VMMTenant's self.creator was not set")
62
Omar Abdelkader392239a2017-08-03 14:53:26 -070063 super(VMMTenant, self).save(*args, **kwargs)
64 # This call needs to happen so that an instance is created for this
65 # tenant is created in the slice. One instance is created per tenant.
66 model_policy_vmmtenant(self.pk)
67
68 def delete(self, *args, **kwargs):
69 # Delete the instance that was created for this tenant
70 self.cleanup_container()
71 super(VMMTenant, self).delete(*args, **kwargs)
72
73def model_policy_vmmtenant(pk):
74 # This section of code is atomic to prevent race conditions
75 with transaction.atomic():
76 # We find all of the tenants that are waiting to update
77 tenant = VMMTenant.objects.select_for_update().filter(pk=pk)
78 if not tenant:
79 return
80 # Since this code is atomic it is safe to always use the first tenant
81 tenant = tenant[0]
82 tenant.manage_container()