blob: 50ec6ad95fe7b27ac07652d2d315d0035a9cf956 [file] [log] [blame]
Sapan Bhatia24836f12013-08-27 10:16:05 -04001import os
2import base64
3from planetstack.config import Config
Sapan Bhatia04c94ad2013-09-02 18:00:28 -04004from observer.openstacksyncstep import OpenStackSyncStep
5from core.models.sliver import Sliver
Sapan Bhatia24836f12013-08-27 10:16:05 -04006
7class SyncSliverIps(OpenStackSyncStep):
Tony Mackce79de02013-09-24 10:12:33 -04008 provides=[Sliver]
9 requested_interval=0
10 def fetch_pending(self):
11 slivers = Sliver.objects.filter(ip=None)
12 return slivers
Sapan Bhatia24836f12013-08-27 10:16:05 -040013
Tony Mackce79de02013-09-24 10:12:33 -040014 def sync_record(self, sliver):
Tony Mack387a73f2013-09-18 07:59:14 -040015 driver = self.driver.client_driver(tenant=sliver.slice.name)
Tony Mackce79de02013-09-24 10:12:33 -040016 servers = driver.shell.nova.servers.findall(id=sliver.instance_id)
17 if not servers:
18 return
19 server = servers[0]
20 ips = server.addresses.get(sliver.slice.name, [])
21 if not ips:
22 return
23 sliver.ip = ips[0]['addr']
24 sliver.save()
25 logger.info("saved sliver ip: %s %s" % (sliver, ips[0]))