Copyright update
[openflowjava.git] / openflow-protocol-impl / src / main / java / org / opendaylight / openflowjava / protocol / impl / serialization / factories / SetAsyncInputMessageFactory.java
index e83c58995ece6eebb15fc27b260843f513b5dc9d..c647aaf708b53b605a9312d3e10b8eb59f498be6 100644 (file)
-/* 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