[SEBA-55] Handling multiple events for the same ONUDevice
Change-Id: Ic0de47151d8885952536322bfb4a2258ade3fd62
diff --git a/xos/synchronizer/models/convenience/hippieossservice.py b/xos/synchronizer/models/convenience/hippieossservice.py
index 0959303..33ab09a 100644
--- a/xos/synchronizer/models/convenience/hippieossservice.py
+++ b/xos/synchronizer/models/convenience/hippieossservice.py
@@ -18,11 +18,10 @@
# {
# 'status': 'activate',
# 'serial_number': 'BRCM1234',
-# 'uni_port_id': 'of:00100101',
# 'of_dpid': 'of:109299321'
# }
-from xosapi.orm import ORMWrapper, register_convenience_wrapper
+from xosapi.orm import register_convenience_wrapper
from xosapi.convenience.serviceinstance import ORMWrapperServiceInstance
import logging as log
@@ -30,18 +29,21 @@
class ORMWrapperHippieOSSService(ORMWrapperServiceInstance):
def validate_onu(self, event):
- log.info("validating ONU %s" % event["serial_number"])
- # TODO check if a service instance for this serial_number already exists
+ log.info("validating ONU %s" % event["serial_number"], event=event)
- # create an HippieOSSServiceInstance, the validation will be triggered in the corresponding sync step
- oss_si = self.stub.HippieOSSServiceInstance(
- serial_number=event["serial_number"],
- of_dpid=event["of_dpid"]
- )
- oss_si.save()
-
-
-
+ try:
+ oss_si = self.stub.HippieOSSServiceInstance.objects.get(serial_number=event["serial_number"])
+ oss_si.no_sync = False;
+ log.debug("Found existing HippieOSSServiceInstance", si=oss_si)
+ except IndexError:
+ # create an HippieOSSServiceInstance, the validation will be triggered in the corresponding sync step
+ oss_si = self.stub.HippieOSSServiceInstance(
+ serial_number=event["serial_number"],
+ of_dpid=event["of_dpid"]
+ )
+ log.debug("Created new HippieOSSServiceInstance", si=oss_si)
+
+ oss_si.save(always_update_timestamp=True)
register_convenience_wrapper("HippieOSSService", ORMWrapperHippieOSSService)