Merge branch 'master' of ssh://git.planet-lab.org/git/plstackapi
diff --git a/planetstack/openstack/client.py b/planetstack/openstack/client.py
index df340f6..72c5cb4 100644
--- a/planetstack/openstack/client.py
+++ b/planetstack/openstack/client.py
@@ -176,7 +176,7 @@
         token = self.keystone.client.tokens.authenticate(username=self.keystone.username, password=self.keystone.password, tenant_name=self.keystone.tenant)
         #self.glance = GlanceClient(*args, **kwds)
         
-        self.glanceclient = GlanceClientNew('1', endpoint='http://%s:9292' % hostname, token=token.id, **kwds)
+        self.glanceclient = GlanceClientNew('1', endpoint='https://%s:9292' % hostname, token=token.id, **kwds)
         self.nova = NovaClient(*args, **kwds)
         # self.nova_db = NovaDB(*args, **kwds)
         self.quantum = QuantumClient(*args, **kwds)
diff --git a/planetstack/openstack_observer/ceilometer.py b/planetstack/openstack_observer/ceilometer.py
index f93dc1a..7383524 100644
--- a/planetstack/openstack_observer/ceilometer.py
+++ b/planetstack/openstack_observer/ceilometer.py
@@ -11,16 +11,16 @@
 from core.models import *
 
 def object_to_filter(model_name, pk):
