Java tutorial
/* * 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.deserialization.factories; import io.netty.buffer.ByteBuf; import java.util.ArrayList; import java.util.List; import org.opendaylight.openflowjava.protocol.impl.deserialization.OFDeserializer; 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.GetAsyncOutput; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.GetAsyncOutputBuilder; 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.FlowRemovedMaskBuilder; 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.PacketInMaskBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PortStatusMask; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.async.body.grouping.PortStatusMaskBuilder; /** * Translates GetAsyncReply messages * @author timotej.kubas * @author michal.polkorab */ public class GetAsyncReplyMessageFactory implements OFDeserializer<GetAsyncOutput> { private static GetAsyncReplyMessageFactory instance; private static final byte SEPARATE_ROLES = 2; private GetAsyncReplyMessageFactory() { // singleton } /** * @return singleton factory */ public static synchronized GetAsyncReplyMessageFactory getInstance() { if (instance == null) { instance = new GetAsyncReplyMessageFactory(); } return instance; } @Override public GetAsyncOutput bufferToMessage(ByteBuf rawMessage, short version) { GetAsyncOutputBuilder builder = new GetAsyncOutputBuilder(); builder.setVersion(version); builder.setXid(rawMessage.readUnsignedInt()); builder.setPacketInMask(decodePacketInMask(rawMessage)); builder.setPortStatusMask(decodePortStatusMask(rawMessage)); builder.setFlowRemovedMask(decodeFlowRemovedMask(rawMessage)); return builder.build(); } private static List<PacketInMask> decodePacketInMask(ByteBuf input) { List<PacketInMask> inMasks = new ArrayList<>(); PacketInMaskBuilder maskBuilder; for (int i = 0; i < SEPARATE_ROLES; i++) { maskBuilder = new PacketInMaskBuilder(); maskBuilder.setMask(decodePacketInReasons(input.readUnsignedInt())); inMasks.add(maskBuilder.build()); } return inMasks; } private static List<PortStatusMask> decodePortStatusMask(ByteBuf input) { List<PortStatusMask> inMasks = new ArrayList<>(); PortStatusMaskBuilder maskBuilder; for (int i = 0; i < SEPARATE_ROLES; i++) { maskBuilder = new PortStatusMaskBuilder(); maskBuilder.setMask(decodePortReasons(input.readUnsignedInt())); inMasks.add(maskBuilder.build()); } return inMasks; } private static List<FlowRemovedMask> decodeFlowRemovedMask(ByteBuf input) { List<FlowRemovedMask> inMasks = new ArrayList<>(); FlowRemovedMaskBuilder maskBuilder; for (int i = 0; i < SEPARATE_ROLES; i++) { maskBuilder = new FlowRemovedMaskBuilder(); maskBuilder.setMask(decodeFlowRemovedReasons(input.readUnsignedInt())); inMasks.add(maskBuilder.build()); } return inMasks; } private static List<PacketInReason> decodePacketInReasons(long input) { List<PacketInReason> reasons = new ArrayList<>(); if ((input & (1 << 0)) != 0) { reasons.add(PacketInReason.OFPRNOMATCH); } if ((input & (1 << 1)) != 0) { reasons.add(PacketInReason.OFPRACTION); } if ((input & (1 << 2)) != 0) { reasons.add(PacketInReason.OFPRINVALIDTTL); } return reasons; } private static List<PortReason> decodePortReasons(long input) { List<PortReason> reasons = new ArrayList<>(); if ((input & (1 << 0)) != 0) { reasons.add(PortReason.OFPPRADD); } if ((input & (1 << 1)) != 0) { reasons.add(PortReason.OFPPRDELETE); } if ((input & (1 << 2)) != 0) { reasons.add(PortReason.OFPPRMODIFY); } return reasons; } private static List<FlowRemovedReason> decodeFlowRemovedReasons(long input) { List<FlowRemovedReason> reasons = new ArrayList<>(); if ((input & (1 << 0)) != 0) { reasons.add(FlowRemovedReason.OFPRRIDLETIMEOUT); } if ((input & (1 << 1)) != 0) { reasons.add(FlowRemovedReason.OFPRRHARDTIMEOUT); } if ((input & (1 << 2)) != 0) { reasons.add(FlowRemovedReason.OFPRRDELETE); } if ((input & (1 << 3)) != 0) { reasons.add(FlowRemovedReason.OFPRRGROUPDELETE); } return reasons; } }