blob: 9b65f2557544ab828b7bf027ea4069dd3d3dbdd6 [file] [log] [blame]
helenyrwu0407c642016-06-09 12:01:30 -07001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2016-present Open Networking Foundation
helenyrwu0407c642016-06-09 12:01:30 -07003 *
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
17package org.onosproject.provider.netconf.alarm;
18
Laszlo Papp35cc7c42018-09-17 07:41:09 +010019import com.google.common.collect.ImmutableList;
helenyrwu0407c642016-06-09 12:01:30 -070020import com.google.common.collect.Maps;
gyewan.an91d7e7e2019-01-17 15:12:48 +090021import org.onosproject.netconf.NetconfException;
Ray Milkeyd84f89b2018-08-17 14:54:17 -070022import org.osgi.service.component.annotations.Activate;
23import org.osgi.service.component.annotations.Component;
24import org.osgi.service.component.annotations.Deactivate;
25import org.osgi.service.component.annotations.Reference;
26import org.osgi.service.component.annotations.ReferenceCardinality;
Thomas Vachuska52f2cd12018-11-08 21:20:04 -080027import org.onosproject.alarm.Alarm;
28import org.onosproject.alarm.AlarmProvider;
29import org.onosproject.alarm.AlarmProviderService;
30import org.onosproject.alarm.AlarmProviderRegistry;
31import org.onosproject.alarm.AlarmTranslator;
32import org.onosproject.alarm.DeviceAlarmConfig;
Laszlo Papp35cc7c42018-09-17 07:41:09 +010033import org.onosproject.net.Device;
helenyrwu0407c642016-06-09 12:01:30 -070034import org.onosproject.net.DeviceId;
Laszlo Papp35cc7c42018-09-17 07:41:09 +010035import org.onosproject.net.device.DeviceService;
36import org.onosproject.net.driver.DefaultDriverData;
37import org.onosproject.net.driver.DefaultDriverHandler;
38import org.onosproject.net.driver.Driver;
39import org.onosproject.net.driver.DriverData;
40import org.onosproject.net.driver.DriverService;
helenyrwu0407c642016-06-09 12:01:30 -070041import org.onosproject.net.provider.AbstractProvider;
42import org.onosproject.net.provider.ProviderId;
Yuta HIGUCHIe3ae8212017-04-20 10:18:41 -070043import org.onosproject.netconf.FilteringNetconfDeviceOutputEventListener;
helenyrwu0407c642016-06-09 12:01:30 -070044import org.onosproject.netconf.NetconfController;
45import org.onosproject.netconf.NetconfDevice;
46import org.onosproject.netconf.NetconfDeviceInfo;
47import org.onosproject.netconf.NetconfDeviceListener;
48import org.onosproject.netconf.NetconfDeviceOutputEvent;
49import org.onosproject.netconf.NetconfDeviceOutputEventListener;
50import org.onosproject.netconf.NetconfSession;
helenyrwu0407c642016-06-09 12:01:30 -070051import org.slf4j.Logger;
52
helenyrwu45700842016-06-09 12:01:30 -070053import java.io.ByteArrayInputStream;
54import java.io.InputStream;
55import java.nio.charset.StandardCharsets;
helenyrwu0407c642016-06-09 12:01:30 -070056import java.util.Collection;
helenyrwu0407c642016-06-09 12:01:30 -070057import java.util.Map;
Laszlo Papp35cc7c42018-09-17 07:41:09 +010058import java.util.Set;
helenyrwu0407c642016-06-09 12:01:30 -070059
60import static org.slf4j.LoggerFactory.getLogger;
61
62/**
63 * Provider which uses an Alarm Manager to keep track of device notifications.
64 */
Ray Milkey86ad7bb2018-09-27 12:32:28 -070065@Component(immediate = true, service = AlarmProvider.class)
helenyrwu0407c642016-06-09 12:01:30 -070066public class NetconfAlarmProvider extends AbstractProvider implements AlarmProvider {
67
68 public static final String ACTIVE = "active";
69 private final Logger log = getLogger(getClass());
helenyrwu82b50d42016-07-15 11:35:32 -070070 private final AlarmTranslator translator = new NetconfAlarmTranslator();
helenyrwu0407c642016-06-09 12:01:30 -070071
Ray Milkeyd84f89b2018-08-17 14:54:17 -070072 @Reference(cardinality = ReferenceCardinality.MANDATORY)
helenyrwu0407c642016-06-09 12:01:30 -070073 protected AlarmProviderRegistry providerRegistry;
74
Ray Milkeyd84f89b2018-08-17 14:54:17 -070075 @Reference(cardinality = ReferenceCardinality.MANDATORY)
helenyrwu0407c642016-06-09 12:01:30 -070076 protected NetconfController controller;
77
Ray Milkey86ad7bb2018-09-27 12:32:28 -070078 @Reference(cardinality = ReferenceCardinality.MANDATORY)
Laszlo Papp35cc7c42018-09-17 07:41:09 +010079 protected DriverService driverService;
80
Ray Milkey86ad7bb2018-09-27 12:32:28 -070081 @Reference(cardinality = ReferenceCardinality.MANDATORY)
Laszlo Papp35cc7c42018-09-17 07:41:09 +010082 protected DeviceService deviceService;
83
helenyrwu0407c642016-06-09 12:01:30 -070084 protected AlarmProviderService providerService;
85
86 private Map<DeviceId, InternalNotificationListener> idNotificationListenerMap = Maps.newHashMap();
87
88 public NetconfAlarmProvider() {
89 super(new ProviderId("netconf", "org.onosproject.netconf"));
90 }
91
92 private NetconfDeviceListener deviceListener = new InnerDeviceListener();
93
94 @Activate
95 public void activate() {
96 providerService = providerRegistry.register(this);
97 controller.getNetconfDevices().forEach(id -> {
98 NetconfDevice device = controller.getNetconfDevice(id);
gyewan.an91d7e7e2019-01-17 15:12:48 +090099 if (device.isMasterSession()) {
100 NetconfSession session = device.getSession();
101 InternalNotificationListener listener = new InternalNotificationListener(device.getDeviceInfo());
102 try {
103 session.addDeviceOutputListener(listener);
104 } catch (NetconfException e) {
105 log.error("addDeviceOutputListener Error {} ", e.getMessage());
106 }
107 idNotificationListenerMap.put(id, listener);
108 }
helenyrwu0407c642016-06-09 12:01:30 -0700109 });
110 controller.addDeviceListener(deviceListener);
111 log.info("NetconfAlarmProvider Started");
112 }
113
114 @Deactivate
115 public void deactivate() {
116 providerRegistry.unregister(this);
117 idNotificationListenerMap.forEach((id, listener) -> {
gyewan.an91d7e7e2019-01-17 15:12:48 +0900118 NetconfDevice device = controller.getNetconfDevice(id);
119 if (device.isMasterSession()) {
120 try {
121 device.getSession().removeDeviceOutputListener(listener);
122 } catch (NetconfException e) {
123 log.error("RemoveDeviceOutputListener Error {}", e.getMessage());
124 }
125 }
helenyrwu0407c642016-06-09 12:01:30 -0700126 });
127 controller.removeDeviceListener(deviceListener);
128 providerService = null;
129 log.info("NetconfAlarmProvider Stopped");
130 }
131
132 @Override
133 public void triggerProbe(DeviceId deviceId) {
Yuta HIGUCHI0454d702017-03-17 10:08:38 -0700134 log.debug("Alarm probe triggered with {}", deviceId);
helenyrwu0407c642016-06-09 12:01:30 -0700135 }
136
137 private void triggerProbe(DeviceId deviceId, Collection<Alarm> alarms) {
138 providerService.updateAlarmList(deviceId, alarms);
139 triggerProbe(deviceId);
140 }
141
Yuta HIGUCHIe3ae8212017-04-20 10:18:41 -0700142 private class InternalNotificationListener
143 extends FilteringNetconfDeviceOutputEventListener
helenyrwu0407c642016-06-09 12:01:30 -0700144 implements NetconfDeviceOutputEventListener {
145
146 InternalNotificationListener(NetconfDeviceInfo deviceInfo) {
147 super(deviceInfo);
148 }
149
150 @Override
151 public void event(NetconfDeviceOutputEvent event) {
152 if (event.type() == NetconfDeviceOutputEvent.Type.DEVICE_NOTIFICATION) {
153 DeviceId deviceId = event.getDeviceInfo().getDeviceId();
Laszlo Papp35cc7c42018-09-17 07:41:09 +0100154 Driver deviceDriver = driverService.getDriver(deviceId);
155 Device device = deviceService.getDevice(deviceId);
156 if (deviceDriver != null && device.is(DeviceAlarmConfig.class)) {
157 DeviceAlarmConfig alarmTranslator = device.as(DeviceAlarmConfig.class);
158 DriverData driverData = new DefaultDriverData(deviceDriver, deviceId);
159 alarmTranslator.setHandler(new DefaultDriverHandler(driverData));
160 Set<Alarm> alarms = alarmTranslator.translateAlarms(ImmutableList.of(event));
161 triggerProbe(deviceId, alarms);
162 } else {
163 String message = event.getMessagePayload();
164 InputStream in = new ByteArrayInputStream(message.getBytes(StandardCharsets.UTF_8));
165 Collection<Alarm> newAlarms = translator.translateToAlarm(deviceId, in);
166 triggerProbe(deviceId, newAlarms);
167 }
helenyrwu0407c642016-06-09 12:01:30 -0700168 }
169 }
170 }
171
172 private class InnerDeviceListener implements NetconfDeviceListener {
173
174 @Override
175 public void deviceAdded(DeviceId deviceId) {
gyewan.an91d7e7e2019-01-17 15:12:48 +0900176 try {
177 NetconfDevice device = controller.getNetconfDevice(deviceId);
178 NetconfSession session = device.getSession();
179 InternalNotificationListener listener = new InternalNotificationListener(device.getDeviceInfo());
180 session.addDeviceOutputListener(listener);
181 idNotificationListenerMap.put(deviceId, listener);
182 } catch (NetconfException e) {
183 log.error("Device add fail {}", e.getMessage());
184 }
helenyrwu0407c642016-06-09 12:01:30 -0700185 }
186
187 @Override
188 public void deviceRemoved(DeviceId deviceId) {
189 idNotificationListenerMap.remove(deviceId);
190 }
191 }
192}