blob: 7234b704501da72403f35e50d36798a5b2cfdd1c [file] [log] [blame]
/*
* Copyright 2015-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;
import org.onosproject.event.AbstractEvent;
/**
* Describes virtual network event.
*/
public class VirtualNetworkEvent extends AbstractEvent<VirtualNetworkEvent.Type, NetworkId> {
/**
* Type of virtual network events.
*/
public enum Type {
/**
* Signifies that a new tenant identifier was registered.
*/
TENANT_REGISTERED,
/**
* Signifies that a tenant identifier was unregistered.
*/
TENANT_UNREGISTERED,
/**
* Signifies that a new virtual network was added.
*/
NETWORK_ADDED,
/**
* Signifies that a virtual network was updated.
*/
NETWORK_UPDATED,
/**
* Signifies that a virtual network was removed.
*/
NETWORK_REMOVED,
/**
* Signifies that a new virtual network device was added.
*/
VIRTUAL_DEVICE_ADDED,
/**
* Signifies that a virtual network device was updated.
*/
VIRTUAL_DEVICE_UPDATED,
/**
* Signifies that a virtual network device was removed.
*/
VIRTUAL_DEVICE_REMOVED,
/**
* Signifies that a new virtual network port was added.
*/
VIRTUAL_PORT_ADDED,
/**
* Signifies that a virtual network port was updated.
*/
VIRTUAL_PORT_UPDATED,
/**
* Signifies that a virtual network port was removed.
*/
VIRTUAL_PORT_REMOVED
}
private final VirtualDevice virtualDevice;
private final VirtualPort virtualPort;
/**
* Creates an event of a given type and for the specified subject.
*
* @param type event type
* @param subject event subject
*/
public VirtualNetworkEvent(Type type, NetworkId subject) {
this(type, subject, null, null);
}
/**
* Creates an event of a given type and for the specified subject and the
* virtual device.
*
* @param type event type
* @param subject event subject
* @param virtualDevice virtual device
*/
public VirtualNetworkEvent(Type type, NetworkId subject, VirtualDevice virtualDevice) {
this(type, subject, virtualDevice, null);
}
/**
* Creates an event of a given type and for the specified subject and the
* virtual port.
*
* @param type event type
* @param subject event subject
* @param virtualPort virtual port
*/
public VirtualNetworkEvent(Type type, NetworkId subject, VirtualPort virtualPort) {
this(type, subject, null, virtualPort);
}
/**
* Creates an event of a given type and for the specified subject, virtual device and
* virtual port.
*
* @param type event type
* @param subject event subject
* @param virtualDevice virtual device
* @param virtualPort virtual port
*/
private VirtualNetworkEvent(Type type, NetworkId subject, VirtualDevice virtualDevice,
VirtualPort virtualPort) {
super(type, subject);
this.virtualDevice = virtualDevice;
this.virtualPort = virtualPort;
}
/**
* Creates an event of a given type and for the specified subject and time.
*
* @param type event type
* @param subject event subject
* @param time occurrence time
*/
public VirtualNetworkEvent(Type type, NetworkId subject, long time) {
this(type, subject, null, null, time);
}
/**
* Creates an event of a given type and for the specified subject, virtual device and time.
*
* @param type event type
* @param subject event subject
* @param virtualDevice virtual device
* @param time occurrence time
*/
public VirtualNetworkEvent(Type type, NetworkId subject, VirtualDevice virtualDevice,
long time) {
this(type, subject, virtualDevice, null, time);
}
/**
* Creates an event of a given type and for the specified subject, virtual port and time.
*
* @param type device event type
* @param subject event subject
* @param virtualPort virtual port
* @param time occurrence time
*/
public VirtualNetworkEvent(Type type, NetworkId subject, VirtualPort virtualPort,
long time) {
this(type, subject, null, virtualPort, time);
}
/**
* Creates an event of a given type and for the specified subject, virtual device,
* virtual port and time.
*
* @param type device event type
* @param subject event subject
* @param virtualDevice virtual device
* @param virtualPort virtual port
* @param time occurrence time
*/
private VirtualNetworkEvent(Type type, NetworkId subject, VirtualDevice virtualDevice,
VirtualPort virtualPort, long time) {
super(type, subject, time);
this.virtualDevice = virtualDevice;
this.virtualPort = virtualPort;
}
/**
* Returns virtual device affected by event - may be null (for events relating to
* tenants, virtual networks and virtual ports).
*
* @return virtual device
*/
public VirtualDevice virtualDevice() {
return virtualDevice;
}
/**
* Returns virtual port affected by event - may be null (for events relating to
* tenants, virtual networks and virtual devices).
*
* @return virtual port
*/
public VirtualPort virtualPort() {
return virtualPort;
}
}