/* * Copyright (c) 2014 Contextream, Inc. 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.lispflowmapping.implementation.serializer.address; import java.nio.ByteBuffer; import java.util.ArrayList; import java.util.List; import org.apache.commons.lang3.BooleanUtils; import org.opendaylight.lispflowmapping.implementation.serializer.address.factory.LispAFIAddressSerializerFactory; import org.opendaylight.lispflowmapping.implementation.util.ByteUtil; import org.opendaylight.lispflowmapping.implementation.util.LispAFIConvertor; import org.opendaylight.lispflowmapping.type.AddressFamilyNumberEnum; import org.opendaylight.lispflowmapping.type.LispCanonicalAddressFormatEnum; import org.opendaylight.yang.gen.v1.lispflowmapping.rev131031.LcafTrafficEngineeringAddress; import org.opendaylight.yang.gen.v1.lispflowmapping.rev131031.LispAFIAddress; import org.opendaylight.yang.gen.v1.lispflowmapping.rev131031.lcaftrafficengineeringaddress.Hops; import org.opendaylight.yang.gen.v1.lispflowmapping.rev131031.lcaftrafficengineeringaddress.HopsBuilder; import org.opendaylight.yang.gen.v1.lispflowmapping.rev131031.lispaddress.lispaddresscontainer.address.LcafTrafficEngineeringBuilder; import org.opendaylight.yang.gen.v1.lispflowmapping.rev131031.lispsimpleaddress.PrimitiveAddress; import org.opendaylight.yang.gen.v1.lispflowmapping.rev131031.reencaphop.HopBuilder; public class LispTrafficEngineeringLCAFAddressSerializer extends LispLCAFAddressSerializer { private static final LispTrafficEngineeringLCAFAddressSerializer INSTANCE = new LispTrafficEngineeringLCAFAddressSerializer(); // Private constructor prevents instantiation from other classes private LispTrafficEngineeringLCAFAddressSerializer() { } public static LispTrafficEngineeringLCAFAddressSerializer getInstance() { return INSTANCE; } @Override protected short getLcafLength(LispAFIAddress lispAddress) { short totalSize = 0; if (((LcafTrafficEngineeringAddress) lispAddress).getHops() != null) { for (Hops hop : ((LcafTrafficEngineeringAddress) lispAddress).getHops()) { totalSize += LispAddressSerializer.getInstance().getAddressSize((LispAFIAddress) hop.getHop().getPrimitiveAddress()) + 2; } } return totalSize; } @Override protected void serializeData(ByteBuffer buffer, LispAFIAddress lispAddress) { if (((LcafTrafficEngineeringAddress) lispAddress).getHops() != null) { for (Hops hop : ((LcafTrafficEngineeringAddress) lispAddress).getHops()) { serializeAFIAddressHeader(buffer, (LispAFIAddress) hop.getHop().getPrimitiveAddress()); buffer.put((byte) 0); buffer.put((byte) (ByteUtil.boolToBit(BooleanUtils.isTrue(hop.isLookup()), Flags.LOOKUP) | // ByteUtil.boolToBit(BooleanUtils.isTrue(hop.isRLOCProbe()), Flags.RLOC_PROBE) | // ByteUtil.boolToBit(BooleanUtils.isTrue(hop.isStrict()), Flags.STRICT))); LispAddressSerializer serializer = LispAFIAddressSerializerFactory.getSerializer(AddressFamilyNumberEnum .valueOf(((LispAFIAddress) hop.getHop().getPrimitiveAddress()).getAfi())); serializer.serializeData(buffer, (LispAFIAddress) hop.getHop().getPrimitiveAddress()); } } } @Override protected LcafTrafficEngineeringAddress deserializeData(ByteBuffer buffer, byte res2, short length) { List hops = new ArrayList(); while (length > 0) { short afi = buffer.getShort(); LispAddressSerializer serializer = LispAFIAddressSerializerFactory.getSerializer(AddressFamilyNumberEnum.valueOf(afi)); byte flags = (byte) buffer.getShort(); boolean lookup = ByteUtil.extractBit(flags, Flags.LOOKUP); boolean RLOCProbe = ByteUtil.extractBit(flags, Flags.RLOC_PROBE); boolean strict = ByteUtil.extractBit(flags, Flags.STRICT); LispAFIAddress address = serializer.deserializeData(buffer); HopsBuilder builder = new HopsBuilder(); builder.setLookup(lookup); builder.setRLOCProbe(RLOCProbe); builder.setStrict(strict); builder.setHop(new HopBuilder().setPrimitiveAddress((PrimitiveAddress) LispAFIConvertor.toPrimitive(address)).build()); length -= LispAddressSerializer.getInstance().getAddressSize((LispAFIAddress) builder.getHop().getPrimitiveAddress()) + 2; hops.add(builder.build()); } return new LcafTrafficEngineeringBuilder().setAfi(AddressFamilyNumberEnum.LCAF.getIanaCode()) .setLcafType((short) LispCanonicalAddressFormatEnum.TRAFFIC_ENGINEERING.getLispCode()).setHops(hops).build(); } private interface Flags { int LOOKUP = 0x04; int RLOC_PROBE = 0x02; int STRICT = 0x01; } }