BUG-612 : switched PCEP message serializers to ByteBuf
[bgpcep.git] / pcep / impl / src / main / java / org / opendaylight / protocol / pcep / impl / object / PCEPBandwidthObjectParser.java
index bd7b025d5204641bef7aff33acba8cea10e71f04..38de20a9031666e4a7bcc4194cf8a5f4e9b79527 100644 (file)
@@ -7,83 +7,26 @@
  */
 package org.opendaylight.protocol.pcep.impl.object;
 
-import org.opendaylight.protocol.pcep.PCEPDeserializerException;
-import org.opendaylight.protocol.pcep.PCEPDocumentedException;
-import org.opendaylight.protocol.pcep.spi.AbstractObjectParser;
-import org.opendaylight.protocol.pcep.spi.HandlerRegistry;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ieee754.rev130819.Float32;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.BandwidthObject;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.Object;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.ObjectHeader;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.Tlv;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.pcreq.message.pcreq.message.requests.segment.computation.p2p.reported.route.BandwidthBuilder;
+import io.netty.buffer.ByteBuf;
+
+import org.opendaylight.protocol.pcep.spi.ObjectUtil;
+import org.opendaylight.protocol.pcep.spi.TlvRegistry;
 
 /**
- * Parser for {@link BandwidthObject}
+ * Parser for Bandwidth
  */
-public class PCEPBandwidthObjectParser extends AbstractObjectParser<BandwidthBuilder> {
-
-       public static final int E_CLASS = 5;
-
-       public static final int E_TYPE = 1;
-
-       public static final int CLASS = 5;
-
-       public static final int TYPE = 2;
-
-       private static final int BANDWIDTH_F_LENGTH = 4;
-
-       public PCEPBandwidthObjectParser(final HandlerRegistry registry) {
-               super(registry);
-       }
-
-       @Override
-       public BandwidthObject parseObject(final ObjectHeader header, final byte[] bytes) throws PCEPDeserializerException,
-                       PCEPDocumentedException {
-               if (bytes == null || bytes.length == 0)
-                       throw new IllegalArgumentException("Array of bytes is mandatory. Can't be null or empty.");
-               if (bytes.length != BANDWIDTH_F_LENGTH)
-                       throw new PCEPDeserializerException("Wrong length of array of bytes. Passed: " + bytes.length + "; Expected: "
-                                       + BANDWIDTH_F_LENGTH + ".");
-
-               final BandwidthBuilder builder = new BandwidthBuilder();
-
-               builder.setIgnore(header.isIgnore());
-               builder.setProcessingRule(header.isProcessingRule());
-
-               builder.setBandwidth(new Float32(bytes));
-
-               return builder.build();
-       }
-
-       @Override
-       public void addTlv(final BandwidthBuilder builder, final Tlv tlv) {
-               // No tlvs defined
-       }
-
-       @Override
-       public byte[] serializeObject(final Object object) {
-               if (!(object instanceof BandwidthObject))
-                       throw new IllegalArgumentException("Wrong instance of PCEPObject. Passed " + object.getClass() + ". Needed BandwidthObject.");
-
-               return ((BandwidthObject) object).getBandwidth().getValue();
-       }
+public class PCEPBandwidthObjectParser extends AbstractBandwidthParser {
 
-       @Override
-       public int getObjectType() {
-               return TYPE;
-       }
+    public static final int CLASS = 5;
 
-       @Override
-       public int getObjectClass() {
-               return CLASS;
-       }
+    public static final int TYPE = 1;
 
-       public int getEObjectType() {
-               return E_TYPE;
-       }
+    public PCEPBandwidthObjectParser(final TlvRegistry tlvReg) {
+        super(tlvReg);
+    }
 
-       public int getEObjectClass() {
-               return E_CLASS;
-       }
+    @Override
+    protected void formatBandwidth(boolean processed, boolean ignored, ByteBuf body, ByteBuf buffer) {
+        ObjectUtil.formatSubobject(TYPE, CLASS, processed, ignored, body, buffer);
+    }
 }