blob: 304bb5cdcc8b6e31d8b0edd5e3e1a972b6f0379e [file] [log] [blame]
package net.floodlightcontroller.util;
import net.floodlightcontroller.util.IPv4;
import net.floodlightcontroller.util.MACAddress;
import net.floodlightcontroller.util.Port;
import org.codehaus.jackson.annotate.JsonProperty;
/**
* The class representing a single Flow Entry action.
*
* A set of Flow Entry actions need to be applied to each packet.
*/
public class FlowEntryAction {
/**
* Special action values.
*
* Those values are taken as-is from the OpenFlow-v1.0.0 specification
* (pp 21-22).
*/
public enum ActionValues {
ACTION_OUTPUT ((short)0x0), // Output to switch port
ACTION_SET_VLAN_VID ((short)0x1), // Set the 802.1q VLAN id
ACTION_SET_VLAN_PCP ((short)0x2), // Set the 802.1q priority
ACTION_STRIP_VLAN ((short)0x3), // Strip the 802.1q header
ACTION_SET_DL_SRC ((short)0x4), // Ethernet source address
ACTION_SET_DL_DST ((short)0x5), // Ethernet destination address
ACTION_SET_NW_SRC ((short)0x6), // IP source address
ACTION_SET_NW_DST ((short)0x7), // IP destination address
ACTION_SET_NW_TOS ((short)0x8), // IP ToS (DSCP field, 6 bits)
ACTION_SET_TP_SRC ((short)0x9), // TCP/UDP source port
ACTION_SET_TP_DST ((short)0xa), // TCP/UDP destination port
ACTION_ENQUEUE ((short)0xb), // Output to queue on port
ACTION_VENDOR ((short)0xffff); // Vendor-specific
private final short value; // The value
/**
* Constructor for a given value.
*
* @param value the value to use for the initialization.
*/
private ActionValues(short value) {
this.value = value;
}
}
/**
* Action structure for ACTION_OUTPUT: Output to switch port.
*/
public class ActionOutput {
private Port port; // Output port
private short maxLen; // Max. length (in bytes) to send to controller
// if the port is set to PORT_CONTROLLER
/**
* Constructor for a given output port and maximum length.
*
* @param port the output port to set.
* @param maxLen the maximum length (in bytes) to send to controller
* if the port is set to PORT_CONTROLLER.
*/
public ActionOutput(Port port, short maxLen) {
this.port = port;
this.maxLen = maxLen;
}
/**
* Get the output port.
*
* @return the output port.
*/
@JsonProperty("port")
public Port port() {
return this.port;
}
/**
* Get the maximum length (in bytes) to send to controller if the
* port is set to PORT_CONTROLLER.
*
* @return the maximum length (in bytes) to send to controller if the
* port is set to PORT_CONTROLLER.
*/
@JsonProperty("maxLen")
public short maxLen() {
return this.maxLen;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [port=XXX maxLen=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "port=" + port.toString();
ret += " maxLen=" + maxLen;
ret += "]";
return ret;
}
}
/**
* Action structure for ACTION_SET_VLAN_VID: Set the 802.1q VLAN id
*/
public class ActionSetVlanId {
private short vlanId; // The VLAN ID to set
/**
* Constructor for a given VLAN ID.
*
* @param vlanId the VLAN ID to set.
*/
ActionSetVlanId(short vlanId) {
this.vlanId = vlanId;
}
/**
* Get the VLAN ID.
*
* @return the VLAN ID.
*/
@JsonProperty("vlanId")
public short vlanId() {
return this.vlanId;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [vlanId=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "vlanId=" + this.vlanId;
ret += "]";
return ret;
}
}
/**
* Action structure for ACTION_SET_VLAN_PCP: Set the 802.1q priority
*/
public class ActionSetVlanPriority {
private byte vlanPriority; // The VLAN priority to set
/**
* Constructor for a given VLAN priority.
*
* @param vlanPriority the VLAN priority to set.
*/
ActionSetVlanPriority(byte vlanPriority) {
this.vlanPriority = vlanPriority;
}
/**
* Get the VLAN priority.
*
* @return the VLAN priority.
*/
@JsonProperty("vlanPriority")
public byte vlanPriority() {
return this.vlanPriority;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [vlanPriority=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "vlanPriority=" + this.vlanPriority;
ret += "]";
return ret;
}
}
/**
* Action structure for ACTION_STRIP_VLAN: Strip the 802.1q header
*/
public class ActionStripVlan {
private boolean stripVlan; // If true, strip the VLAN header
/**
* Constructor for a given boolean flag.
*
* @param stripVlan if true, strip the VLAN header.
*/
ActionStripVlan(boolean stripVlan) {
this.stripVlan = stripVlan;
}
/**
* Get the boolean flag whether the VLAN header should be stripped.
*
* @return the boolean flag whether the VLAN header should be stripped.
*/
@JsonProperty("stripVlan")
public boolean stripVlan() {
return this.stripVlan;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [stripVlan=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "stripVlan=" + this.stripVlan;
ret += "]";
return ret;
}
}
/**
* Action structure for ACTION_SET_DL_SRC and ACTION_SET_DL_DST:
* Set the Ethernet source/destination address.
*/
public class ActionSetEthernetAddr {
private MACAddress addr; // The MAC address to set
/**
* Constructor for a given MAC address.
*
* @param addr the MAC address to set.
*/
ActionSetEthernetAddr(MACAddress addr) {
this.addr = addr;
}
/**
* Get the MAC address.
*
* @return the MAC address.
*/
@JsonProperty("addr")
public MACAddress addr() {
return this.addr;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [addr=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "addr=" + addr.toString();
ret += "]";
return ret;
}
}
/**
* Action structure for ACTION_SET_NW_SRC and ACTION_SET_NW_DST:
* Set the IPv4 source/destination address.
*/
public class ActionSetIPv4Addr {
private IPv4 addr; // The IPv4 address to set
/**
* Constructor for a given IPv4 address.
*
* @param addr the IPv4 address to set.
*/
ActionSetIPv4Addr(IPv4 addr) {
this.addr = addr;
}
/**
* Get the IPv4 address.
*
* @return the IPv4 address.
*/
@JsonProperty("addr")
public IPv4 addr() {
return this.addr;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [addr=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "addr=" + addr.toString();
ret += "]";
return ret;
}
}
/**
* Action structure for ACTION_SET_NW_TOS:
* Set the IP ToS (DSCP field, 6 bits).
*/
public class ActionSetIpToS {
private byte ipToS; // The IP ToS to set DSCP field, 6 bits)
/**
* Constructor for a given IP ToS (DSCP field, 6 bits).
*
* @param ipToS the IP ToS (DSCP field, 6 bits) to set.
*/
ActionSetIpToS(byte ipToS) {
this.ipToS = ipToS;
}
/**
* Get the IP ToS (DSCP field, 6 bits).
*
* @return the IP ToS (DSCP field, 6 bits).
*/
@JsonProperty("ipToS")
public byte ipToS() {
return this.ipToS;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [ipToS=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "ipToS=" + ipToS;
ret += "]";
return ret;
}
}
/**
* Action structure for ACTION_SET_TP_SRC and ACTION_SET_TP_DST:
* Set the TCP/UDP source/destination port.
*/
public class ActionSetTcpUdpPort {
private short port; // The TCP/UDP port to set
/**
* Constructor for a given TCP/UDP port.
*
* @param port the TCP/UDP port to set.
*/
ActionSetTcpUdpPort(short port) {
this.port = port;
}
/**
* Get the TCP/UDP port.
*
* @return the TCP/UDP port.
*/
@JsonProperty("port")
public short port() {
return this.port;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [port=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "port=" + port;
ret += "]";
return ret;
}
}
/**
* Action structure for ACTION_ENQUEUE: Output to queue on port.
*/
public class ActionEnqueue {
private Port port; // Port that queue belongs. Should
// refer to a valid physical port
// (i.e. < PORT_MAX) or PORT_IN_PORT
private int queueId; // Where to enqueue the packets
/**
* Constructor for a given port and queue ID.
*
* @param port the port to set.
* @param queueId the queue ID on the port.
*/
public ActionEnqueue(Port port, int queueId) {
this.port = port;
this.queueId = queueId;
}
/**
* Get the port.
*
* @return the port.
*/
@JsonProperty("port")
public Port port() {
return this.port;
}
/**
* Get the queue ID.
*
* @return the queue ID.
*/
@JsonProperty("queueId")
public int queueId() {
return this.queueId;
}
/**
* Convert the action to a string.
*
* The string has the following form:
* [port=XXX queueId=XXX]
*
* @return the action as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "port=" + port.toString();
ret += " queueId=" + queueId;
ret += "]";
return ret;
}
}
private ActionValues actionType; // The action type
//
// The actions.
// NOTE: Only one action should be set.
//
private ActionOutput actionOutput;
private ActionSetVlanId actionSetVlanId;
private ActionSetVlanPriority actionSetVlanPriority;
private ActionStripVlan actionStripVlan;
private ActionSetEthernetAddr actionSetEthernetSrcAddr;
private ActionSetEthernetAddr actionSetEthernetDstAddr;
private ActionSetIPv4Addr actionSetIPv4SrcAddr;
private ActionSetIPv4Addr actionSetIPv4DstAddr;
private ActionSetIpToS actionSetIpToS;
private ActionSetTcpUdpPort actionSetTcpUdpSrcPort;
private ActionSetTcpUdpPort actionSetTcpUdpDstPort;
private ActionEnqueue actionEnqueue;
/**
* Default constructor.
*/
public FlowEntryAction() {
actionType = ActionValues.ACTION_VENDOR; // XXX: Initial value
}
/**
* Get the action type.
*
* @return the action type.
*/
@JsonProperty("actionType")
public ActionValues actionType() { return actionType; }
/**
* Get the output action.
*
* @return the output action.
*/
@JsonProperty("actionOutput")
public ActionOutput actionOutput() { return actionOutput; }
/**
* Set the output action on a port.
*
* @param port the output port to set.
*/
@JsonProperty("actionOutput")
public void setActionOutput(Port port) {
actionOutput = new ActionOutput(port, (short)0);
actionType = ActionValues.ACTION_OUTPUT;
}
/**
* Set the output action to controller.
*
* @param maxLen the maximum length (in bytes) to send to controller.
*/
@JsonProperty("actionOutputToController")
public void setActionOutputToController(short maxLen) {
Port port = new Port(Port.PortValues.PORT_CONTROLLER);
actionOutput = new ActionOutput(port, maxLen);
actionType = ActionValues.ACTION_OUTPUT;
}
/**
* Get the action to set the VLAN ID.
*
* @return the action to set the VLAN ID.
*/
@JsonProperty("actionSetVlanId")
public ActionSetVlanId actionSetVlanId() { return actionSetVlanId; }
/**
* Set the action to set the VLAN ID.
*
* @param vlanId the VLAN ID to set.
*/
@JsonProperty("actionSetVlanId")
public void setActionSetVlanId(short vlanId) {
actionSetVlanId = new ActionSetVlanId(vlanId);
actionType = ActionValues.ACTION_SET_VLAN_VID;
}
/**
* Get the action to set the VLAN priority.
*
* @return the action to set the VLAN priority.
*/
@JsonProperty("actionSetVlanPriority")
public ActionSetVlanPriority actionSetVlanPriority() {
return actionSetVlanPriority;
}
/**
* Set the action to set the VLAN priority.
*
* @param vlanPriority the VLAN priority to set.
*/
@JsonProperty("actionSetVlanPriority")
public void setActionSetVlanPriority(byte vlanPriority) {
actionSetVlanPriority = new ActionSetVlanPriority(vlanPriority);
actionType = ActionValues.ACTION_SET_VLAN_PCP;
}
/**
* Get the action to strip the VLAN header.
*
* @return the action to strip the VLAN header.
*/
@JsonProperty("actionStripVlan")
public ActionStripVlan actionStripVlan() {
return actionStripVlan;
}
/**
* Set the action to strip the VLAN header.
*
* @param stripVlan if true, strip the VLAN header.
*/
@JsonProperty("actionStripVlan")
public void setActionStripVlan(boolean stripVlan) {
actionStripVlan = new ActionStripVlan(stripVlan);
actionType = ActionValues.ACTION_STRIP_VLAN;
}
/**
* Get the action to set the Ethernet source address.
*
* @return the action to set the Ethernet source address.
*/
@JsonProperty("actionSetEthernetSrcAddr")
public ActionSetEthernetAddr actionSetEthernetSrcAddr() {
return actionSetEthernetSrcAddr;
}
/**
* Set the action to set the Ethernet source address.
*
* @param addr the MAC address to set as the Ethernet source address.
*/
@JsonProperty("actionSetEthernetSrcAddr")
public void setActionSetEthernetSrcAddr(MACAddress addr) {
actionSetEthernetSrcAddr = new ActionSetEthernetAddr(addr);
actionType = ActionValues.ACTION_SET_DL_SRC;
}
/**
* Get the action to set the Ethernet destination address.
*
* @return the action to set the Ethernet destination address.
*/
@JsonProperty("actionSetEthernetDstAddr")
public ActionSetEthernetAddr actionSetEthernetDstAddr() {
return actionSetEthernetDstAddr;
}
/**
* Set the action to set the Ethernet destination address.
*
* @param addr the MAC address to set as the Ethernet destination address.
*/
@JsonProperty("actionSetEthernetDstAddr")
public void setActionSetEthernetDstAddr(MACAddress addr) {
actionSetEthernetDstAddr = new ActionSetEthernetAddr(addr);
actionType = ActionValues.ACTION_SET_DL_DST;
}
/**
* Get the action to set the IPv4 source address.
*
* @return the action to set the IPv4 source address.
*/
@JsonProperty("actionSetIPv4SrcAddr")
public ActionSetIPv4Addr actionSetIPv4SrcAddr() {
return actionSetIPv4SrcAddr;
}
/**
* Set the action to set the IPv4 source address.
*
* @param addr the IPv4 address to set as the IPv4 source address.
*/
@JsonProperty("actionSetIPv4SrcAddr")
public void setActionSetIPv4SrcAddr(IPv4 addr) {
actionSetIPv4SrcAddr = new ActionSetIPv4Addr(addr);
actionType = ActionValues.ACTION_SET_NW_SRC;
}
/**
* Get the action to set the IPv4 destination address.
*
* @return the action to set the IPv4 destination address.
*/
@JsonProperty("actionSetIPv4DstAddr")
public ActionSetIPv4Addr actionSetIPv4DstAddr() {
return actionSetIPv4DstAddr;
}
/**
* Set the action to set the IPv4 destination address.
*
* @param addr the IPv4 address to set as the IPv4 destination address.
*/
@JsonProperty("actionSetIPv4DstAddr")
public void setActionSetIPv4DstAddr(IPv4 addr) {
actionSetIPv4DstAddr = new ActionSetIPv4Addr(addr);
actionType = ActionValues.ACTION_SET_NW_DST;
}
/**
* Get the action to set the IP ToS (DSCP field, 6 bits).
*
* @return the action to set the IP ToS (DSCP field, 6 bits).
*/
@JsonProperty("actionSetIpToS")
public ActionSetIpToS actionSetIpToS() {
return actionSetIpToS;
}
/**
* Set the action to set the IP ToS (DSCP field, 6 bits).
*
* @param ipToS the IP ToS (DSCP field, 6 bits) to set.
*/
@JsonProperty("actionSetIpToS")
public void setActionSetIpToS(byte ipToS) {
actionSetIpToS = new ActionSetIpToS(ipToS);
actionType = ActionValues.ACTION_SET_NW_TOS;
}
/**
* Get the action to set the TCP/UDP source port.
*
* @return the action to set the TCP/UDP source port.
*/
@JsonProperty("actionSetTcpUdpSrcPort")
public ActionSetTcpUdpPort actionSetTcpUdpSrcPort() {
return actionSetTcpUdpSrcPort;
}
/**
* Set the action to set the TCP/UDP source port.
*
* @param port the TCP/UDP port to set as the TCP/UDP source port.
*/
@JsonProperty("actionSetTcpUdpSrcPort")
public void setActionSetTcpUdpSrcPort(short port) {
actionSetTcpUdpSrcPort = new ActionSetTcpUdpPort(port);
actionType = ActionValues.ACTION_SET_TP_SRC;
}
/**
* Get the action to set the TCP/UDP destination port.
*
* @return the action to set the TCP/UDP destination port.
*/
@JsonProperty("actionSetTcpUdpDstPort")
public ActionSetTcpUdpPort actionSetTcpUdpDstPort() {
return actionSetTcpUdpDstPort;
}
/**
* Set the action to set the TCP/UDP destination port.
*
* @param port the TCP/UDP port to set as the TCP/UDP destination port.
*/
@JsonProperty("actionSetTcpUdpDstPort")
public void setActionSetTcpUdpDstPort(short port) {
actionSetTcpUdpDstPort = new ActionSetTcpUdpPort(port);
actionType = ActionValues.ACTION_SET_TP_DST;
}
/**
* Get the action to output to queue on a port.
*
* @return the action to output to queue on a port.
*/
@JsonProperty("actionEnqueue")
public ActionEnqueue actionEnqueue() { return actionEnqueue; }
/**
* Set the action to output to queue on a port.
*
* @param port the port to set.
* @param int queueId the queue ID to set.
*/
@JsonProperty("actionEnqueue")
public void setActionEnqueue(Port port, int queueId) {
actionEnqueue = new ActionEnqueue(port, queueId);
actionType = ActionValues.ACTION_ENQUEUE;
}
/**
* Convert the set of actions to a string.
*
* The string has the following form:
* [type=XXX action=XXX]
*
* @return the set of actions as a string.
*/
@Override
public String toString() {
String ret = "[";
ret += "type=" + actionType;
switch (actionType) {
case ACTION_OUTPUT:
ret += " action=" + actionOutput.toString();
break;
case ACTION_SET_VLAN_VID:
ret += " action=" + actionSetVlanId.toString();
break;
case ACTION_SET_VLAN_PCP:
ret += " action=" + actionSetVlanPriority.toString();
break;
case ACTION_STRIP_VLAN:
ret += " action=" + actionStripVlan.toString();
break;
case ACTION_SET_DL_SRC:
ret += " action=" + actionSetEthernetSrcAddr.toString();
break;
case ACTION_SET_DL_DST:
ret += " action=" + actionSetEthernetDstAddr.toString();
break;
case ACTION_SET_NW_SRC:
ret += " action=" + actionSetIPv4SrcAddr.toString();
break;
case ACTION_SET_NW_DST:
ret += " action=" + actionSetIPv4DstAddr.toString();
break;
case ACTION_SET_NW_TOS:
ret += " action=" + actionSetIpToS.toString();
break;
case ACTION_SET_TP_SRC:
ret += " action=" + actionSetTcpUdpSrcPort.toString();
break;
case ACTION_SET_TP_DST:
ret += " action=" + actionSetTcpUdpDstPort.toString();
break;
case ACTION_ENQUEUE:
ret += " action=" + actionEnqueue.toString();
break;
}
ret += "]";
return ret;
}
}