blob: 049b3165cf8eb068c281db4f7dc570eb3d1e2e51 [file] [log] [blame]
import os
import base64
from django.db.models import F, Q
from planetstack.config import Config
from observer.syncstep import SyncStep
from core.models import Service
from hpc.models import HpcService
from util.logger import Logger, logging
logger = Logger(level=logging.INFO)
class SyncHpcService(SyncStep):
provides=[HpcService]
requested_interval=0
def fetch_pending(self):
return HpcService.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
def extract_slice_info(hpc_service):
""" Produce a dict that describes the slices for the CMI
slice_coblitz = <name of coblitz slice>
service_coblitz = <name of coblitz service>
hostname_coblitz = <name of first coblitz slice>
hostnames_coblitz = <name_of_first_cob_slice>,<name_of_second_cob_slice>,...
slice_cmi = <name of cmi slice>
...
"""
slicenames = {}
slicehosts = {}
for slice in hpc_service.service.all():
name = slice.name
if not ("_" in name):
continue
if "coblitz" in name:
slicenames["coblitz"] = name
slicehosts["coblitz"] = [sliver.node.name for sliver in slice.slivers.all()]
elif "cmi" in name:
slicenames["cmi"] = name
slicehosts["cmi"] = [sliver.node.name for sliver in slice.slivers.all()]
base_hrn = None
if "coblitz" in slicenames:
base_hrn = slicenames["coblitz"].split("_")[0]
mapping = {}
mapping["base_hrn"] = base_hrn
for (k,v) in slicenames.items():
mapping["slice_" + k] = v
mapping["service_" + k] = v.split("_",1)[1]
for (k,v) in slicehosts.items()
mapping["hostname_" + k] = v[0]
mapping["hostnames_" + k] = ",".join(v)
return mapping
def write_slices_file(self, hpc_service):
mapping = self.extract_slicenames(hpc_service)
fn = "/tmp/slices"
f = open(fn, "w")
f.write("""
ENABLE_PLC=True
ENABLE_PS=False
BASE_HRN="%(base_hrn)"
RELEVANT_SERVICE_NAMES=['%(service_coblitz)', '%(service_dnsredir)', '%(service_dnsdemux)']
COBLITZ_SLICE_NAME="%(slice_coblitz)"
COBLITZ_SLICE_ID=1
COBLITZ_PS_SLICE_NAME="%(slice_coblitz)"
DNSREDIR_SLICE_NAME="%(slice_dnsredir)"
DNSREDIR_SLICE_ID=2
DNSREDIR_PS_SLICE_NAME="%(slice_dnsredir)"
DNSDEMUX_SLICE_NAME="%(slice_dnsdemux)"
DNSDEMUX_SLICE_ID=3
DNSDEMUX_PS_SLICE_NAME="%(slice_dnsdemux)"
CMI_URL="http://%(hostname_cmi)"
CMI_HTTP_PORT="8004"
CMI_HTTPS_PORT="8003"
PUPPET_MASTER_HOSTNAME="%(hostname_cmi)"
PUPPET_MASTER_PORT="8140"
""")
def sync_record(self, hpc_service):
logger.info("sync'ing hpc_service %s" % str(hpc_service))
hpc_service.save()