blob: 14c20b33148d0b31e37f33216e56257a675bb20f [file] [log] [blame]
kmcpeake4fe18c82015-11-17 20:07:39 +00001/*
Thomas Vachuska52f2cd12018-11-08 21:20:04 -08002 * Copyright 2018-present Open Networking Foundation
kmcpeake4fe18c82015-11-17 20:07:39 +00003 *
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 */
Thomas Vachuska52f2cd12018-11-08 21:20:04 -080016package org.onosproject.alarm;
kmcpeake4fe18c82015-11-17 20:07:39 +000017
18import org.onosproject.net.DeviceId;
19import org.onosproject.net.provider.Provider;
20
21/**
Andrea Campanellae72ac552016-04-11 10:04:52 -070022 * Abstraction of an entity capable of supplying alarms collected from
23 * network devices.
kmcpeake4fe18c82015-11-17 20:07:39 +000024 */
25public interface AlarmProvider extends Provider {
26
27 /**
Andrea Campanellae72ac552016-04-11 10:04:52 -070028 * Triggers an asynchronous discovery of the alarms on the specified device,
29 * intended to refresh internal alarm model for the device. An indirect
30 * result of this should be a event sent later with discovery result
31 * ie a set of alarms.
kmcpeake4fe18c82015-11-17 20:07:39 +000032 *
33 * @param deviceId ID of device to be probed
34 */
35 void triggerProbe(DeviceId deviceId);
kmcpeake4fe18c82015-11-17 20:07:39 +000036}