blob: 33ab09afd04728d9e7d0fd6da19b4ae1b0c4bacc [file] [log] [blame]
Matteo Scandolo75298822018-05-22 11:25:42 -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',
Matteo Scandolo75298822018-05-22 11:25:42 -070021# 'of_dpid': 'of:109299321'
22# }
23
Matteo Scandolod1e5b382018-07-10 13:15:14 -070024from xosapi.orm import register_convenience_wrapper
Matteo Scandolo75298822018-05-22 11:25:42 -070025from xosapi.convenience.serviceinstance import ORMWrapperServiceInstance
26
27import logging as log
28
29class ORMWrapperHippieOSSService(ORMWrapperServiceInstance):
30
31 def validate_onu(self, event):
Matteo Scandolo75298822018-05-22 11:25:42 -070032
Matteo Scandolod1e5b382018-07-10 13:15:14 -070033 log.info("validating ONU %s" % event["serial_number"], event=event)
Matteo Scandolo75298822018-05-22 11:25:42 -070034
Matteo Scandolod1e5b382018-07-10 13:15:14 -070035 try:
36 oss_si = self.stub.HippieOSSServiceInstance.objects.get(serial_number=event["serial_number"])
37 oss_si.no_sync = False;
38 log.debug("Found existing HippieOSSServiceInstance", si=oss_si)
39 except IndexError:
40 # create an HippieOSSServiceInstance, the validation will be triggered in the corresponding sync step
41 oss_si = self.stub.HippieOSSServiceInstance(
42 serial_number=event["serial_number"],
43 of_dpid=event["of_dpid"]
44 )
45 log.debug("Created new HippieOSSServiceInstance", si=oss_si)
46
47 oss_si.save(always_update_timestamp=True)
Matteo Scandolo75298822018-05-22 11:25:42 -070048
49register_convenience_wrapper("HippieOSSService", ORMWrapperHippieOSSService)