| /* |
| * Copyright 2016-present Open Networking Laboratory |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package org.onosproject.incubator.net.virtual.provider; |
| |
| import org.onosproject.incubator.net.virtual.VirtualPortDescription; |
| import org.onosproject.net.DeviceId; |
| import org.onosproject.net.MastershipRole; |
| import org.onosproject.net.device.PortStatistics; |
| |
| import java.util.Collection; |
| import java.util.List; |
| |
| /** |
| * Service through which virtual device providers can inject virtual device |
| * information into the core. |
| */ |
| public interface VirtualDeviceProviderService |
| extends VirtualProviderService<VirtualDeviceProvider> { |
| |
| /** |
| * Updates information about all ports of a device. It is up to the core to |
| * determine what has changed. |
| * |
| * @param deviceId identity of the device |
| * @param portDescs list of virtual device ports |
| */ |
| void updatePorts(DeviceId deviceId, List<VirtualPortDescription> portDescs); |
| |
| /** |
| * Notifies the core about port status change of a single port. |
| * |
| * @param deviceId identity of the device |
| * @param portDesc description of the virtual port that changed |
| */ |
| void portStatusChanged(DeviceId deviceId, VirtualPortDescription portDesc); |
| |
| /** |
| * Notifies the core about the result of a RoleRequest sent to a device. |
| * |
| * @param deviceId identity of the device |
| * @param requested mastership role that was requested by the node |
| * @param response mastership role the switch accepted |
| */ |
| void receivedRoleReply(DeviceId deviceId, MastershipRole requested, |
| MastershipRole response); |
| |
| /** |
| * Updates statistics about all ports of a device. |
| * |
| * @param deviceId identity of the device |
| * @param portStatistics list of device port statistics |
| */ |
| void updatePortStatistics(DeviceId deviceId, |
| Collection<PortStatistics> portStatistics); |
| } |