-/* Copyright (C)2013 Pantheon Technologies, s.r.o. All rights reserved. */\r
-package org.opendaylight.openflowjava.protocol.impl.serialization.factories;\r
-\r
-import io.netty.buffer.ByteBuf;\r
-\r
-import java.util.HashMap;\r
-import java.util.List;\r
-import java.util.Map;\r
-\r
-import org.opendaylight.openflowjava.protocol.impl.serialization.OFSerializer;\r
-import org.opendaylight.openflowjava.protocol.impl.util.ByteBufUtils;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.FlowRemovedReason;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PacketInReason;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PortReason;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.SetAsyncInput;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.FlowRemovedMask;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PacketInMask;\r
-import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PortStatusMask;\r
-\r
-/**\r
- * Translates SetAsync messages\r
- * @author timotej.kubas\r
- * @author michal.polkorab\r
- */\r
-public class SetAsyncInputMessageFactory implements OFSerializer<SetAsyncInput> {\r
- private static final byte MESSAGE_TYPE = 28;\r
- private static final int MESSAGE_LENGTH = 32; \r
- private static SetAsyncInputMessageFactory instance;\r
- \r
-\r
- private SetAsyncInputMessageFactory() {\r
- // singleton\r
- }\r
- \r
- /**\r
- * @return singleton factory\r
- */\r
- public static synchronized SetAsyncInputMessageFactory getInstance() {\r
- if (instance == null) {\r
- instance = new SetAsyncInputMessageFactory();\r
- }\r
- return instance;\r
- }\r
- \r
- @Override\r
- public void messageToBuffer(short version, ByteBuf out,\r
- SetAsyncInput message) {\r
- ByteBufUtils.writeOFHeader(instance, message, out);\r
- encodePacketInMask(message.getPacketInMask(), out);\r
- encodePortStatusMask(message.getPortStatusMask(), out);\r
- encodeFlowRemovedMask(message.getFlowRemovedMask(), out);\r
- }\r
-\r
- @Override\r
- public int computeLength(SetAsyncInput message) {\r
- return MESSAGE_LENGTH;\r
- }\r
-\r
- @Override\r
- public byte getMessageType() {\r
- return MESSAGE_TYPE;\r
- }\r
- \r
- private static void encodePacketInMask(List<PacketInMask> packetInMask, ByteBuf outBuffer) {\r
- if (packetInMask != null) {\r
- for (PacketInMask currentPacketMask : packetInMask) {\r
- List<PacketInReason> mask = currentPacketMask.getMask();\r
- if (mask != null) {\r
- Map<Integer, Boolean> packetInReasonMap = new HashMap<>();\r
- for (PacketInReason packetInReason : mask) {\r
- if (PacketInReason.OFPRNOMATCH.equals(packetInReason)) {\r
- packetInReasonMap.put(PacketInReason.OFPRNOMATCH.getIntValue(), true);\r
- } else if (PacketInReason.OFPRACTION.equals(packetInReason)) {\r
- packetInReasonMap.put(PacketInReason.OFPRACTION.getIntValue(), true);\r
- } else if (PacketInReason.OFPRINVALIDTTL.equals(packetInReason)) {\r
- packetInReasonMap.put(PacketInReason.OFPRINVALIDTTL.getIntValue(), true);\r
- }\r
- }\r
- outBuffer.writeInt(ByteBufUtils.fillBitMaskFromMap(packetInReasonMap));\r
- }\r
- }\r
- }\r
- }\r
- \r
- private static void encodePortStatusMask(List<PortStatusMask> portStatusMask, ByteBuf outBuffer) {\r
- if (portStatusMask != null) {\r
- for (PortStatusMask currentPortStatusMask : portStatusMask) {\r
- List<PortReason> mask = currentPortStatusMask.getMask();\r
- if (mask != null) {\r
- Map<Integer, Boolean> portStatusReasonMap = new HashMap<>();\r
- for (PortReason packetInReason : mask) {\r
- if (PortReason.OFPPRADD.equals(packetInReason)) {\r
- portStatusReasonMap.put(PortReason.OFPPRADD.getIntValue(), true);\r
- } else if (PortReason.OFPPRDELETE.equals(packetInReason)) {\r
- portStatusReasonMap.put(PortReason.OFPPRDELETE.getIntValue(), true);\r
- } else if (PortReason.OFPPRMODIFY.equals(packetInReason)) {\r
- portStatusReasonMap.put(PortReason.OFPPRMODIFY.getIntValue(), true);\r
- }\r
- }\r
- outBuffer.writeInt(ByteBufUtils.fillBitMaskFromMap(portStatusReasonMap));\r
- }\r
- }\r
- }\r
- }\r
- \r
- private static void encodeFlowRemovedMask(List<FlowRemovedMask> flowRemovedMask, ByteBuf outBuffer) {\r
- if (flowRemovedMask != null) {\r
- for (FlowRemovedMask currentFlowRemovedMask : flowRemovedMask) {\r
- List<FlowRemovedReason> mask = currentFlowRemovedMask.getMask();\r
- if (mask != null) {\r
- Map<Integer, Boolean> flowRemovedReasonMap = new HashMap<>();\r
- for (FlowRemovedReason packetInReason : mask) {\r
- if (FlowRemovedReason.OFPRRIDLETIMEOUT.equals(packetInReason)) {\r
- flowRemovedReasonMap.put(FlowRemovedReason.OFPRRIDLETIMEOUT.getIntValue(), true);\r
- } else if (FlowRemovedReason.OFPRRHARDTIMEOUT.equals(packetInReason)) {\r
- flowRemovedReasonMap.put(FlowRemovedReason.OFPRRHARDTIMEOUT.getIntValue(), true);\r
- } else if (FlowRemovedReason.OFPRRDELETE.equals(packetInReason)) {\r
- flowRemovedReasonMap.put(FlowRemovedReason.OFPRRDELETE.getIntValue(), true);\r
- } else if (FlowRemovedReason.OFPRRGROUPDELETE.equals(packetInReason)) {\r
- flowRemovedReasonMap.put(FlowRemovedReason.OFPRRGROUPDELETE.getIntValue(), true);\r
- }\r
- }\r
- outBuffer.writeInt(ByteBufUtils.fillBitMaskFromMap(flowRemovedReasonMap));\r
- }\r
- }\r
- }\r
- }\r
- \r
+/*
+ * Copyright (c) 2013 Pantheon Technologies s.r.o. 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
+ */
+
+package org.opendaylight.openflowjava.protocol.impl.serialization.factories;
+
+import io.netty.buffer.ByteBuf;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import org.opendaylight.openflowjava.protocol.impl.serialization.OFSerializer;
+import org.opendaylight.openflowjava.protocol.impl.util.ByteBufUtils;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.FlowRemovedReason;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PacketInReason;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PortReason;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.SetAsyncInput;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.FlowRemovedMask;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PacketInMask;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PortStatusMask;
+
+/**
+ * Translates SetAsync messages
+ * @author timotej.kubas
+ * @author michal.polkorab
+ */
+public class SetAsyncInputMessageFactory implements OFSerializer<SetAsyncInput> {
+ private static final byte MESSAGE_TYPE = 28;
+ private static final int MESSAGE_LENGTH = 32;
+ private static SetAsyncInputMessageFactory instance;
+
+
+ private SetAsyncInputMessageFactory() {
+ // singleton
+ }
+
+ /**
+ * @return singleton factory
+ */
+ public static synchronized SetAsyncInputMessageFactory getInstance() {
+ if (instance == null) {
+ instance = new SetAsyncInputMessageFactory();
+ }
+ return instance;
+ }
+
+ @Override
+ public void messageToBuffer(short version, ByteBuf out,
+ SetAsyncInput message) {
+ ByteBufUtils.writeOFHeader(instance, message, out);
+ encodePacketInMask(message.getPacketInMask(), out);
+ encodePortStatusMask(message.getPortStatusMask(), out);
+ encodeFlowRemovedMask(message.getFlowRemovedMask(), out);
+ }
+
+ @Override
+ public int computeLength(SetAsyncInput message) {
+ return MESSAGE_LENGTH;
+ }
+
+ @Override
+ public byte getMessageType() {
+ return MESSAGE_TYPE;
+ }
+
+ private static void encodePacketInMask(List<PacketInMask> packetInMask, ByteBuf outBuffer) {
+ if (packetInMask != null) {
+ for (PacketInMask currentPacketMask : packetInMask) {
+ List<PacketInReason> mask = currentPacketMask.getMask();
+ if (mask != null) {
+ Map<Integer, Boolean> packetInReasonMap = new HashMap<>();
+ for (PacketInReason packetInReason : mask) {
+ if (PacketInReason.OFPRNOMATCH.equals(packetInReason)) {
+ packetInReasonMap.put(PacketInReason.OFPRNOMATCH.getIntValue(), true);
+ } else if (PacketInReason.OFPRACTION.equals(packetInReason)) {
+ packetInReasonMap.put(PacketInReason.OFPRACTION.getIntValue(), true);
+ } else if (PacketInReason.OFPRINVALIDTTL.equals(packetInReason)) {
+ packetInReasonMap.put(PacketInReason.OFPRINVALIDTTL.getIntValue(), true);
+ }
+ }
+ outBuffer.writeInt(ByteBufUtils.fillBitMaskFromMap(packetInReasonMap));
+ }
+ }
+ }
+ }
+
+ private static void encodePortStatusMask(List<PortStatusMask> portStatusMask, ByteBuf outBuffer) {
+ if (portStatusMask != null) {
+ for (PortStatusMask currentPortStatusMask : portStatusMask) {
+ List<PortReason> mask = currentPortStatusMask.getMask();
+ if (mask != null) {
+ Map<Integer, Boolean> portStatusReasonMap = new HashMap<>();
+ for (PortReason packetInReason : mask) {
+ if (PortReason.OFPPRADD.equals(packetInReason)) {
+ portStatusReasonMap.put(PortReason.OFPPRADD.getIntValue(), true);
+ } else if (PortReason.OFPPRDELETE.equals(packetInReason)) {
+ portStatusReasonMap.put(PortReason.OFPPRDELETE.getIntValue(), true);
+ } else if (PortReason.OFPPRMODIFY.equals(packetInReason)) {
+ portStatusReasonMap.put(PortReason.OFPPRMODIFY.getIntValue(), true);
+ }
+ }
+ outBuffer.writeInt(ByteBufUtils.fillBitMaskFromMap(portStatusReasonMap));
+ }
+ }
+ }
+ }
+
+ private static void encodeFlowRemovedMask(List<FlowRemovedMask> flowRemovedMask, ByteBuf outBuffer) {
+ if (flowRemovedMask != null) {
+ for (FlowRemovedMask currentFlowRemovedMask : flowRemovedMask) {
+ List<FlowRemovedReason> mask = currentFlowRemovedMask.getMask();
+ if (mask != null) {
+ Map<Integer, Boolean> flowRemovedReasonMap = new HashMap<>();
+ for (FlowRemovedReason packetInReason : mask) {
+ if (FlowRemovedReason.OFPRRIDLETIMEOUT.equals(packetInReason)) {
+ flowRemovedReasonMap.put(FlowRemovedReason.OFPRRIDLETIMEOUT.getIntValue(), true);
+ } else if (FlowRemovedReason.OFPRRHARDTIMEOUT.equals(packetInReason)) {
+ flowRemovedReasonMap.put(FlowRemovedReason.OFPRRHARDTIMEOUT.getIntValue(), true);
+ } else if (FlowRemovedReason.OFPRRDELETE.equals(packetInReason)) {
+ flowRemovedReasonMap.put(FlowRemovedReason.OFPRRDELETE.getIntValue(), true);
+ } else if (FlowRemovedReason.OFPRRGROUPDELETE.equals(packetInReason)) {
+ flowRemovedReasonMap.put(FlowRemovedReason.OFPRRGROUPDELETE.getIntValue(), true);
+ }
+ }
+ outBuffer.writeInt(ByteBufUtils.fillBitMaskFromMap(flowRemovedReasonMap));
+ }
+ }
+ }
+ }
+
}
\ No newline at end of file