blob: 20420cd38ff74ed7b8a441711eafb272f186c6d9 [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;
Ray Milkeyd84f89b2018-08-17 14:54:17 -070021import org.osgi.service.component.annotations.Activate;
22import org.osgi.service.component.annotations.Component;
23import org.osgi.service.component.annotations.Deactivate;
24import org.osgi.service.component.annotations.Reference;
25import org.osgi.service.component.annotations.ReferenceCardinality;
helenyrwu0407c642016-06-09 12:01:30 -070026import org.onosproject.incubator.net.faultmanagement.alarm.Alarm;
27import org.onosproject.incubator.net.faultmanagement.alarm.AlarmProvider;
28import org.onosproject.incubator.net.faultmanagement.alarm.AlarmProviderService;
helenyrwu0407c642016-06-09 12:01:30 -070029import org.onosproject.incubator.net.faultmanagement.alarm.AlarmProviderRegistry;
helenyrwu82b50d42016-07-15 11:35:32 -070030import org.onosproject.incubator.net.faultmanagement.alarm.AlarmTranslator;
Laszlo Papp35cc7c42018-09-17 07:41:09 +010031import org.onosproject.incubator.net.faultmanagement.alarm.DeviceAlarmConfig;
32import org.onosproject.net.Device;
helenyrwu0407c642016-06-09 12:01:30 -070033import org.onosproject.net.DeviceId;
Laszlo Papp35cc7c42018-09-17 07:41:09 +010034import org.onosproject.net.device.DeviceService;
35import org.onosproject.net.driver.DefaultDriverData;
36import org.onosproject.net.driver.DefaultDriverHandler;
37import org.onosproject.net.driver.Driver;
38import org.onosproject.net.driver.DriverData;
39import org.onosproject.net.driver.DriverService;
helenyrwu0407c642016-06-09 12:01:30 -070040import org.onosproject.net.provider.AbstractProvider;
41import org.onosproject.net.provider.ProviderId;
Yuta HIGUCHIe3ae8212017-04-20 10:18:41 -070042import org.onosproject.netconf.FilteringNetconfDeviceOutputEventListener;
helenyrwu0407c642016-06-09 12:01:30 -070043import org.onosproject.netconf.NetconfController;
44import org.onosproject.netconf.NetconfDevice;
45import org.onosproject.netconf.NetconfDeviceInfo;
46import org.onosproject.netconf.NetconfDeviceListener;
47import org.onosproject.netconf.NetconfDeviceOutputEvent;
48import org.onosproject.netconf.NetconfDeviceOutputEventListener;
49import org.onosproject.netconf.NetconfSession;
helenyrwu0407c642016-06-09 12:01:30 -070050import org.slf4j.Logger;
51
helenyrwu45700842016-06-09 12:01:30 -070052import java.io.ByteArrayInputStream;
53import java.io.InputStream;
54import java.nio.charset.StandardCharsets;
helenyrwu0407c642016-06-09 12:01:30 -070055import java.util.Collection;
helenyrwu0407c642016-06-09 12:01:30 -070056import java.util.Map;
Laszlo Papp35cc7c42018-09-17 07:41:09 +010057import java.util.Set;
helenyrwu0407c642016-06-09 12:01:30 -070058
59import static org.slf4j.LoggerFactory.getLogger;
60
61/**
62 * Provider which uses an Alarm Manager to keep track of device notifications.
63 */
Ray Milkey86ad7bb2018-09-27 12:32:28 -070064@Component(immediate = true, service = AlarmProvider.class)
helenyrwu0407c642016-06-09 12:01:30 -070065public class NetconfAlarmProvider extends AbstractProvider implements AlarmProvider {
66
67 public static final String ACTIVE = "active";
68 private final Logger log = getLogger(getClass());
helenyrwu82b50d42016-07-15 11:35:32 -070069 private final AlarmTranslator translator = new NetconfAlarmTranslator();
helenyrwu0407c642016-06-09 12:01:30 -070070
Ray Milkeyd84f89b2018-08-17 14:54:17 -070071 @Reference(cardinality = ReferenceCardinality.MANDATORY)
helenyrwu0407c642016-06-09 12:01:30 -070072 protected AlarmProviderRegistry providerRegistry;
73
Ray Milkeyd84f89b2018-08-17 14:54:17 -070074 @Reference(cardinality = ReferenceCardinality.MANDATORY)
helenyrwu0407c642016-06-09 12:01:30 -070075 protected NetconfController controller;
76
Ray Milkey86ad7bb2018-09-27 12:32:28 -070077 @Reference(cardinality = ReferenceCardinality.MANDATORY)
Laszlo Papp35cc7c42018-09-17 07:41:09 +010078 protected DriverService driverService;
79
Ray Milkey86ad7bb2018-09-27 12:32:28 -070080 @Reference(cardinality = ReferenceCardinality.MANDATORY)
Laszlo Papp35cc7c42018-09-17 07:41:09 +010081 protected DeviceService deviceService;
82
helenyrwu0407c642016-06-09 12:01:30 -070083 protected AlarmProviderService providerService;
84
85 private Map<DeviceId, InternalNotificationListener> idNotificationListenerMap = Maps.newHashMap();
86
87 public NetconfAlarmProvider() {
88 super(new ProviderId("netconf", "org.onosproject.netconf"));
89 }
90
91 private NetconfDeviceListener deviceListener = new InnerDeviceListener();
92
93 @Activate
94 public void activate() {
95 providerService = providerRegistry.register(this);
96 controller.getNetconfDevices().forEach(id -> {
97 NetconfDevice device = controller.getNetconfDevice(id);
98 NetconfSession session = device.getSession();
99 InternalNotificationListener listener = new InternalNotificationListener(device.getDeviceInfo());
100 session.addDeviceOutputListener(listener);
101 idNotificationListenerMap.put(id, listener);
102 });
103 controller.addDeviceListener(deviceListener);
104 log.info("NetconfAlarmProvider Started");
105 }
106
107 @Deactivate
108 public void deactivate() {
109 providerRegistry.unregister(this);
110 idNotificationListenerMap.forEach((id, listener) -> {
111 controller.getNetconfDevice(id)
helenyrwu45700842016-06-09 12:01:30 -0700112 .getSession()
113 .removeDeviceOutputListener(listener);
helenyrwu0407c642016-06-09 12:01:30 -0700114 });
115 controller.removeDeviceListener(deviceListener);
116 providerService = null;
117 log.info("NetconfAlarmProvider Stopped");
118 }
119
120 @Override
121 public void triggerProbe(DeviceId deviceId) {
Yuta HIGUCHI0454d702017-03-17 10:08:38 -0700122 log.debug("Alarm probe triggered with {}", deviceId);
helenyrwu0407c642016-06-09 12:01:30 -0700123 }
124
125 private void triggerProbe(DeviceId deviceId, Collection<Alarm> alarms) {
126 providerService.updateAlarmList(deviceId, alarms);
127 triggerProbe(deviceId);
128 }
129
Yuta HIGUCHIe3ae8212017-04-20 10:18:41 -0700130 private class InternalNotificationListener
131 extends FilteringNetconfDeviceOutputEventListener
helenyrwu0407c642016-06-09 12:01:30 -0700132 implements NetconfDeviceOutputEventListener {
133
134 InternalNotificationListener(NetconfDeviceInfo deviceInfo) {
135 super(deviceInfo);
136 }
137
138 @Override
139 public void event(NetconfDeviceOutputEvent event) {
140 if (event.type() == NetconfDeviceOutputEvent.Type.DEVICE_NOTIFICATION) {
141 DeviceId deviceId = event.getDeviceInfo().getDeviceId();
Laszlo Papp35cc7c42018-09-17 07:41:09 +0100142 Driver deviceDriver = driverService.getDriver(deviceId);
143 Device device = deviceService.getDevice(deviceId);
144 if (deviceDriver != null && device.is(DeviceAlarmConfig.class)) {
145 DeviceAlarmConfig alarmTranslator = device.as(DeviceAlarmConfig.class);
146 DriverData driverData = new DefaultDriverData(deviceDriver, deviceId);
147 alarmTranslator.setHandler(new DefaultDriverHandler(driverData));
148 Set<Alarm> alarms = alarmTranslator.translateAlarms(ImmutableList.of(event));
149 triggerProbe(deviceId, alarms);
150 } else {
151 String message = event.getMessagePayload();
152 InputStream in = new ByteArrayInputStream(message.getBytes(StandardCharsets.UTF_8));
153 Collection<Alarm> newAlarms = translator.translateToAlarm(deviceId, in);
154 triggerProbe(deviceId, newAlarms);
155 }
helenyrwu0407c642016-06-09 12:01:30 -0700156 }
157 }
158 }
159
160 private class InnerDeviceListener implements NetconfDeviceListener {
161
162 @Override
163 public void deviceAdded(DeviceId deviceId) {
164 NetconfDevice device = controller.getNetconfDevice(deviceId);
165 NetconfSession session = device.getSession();
166 InternalNotificationListener listener = new InternalNotificationListener(device.getDeviceInfo());
167 session.addDeviceOutputListener(listener);
168 idNotificationListenerMap.put(deviceId, listener);
169 }
170
171 @Override
172 public void deviceRemoved(DeviceId deviceId) {
173 idNotificationListenerMap.remove(deviceId);
174 }
175 }
176}