aboutsummaryrefslogtreecommitdiffstats
path: root/framework/src/onos/core/api/src/main/java/org/onosproject/net/flow/criteria/Criteria.java
diff options
context:
space:
mode:
Diffstat (limited to 'framework/src/onos/core/api/src/main/java/org/onosproject/net/flow/criteria/Criteria.java')
-rw-r--r--framework/src/onos/core/api/src/main/java/org/onosproject/net/flow/criteria/Criteria.java624
1 files changed, 0 insertions, 624 deletions
diff --git a/framework/src/onos/core/api/src/main/java/org/onosproject/net/flow/criteria/Criteria.java b/framework/src/onos/core/api/src/main/java/org/onosproject/net/flow/criteria/Criteria.java
deleted file mode 100644
index c94b1e02..00000000
--- a/framework/src/onos/core/api/src/main/java/org/onosproject/net/flow/criteria/Criteria.java
+++ /dev/null
@@ -1,624 +0,0 @@
-/*
- * Copyright 2014-2015 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.net.flow.criteria;
-
-import org.onlab.packet.EthType;
-import org.onlab.packet.Ip4Address;
-import org.onlab.packet.Ip6Address;
-import org.onlab.packet.IpPrefix;
-import org.onlab.packet.MacAddress;
-import org.onlab.packet.MplsLabel;
-import org.onlab.packet.TpPort;
-import org.onlab.packet.VlanId;
-import org.onosproject.net.DeviceId;
-import org.onosproject.net.IndexedLambda;
-import org.onosproject.net.Lambda;
-import org.onosproject.net.OchSignal;
-import org.onosproject.net.OchSignalType;
-import org.onosproject.net.OduSignalId;
-import org.onosproject.net.OduSignalType;
-import org.onosproject.net.PortNumber;
-import org.onosproject.net.flow.criteria.Criterion.Type;
-
-/**
- * Factory class to create various traffic selection criteria.
- */
-public final class Criteria {
-
- //TODO: incomplete type implementation. Need to implement complete list from Criterion
-
- // Ban construction
- private Criteria() {
- }
-
- /**
- * Creates a match on IN_PORT field using the specified value.
- *
- * @param port inport value
- * @return match criterion
- */
- public static Criterion matchInPort(PortNumber port) {
- return new PortCriterion(port, Type.IN_PORT);
- }
-
- /**
- * Creates a match on IN_PHY_PORT field using the specified value.
- *
- * @param port inport value
- * @return match criterion
- */
- public static Criterion matchInPhyPort(PortNumber port) {
- return new PortCriterion(port, Type.IN_PHY_PORT);
- }
-
- /**
- * Creates a match on METADATA field using the specified value.
- *
- * @param metadata metadata value (64 bits data)
- * @return match criterion
- */
- public static Criterion matchMetadata(long metadata) {
- return new MetadataCriterion(metadata);
- }
-
- /**
- * Creates a match on ETH_DST field using the specified value. This value
- * may be a wildcard mask.
- *
- * @param mac MAC address value or wildcard mask
- * @return match criterion
- */
- public static Criterion matchEthDst(MacAddress mac) {
- return new EthCriterion(mac, Type.ETH_DST);
- }
-
- /**
- * Creates a match on ETH_SRC field using the specified value. This value
- * may be a wildcard mask.
- *
- * @param mac MAC address value or wildcard mask
- * @return match criterion
- */
- public static Criterion matchEthSrc(MacAddress mac) {
- return new EthCriterion(mac, Type.ETH_SRC);
- }
-
- /**
- * Creates a match on ETH_TYPE field using the specified value.
- *
- * @param ethType eth type value (16 bits unsigned integer)
- * @return match criterion
- */
- public static Criterion matchEthType(int ethType) {
- return new EthTypeCriterion(ethType);
- }
-
- /**
- * Creates a match on ETH_TYPE field using the specified value.
- *
- * @param ethType eth type value
- * @return match criterion
- */
- public static Criterion matchEthType(EthType ethType) {
- return new EthTypeCriterion(ethType);
- }
-
- /**
- * Creates a match on VLAN ID field using the specified value.
- *
- * @param vlanId vlan id value
- * @return match criterion
- */
- public static Criterion matchVlanId(VlanId vlanId) {
- return new VlanIdCriterion(vlanId);
- }
-
- /**
- * Creates a match on VLAN PCP field using the specified value.
- *
- * @param vlanPcp vlan pcp value (3 bits)
- * @return match criterion
- */
- public static Criterion matchVlanPcp(byte vlanPcp) {
- return new VlanPcpCriterion(vlanPcp);
- }
-
- /**
- * Creates a match on IP DSCP field using the specified value.
- *
- * @param ipDscp ip dscp value (6 bits)
- * @return match criterion
- */
- public static Criterion matchIPDscp(byte ipDscp) {
- return new IPDscpCriterion(ipDscp);
- }
-
- /**
- * Creates a match on IP ECN field using the specified value.
- *
- * @param ipEcn ip ecn value (2 bits)
- * @return match criterion
- */
- public static Criterion matchIPEcn(byte ipEcn) {
- return new IPEcnCriterion(ipEcn);
- }
-
- /**
- * Creates a match on IP proto field using the specified value.
- *
- * @param proto ip protocol value (8 bits unsigned integer)
- * @return match criterion
- */
- public static Criterion matchIPProtocol(short proto) {
- return new IPProtocolCriterion(proto);
- }
-
- /**
- * Creates a match on IPv4 source field using the specified value.
- *
- * @param ip ipv4 source value
- * @return match criterion
- */
- public static Criterion matchIPSrc(IpPrefix ip) {
- return new IPCriterion(ip, Type.IPV4_SRC);
- }
-
- /**
- * Creates a match on IPv4 destination field using the specified value.
- *
- * @param ip ipv4 source value
- * @return match criterion
- */
- public static Criterion matchIPDst(IpPrefix ip) {
- return new IPCriterion(ip, Type.IPV4_DST);
- }
-
- /**
- * Creates a match on TCP source port field using the specified value.
- *
- * @param tcpPort TCP source port
- * @return match criterion
- * @deprecated in Drake release
- */
- @Deprecated
- public static Criterion matchTcpSrc(short tcpPort) {
- return new TcpPortCriterion(TpPort.tpPort(tcpPort), Type.TCP_SRC);
- }
-
- /**
- * Creates a match on TCP source port field using the specified value.
- *
- * @param tcpPort TCP source port
- * @return match criterion
- */
- public static Criterion matchTcpSrc(TpPort tcpPort) {
- return new TcpPortCriterion(tcpPort, Type.TCP_SRC);
- }
-
- /**
- * Creates a match on TCP destination port field using the specified value.
- *
- * @param tcpPort TCP destination port
- * @return match criterion
- * @deprecated in Drake release
- */
- @Deprecated
- public static Criterion matchTcpDst(short tcpPort) {
- return new TcpPortCriterion(TpPort.tpPort(tcpPort), Type.TCP_DST);
- }
-
- /**
- * Creates a match on TCP destination port field using the specified value.
- *
- * @param tcpPort TCP destination port
- * @return match criterion
- */
- public static Criterion matchTcpDst(TpPort tcpPort) {
- return new TcpPortCriterion(tcpPort, Type.TCP_DST);
- }
-
- /**
- * Creates a match on TCP flags using the specified value.
- *
- * @param flags TCP flags
- * @return match criterion
- */
- public static Criterion matchTcpFlags(int flags) {
- return new TcpFlagsCriterion(flags);
- }
-
- /**
- * Creates a match on UDP source port field using the specified value.
- *
- * @param udpPort UDP source port
- * @return match criterion
- * @deprecated in Drake release
- */
- @Deprecated
- public static Criterion matchUdpSrc(short udpPort) {
- return new UdpPortCriterion(TpPort.tpPort(udpPort), Type.UDP_SRC);
- }
-
- /**
- * Creates a match on UDP source port field using the specified value.
- *
- * @param udpPort UDP source port
- * @return match criterion
- */
- public static Criterion matchUdpSrc(TpPort udpPort) {
- return new UdpPortCriterion(udpPort, Type.UDP_SRC);
- }
-
- /**
- * Creates a match on UDP destination port field using the specified value.
- *
- * @param udpPort UDP destination port
- * @return match criterion
- * @deprecated in Drake release
- */
- @Deprecated
- public static Criterion matchUdpDst(short udpPort) {
- return new UdpPortCriterion(TpPort.tpPort(udpPort), Type.UDP_DST);
- }
-
- /**
- * Creates a match on UDP destination port field using the specified value.
- *
- * @param udpPort UDP destination port
- * @return match criterion
- */
- public static Criterion matchUdpDst(TpPort udpPort) {
- return new UdpPortCriterion(udpPort, Type.UDP_DST);
- }
-
- /**
- * Creates a match on SCTP source port field using the specified value.
- *
- * @param sctpPort SCTP source port
- * @return match criterion
- * @deprecated in Drake release
- */
- @Deprecated
- public static Criterion matchSctpSrc(short sctpPort) {
- return new SctpPortCriterion(TpPort.tpPort(sctpPort), Type.SCTP_SRC);
- }
-
- /**
- * Creates a match on SCTP source port field using the specified value.
- *
- * @param sctpPort SCTP source port
- * @return match criterion
- */
- public static Criterion matchSctpSrc(TpPort sctpPort) {
- return new SctpPortCriterion(sctpPort, Type.SCTP_SRC);
- }
-
- /**
- * Creates a match on SCTP destination port field using the specified
- * value.
- *
- * @param sctpPort SCTP destination port
- * @return match criterion
- * @deprecated in Drake release
- */
- @Deprecated
- public static Criterion matchSctpDst(short sctpPort) {
- return new SctpPortCriterion(TpPort.tpPort(sctpPort), Type.SCTP_DST);
- }
-
- /**
- * Creates a match on SCTP destination port field using the specified
- * value.
- *
- * @param sctpPort SCTP destination port
- * @return match criterion
- */
- public static Criterion matchSctpDst(TpPort sctpPort) {
- return new SctpPortCriterion(sctpPort, Type.SCTP_DST);
- }
-
- /**
- * Creates a match on ICMP type field using the specified value.
- *
- * @param icmpType ICMP type (8 bits unsigned integer)
- * @return match criterion
- */
- public static Criterion matchIcmpType(short icmpType) {
- return new IcmpTypeCriterion(icmpType);
- }
-
- /**
- * Creates a match on ICMP code field using the specified value.
- *
- * @param icmpCode ICMP code (8 bits unsigned integer)
- * @return match criterion
- */
- public static Criterion matchIcmpCode(short icmpCode) {
- return new IcmpCodeCriterion(icmpCode);
- }
-
- /**
- * Creates a match on IPv6 source field using the specified value.
- *
- * @param ip ipv6 source value
- * @return match criterion
- */
- public static Criterion matchIPv6Src(IpPrefix ip) {
- return new IPCriterion(ip, Type.IPV6_SRC);
- }
-
- /**
- * Creates a match on IPv6 destination field using the specified value.
- *
- * @param ip ipv6 destination value
- * @return match criterion
- */
- public static Criterion matchIPv6Dst(IpPrefix ip) {
- return new IPCriterion(ip, Type.IPV6_DST);
- }
-
- /**
- * Creates a match on IPv6 flow label field using the specified value.
- *
- * @param flowLabel IPv6 flow label (20 bits)
- * @return match criterion
- */
- public static Criterion matchIPv6FlowLabel(int flowLabel) {
- return new IPv6FlowLabelCriterion(flowLabel);
- }
-
- /**
- * Creates a match on ICMPv6 type field using the specified value.
- *
- * @param icmpv6Type ICMPv6 type (8 bits unsigned integer)
- * @return match criterion
- */
- public static Criterion matchIcmpv6Type(short icmpv6Type) {
- return new Icmpv6TypeCriterion(icmpv6Type);
- }
-
- /**
- * Creates a match on ICMPv6 code field using the specified value.
- *
- * @param icmpv6Code ICMPv6 code (8 bits unsigned integer)
- * @return match criterion
- */
- public static Criterion matchIcmpv6Code(short icmpv6Code) {
- return new Icmpv6CodeCriterion(icmpv6Code);
- }
-
- /**
- * Creates a match on IPv6 Neighbor Discovery target address using the
- * specified value.
- *
- * @param targetAddress IPv6 Neighbor Discovery target address
- * @return match criterion
- */
- public static Criterion matchIPv6NDTargetAddress(Ip6Address targetAddress) {
- return new IPv6NDTargetAddressCriterion(targetAddress);
- }
-
- /**
- * Creates a match on IPv6 Neighbor Discovery source link-layer address
- * using the specified value.
- *
- * @param mac IPv6 Neighbor Discovery source link-layer address
- * @return match criterion
- */
- public static Criterion matchIPv6NDSourceLinkLayerAddress(MacAddress mac) {
- return new IPv6NDLinkLayerAddressCriterion(mac, Type.IPV6_ND_SLL);
- }
-
- /**
- * Creates a match on IPv6 Neighbor Discovery target link-layer address
- * using the specified value.
- *
- * @param mac IPv6 Neighbor Discovery target link-layer address
- * @return match criterion
- */
- public static Criterion matchIPv6NDTargetLinkLayerAddress(MacAddress mac) {
- return new IPv6NDLinkLayerAddressCriterion(mac, Type.IPV6_ND_TLL);
- }
-
- /**
- * Creates a match on MPLS label.
- *
- * @param mplsLabel MPLS label (20 bits)
- * @return match criterion
- */
- public static Criterion matchMplsLabel(MplsLabel mplsLabel) {
- return new MplsCriterion(mplsLabel);
- }
-
- /**
- * Creates a match on MPLS Bottom-of-Stack indicator bit.
- *
- * @param mplsBos boolean value indicating true (BOS=1) or false (BOS=0)
- * @return match criterion
- */
- public static Criterion matchMplsBos(boolean mplsBos) {
- return new MplsBosCriterion(mplsBos);
- }
-
- /**
- * Creates a match on MPLS TC.
- *
- * @param mplsTc MPLS TC (3 bits)
- * @return match criterion
- */
- public static Criterion matchMplsTc(byte mplsTc) {
- return new MplsTcCriterion(mplsTc);
- }
-
- /**
- * Creates a match on Tunnel ID.
- *
- * @param tunnelId Tunnel ID (64 bits)
- * @return match criterion
- */
- public static Criterion matchTunnelId(long tunnelId) {
- return new TunnelIdCriterion(tunnelId);
- }
-
- /**
- * Creates a match on IPv6 Extension Header pseudo-field fiags.
- * Those are defined in Criterion.IPv6ExthdrFlags.
- *
- * @param exthdrFlags IPv6 Extension Header pseudo-field flags (16 bits)
- * @return match criterion
- */
- public static Criterion matchIPv6ExthdrFlags(int exthdrFlags) {
- return new IPv6ExthdrFlagsCriterion(exthdrFlags);
- }
-
- /**
- * Creates a match on lambda using the specified value.
- *
- * @param lambda lambda
- * @return match criterion
- */
- public static Criterion matchLambda(Lambda lambda) {
- if (lambda instanceof IndexedLambda) {
- return new IndexedLambdaCriterion((IndexedLambda) lambda);
- } else if (lambda instanceof OchSignal) {
- return new OchSignalCriterion((OchSignal) lambda);
- } else {
- throw new UnsupportedOperationException(String.format("Unsupported type of Lambda: %s", lambda));
- }
- }
-
- /**
- * Create a match on OCh (Optical Channel) signal type.
- *
- * @param signalType OCh signal type
- * @return match criterion
- */
- public static Criterion matchOchSignalType(OchSignalType signalType) {
- return new OchSignalTypeCriterion(signalType);
- }
-
- /**
- * Creates a match on ODU (Optical channel Data Unit) signal ID using the specified value.
- *
- * @param oduSignalId ODU Signal Id
- * @return match criterion
- */
- public static Criterion matchOduSignalId(OduSignalId oduSignalId) {
- return new OduSignalIdCriterion(oduSignalId);
- }
-
- /**
- * Creates a match on ODU (Optical channel Data Unit) signal Type using the specified value.
- *
- * @param signalType ODU Signal Type
- * @return match criterion
- */
- public static Criterion matchOduSignalType(OduSignalType signalType) {
- return new OduSignalTypeCriterion(signalType);
- }
-
- /**
- * Creates a match on IPv4 destination field using the specified value.
- *
- * @param ip ipv4 destination value
- * @return match criterion
- */
- public static Criterion matchArpTpa(Ip4Address ip) {
- return new ArpPaCriterion(ip, Type.ARP_TPA);
- }
-
- /**
- * Creates a match on IPv4 source field using the specified value.
- *
- * @param ip ipv4 source value
- * @return match criterion
- */
- public static Criterion matchArpSpa(Ip4Address ip) {
- return new ArpPaCriterion(ip, Type.ARP_SPA);
- }
-
- /**
- * Creates a match on MAC destination field using the specified value.
- *
- * @param mac MAC destination value
- * @return match criterion
- */
- public static Criterion matchArpTha(MacAddress mac) {
- return new ArpHaCriterion(mac, Type.ARP_THA);
- }
-
- /**
- * Creates a match on MAC source field using the specified value.
- *
- * @param mac MAC source value
- * @return match criterion
- */
- public static Criterion matchArpSha(MacAddress mac) {
- return new ArpHaCriterion(mac, Type.ARP_SHA);
- }
-
- /**
- * Creates a match on arp operation type field using the specified value.
- *
- * @param arpOp arp operation type value
- * @return match criterion
- */
- public static Criterion matchArpOp(int arpOp) {
- return new ArpOpCriterion(arpOp, Type.ARP_OP);
- }
-
- /**
- * Creates a match on PBB I-SID field using the specific value.
- *
- * @param pbbIsid PBB I-SID
- * @return match criterion
- */
- public static Criterion matchPbbIsid(int pbbIsid) {
- return new PbbIsidCriterion(pbbIsid);
- }
-
- /**
- * Creates an extension criterion for the specified extension selector.
- *
- * @param extensionSelector extension selector
- * @param deviceId device ID
- * @return match criterion
- */
- public static Criterion extension(ExtensionSelector extensionSelector,
- DeviceId deviceId) {
- return new ExtensionCriterion(extensionSelector, deviceId);
- }
-
- /**
- * Creates a dummy criterion.
- *
- * @return match criterion
- */
- public static Criterion dummy() {
- return new DummyCriterion();
- }
-
- /**
- * Dummy Criterion used with @see{FilteringObjective}.
- */
- private static class DummyCriterion implements Criterion {
-
- @Override
- public Type type() {
- return Type.DUMMY;
- }
- }
-}