import os import base64 import random from datetime import datetime from django.db.models import F, Q from planetstack.config import Config from observer.openstacksyncstep import OpenStackSyncStep from core.models.node import Node from core.models.deployment import Deployment from core.models.site import Site class SyncNodes(OpenStackSyncStep): provides=[Node] requested_interval=0 def fetch_pending(self): config = Config() deployment = Deployment.objects.filter(name=config.plc_deployment)[0] login_bases = ['princeton', 'stanford', 'gt', 'uw', 'mpisws'] sites = Site.objects.filter(login_base__in=login_bases) # collect local nodes nodes = Node.objects.all() node_hostnames = [node.name for node in nodes] # collect nova nodes # generate list of new nodes new_nodes = [] compute_nodes = self.driver.shell.nova.hypervisors.list() for compute_node in compute_nodes: if compute_node.hypervisor_hostname not in node_hostnames: # pick a random site to add the node to for now site_index = random.randint(0, len(sites)) node = Node(name=compute_node.hypervisor_hostname, site=sites[site_index], deployment=deployment) new_nodes.append(node) return new_nodes def sync_record(self, node): node.save()