+/**
+ * Copyright (c) 2014 Ericsson India Global Services Pvt Ltd. and others. All rights reserved.
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v1.0 which accompanies this distribution,
+ * and is available at http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributor: hema.gopalkrishnan@ericsson.com
+ */
package org.opendaylight.openflowplugin.openflow.md.core.sal.convertor;
-import org.opendaylight.openflowjava.protocol.api.util.BinContent;
-import org.opendaylight.openflowplugin.openflow.md.OFConstants;
+import com.google.common.collect.Ordering;
+import org.opendaylight.openflowplugin.extension.api.ConverterExtensionKey;
+import org.opendaylight.openflowplugin.extension.api.ConvertorActionToOFJava;
+import org.opendaylight.openflowplugin.extension.api.ConvertorToOFJava;
+import org.opendaylight.openflowplugin.extension.api.TypeVersionKey;
+import org.opendaylight.openflowplugin.extension.api.path.ActionPath;
+import org.opendaylight.openflowplugin.api.OFConstants;
+import org.opendaylight.openflowplugin.openflow.md.core.extension.ActionExtensionHelper;
+import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.action.ActionSetNwDstReactor;
+import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.action.ActionSetNwSrcReactor;
+import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.common.OrderComparator;
import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.match.MatchConvertorImpl;
import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.match.MatchReactor;
+import org.opendaylight.openflowplugin.openflow.md.core.session.OFSessionUtil;
import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Ipv4Address;
+import org.opendaylight.openflowplugin.openflow.md.util.OpenflowPortsUtil;
+import org.opendaylight.openflowplugin.openflow.md.util.OpenflowVersion;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Dscp;
import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.Uri;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.CopyTtlInCase;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.CopyTtlInCaseBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.dl.src.action._case.SetDlSrcAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.mpls.ttl.action._case.SetMplsTtlAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.mpls.ttl.action._case.SetMplsTtlActionBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.nw.dst.action._case.SetNwDstAction;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.nw.src.action._case.SetNwSrcAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.nw.tos.action._case.SetNwTosAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.nw.ttl.action._case.SetNwTtlActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.queue.action._case.SetQueueAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.tp.src.action._case.SetTpSrcAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.vlan.id.action._case.SetVlanIdAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.action.set.vlan.pcp.action._case.SetVlanPcpAction;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.address.address.Ipv4;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.rev131026.OutputPortValues;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.l2.types.rev130827.VlanId;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.port.rev130925.CommonPort;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.DlAddressAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.DlAddressActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.EthertypeAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.EthertypeActionBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.ExperimenterAction;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.ExperimenterActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.GroupIdAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.GroupIdActionBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.IpAddressActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.MaxLengthAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.MaxLengthActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.MplsTtlAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.OxmFieldsActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.PortAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.PortActionBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.PortMatchEntry;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.PortMatchEntryBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.QueueIdAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.QueueIdActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.VlanPcpAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.VlanPcpActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.VlanVidAction;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.VlanVidActionBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Experimenter;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.VlanVidMatchEntry;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.VlanVidMatchEntryBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Group;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PopMpls;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PopPbb;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetMplsTtl;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetNwTtl;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetQueue;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.ActionsList;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.ActionsListBuilder;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.ActionBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.grouping.Action;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.grouping.ActionBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.EtherType;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PortNumber;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PortNumberValues;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PortNumberValuesV10;
-import org.opendaylight.yangtools.yang.binding.Augmentation;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.EthDst;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.EthSrc;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.OpenflowBasicClass;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.TcpDst;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.TcpSrc;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.VlanVid;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.oxm.fields.grouping.MatchEntries;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev130731.oxm.fields.grouping.MatchEntriesBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.general.rev140714.ExtensionKey;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.general.rev140714.GeneralExtensionGrouping;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflowplugin.extension.general.rev140714.general.extension.grouping.Extension;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
+
import java.math.BigInteger;
import java.util.ArrayList;
import java.util.List;
* converts into OF Data
* @author avishnoi@in.ibm.com Added convertor for OF bucket actions to SAL
* actions
- *
*/
public final class ActionConvertor {
private static final Logger logger = LoggerFactory.getLogger(ActionConvertor.class);
- private static final String PREFIX_SEPARATOR = "/";
- final private static Long MAXPortOF13 = new Long(4294967040L); // 0xffffff00
- final private static Long MAXPortOF10 = new Long(0xff00);
private ActionConvertor() {
// NOOP
}
- public static List<ActionsList> getActionList(
+ /**
+ * Translates SAL actions into OF Library actions
+ *
+ * @param actions SAL actions
+ * @param version Openflow protocol version used
+ * @param datapathid
+ * @return OF Library actions
+ */
+ public static List<Action> getActions(
List<org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.list.Action> actions,
- short version,BigInteger datapathid)
-
- {
- ActionsListBuilder actionsListBuilder = new ActionsListBuilder();
- List<ActionsList> actionsList = new ArrayList<ActionsList>();
+ short version, BigInteger datapathid) {
+ List<Action> actionsList = new ArrayList<>();
+ Action ofAction;
+ actions = Ordering.from(OrderComparator.<org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.list.Action>toInstance())
+ .sortedCopy(actions);
for (int actionItem = 0; actionItem < actions.size(); actionItem++) {
-
- ActionsList list = null;
+ ofAction = null;
+ ActionBuilder actionBuilder = new ActionBuilder();
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action = actions.get(
actionItem).getAction();
if (action instanceof OutputActionCase)
- list = salToOFOutputAction(action, actionsListBuilder, version);
+ ofAction = salToOFOutputAction(action, actionBuilder, version);
else if (action instanceof GroupActionCase)
- list = SalToOFGroupAction(action, actionsListBuilder);
+ ofAction = SalToOFGroupAction(action, actionBuilder);
else if (action instanceof CopyTtlOutCase)
- list = SalToOFCopyTTLIOut(actionsListBuilder);
+ ofAction = SalToOFCopyTTLIOut(actionBuilder);
else if (action instanceof CopyTtlInCase)
- list = SalToOFCopyTTLIIn(actionsListBuilder);
+ ofAction = SalToOFCopyTTLIIn(actionBuilder);
else if (action instanceof SetMplsTtlActionCase)
- list = SalToOFSetMplsTtl(action, actionsListBuilder);
+ ofAction = SalToOFSetMplsTtl(action, actionBuilder);
else if (action instanceof DecMplsTtlCase)
- list = SalToOFDecMplsTtl(actionsListBuilder);
+ ofAction = SalToOFDecMplsTtl(actionBuilder);
else if (action instanceof PushVlanActionCase)
- list = SalToOFPushVlanAction(action, actionsListBuilder);
+ ofAction = SalToOFPushVlanAction(action, actionBuilder, version);
else if (action instanceof PopVlanActionCase)
- list = SalToOFPopVlan(action, actionsListBuilder);
+ ofAction = (version == OFConstants.OFP_VERSION_1_0) ?
+ SalToOFStripVlan(actionBuilder, version)
+ : SalToOFPopVlan(actionBuilder);
else if (action instanceof PushMplsActionCase)
- list = SalToOFPushMplsAction(action, actionsListBuilder);
+ ofAction = SalToOFPushMplsAction(action, actionBuilder);
else if (action instanceof PopMplsActionCase)
- list = SalToOFPopMpls(action, actionsListBuilder);
+ ofAction = SalToOFPopMpls(action, actionBuilder);
else if (action instanceof SetQueueActionCase)
- list = SalToOFSetQueue(action, actionsListBuilder);
+ ofAction = SalToOFSetQueue(action, actionBuilder);
else if (action instanceof SetNwTtlActionCase)
- list = SalToOFSetNwTtl(action, actionsListBuilder);
+ ofAction = SalToOFSetNwTtl(action, actionBuilder);
else if (action instanceof DecNwTtlCase)
- list = SalToOFDecNwTtl(action, actionsListBuilder);
+ ofAction = SalToOFDecNwTtl(actionBuilder);
else if (action instanceof SetFieldCase)
- list = SalToOFSetField(action, actionsListBuilder, version,datapathid);
+ ofAction = SalToOFSetField(action, actionBuilder, version, datapathid);
else if (action instanceof PushPbbActionCase)
- list = SalToOFPushPbbAction(action, actionsListBuilder);
+ ofAction = SalToOFPushPbbAction(action, actionBuilder);
else if (action instanceof PopPbbActionCase)
- list = SalToOFPopPBB(action, actionsListBuilder);
- else if (action instanceof ExperimenterAction)
- list = SalToOFExperimenter(action, actionsListBuilder);
+ ofAction = SalToOFPopPBB(actionBuilder);
+
+ // 1.0 Actions
+ else if (action instanceof SetVlanIdActionCase) {
+ /*if (version == OFConstants.OFP_VERSION_1_0) {
- // 1.0 Actions
- else if (action instanceof SetVlanIdActionCase)
- list = SalToOFSetVlanId(action, actionsListBuilder, version);
+ } else {
+ List<Action> setVlanIdActionsList = convertToOF13(action, actionBuilder);
+ actionsList.addAll(setVlanIdActionsList);
+ }*/
+ ofAction = SalToOFSetVlanId(action, actionBuilder, version);
+ }
else if (action instanceof SetVlanPcpActionCase)
- list = SalToOFSetVlanpcp(action, actionsListBuilder, version);
+ ofAction = SalToOFSetVlanpcp(action, actionBuilder, version);
else if (action instanceof StripVlanActionCase)
- list = SalToOFStripVlan(action, actionsListBuilder, version);
+ ofAction = SalToOFStripVlan(actionBuilder, version);
else if (action instanceof SetDlSrcActionCase)
- list = SalToOFSetDlSrc(action, actionsListBuilder, version);
+ ofAction = SalToOFSetDlSrc(action, actionBuilder, version);
else if (action instanceof SetDlDstActionCase)
- list = SalToOFSetDlDst(action, actionsListBuilder, version);
+ ofAction = SalToOFSetDlDst(action, actionBuilder, version);
else if (action instanceof SetNwSrcActionCase)
- list = SalToOFSetNwSrc(action, actionsListBuilder, version);
+ ofAction = SalToOFSetNwSrc(action, actionBuilder, version);
else if (action instanceof SetNwDstActionCase)
- list = SalToOFSetNwDst(action, actionsListBuilder, version);
+ ofAction = SalToOFSetNwDst(action, actionBuilder, version);
else if (action instanceof SetTpSrcActionCase)
- list = SalToOFSetTpSrc(action, actionsListBuilder, version);
+ ofAction = SalToOFSetTpSrc(action, actionBuilder, version);
else if (action instanceof SetTpDstActionCase)
- list = SalToOFSetTpDst(action, actionsListBuilder, version);
+ ofAction = SalToOFSetTpDst(action, actionBuilder, version);
else if (action instanceof SetNwTosActionCase)
- list = SalToOFSetNwTos(action, actionsListBuilder, version);
-
- if(list != null){
- actionsList.add(list);
+ ofAction = SalToOFSetNwTos(action, actionBuilder, version);
+ else if (action instanceof GeneralExtensionGrouping) {
+
+ /**
+ * TODO: EXTENSION PROPOSAL (action, MD-SAL to OFJava)
+ * - we might need sessionContext as converter input
+ *
+ */
+
+ GeneralExtensionGrouping extensionCaseGrouping = (GeneralExtensionGrouping) action;
+ Extension extAction = extensionCaseGrouping.getExtension();
+ ConverterExtensionKey<? extends ExtensionKey> key = new ConverterExtensionKey<>(extensionCaseGrouping.getExtensionKey(), version);
+ ConvertorToOFJava<Action> convertor =
+ OFSessionUtil.getExtensionConvertorProvider().getConverter(key);
+ if (convertor != null) {
+ ofAction = convertor.convert(extAction);
+ }
+ } else {
+ // try vendor codecs
+ TypeVersionKey<org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action> key =
+ new TypeVersionKey<>(
+ (Class<? extends org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action>) action.getImplementedInterface(),
+ version);
+ ConvertorActionToOFJava<org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action, Action> convertor =
+ OFSessionUtil.getExtensionConvertorProvider().getConverter(key);
+ if (convertor != null) {
+ ofAction = convertor.convert(action);
+ }
+ }
+
+ if (ofAction != null) {
+ actionsList.add(ofAction);
}
-
}
return actionsList;
-
}
- private static ActionsList SalToOFSetField(
+ private static Action SalToOFSetField(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version,BigInteger datapathid) {
+ ActionBuilder actionBuilder, short version, BigInteger datapathid) {
SetFieldCase setFieldCase = (SetFieldCase) action;
- org.opendaylight.yang.gen.v1.urn.opendaylight.model.match.types.rev131026.Match match = setFieldCase
- .getSetField();
+ org.opendaylight.yang.gen.v1.urn.opendaylight.model.match.types.rev131026.Match match =
+ setFieldCase.getSetField();
+
+ if (version == OFConstants.OFP_VERSION_1_0) {
+ // pushvlan +setField can be called to configure 1.0 switches via MDSAL app
+ if (match.getVlanMatch() != null) {
+ VlanVidActionBuilder vlanidActionBuilder = new VlanVidActionBuilder();
+ vlanidActionBuilder.setVlanVid(match.getVlanMatch().getVlanId().getVlanId().getValue());
+ actionBuilder.setType(
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetVlanVid.class);
+ actionBuilder.addAugmentation(VlanVidAction.class, vlanidActionBuilder.build());
+ return actionBuilder.build();
+ } else {
+ return emtpyAction(actionBuilder);
+ }
- OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
- MatchReactor.getInstance().convert(match, version, oxmFieldsActionBuilder,datapathid);
+ } else {
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ MatchReactor.getInstance().convert(match, version, oxmFieldsActionBuilder, datapathid);
- ActionBuilder actionBuilder = new ActionBuilder();
- actionBuilder
- .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+ actionBuilder.setType(
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
- actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
+ }
}
- private static ActionsList SalToOFDecNwTtl(
- org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ private static Action SalToOFDecNwTtl(ActionBuilder actionBuilder) {
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.DecNwTtl.class);
-
- return emtpyAction(actionBuilder, actionsListBuilder);
+ return emtpyAction(actionBuilder);
}
- private static ActionsList SalToOFPushMplsAction(
+ private static Action SalToOFPushMplsAction(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ ActionBuilder actionBuilder) {
PushMplsActionCase pushMplsActionCase = (PushMplsActionCase) action;
-
actionBuilder.setType(PushMpls.class);
- return SalToOFPushAction(pushMplsActionCase.getPushMplsAction().getEthernetType(), actionBuilder,
- actionsListBuilder);
-
+ return SalToOFPushAction(pushMplsActionCase.getPushMplsAction().getEthernetType(), actionBuilder);
}
- private static ActionsList SalToOFPushPbbAction(
+ private static Action SalToOFPushPbbAction(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ ActionBuilder actionBuilder) {
PushPbbActionCase pushPbbActionCase = (PushPbbActionCase) action;
actionBuilder.setType(PushPbb.class);
- return SalToOFPushAction(pushPbbActionCase.getPushPbbAction().getEthernetType(), actionBuilder,
- actionsListBuilder);
+ return SalToOFPushAction(pushPbbActionCase.getPushPbbAction().getEthernetType(), actionBuilder);
}
- private static ActionsList SalToOFPushVlanAction(
+ private static Action SalToOFPushVlanAction(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ ActionBuilder actionBuilder, short version) {
+ if (version == OFConstants.OFP_VERSION_1_0) {
+ // if client configure openflow 1.0 switch as a openflow 1.3 switch using openflow 1.3 instructions
+ // then we can ignore PUSH_VLAN as set-vlan-id will push a vlan header if not present
+ return emtpyAction(actionBuilder);
+ }
+
PushVlanActionCase pushVlanActionCase = (PushVlanActionCase) action;
PushVlanAction pushVlanAction = pushVlanActionCase.getPushVlanAction();
actionBuilder.setType(PushVlan.class);
- return SalToOFPushAction(pushVlanAction.getEthernetType(), actionBuilder, actionsListBuilder);
-
+ return SalToOFPushAction(pushVlanAction.getEthernetType(), actionBuilder);
}
- private static ActionsList SalToOFSetNwTtl(
+ private static Action SalToOFSetNwTtl(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ ActionBuilder actionBuilder) {
SetNwTtlActionCase nwTtlActionCase = (SetNwTtlActionCase) action;
NwTtlActionBuilder nwTtlActionBuilder = new NwTtlActionBuilder();
nwTtlActionBuilder.setNwTtl(nwTtlActionCase.getSetNwTtlAction().getNwTtl());
actionBuilder.setType(SetNwTtl.class);
actionBuilder.addAugmentation(NwTtlAction.class, nwTtlActionBuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
-
+ return actionBuilder.build();
}
- private static ActionsList SalToOFSetQueue(
+ private static Action SalToOFSetQueue(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ ActionBuilder actionBuilder) {
SetQueueActionCase setQueueActionCase = (SetQueueActionCase) action;
SetQueueAction setQueueAction = setQueueActionCase.getSetQueueAction();
actionBuilder.setType(SetQueue.class);
actionBuilder.addAugmentation(QueueIdAction.class, queueIdActionBuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
}
- private static ActionsList SalToOFPopMpls(
+ private static Action SalToOFPopMpls(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ ActionBuilder actionBuilder) {
PopMplsActionCase popMplsActionCase = (PopMplsActionCase) action;
actionBuilder.setType(PopMpls.class);
- return SalToOFPushAction(popMplsActionCase.getPopMplsAction().getEthernetType(), actionBuilder,
- actionsListBuilder);
+ return SalToOFPushAction(popMplsActionCase.getPopMplsAction().getEthernetType(), actionBuilder);
}
- private static ActionsList SalToOFPopVlan(
- org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ private static Action SalToOFPopVlan(ActionBuilder actionBuilder) {
actionBuilder.setType(PopVlan.class);
-
- return emtpyAction(actionBuilder, actionsListBuilder);
+ return emtpyAction(actionBuilder);
}
- private static ActionsList SalToOFPopPBB(
- org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ private static Action SalToOFPopPBB(ActionBuilder actionBuilder) {
actionBuilder.setType(PopPbb.class);
- return emtpyAction(actionBuilder, actionsListBuilder);
+ return emtpyAction(actionBuilder);
}
- private static ActionsList SalToOFExperimenter(
+ // set-vlan-id (1.0 feature) can be called on 1.3 switches as well using ADSAL apis
+ private static Action SalToOFSetVlanId(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
+ ActionBuilder actionBuilder, short version) {
- ActionBuilder actionBuilder = new ActionBuilder();
- ExperimenterActionBuilder experimenterActionBuilder = new ExperimenterActionBuilder();
- experimenterActionBuilder.setExperimenter(((ExperimenterAction) action).getExperimenter());
- actionBuilder.setType(Experimenter.class);
- actionBuilder
- .addAugmentation(
- ExperimenterAction.class,
- (Augmentation<org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action>) experimenterActionBuilder);
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
-
- }
-
- private static ActionsList SalToOFSetVlanId(
- org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
+ SetVlanIdActionCase setvlanidcase = (SetVlanIdActionCase) action;
+ SetVlanIdAction setvlanidaction = setvlanidcase.getSetVlanIdAction();
if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
- SetVlanIdActionCase setvlanidcase = (SetVlanIdActionCase) action;
- SetVlanIdAction setvlanidaction = setvlanidcase.getSetVlanIdAction();
VlanVidActionBuilder vlanidActionBuilder = new VlanVidActionBuilder();
vlanidActionBuilder.setVlanVid(setvlanidaction.getVlanId().getValue());
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetVlanVid.class);
actionBuilder.addAugmentation(VlanVidAction.class, vlanidActionBuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
+
+ } else if (version >= OFConstants.OFP_VERSION_1_3) {
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+ List<MatchEntries> matchEntriesList = new ArrayList<>();
+ MatchEntriesBuilder matchEntriesBuilder = new MatchEntriesBuilder();
+ matchEntriesBuilder.setOxmClass(OpenflowBasicClass.class);
+ matchEntriesBuilder.setOxmMatchField(VlanVid.class);
+ VlanVidMatchEntryBuilder vlanVidBuilder = new VlanVidMatchEntryBuilder();
+ vlanVidBuilder.setCfiBit(true);
+ vlanVidBuilder.setVlanVid(setvlanidaction.getVlanId().getValue());
+ matchEntriesBuilder.addAugmentation(VlanVidMatchEntry.class, vlanVidBuilder.build());
+ matchEntriesBuilder.setHasMask(false);
+ matchEntriesList.add(matchEntriesBuilder.build());
+ oxmFieldsActionBuilder.setMatchEntries(matchEntriesList);
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
} else {
logger.error("Unknown Action Type for the Version", version);
return null;
}
-
}
- private static ActionsList SalToOFSetVlanpcp(
+ private static Action SalToOFSetVlanpcp(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
+ ActionBuilder actionBuilder, short version) {
- if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
- SetVlanPcpActionCase setvlanpcpcase = (SetVlanPcpActionCase) action;
- SetVlanPcpAction setvlanpcpaction = setvlanpcpcase.getSetVlanPcpAction();
+ SetVlanPcpActionCase setvlanpcpcase = (SetVlanPcpActionCase) action;
+ SetVlanPcpAction setvlanpcpaction = setvlanpcpcase.getSetVlanPcpAction();
+ if (version == OFConstants.OFP_VERSION_1_0) {
VlanPcpActionBuilder vlanpcpActionBuilder = new VlanPcpActionBuilder();
vlanpcpActionBuilder.setVlanPcp(setvlanpcpaction.getVlanPcp().getValue());
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetVlanPcp.class);
actionBuilder.addAugmentation(VlanPcpAction.class, vlanpcpActionBuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
+ } else if (version >= OFConstants.OFP_VERSION_1_3) {
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+ List<MatchEntries> matchEntriesList = new ArrayList<>();
+ matchEntriesList.add(MatchConvertorImpl.toOfVlanPcp(setvlanpcpaction.getVlanPcp()));
+ oxmFieldsActionBuilder.setMatchEntries(matchEntriesList);
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
} else {
logger.error("Unknown Action Type for the Version", version);
return null;
}
-
}
- private static ActionsList SalToOFStripVlan(
- org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
-
+ private static Action SalToOFStripVlan(ActionBuilder actionBuilder, short version) {
if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.StripVlan.class);
- return emtpyAction(actionBuilder, actionsListBuilder);
+ return emtpyAction(actionBuilder);
+ } else if (version >= OFConstants.OFP_VERSION_1_3) {
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+ List<MatchEntries> matchEntriesList = new ArrayList<>();
+ MatchEntriesBuilder matchEntriesBuilder = new MatchEntriesBuilder();
+ matchEntriesBuilder.setOxmClass(OpenflowBasicClass.class);
+ matchEntriesBuilder.setOxmMatchField(VlanVid.class);
+ VlanVidMatchEntryBuilder vlanVidBuilder = new VlanVidMatchEntryBuilder();
+ vlanVidBuilder.setCfiBit(true);
+ vlanVidBuilder.setVlanVid(0x0000);
+ matchEntriesBuilder.addAugmentation(VlanVidMatchEntry.class, vlanVidBuilder.build());
+ matchEntriesBuilder.setHasMask(false);
+ matchEntriesList.add(matchEntriesBuilder.build());
+ oxmFieldsActionBuilder.setMatchEntries(matchEntriesList);
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
} else {
logger.error("Unknown Action Type for the Version", version);
return null;
}
-
}
- private static ActionsList SalToOFSetDlSrc(
+ private static Action SalToOFSetDlSrc(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
+ ActionBuilder actionBuilder, short version) {
- if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
- SetDlSrcActionCase setdlsrccase = (SetDlSrcActionCase) action;
- SetDlSrcAction setdlsrcaction = setdlsrccase.getSetDlSrcAction();
+ SetDlSrcActionCase setdlsrccase = (SetDlSrcActionCase) action;
+ SetDlSrcAction setdlsrcaction = setdlsrccase.getSetDlSrcAction();
+ if (version == OFConstants.OFP_VERSION_1_0) {
DlAddressActionBuilder dladdressactionbuilder = new DlAddressActionBuilder();
dladdressactionbuilder.setDlAddress(setdlsrcaction.getAddress());
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetDlSrc.class);
actionBuilder.addAugmentation(DlAddressAction.class, dladdressactionbuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
+ } else if (version >= OFConstants.OFP_VERSION_1_3) {
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+ List<MatchEntries> matchEntriesList = new ArrayList<>();
+ matchEntriesList.add(MatchConvertorImpl.toOfMacAddress(EthSrc.class, setdlsrcaction.getAddress(), null));
+ oxmFieldsActionBuilder.setMatchEntries(matchEntriesList);
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
} else {
logger.error("Unknown Action Type for the Version", version);
return null;
}
-
}
- private static ActionsList SalToOFSetDlDst(
+ private static Action SalToOFSetDlDst(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
+ ActionBuilder actionBuilder, short version) {
- if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
- SetDlDstActionCase setdldstcase = (SetDlDstActionCase) action;
- SetDlDstAction setdldstaction = setdldstcase.getSetDlDstAction();
+ SetDlDstActionCase setdldstcase = (SetDlDstActionCase) action;
+ SetDlDstAction setdldstaction = setdldstcase.getSetDlDstAction();
+ if (version == OFConstants.OFP_VERSION_1_0) {
DlAddressActionBuilder dladdressactionbuilder = new DlAddressActionBuilder();
dladdressactionbuilder.setDlAddress(setdldstaction.getAddress());
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetDlDst.class);
actionBuilder.addAugmentation(DlAddressAction.class, dladdressactionbuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
+ } else if (version >= OFConstants.OFP_VERSION_1_3) {
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+ List<MatchEntries> matchEntriesList = new ArrayList<>();
+ matchEntriesList.add(MatchConvertorImpl.toOfMacAddress(EthDst.class, setdldstaction.getAddress(), null));
+ oxmFieldsActionBuilder.setMatchEntries(matchEntriesList);
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
} else {
logger.error("Unknown Action Type for the Version", version);
return null;
}
-
}
- private static ActionsList SalToOFSetNwSrc(
+ protected static Action SalToOFSetNwSrc(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
-
- if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
- SetNwSrcActionCase setnwsrccase = (SetNwSrcActionCase) action;
- SetNwSrcAction setnwsrcaction = setnwsrccase.getSetNwSrcAction();
+ ActionBuilder actionBuilder, short version) {
- IpAddressActionBuilder ipvaddress = new IpAddressActionBuilder();
- Ipv4 address_ipv4 = (Ipv4) setnwsrcaction.getAddress();
- Ipv4Address address = new Ipv4Address(address_ipv4.getIpv4Address().getValue());
- ipvaddress.setIpAddress(address);
- actionBuilder
- .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetNwSrc.class);
- actionBuilder.addAugmentation(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.IpAddressAction.class,
- ipvaddress.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
- } else {
- logger.error("Unknown Action Type for the Version", version);
+ try {
+ ActionSetNwSrcReactor.getInstance().convert((SetNwSrcActionCase) action, version, actionBuilder, null);
+ } catch (Exception e) {
+ logger.error(e.getMessage(), e);
return null;
}
+ return actionBuilder.build();
}
- private static ActionsList SalToOFSetNwDst(
+ protected static Action SalToOFSetNwDst(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
-
- if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
- SetNwDstActionCase setnwdstcase = (SetNwDstActionCase) action;
- SetNwDstAction setnwdstaction = setnwdstcase.getSetNwDstAction();
-
- IpAddressActionBuilder ipvaddress = new IpAddressActionBuilder();
- Ipv4 address_ipv4 = (Ipv4) setnwdstaction.getAddress();
- Ipv4Address address = new Ipv4Address(address_ipv4.getIpv4Address().getValue());
- ipvaddress.setIpAddress(address);
- actionBuilder
- .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetNwDst.class);
- actionBuilder.addAugmentation(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.augments.rev131002.IpAddressAction.class,
- ipvaddress.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ ActionBuilder actionBuilder, short version) {
- } else {
- logger.error("Unknown Action Type for the Version", version);
+ try {
+ ActionSetNwDstReactor.getInstance().convert((SetNwDstActionCase) action, version, actionBuilder, null);
+ } catch (Exception e) {
+ logger.error(e.getMessage(), e);
return null;
}
+ return actionBuilder.build();
}
- private static ActionsList SalToOFSetNwTos(
+ private static Action SalToOFSetNwTos(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
+ ActionBuilder actionBuilder, short version) {
- if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
- SetNwTosActionCase setnwtoscase = (SetNwTosActionCase) action;
- SetNwTosAction setnwtosaction = setnwtoscase.getSetNwTosAction();
+ SetNwTosActionCase setnwtoscase = (SetNwTosActionCase) action;
+ SetNwTosAction setnwtosaction = setnwtoscase.getSetNwTosAction();
+ if (version == OFConstants.OFP_VERSION_1_0) {
NwTosActionBuilder tosBuilder = new NwTosActionBuilder();
tosBuilder.setNwTos(setnwtosaction.getTos().shortValue());
actionBuilder.addAugmentation(NwTosAction.class, tosBuilder.build());
- actionBuilder.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetNwTos.class);
-
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetNwTos.class);
+ return actionBuilder.build();
+ } else if (version >= OFConstants.OFP_VERSION_1_3) {
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+ List<MatchEntries> matchEntriesList = new ArrayList<>();
+ matchEntriesList.add(MatchConvertorImpl.toOfIpDscp(new Dscp(setnwtosaction.getTos().shortValue())));
+ oxmFieldsActionBuilder.setMatchEntries(matchEntriesList);
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
} else {
logger.error("Unknown Action Type for the Version", version);
return null;
}
-
- private static ActionsList SalToOFSetTpSrc(
+ private static Action SalToOFSetTpSrc(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
+ ActionBuilder actionBuilder, short version) {
if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
SetTpSrcActionCase settpsrccase = (SetTpSrcActionCase) action;
SetTpSrcAction settpsrcaction = settpsrccase.getSetTpSrcAction();
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetTpSrc.class);
actionBuilder.addAugmentation(PortAction.class, settpsrc.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
- } else {
- logger.error("Unknown Action Type for the Version", version);
- return null;
+ return actionBuilder.build();
+ } else if (version == OFConstants.OFP_VERSION_1_3) {
+ SetTpSrcActionCase settpsrccase = (SetTpSrcActionCase) action;
+ SetTpSrcAction settpsrcaction = settpsrccase.getSetTpSrcAction();
+
+ MatchEntriesBuilder matchEntriesBuilder = new MatchEntriesBuilder();
+ matchEntriesBuilder.setOxmClass(OpenflowBasicClass.class);
+ matchEntriesBuilder.setHasMask(false);
+ matchEntriesBuilder.setOxmMatchField(TcpSrc.class);
+ PortMatchEntryBuilder portMatchEntryBuilder = new PortMatchEntryBuilder();
+ portMatchEntryBuilder.setPort(new org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.PortNumber(settpsrcaction.getPort().getValue().intValue()));
+ matchEntriesBuilder.addAugmentation(PortMatchEntry.class, portMatchEntryBuilder.build());
+
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ List<MatchEntries> matchEntries = new ArrayList<MatchEntries>();
+ matchEntries.add(matchEntriesBuilder.build());
+ oxmFieldsActionBuilder.setMatchEntries(matchEntries);
+
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
}
-
+ logger.error("Unknown Action Type for the Version", version);
+ return null;
}
- private static ActionsList SalToOFSetTpDst(
+ private static Action SalToOFSetTpDst(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
+ ActionBuilder actionBuilder, short version) {
if (version == OFConstants.OFP_VERSION_1_0) {
- ActionBuilder actionBuilder = new ActionBuilder();
-
SetTpDstActionCase settpdstcase = (SetTpDstActionCase) action;
SetTpDstAction settpdstaction = settpdstcase.getSetTpDstAction();
PortActionBuilder settpdst = new PortActionBuilder();
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetTpDst.class);
actionBuilder.addAugmentation(PortAction.class, settpdst.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
- } else {
- logger.error("Unknown Action Type for the Version", version);
- return null;
+ return actionBuilder.build();
+ } else if (version == OFConstants.OFP_VERSION_1_3) {
+ SetTpDstActionCase settpdstcase = (SetTpDstActionCase) action;
+ SetTpDstAction settpdstaction = settpdstcase.getSetTpDstAction();
+
+ MatchEntriesBuilder matchEntriesBuilder = new MatchEntriesBuilder();
+ matchEntriesBuilder.setOxmClass(OpenflowBasicClass.class);
+ matchEntriesBuilder.setHasMask(false);
+ matchEntriesBuilder.setOxmMatchField(TcpDst.class);
+ PortMatchEntryBuilder portMatchEntryBuilder = new PortMatchEntryBuilder();
+ portMatchEntryBuilder.setPort(new org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev100924.PortNumber(settpdstaction.getPort().getValue().intValue()));
+ matchEntriesBuilder.addAugmentation(PortMatchEntry.class, portMatchEntryBuilder.build());
+
+ actionBuilder
+ .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class);
+
+ OxmFieldsActionBuilder oxmFieldsActionBuilder = new OxmFieldsActionBuilder();
+ List<MatchEntries> matchEntries = new ArrayList<MatchEntries>();
+ matchEntries.add(matchEntriesBuilder.build());
+ oxmFieldsActionBuilder.setMatchEntries(matchEntries);
+
+ actionBuilder.addAugmentation(OxmFieldsAction.class, oxmFieldsActionBuilder.build());
+ return actionBuilder.build();
}
-
+ logger.error("Unknown Action Type for the Version", version);
+ return null;
}
- private static ActionsList SalToOFGroupAction(
+ private static Action SalToOFGroupAction(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
+ ActionBuilder actionBuilder) {
GroupActionCase groupActionCase = (GroupActionCase) action;
GroupAction groupAction = groupActionCase.getGroupAction();
GroupIdActionBuilder groupIdBuilder = new GroupIdActionBuilder();
groupIdBuilder.setGroupId(groupAction.getGroupId());
- ActionBuilder actionBuilder = new ActionBuilder();
actionBuilder.setType(Group.class);
actionBuilder.addAugmentation(GroupIdAction.class, groupIdBuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
}
- private static ActionsList SalToOFPushAction(Integer ethernetType, ActionBuilder actionBuilder,
- ActionsListBuilder actionsListBuilder) {
-
+ private static Action SalToOFPushAction(Integer ethernetType, ActionBuilder actionBuilder) {
EthertypeActionBuilder ethertypeActionBuilder = new EthertypeActionBuilder();
- ethertypeActionBuilder.setEthertype(new EtherType(ethernetType));
+ if (ethernetType != null) {
+ ethertypeActionBuilder.setEthertype(new EtherType(ethernetType));
+ }
/* OF */
actionBuilder.addAugmentation(EthertypeAction.class, ethertypeActionBuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
}
- private static ActionsList SalToOFDecMplsTtl(ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ private static Action SalToOFDecMplsTtl(ActionBuilder actionBuilder) {
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.DecMplsTtl.class);
- return emtpyAction(actionBuilder, actionsListBuilder);
+ return emtpyAction(actionBuilder);
}
- private static ActionsList SalToOFSetMplsTtl(
+ private static Action SalToOFSetMplsTtl(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
-
+ ActionBuilder actionBuilder) {
SetMplsTtlActionCase mplsTtlActionCase = (SetMplsTtlActionCase) action;
SetMplsTtlAction mplsTtlAction = mplsTtlActionCase.getSetMplsTtlAction();
/* OF */
actionBuilder.setType(SetMplsTtl.class);
actionBuilder.addAugmentation(MplsTtlAction.class, mplsTtlActionBuilder.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
}
- private static ActionsList SalToOFCopyTTLIIn(ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ private static Action SalToOFCopyTTLIIn(ActionBuilder actionBuilder) {
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.CopyTtlIn.class);
- return emtpyAction(actionBuilder, actionsListBuilder);
+ return emtpyAction(actionBuilder);
}
- private static ActionsList SalToOFCopyTTLIOut(ActionsListBuilder actionsListBuilder) {
- ActionBuilder actionBuilder = new ActionBuilder();
+ private static Action SalToOFCopyTTLIOut(ActionBuilder actionBuilder) {
actionBuilder
.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.CopyTtlOut.class);
- return emtpyAction(actionBuilder, actionsListBuilder);
+ return emtpyAction(actionBuilder);
}
- private static ActionsList emtpyAction(ActionBuilder actionBuilder, ActionsListBuilder actionsListBuilder) {
-
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ private static Action emtpyAction(ActionBuilder actionBuilder) {
+ return actionBuilder.build();
}
- private static ActionsList salToOFOutputAction(
+ private static Action salToOFOutputAction(
org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action action,
- ActionsListBuilder actionsListBuilder, short version) {
+ ActionBuilder actionBuilder, short version) {
OutputActionCase outputActionCase = ((OutputActionCase) action);
OutputAction outputAction = outputActionCase.getOutputAction();
if (outputAction.getMaxLength() != null) {
maxLenActionBuilder.setMaxLength(outputAction.getMaxLength());
} else {
- maxLenActionBuilder.setMaxLength(new Integer(0));
+ maxLenActionBuilder.setMaxLength(0);
}
- ActionBuilder actionBuilder = new ActionBuilder();
actionBuilder.addAugmentation(MaxLengthAction.class, maxLenActionBuilder.build());
Uri uri = outputAction.getOutputNodeConnector();
- if (version >= OFConstants.OFP_VERSION_1_3) {
-
- if (uri.getValue().equals(OutputPortValues.CONTROLLER.toString())) {
- portAction.setPort(new PortNumber(BinContent.intToUnsignedLong(PortNumberValues.CONTROLLER
- .getIntValue())));
- } else if (uri.getValue().equals(OutputPortValues.ALL.toString())) {
- portAction.setPort(new PortNumber(BinContent.intToUnsignedLong(PortNumberValues.ALL.getIntValue())));
- } else if (uri.getValue().equals(OutputPortValues.ANY.toString())) {
- portAction.setPort(new PortNumber(BinContent.intToUnsignedLong(PortNumberValues.ANY.getIntValue())));
-
- } else if (uri.getValue().equals(OutputPortValues.FLOOD.toString())) {
- portAction.setPort(new PortNumber(BinContent.intToUnsignedLong(PortNumberValues.FLOOD.getIntValue())));
-
- } else if (uri.getValue().equals(OutputPortValues.INPORT.toString())) {
- portAction.setPort(new PortNumber(BinContent.intToUnsignedLong(PortNumberValues.INPORT.getIntValue())));
-
- } else if (uri.getValue().equals(OutputPortValues.LOCAL.toString())) {
- portAction.setPort(new PortNumber(BinContent.intToUnsignedLong(PortNumberValues.LOCAL.getIntValue())));
-
- } else if (uri.getValue().equals(OutputPortValues.NORMAL.toString())) {
- portAction.setPort(new PortNumber(BinContent.intToUnsignedLong(PortNumberValues.NORMAL.getIntValue())));
-
- } else if (uri.getValue().equals(OutputPortValues.TABLE.toString())) {
- portAction.setPort(new PortNumber(BinContent.intToUnsignedLong(PortNumberValues.TABLE.getIntValue())));
-
- } else if (uri.getValue().equals(OutputPortValues.NONE.toString())) {
- logger.error("Unknown Port Type for the Version");
- } else if (InventoryDataServiceUtil.portNumberfromNodeConnectorId(outputAction.getOutputNodeConnector().getValue()) < MAXPortOF13) {
- portAction.setPort(new PortNumber(InventoryDataServiceUtil.portNumberfromNodeConnectorId(outputAction.getOutputNodeConnector().getValue())));
- } else {
- logger.error("Invalid Port for Output Action");
- }
- } else if (version == OFConstants.OFP_VERSION_1_0) {
-
- if (uri.getValue().equals(OutputPortValues.CONTROLLER.toString())) {
- portAction.setPort(new PortNumber((long) PortNumberValuesV10.CONTROLLER.getIntValue()));
- } else if (uri.getValue().equals(OutputPortValues.ALL.toString())) {
- portAction.setPort(new PortNumber((long) PortNumberValuesV10.ALL.getIntValue()));
- } else if (uri.getValue().equals(OutputPortValues.FLOOD.toString())) {
- portAction.setPort(new PortNumber((long) PortNumberValuesV10.FLOOD.getIntValue()));
- } else if (uri.getValue().equals(OutputPortValues.INPORT.toString())) {
- portAction.setPort(new PortNumber((long) PortNumberValuesV10.INPORT.getIntValue()));
- } else if (uri.getValue().equals(OutputPortValues.LOCAL.toString())) {
- portAction.setPort(new PortNumber((long) PortNumberValuesV10.LOCAL.getIntValue()));
- } else if (uri.getValue().equals(OutputPortValues.NORMAL.toString())) {
- portAction.setPort(new PortNumber((long) PortNumberValuesV10.NORMAL.getIntValue()));
- } else if (uri.getValue().equals(OutputPortValues.TABLE.toString())) {
- portAction.setPort(new PortNumber((long) PortNumberValuesV10.TABLE.getIntValue()));
- } else if (uri.getValue().equals(OutputPortValues.NONE.toString())) {
- portAction.setPort(new PortNumber((long) PortNumberValuesV10.NONE.getIntValue()));
- } else if (uri.getValue().equals(OutputPortValues.ANY.toString())) {
- logger.error("Unknown Port Type for the Version");
- } else if (InventoryDataServiceUtil.portNumberfromNodeConnectorId(outputAction.getOutputNodeConnector().getValue()) < MAXPortOF10) {
- portAction.setPort(new PortNumber(InventoryDataServiceUtil.portNumberfromNodeConnectorId(outputAction.getOutputNodeConnector().getValue())));
- } else {
- logger.error("Invalid Port for Output Action");
- }
+ OpenflowVersion ofVersion = OpenflowVersion.get(version);
+ Long portNumber = InventoryDataServiceUtil.portNumberfromNodeConnectorId(ofVersion, uri.getValue());
+ if (OpenflowPortsUtil.checkPortValidity(ofVersion, portNumber)) {
+ portAction.setPort(new PortNumber(portNumber));
+ } else {
+ logger.error("Invalid Port specified " + portNumber + " for Output Action for OF version:" + ofVersion);
}
- actionBuilder
- .setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Output.class);
+ actionBuilder.setType(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Output.class);
actionBuilder.addAugmentation(PortAction.class, portAction.build());
- actionsListBuilder.setAction(actionBuilder.build());
- return actionsListBuilder.build();
+ return actionBuilder.build();
}
* Method to convert OF actions associated with bucket to SAL Actions.
*
* @param actionList
+ * @param ofVersion current ofp version
+ * @param actionPath TODO
* @return List of converted SAL Actions.
*/
public static List<org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action> toMDSalActions(
- List<ActionsList> actionList) {
-
- List<org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action> bucketActions = new ArrayList<org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action>();
- for (ActionsList actionDesc : actionList) {
-
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action = actionDesc
- .getAction();
+ List<Action> actionList, OpenflowVersion ofVersion, ActionPath actionPath) {
+ List<org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action> bucketActions = new ArrayList<>();
+ for (Action action : actionList) {
if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Output.class))
- bucketActions.add(ofToSALOutputAction(action));
- else if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Group.class))
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Output.class)) {
+ bucketActions.add(ofToSALOutputAction(ofVersion, action));
+
+ } else if (action.getType().equals(
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Group.class)) {
bucketActions.add(ofToSALGroupAction(action));
- else if (action.getType().equals(
+
+ } else if (action.getType().equals(
org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.CopyTtlOut.class)) {
CopyTtlOutBuilder copyTtlOutaction = new CopyTtlOutBuilder();
bucketActions.add(new CopyTtlOutCaseBuilder().setCopyTtlOut(copyTtlOutaction.build()).build());
+
} else if (action.getType().equals(
org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.CopyTtlIn.class)) {
CopyTtlInBuilder copyTtlInaction = new CopyTtlInBuilder();
bucketActions.add(new CopyTtlInCaseBuilder().setCopyTtlIn(copyTtlInaction.build()).build());
+
} else if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetMplsTtl.class))
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetMplsTtl.class)) {
bucketActions.add(ofToSALSetMplsTtl(action));
- else if (action.getType().equals(
+
+ } else if (action.getType().equals(
org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.DecMplsTtl.class)) {
DecMplsTtlBuilder decMplsTtl = new DecMplsTtlBuilder();
bucketActions.add(new DecMplsTtlCaseBuilder().setDecMplsTtl(decMplsTtl.build()).build());
+
} else if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PushVlan.class))
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PushVlan.class)) {
bucketActions.add(ofToSALPushVlanAction(action));
- else if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PopVlan.class)) {
+
+ } else if (action.getType().equals(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PopVlan.class)
+ || action.getType().equals(org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.StripVlan.class)) {
+ // OF1.0 nodes will emit StripVlan and OF1.3+ will emit StripVlan/PopVlan, convert both to PopVlan for SAL
PopVlanActionBuilder popVlan = new PopVlanActionBuilder();
bucketActions.add(new PopVlanActionCaseBuilder().setPopVlanAction(popVlan.build()).build());
+
} else if (action.getType().equals(
org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PushMpls.class)) {
- PushMplsActionBuilder pushMpls = new PushMplsActionBuilder();
- bucketActions.add(new PushMplsActionCaseBuilder().setPushMplsAction(pushMpls.build()).build());
+ bucketActions.add(ofToSALPushMplsAction(action));
+
} else if (action.getType().equals(
org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PopMpls.class)) {
- PopMplsActionBuilder popMpls = new PopMplsActionBuilder();
- bucketActions.add(new PopMplsActionCaseBuilder().setPopMplsAction(popMpls.build()).build());
+ bucketActions.add(ofToSALPopMplsAction(action));
+
} else if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetQueue.class))
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetQueue.class)) {
bucketActions.add(ofToSALSetQueue(action));
- else if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetNwTtl.class))
+ } else if (action.getType().equals(
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetNwTtl.class)) {
bucketActions.add(ofToSALSetNwTtl(action));
- else if (action.getType().equals(
+
+ } else if (action.getType().equals(
org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.DecNwTtl.class)) {
DecNwTtlBuilder decNwTtl = new DecNwTtlBuilder();
bucketActions.add(new DecNwTtlCaseBuilder().setDecNwTtl(decNwTtl.build()).build());
+
} else if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class))
- bucketActions.add(new SetFieldCaseBuilder().setSetField(MatchConvertorImpl.ofToSALSetField(action))
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.SetField.class)) {
+ bucketActions.add(new SetFieldCaseBuilder().setSetField(MatchConvertorImpl.fromOFSetFieldToSALSetFieldAction(action, ofVersion))
.build());
-
- else if (action.getType().equals(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PushPbb.class))
+ } else if (action.getType().equals(
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PushPbb.class)) {
bucketActions.add(ofToSALPushPbbAction(action));
- else if (action.getType().equals(
+
+ } else if (action.getType().equals(
org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.PopPbb.class)) {
PopPbbActionBuilder popPbb = new PopPbbActionBuilder();
bucketActions.add(new PopPbbActionCaseBuilder().setPopPbbAction(popPbb.build()).build());
+
} else if (action.getType().equals(
org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.Experimenter.class)) {
- // bucketActions.add(ofToSALExperimenter(action));
- // TODO: Need to explore/discuss on how to handle experimenter
- // case.
+ /**
+ * TODO: EXTENSION PROPOSAL (action, OFJava to MD-SAL)
+ * - we might also need a way on how to identify exact type of augmentation to be
+ * used as match can be bound to multiple models
+ */
+ org.opendaylight.yang.gen.v1.urn.opendaylight.action.types.rev131112.action.Action processedAction =
+ ActionExtensionHelper.processAlienAction(action, ofVersion, actionPath);
+ if (processedAction != null) {
+ bucketActions.add(processedAction);
+ }
}
-
}
return bucketActions;
}
/**
* Method converts OF Output action object to SAL Output action object.
*
- * @param action
- * org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.
- * action.rev130731.actions.actions.list.Action
+ * @param ofVersion
+ * @param ofVersion
+ * @param action org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.
+ * action.rev130731.actions.actions.list.Action
* @return OutputAction
*/
- public static OutputActionCase ofToSALOutputAction(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action) {
-
+ public static OutputActionCase ofToSALOutputAction(OpenflowVersion ofVersion, Action action) {
OutputActionBuilder outputAction = new OutputActionBuilder();
PortAction port = action.getAugmentation(PortAction.class);
if (port != null) {
- outputAction.setOutputNodeConnector(new Uri(port.getPort().getValue().toString()));
+ CommonPort.PortNumber protocolAgnosticPort = OpenflowPortsUtil.getProtocolAgnosticPort(
+ ofVersion, port.getPort().getValue());
+ String portNumberAsString = OpenflowPortsUtil.portNumberToString(protocolAgnosticPort);
+ outputAction.setOutputNodeConnector(new Uri(portNumberAsString));
} else {
logger.error("Provided action is not OF Output action, no associated port found!");
}
* @param action
* @return GroupAction
*/
- public static GroupActionCase ofToSALGroupAction(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action) {
+ public static GroupActionCase ofToSALGroupAction(Action action) {
GroupActionBuilder groupAction = new GroupActionBuilder();
* @param action
* @return
*/
- public static SetMplsTtlActionCase ofToSALSetMplsTtl(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action) {
+ public static SetMplsTtlActionCase ofToSALSetMplsTtl(Action action) {
SetMplsTtlActionBuilder mplsTtlAction = new SetMplsTtlActionBuilder();
MplsTtlAction mplsTtl = action.getAugmentation(MplsTtlAction.class);
* @param action
* @return PushVlanAction
*/
- public static PushVlanActionCase ofToSALPushVlanAction(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action) {
+ public static PushVlanActionCase ofToSALPushVlanAction(Action action) {
PushVlanActionBuilder pushVlanAction = new PushVlanActionBuilder();
EthertypeAction etherType = action.getAugmentation(EthertypeAction.class);
- pushVlanAction.setVlanId(new VlanId(etherType.getEthertype().getValue()));
+ pushVlanAction.setEthernetType(etherType.getEthertype().getValue());
return new PushVlanActionCaseBuilder().setPushVlanAction(pushVlanAction.build()).build();
}
+ /**
+ * Method converts OF PushMpls action to SAL PushMpls action.
+ *
+ * @param action
+ * @return PushMplsAction
+ */
+ public static PushMplsActionCase ofToSALPushMplsAction(Action action) {
+
+ PushMplsActionBuilder pushMplsAction = new PushMplsActionBuilder();
+
+ EthertypeAction etherType = action.getAugmentation(EthertypeAction.class);
+ pushMplsAction.setEthernetType(etherType.getEthertype().getValue());
+
+ return new PushMplsActionCaseBuilder().setPushMplsAction(pushMplsAction.build()).build();
+ }
+
+ /**
+ * Method converts OF PopMpls action to SAL PopMpls action.
+ *
+ * @param action
+ * @return PopMplsActionCase
+ */
+ public static PopMplsActionCase ofToSALPopMplsAction(Action action) {
+
+ PopMplsActionBuilder popMplsAction = new PopMplsActionBuilder();
+
+ EthertypeAction etherType = action.getAugmentation(EthertypeAction.class);
+ popMplsAction.setEthernetType(etherType.getEthertype().getValue());
+
+ return new PopMplsActionCaseBuilder().setPopMplsAction(popMplsAction.build()).build();
+ }
+
/**
* Method converts OF SetQueue action to SAL SetQueue action.
*
* @param action
* @return SetQueueAction
*/
- public static SetQueueActionCase ofToSALSetQueue(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action) {
+ public static SetQueueActionCase ofToSALSetQueue(Action action) {
SetQueueActionBuilder setQueueAction = new SetQueueActionBuilder();
* @param action
* @return SetNwTtlAction
*/
- public static SetNwTtlActionCase ofToSALSetNwTtl(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action) {
+ public static SetNwTtlActionCase ofToSALSetNwTtl(Action action) {
SetNwTtlActionBuilder setNwTtl = new SetNwTtlActionBuilder();
NwTtlAction nwTtl = action.getAugmentation(NwTtlAction.class);
* @param action
* @return PushVlanAction
*/
- public static PushPbbActionCase ofToSALPushPbbAction(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action) {
+ public static PushPbbActionCase ofToSALPushPbbAction(Action action) {
PushPbbActionBuilder pushPbbAction = new PushPbbActionBuilder();
return new PushPbbActionCaseBuilder().setPushPbbAction(pushPbbAction.build()).build();
}
- public static Object ofToSALExperimenter(
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev130731.actions.actions.list.Action action) {
-
- ExperimenterAction ExperimenterAction = action.getAugmentation(ExperimenterAction.class);
-
- return null;
- /*
- * TODO: Need to explore/discuss about how to handle experimenter
- */
-
- }
}