blob: c692975bc530f7d221a44bd7bd0216aefddfed19 [file] [log] [blame]
Matteo Scandolod30d9742018-08-10 15:39:18 -07001
2# Copyright 2017-present Open Networking Foundation
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15
16
17# validate_onu received event:
18# {
19# 'status': 'activate',
20# 'serial_number': 'BRCM1234',
21# 'of_dpid': 'of:109299321'
22# }
23
24from xosapi.orm import register_convenience_wrapper
25from xosapi.convenience.serviceinstance import ORMWrapperServiceInstance
26
27import logging as log
28
29class ORMWrapperAttWorkflowService(ORMWrapperServiceInstance):
30
31 def validate_onu(self, event):
32
33 log.info("onu.events: validating ONU %s" % event["serial_number"], event=event)
34
35 try:
36 oss_si = self.stub.AttWorkflowDriverServiceInstance.objects.get(serial_number=event["serial_number"])
37 oss_si.no_sync = False;
38 log.debug("onu.events: Found existing AttWorkflowDriverServiceInstance", si=oss_si)
39 except IndexError:
40 # create an AttWorkflowDriverServiceInstance, the validation will be triggered in the corresponding sync step
41 oss_si = self.stub.AttWorkflowDriverServiceInstance(
42 serial_number=event["serial_number"],
43 of_dpid=event["of_dpid"]
44 )
45 log.debug("onu.events: Created new AttWorkflowDriverServiceInstance", si=oss_si)
46
47 oss_si.save(always_update_timestamp=True)
48
49register_convenience_wrapper("AttWorkflowDriverService", ORMWrapperAttWorkflowService)