2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.protocol.pcep.impl.object;
10 import java.util.BitSet;
12 import org.opendaylight.protocol.pcep.spi.AbstractObjectWithTlvsParser;
13 import org.opendaylight.protocol.pcep.spi.ObjectUtil;
14 import org.opendaylight.protocol.pcep.spi.PCEPDeserializerException;
15 import org.opendaylight.protocol.pcep.spi.TlvHandlerRegistry;
16 import org.opendaylight.protocol.util.ByteArray;
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.Object;
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.ObjectHeader;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.lspa.object.Lspa;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.lspa.object.LspaBuilder;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.lspa.object.lspa.Tlvs;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.lspa.object.lspa.TlvsBuilder;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.rsvp.rev130820.AttributeFilter;
25 import com.google.common.primitives.UnsignedBytes;
28 * Parser for {@link Lspa}
30 public class PCEPLspaObjectParser extends AbstractObjectWithTlvsParser<TlvsBuilder> {
32 public static final int CLASS = 9;
34 public static final int TYPE = 1;
37 * lengths of fields in bytes
39 private static final int EXC_ANY_F_LENGTH = 4;
40 private static final int INC_ANY_F_LENGTH = 4;
41 private static final int INC_ALL_F_LENGTH = 4;
42 private static final int SET_PRIO_F_LENGTH = 1;
43 private static final int HOLD_PRIO_F_LENGTH = 1;
44 private static final int FLAGS_F_LENGTH = 1;
47 * offsets of flags inside flags field in bits
49 private static final int L_FLAG_OFFSET = 7;
52 * offsets of fields in bytes
54 private static final int EXC_ANY_F_OFFSET = 0;
55 private static final int INC_ANY_F_OFFSET = EXC_ANY_F_OFFSET + EXC_ANY_F_LENGTH;
56 private static final int INC_ALL_F_OFFSET = INC_ANY_F_OFFSET + INC_ANY_F_LENGTH;
57 private static final int SET_PRIO_F_OFFSET = INC_ALL_F_OFFSET + INC_ALL_F_LENGTH;
58 private static final int HOLD_PRIO_F_OFFSET = SET_PRIO_F_OFFSET + SET_PRIO_F_LENGTH;
59 private static final int FLAGS_F_OFFSET = HOLD_PRIO_F_OFFSET + HOLD_PRIO_F_LENGTH;
60 private static final int TLVS_F_OFFSET = FLAGS_F_OFFSET + FLAGS_F_LENGTH + 1;
62 public PCEPLspaObjectParser(final TlvHandlerRegistry tlvReg) {
67 public Lspa parseObject(final ObjectHeader header, final byte[] bytes) throws PCEPDeserializerException {
69 throw new IllegalArgumentException("Bytes array is mandatory.");
71 final BitSet flags = ByteArray.bytesToBitSet(ByteArray.subByte(bytes, FLAGS_F_OFFSET, FLAGS_F_LENGTH));
73 final LspaBuilder builder = new LspaBuilder();
74 final TlvsBuilder tbuilder = new TlvsBuilder();
75 parseTlvs(tbuilder, ByteArray.cutBytes(bytes, TLVS_F_OFFSET));
76 builder.setTlvs(tbuilder.build());
78 builder.setIgnore(header.isIgnore());
79 builder.setProcessingRule(header.isProcessingRule());
81 builder.setHoldPriority((short) UnsignedBytes.toInt(bytes[HOLD_PRIO_F_OFFSET]));
82 builder.setSetupPriority((short) UnsignedBytes.toInt(bytes[SET_PRIO_F_OFFSET]));
83 builder.setLocalProtectionDesired(flags.get(L_FLAG_OFFSET));
84 builder.setExcludeAny(new AttributeFilter(ByteArray.bytesToLong(ByteArray.subByte(bytes, EXC_ANY_F_OFFSET, EXC_ANY_F_LENGTH))));
85 builder.setIncludeAll(new AttributeFilter(ByteArray.bytesToLong(ByteArray.subByte(bytes, INC_ALL_F_OFFSET, INC_ALL_F_LENGTH))));
86 builder.setIncludeAny(new AttributeFilter(ByteArray.bytesToLong(ByteArray.subByte(bytes, INC_ANY_F_OFFSET, INC_ANY_F_LENGTH))));
87 return builder.build();
91 public byte[] serializeObject(final Object object) {
92 if (!(object instanceof Lspa)) {
93 throw new IllegalArgumentException("Wrong instance of PCEPObject. Passed " + object.getClass() + ". Needed LspaObject.");
95 final Lspa lspaObj = (Lspa) object;
97 final byte[] tlvs = serializeTlvs(lspaObj.getTlvs());
98 final byte[] retBytes = new byte[TLVS_F_OFFSET + tlvs.length + getPadding(TLVS_F_OFFSET + tlvs.length, PADDED_TO)];
100 if (lspaObj.getExcludeAny() != null) {
101 System.arraycopy(ByteArray.longToBytes(lspaObj.getExcludeAny().getValue(), EXC_ANY_F_LENGTH), 0, retBytes, EXC_ANY_F_OFFSET,
104 if (lspaObj.getIncludeAny() != null) {
105 System.arraycopy(ByteArray.longToBytes(lspaObj.getIncludeAny().getValue(), INC_ANY_F_LENGTH), 0, retBytes, INC_ANY_F_OFFSET,
108 if (lspaObj.getIncludeAll() != null) {
109 System.arraycopy(ByteArray.longToBytes(lspaObj.getIncludeAll().getValue(), INC_ALL_F_LENGTH), 0, retBytes, INC_ALL_F_OFFSET,
112 if (lspaObj.getSetupPriority() != null) {
113 retBytes[SET_PRIO_F_OFFSET] = UnsignedBytes.checkedCast(lspaObj.getSetupPriority());
115 if (lspaObj.getHoldPriority() != null) {
116 retBytes[HOLD_PRIO_F_OFFSET] = UnsignedBytes.checkedCast(lspaObj.getHoldPriority());
119 final BitSet flags = new BitSet(FLAGS_F_LENGTH * Byte.SIZE);
120 if (lspaObj.isLocalProtectionDesired() != null && lspaObj.isLocalProtectionDesired()) {
121 flags.set(L_FLAG_OFFSET, lspaObj.isLocalProtectionDesired());
123 ByteArray.copyWhole(ByteArray.bitSetToBytes(flags, FLAGS_F_LENGTH), retBytes, FLAGS_F_OFFSET);
124 ByteArray.copyWhole(tlvs, retBytes, TLVS_F_OFFSET);
125 return ObjectUtil.formatSubobject(TYPE, CLASS, object.isProcessingRule(), object.isIgnore(), retBytes);
128 public byte[] serializeTlvs(final Tlvs tlvs) {
133 public int getObjectType() {
138 public int getObjectClass() {