import com.google.common.annotations.VisibleForTesting;
import java.math.BigInteger;
-import java.util.List;
-import org.opendaylight.openflowplugin.api.OFConstants;
-import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext;
+import org.opendaylight.openflowplugin.api.openflow.device.DeviceInfo;
import org.opendaylight.openflowplugin.api.openflow.device.MessageTranslator;
import org.opendaylight.openflowplugin.api.openflow.md.util.OpenflowVersion;
import org.opendaylight.openflowplugin.extension.api.AugmentTuple;
import org.opendaylight.openflowplugin.extension.api.path.MatchPath;
+import org.opendaylight.openflowplugin.impl.util.NodeConnectorRefToPortTranslator;
import org.opendaylight.openflowplugin.openflow.md.core.extension.MatchExtensionHelper;
import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.match.MatchConvertorImpl;
-import org.opendaylight.openflowplugin.openflow.md.util.InventoryDataServiceUtil;
import org.opendaylight.openflowplugin.openflow.md.util.PacketInUtil;
import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.types.rev131026.FlowCookie;
import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeConnectorRef;
import org.opendaylight.yang.gen.v1.urn.opendaylight.model.match.types.rev131026.Match;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev150225.match.entries.grouping.MatchEntry;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev150225.match.entry.value.grouping.match.entry.value.InPortCase;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.PacketInMessage;
import org.opendaylight.yang.gen.v1.urn.opendaylight.packet.service.rev130709.PacketReceived;
import org.opendaylight.yang.gen.v1.urn.opendaylight.packet.service.rev130709.PacketReceivedBuilder;
*/
public class PacketReceivedTranslator implements MessageTranslator<PacketInMessage, PacketReceived> {
@Override
- public PacketReceived translate(final PacketInMessage input, final DeviceContext deviceContext, final Object connectionDistinguisher) {
+ public PacketReceived translate(final PacketInMessage input, final DeviceInfo deviceInfo, final Object connectionDistinguisher) {
PacketReceivedBuilder packetReceivedBuilder = new PacketReceivedBuilder();
- BigInteger datapathId = deviceContext.getPrimaryConnectionContext().getFeatures().getDatapathId();
+ BigInteger datapathId = deviceInfo.getDatapathId();
- // extract the port number
- Long port = null;
- if (input.getVersion() == OFConstants.OFP_VERSION_1_0 && input.getInPort() != null) {
- port = input.getInPort().longValue();
- } else if (input.getVersion() == OFConstants.OFP_VERSION_1_3) {
- if (input.getMatch() != null && input.getMatch().getMatchEntry() != null) {
- port = getPortNumberFromMatch(input.getMatch().getMatchEntry());
- }
- }
+ // TODO: connection cookie from connection distinguisher
+ // packetReceivedBuilder.setConnectionCookie(new ConnectionCookie(input.getCookie().longValue()));
- //TODO connection cookie from connection distinguisher
-// packetReceivedBuilder.setConnectionCookie(new ConnectionCookie(input.getCookie().longValue()));
packetReceivedBuilder.setPayload(input.getData());
+
// get the Cookie if it exists
if (input.getCookie() != null) {
packetReceivedBuilder.setFlowCookie(new FlowCookie(input.getCookie()));
}
- if (port != null) {
- NodeConnectorRef nodeConnectorRef = deviceContext.lookupNodeConnectorRef(port);
- if (nodeConnectorRef == null) {
- nodeConnectorRef = InventoryDataServiceUtil.nodeConnectorRefFromDatapathIdPortno(
- datapathId, port, OpenflowVersion.get(input.getVersion()), deviceContext.getDeviceState().getNodeInstanceIdentifier());
- deviceContext.storeNodeConnectorRef(port, nodeConnectorRef);
- }
+
+ // Try to create the NodeConnectorRef
+ BigInteger dataPathId = deviceInfo.getDatapathId();
+ NodeConnectorRef nodeConnectorRef = NodeConnectorRefToPortTranslator.toNodeConnectorRef(input, dataPathId);
+
+ // If we was able to create NodeConnectorRef, use it
+ if (nodeConnectorRef != null) {
packetReceivedBuilder.setIngress(nodeConnectorRef);
}
}
return matchBuilder.build();
}
-
- @VisibleForTesting
- static Long getPortNumberFromMatch(final List<MatchEntry> entries) {
- Long port = null;
- for (MatchEntry entry : entries) {
- if (InPortCase.class.equals(entry.getMatchEntryValue().getImplementedInterface())) {
- InPortCase inPortCase = ((InPortCase) entry.getMatchEntryValue());
- org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev150225.match.entry.value.grouping.match.entry.value.in.port._case.InPort inPort = inPortCase.getInPort();
- if (inPort != null) {
- port = inPort.getPortNumber().getValue();
- break;
- }
- }
- }
- return port;
- }
}