-	filter_dict = {
-		'Slice':[Slice, 'tenant_id', 'project_id'],
-		'Sliver':[Sliver, 'instance_id', 'resource_id'],
-		'Site':[Site, 'tenant_id', 'project_id']
-	}
-	
-	mod,field,tag = filter_dict[model_name]
-	obj = mod.objects.get(pk=pk)
-	return '%s=%s'%(tag,mod[field])
-	
+    filter_dict = {
+            'Slice':[Slice, 'tenant_id', 'project_id'],
+            'Sliver':[Sliver, 'instance_id', 'resource_id'],
+            'Site':[Site, 'tenant_id', 'project_id']
+    }
+
+    mod,field,tag = filter_dict[model_name]
+    obj = mod.objects.get(pk=pk)
+    return '%s=%s'%(tag,mod[field])
+
 
 def cli_to_array(cli_query):
     '''This converts from the cli list of queries to what is required
@@ -78,8 +78,8 @@
 
     stats.average/=len(meters)
     return stats
-        
-                
+
+
 
 class CeilometerDriver(MonitorDriver):
     def get_meter(self, meter, obj, pk, keystone=None):
@@ -95,14 +95,14 @@
         token = ceilometer_client.auth_token
 
         ceilo_endpoint = client._get_endpoint(ceilometer_client, **keystone)
-	#ceilometer = client.get_client(2, username=keystone['username'], password=keystone['password'], tenant_name=keystone['tenant_name'], auth_url=keystone['auth_url'])
+        #ceilometer = client.get_client(2, username=keystone['username'], password=keystone['password'], tenant_name=keystone['tenant_name'], auth_url=keystone['auth_url'])
 
         ceilometer = client.Client('2',endpoint = ceilo_endpoint, token = lambda: token)
 
         cur_ts = datetime.datetime.fromtimestamp(time.time()-86400)
         str_ts = cur_ts.strftime('%Y-%m-%dT%H:%M:%S')
-        
-		object_filter = object_to_filter(obj, pk)
+
+        object_filter = object_to_filter(obj, pk)
         filter=';'.join([object_filter,'timestamp>%s'%str_ts])
         #query = cli_to_array("project_id=124de34266b24f57957345cdb43cc9ff;timestamp>2014-12-11T00:00:00")
         query = cli_to_array(filter)
@@ -111,4 +111,3 @@
 
         stats = meters_to_stats(meters)
         return stats
-
diff --git a/planetstack/openstack_observer/steps/__init__.py b/planetstack/openstack_observer/steps/__init__.py
index 72b0b12..6eec315 100644
--- a/planetstack/openstack_observer/steps/__init__.py
+++ b/planetstack/openstack_observer/steps/__init__.py
@@ -3,3 +3,4 @@
 from .sync_controller_users import SyncControllerUsers
 from .sync_controller_site_privileges import SyncControllerSitePrivileges
 from .sync_controller_slice_privileges import SyncControllerSlicePrivileges
+from .sync_controller_networks import SyncControllerNetworks
diff --git a/planetstack/openstack_observer/steps/sync_controller_networks.py b/planetstack/openstack_observer/steps/sync_controller_networks.py
index fa1f439..c90e4df 100644
--- a/planetstack/openstack_observer/steps/sync_controller_networks.py
+++ b/planetstack/openstack_observer/steps/sync_controller_networks.py
@@ -13,7 +13,7 @@
 
 logger = Logger(level=logging.INFO)
 
-class SyncControllerNetwork(OpenStackSyncStep):
+class SyncControllerNetworks(OpenStackSyncStep):
     requested_interval = 0
     provides=[Network, ControllerNetwork, Sliver]
 
@@ -42,8 +42,8 @@
 
 	    network_fields = {'endpoint':controller_network.controller.auth_url,
 			'admin_user':slice.creator.email, # XXX: FIXME
-			'tenant_name':slice.slicename, # XXX: FIXME
-			'admin_password':controller_network.controller.admin_password,
+			'tenant_name':slice.name, # XXX: FIXME
+			'admin_password':slice.creator.remote_password,
 			'name':network_name,
 			'subnet_name':subnet_name,
 			'ansible_tag':'%s-%s@%s'%(network_name,slice.slicename,controller_network.controller.name),
diff --git a/planetstack/openstack_observer/steps/sync_controller_networks.yaml b/planetstack/openstack_observer/steps/sync_controller_networks.yaml
index c85ec55..9b42ea6 100644
--- a/planetstack/openstack_observer/steps/sync_controller_networks.yaml
+++ b/planetstack/openstack_observer/steps/sync_controller_networks.yaml
@@ -6,6 +6,7 @@
         auth_url={{ endpoint }} 
         login_username={{ admin_user }}
         tenant_name={{ tenant_name }}
+        login_tenant_name={{ tenant_name }}
         login_password={{ admin_password }}
         name={{ name }}
         {% if delete %}
@@ -13,11 +14,12 @@
         {% else %}
         state=present
         {% endif %}
-        shared: true
+        shared=true
   - quantum_subnet:
         auth_url={{ endpoint }} 
         login_username={{ admin_user }}
         tenant_name={{ tenant_name }}
+        login_tenant_name={{ tenant_name }}
         login_password={{ admin_password }}
         name={{ subnet_name }} 
         network_name={{ name }} 
@@ -25,5 +27,5 @@
         state=absent
         {% else %}
         state=present 
-        cidr = {{ cidr }}
+        cidr={{ cidr }}
         {% endif %}
diff --git a/planetstack/openstack_observer/steps/sync_images.py b/planetstack/openstack_observer/steps/sync_images.py
deleted file mode 100644
index 9b915fb..0000000
--- a/planetstack/openstack_observer/steps/sync_images.py
+++ /dev/null
@@ -1,42 +0,0 @@
-import os
-import base64
-from django.db.models import F, Q
-from planetstack.config import Config
-from observer.openstacksyncstep import OpenStackSyncStep
-from core.models.image import Image
-
-class SyncImages(OpenStackSyncStep):
-    provides=[Image]
-    requested_interval=0
-
-    def fetch_pending(self, deleted):
-        # Images come from the back end
-        # You can't delete them
-        if (deleted):
-            return []
-
-        # get list of images on disk
-        images_path = Config().observer_images_directory 
-        available_images = {}
-        for f in os.listdir(images_path):
-            if os.path.isfile(os.path.join(images_path ,f)):
-                available_images[f] = os.path.join(images_path ,f)
-
-        images = Image.objects.all()
-        image_names = [image.name for image in images]
-
-        for image_name in available_images:
-            #remove file extension
-            clean_name = ".".join(image_name.split('.')[:-1])
-            if clean_name not in image_names:
-                image = Image(name=clean_name,
-                              disk_format='raw',
-                              container_format='bare', 
-                              path = available_images[image_name])
-                image.save()
-       
-        
-        return Image.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None)) 
-
-    def sync_record(self, image):
-        image.save()
diff --git a/planetstack/openstack_observer/steps/sync_networks.py b/planetstack/openstack_observer/steps/sync_networks.py
deleted file mode 100644
index 9f36ed5..0000000
--- a/planetstack/openstack_observer/steps/sync_networks.py
+++ /dev/null
@@ -1,26 +0,0 @@
-import os
-import base64
-from django.db.models import F, Q
-from planetstack.config import Config
-from observer.openstacksyncstep import OpenStackSyncStep
-from core.models.network import *
-from util.logger import Logger, logging
-from observer.steps.sync_controller_networks import *
-
-logger = Logger(level=logging.INFO)
-
-class SyncNetworks(OpenStackSyncStep):
-    provides=[Network]
-    requested_interval = 0
-
-    def sync_record(self, network):
-        network.save()
-
-    def delete_record(self, network):
-        controller_networks_deleter = SyncControllerNetwork().delete_record
-        for controller_network in ControllerNetwork.objects.filter(network=network):
-            try:
-                controller_network_deleter(controller_network)    
-            except Exception,e:
-                logger.log_exc("Failed to delete controller network %s" % controller_network)
-                raise e
diff --git a/planetstack/openstack_observer/steps/sync_roles.py b/planetstack/openstack_observer/steps/sync_roles.py
deleted file mode 100644
index f08a693..0000000
--- a/planetstack/openstack_observer/steps/sync_roles.py
+++ /dev/null
@@ -1,41 +0,0 @@
-import os
-import base64
-from django.db.models import F, Q
-from planetstack.config import Config
-from observer.openstacksyncstep import OpenStackSyncStep
-from core.models.role import Role
-from core.models.site import SiteRole, Controller, ControllerRole
-from core.models.slice import SliceRole
-
-class SyncRoles(OpenStackSyncStep):
-    provides=[Role]
-    requested_interval=0
-
-    def fetch_pending(self, deleted):
-        # Deleting roles is not supported yet
-        if (deleted):
-            return []
-
-        site_roles = SiteRole.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
-        slice_roles = SliceRole.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
-        controller_roles = ControllerRole.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
-
-        roles = []
-        for site_role in site_roles:
-            roles.append(site_role)
-        for slice_role in slice_roles:
-            roles.append(slice_role)
-        for controller_role in controller_roles:
-            roles.append(controller_role)
-
-        return roles
-
-
-    def sync_record(self, role):
-        if not role.enacted:
-            controllers = Controller.objects.all()
-       	    for controller in controllers:
-                driver = self.driver.admin_driver(controller=controller)
-                driver.create_role(role.role)
-            role.save()
-    
diff --git a/planetstack/openstack_observer/steps/sync_site_privileges.py b/planetstack/openstack_observer/steps/sync_site_privileges.py
deleted file mode 100644
index bfc04b3..0000000
--- a/planetstack/openstack_observer/steps/sync_site_privileges.py
+++ /dev/null
@@ -1,30 +0,0 @@
-import os
-import base64
-from django.db.models import F, Q
-from planetstack.config import Config
-from observer.openstacksyncstep import OpenStackSyncStep
-from core.models import User, ControllerUser, SitePrivilege, SiteDeployment   
-
-class SyncSitePrivilege(OpenStackSyncStep):
-    requested_interval=0
-    provides=[SitePrivilege]
-
-    def fetch_pending(self, deleted):
-        # Deleting site privileges is not supported yet
-        if (deleted):
-            return []
-
-        return SitePrivilege.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
-
-    def sync_record(self, site_priv):
-        # sync site privileges at all site controllers
-        ctrl_site_deployments = SiteDeployment.objects.filter(site_deployment__site=site_priv.site)
-        for ctrl_site_deployment in ctrl_site_deployments:
-            controller_users = ControllerUser.objects.filter(controller=ctrl_site_deployment.controller,
-                                                              user=site_priv.user)
-            if controller_users:
-                kuser_id  = controller_users[0].kuser_id
-                driver = self.driver.admin_driver(controller=ctrl_site_deployment.controller)
-                driver.add_user_role(kuser_id,
-                                     ctrl_site_deployment.controller.tenant_id,
-                                     site_priv.role.role)
diff --git a/planetstack/openstack_observer/steps/sync_slice_memberships.py b/planetstack/openstack_observer/steps/sync_slice_memberships.py
deleted file mode 100644
index e95c533..0000000
--- a/planetstack/openstack_observer/steps/sync_slice_memberships.py
+++ /dev/null
@@ -1,36 +0,0 @@
-import os
-import base64
-from django.db.models import F, Q
-from planetstack.config import Config
-from observer.openstacksyncstep import OpenStackSyncStep
-from core.models.slice import *
-from core.models.controllerusers import ControllerUser
-from util.logger import Logger, logging
-
-logger = Logger(level=logging.INFO)
-
-class SyncSliceMemberships(OpenStackSyncStep):
-    requested_interval=0
-    provides=[SlicePrivilege]
-
-    def fetch_pending(self, deleted):
-        # Deleting site memberships is not supported yet
-        if (deleted):
-            return []
-        return SlicePrivilege.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
-
-    def sync_record(self, slice_memb):
-        # sync slice memberships at all slice controllers 
-        logger.info("syncing slice privilege: %s %s" % (slice_memb.slice.name, slice_memb.user.email))
-        slice_controllers = ControllerSlice.objects.filter(slice=slice_memb.slice)
-        for slice_controller in slice_controllers:
-            if not slice_controller.tenant_id:
-                continue
-            controller_users = ControllerUser.objects.filter(controller=slice_controller.controller,
-                                                              user=slice_memb.user)
-            if controller_users:
-                kuser_id  = controller_users[0].kuser_id
-                driver = self.driver.admin_driver(controller=slice_controller.controller.name)
-                driver.add_user_role(kuser_id,
-                                     slice_controller.tenant_id,
-                                     slice_memb.role.role)
diff --git a/planetstack/openstack_observer/steps/sync_slices.py b/planetstack/openstack_observer/steps/sync_slices.py
deleted file mode 100644
index 99ed44c..0000000
--- a/planetstack/openstack_observer/steps/sync_slices.py
+++ /dev/null
@@ -1,30 +0,0 @@
-import os
-import base64
-from netaddr import IPAddress, IPNetwork
-from django.db.models import F, Q
-from planetstack.config import Config
-from observer.openstacksyncstep import OpenStackSyncStep
-from core.models.slice import Slice, ControllerSlice
-from util.logger import Logger, logging
-from observer.steps.sync_controller_slices import *
-
-logger = Logger(level=logging.INFO)
-
-class SyncSlices(OpenStackSyncStep):
-    provides=[Slice]
-    requested_interval=0
-
-    def sync_record(self, slice):
-        for controller_slice in ControllerSlice.objects.filter(slice=slice):
-            # bump the 'updated' timestamp and trigger observer to update
-            # slice across all controllers 
-            controller_slice.save()    
-
-    def delete_record(self, slice):
-        controller_slice_deleter = SyncControllerSlice().delete_record
-        for controller_slice in ControllerSlice.objects.filter(slice=slice):
-            try:
-                controller_slice_deleter(controller_slice)
-            except Exception,e:
-                logger.log_exc("Failed to delete controller_slice %s" % controller_slice) 
-                raise e
diff --git a/planetstack/openstack_observer/steps/sync_slivers.py b/planetstack/openstack_observer/steps/sync_slivers.py
index 8adb50c..8488b66 100644
--- a/planetstack/openstack_observer/steps/sync_slivers.py
+++ b/planetstack/openstack_observer/steps/sync_slivers.py
@@ -58,7 +58,7 @@
                              if network.template.shared_network_name]
 
         #driver = self.driver.client_driver(caller=sliver.creator, tenant=sliver.slice.name, controller=sliver.controllerNetwork)
-        driver = self.driver.admin_driver(tenant='admin', controller=sliver.controllerNetwork)
+        driver = self.driver.admin_driver(tenant='admin', controller=sliver.node.site_deployment.controller)
         nets = driver.shell.quantum.list_networks()['networks']
         for net in nets:
             if net['name'] in network_templates:
@@ -70,7 +70,7 @@
                     nics.append(net['id'])
 
         # look up image id
-        controller_driver = self.driver.admin_driver(controller=sliver.controllerNetwork)
+        controller_driver = self.driver.admin_driver(controller=sliver.node.site_deployment.controller)
         image_id = None
         images = controller_driver.shell.glanceclient.images.list()
         for image in images:
@@ -102,7 +102,7 @@
         if sliver.userData:
             userData = sliver.userData
 
-        controller = sliver.controllerNetwork
+        controller = sliver.node.site_deployment.controller
         tenant_fields = {'endpoint':controller.auth_url,
                      'admin_user': sliver.creator.username,
                      'admin_password': sliver.creator.password,
diff --git a/planetstack/openstack_observer/steps/sync_users.py b/planetstack/openstack_observer/steps/sync_users.py
deleted file mode 100644
index 4cb1a26..0000000
--- a/planetstack/openstack_observer/steps/sync_users.py
+++ /dev/null
@@ -1,24 +0,0 @@
-import os
-import base64
-import hashlib
-from django.db.models import F, Q
-from planetstack.config import Config
-from observer.openstacksyncstep import OpenStackSyncStep
-from core.models.user import User
-from core.models.controllerusers import  ControllerUser
-from observer.steps.sync_controller_users import SyncControllerUser
-
-class SyncUsers(OpenStackSyncStep):
-    provides=[User]
-    requested_interval=0
-
-    def sync_record(self, user):
-        for controller_user in ControllerUser.objects.filter(user=user):
-            # bump the 'updated' field so user account are updated across 
-            # controllers.
-            controller_user.save()
-
-    def delete_record(self, user):
-        controller_user_deleter = SyncControllerUser().delete_record
-        for controller_user in ControllerUser.objects.filter(user=user):
-            controller_user_deleter(controller_user)