2 * Copyright (c) 2014 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.groupbasedpolicy.renderer.ofoverlay.sf;
11 import java.util.List;
14 import com.google.common.collect.ImmutableList;
16 import org.opendaylight.groupbasedpolicy.api.sf.EtherTypeClassifierDefinition;
17 import org.opendaylight.groupbasedpolicy.api.sf.IpProtoClassifierDefinition;
18 import org.opendaylight.groupbasedpolicy.renderer.ofoverlay.flow.FlowUtils;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.rev131026.flow.MatchBuilder;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.common.rev140421.ClassifierDefinitionId;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.common.rev140421.ParameterName;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.policy.rev140421.subject.feature.definitions.ClassifierDefinition;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.policy.rev140421.subject.feature.instance.ParameterValue;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.has.parameters.type.parameter.type.IntBuilder;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.renderers.renderer.capabilities.supported.classifier.definition.SupportedParameterValues;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.renderers.renderer.capabilities.supported.classifier.definition.SupportedParameterValuesBuilder;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.supported._int.value.fields.SupportedIntValue;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.groupbasedpolicy.renderer.rev151103.supported._int.value.fields.SupportedIntValueBuilder;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.model.match.types.rev131026.match.IpMatchBuilder;
32 * Match on the IP protocol of IP traffic
34 public class IpProtoClassifier extends Classifier {
36 protected IpProtoClassifier(Classifier parent) {
41 public ClassifierDefinitionId getId() {
42 return IpProtoClassifierDefinition.ID;
46 public ClassifierDefinition getClassifierDefinition() {
47 return IpProtoClassifierDefinition.DEFINITION;
51 public List<SupportedParameterValues> getSupportedParameterValues() {
53 List<SupportedIntValue> values = ImmutableList.of(
54 new SupportedIntValueBuilder().setValue(IpProtoClassifierDefinition.ICMP_VALUE).build(),
55 new SupportedIntValueBuilder().setValue(IpProtoClassifierDefinition.SCTP_VALUE).build(),
56 new SupportedIntValueBuilder().setValue(IpProtoClassifierDefinition.TCP_VALUE).build(),
57 new SupportedIntValueBuilder().setValue(IpProtoClassifierDefinition.UDP_VALUE).build());
58 SupportedParameterValuesBuilder b = new SupportedParameterValuesBuilder();
59 b.setParameterName(new ParameterName(IpProtoClassifierDefinition.PROTO_PARAM));
60 b.setParameterType(new IntBuilder().setSupportedIntValue(values).build());
62 return ImmutableList.of(b.build());
66 protected void checkPresenceOfRequiredParams(Map<String, ParameterValue> params) {
67 if (params.get(IpProtoClassifierDefinition.PROTO_PARAM) == null) {
68 throw new IllegalArgumentException(
69 "Parameter " + IpProtoClassifierDefinition.PROTO_PARAM + " " + MSG_NOT_SPECIFIED);
71 if (params.get(IpProtoClassifierDefinition.PROTO_PARAM).getIntValue() == null) {
72 throw new IllegalArgumentException(
73 "Value of " + IpProtoClassifierDefinition.PROTO_PARAM + " " + MSG_PARAMETER_IS_NOT_PRESENT);
78 protected List<MatchBuilder> update(List<MatchBuilder> matches, Map<String, ParameterValue> params) {
79 Long proto = params.get(IpProtoClassifierDefinition.PROTO_PARAM).getIntValue();
80 for (MatchBuilder match : matches) {
82 if (match.getIpMatch() != null) {
83 equalOrNotSetValidation(match.getIpMatch().getIpProtocol(), proto);
86 imb = new IpMatchBuilder();
88 imb.setIpProtocol(proto.shortValue());
89 match.setIpMatch(imb.build());
94 private void equalOrNotSetValidation(Short protoInMatch, long paramValue) {
95 if (protoInMatch != null) {
96 if (paramValue != protoInMatch.longValue()) {
97 throw new IllegalArgumentException(MSG_CLASSIFICATION_CONFLICT_DETECTED + " at "
98 + IpProtoClassifierDefinition.PROTO_PARAM + " parameter for values " + protoInMatch + " and "
99 + paramValue + ". It is not allowed "
100 + "to assign different values to the same parameter among all the classifiers within one rule.");
106 protected void checkPrereqs(List<MatchBuilder> matches) {
107 for (MatchBuilder match : matches) {
108 Long readEthType = null;
110 readEthType = match.getEthernetMatch().getEthernetType().getType().getValue();
111 } catch (NullPointerException e) {
112 throw new IllegalArgumentException(
113 "Parameter " + EtherTypeClassifierDefinition.ETHERTYPE_PARAM + " " + MSG_IS_MISSING);
115 if (!FlowUtils.IPv4.equals(readEthType) && !FlowUtils.IPv6.equals(readEthType)) {
116 throw new IllegalArgumentException("Parameter " + EtherTypeClassifierDefinition.ETHERTYPE_PARAM
117 + " must have value " + FlowUtils.IPv4 + " or " + FlowUtils.IPv6 + ".");
123 * Return the IpProtocol value. May return null.
125 * @param params the parameters of classifier-instance inserted by user
126 * @return the IpProtocol value
128 public static Long getIpProtoValue(Map<String, ParameterValue> params) {
129 if (params == null) {
132 if (params.get(IpProtoClassifierDefinition.PROTO_PARAM) == null) {
135 Long proto = params.get(IpProtoClassifierDefinition.PROTO_PARAM).getIntValue();