/*
- * * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
+ * Copyright (c) 2013 Cisco Systems, 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,
import io.netty.buffer.ByteBuf;
import io.netty.buffer.ByteBufUtil;
import io.netty.buffer.Unpooled;
-import java.util.Arrays;
import java.util.List;
import org.opendaylight.protocol.bgp.parser.BGPDocumentedException;
import org.opendaylight.protocol.bgp.parser.BGPError;
import org.opendaylight.protocol.bgp.parser.BGPParsingException;
-import org.opendaylight.protocol.bgp.parser.impl.message.update.ClusterIdAttributeParser;
-import org.opendaylight.protocol.bgp.parser.impl.message.update.OriginatorIdAttributeParser;
import org.opendaylight.protocol.bgp.parser.spi.AttributeRegistry;
import org.opendaylight.protocol.bgp.parser.spi.MessageParser;
import org.opendaylight.protocol.bgp.parser.spi.MessageSerializer;
@Override
public Update parseMessageBody(final ByteBuf buffer, final int messageLength) throws BGPDocumentedException {
Preconditions.checkArgument(buffer != null && buffer.readableBytes() != 0, "Byte array cannot be null or empty.");
- LOG.trace("Started parsing of update message: {}", Arrays.toString(ByteArray.getAllBytes(buffer)));
+ LOG.trace("Started parsing of update message: {}", ByteBufUtil.hexDump(buffer));
final int withdrawnRoutesLength = buffer.readUnsignedShort();
final UpdateBuilder eventBuilder = new UpdateBuilder();
}
if (totalPathAttrLength > 0) {
try {
- final PathAttributes pathAttributes = this.reg.parseAttributes(buffer.slice(buffer.readerIndex(), totalPathAttrLength));
- buffer.skipBytes(totalPathAttrLength);
+ final PathAttributes pathAttributes = this.reg.parseAttributes(buffer.readSlice(totalPathAttrLength));
eventBuilder.setPathAttributes(pathAttributes);
} catch (final BGPParsingException | RuntimeException e) {
// Catch everything else and turn it into a BGPDocumentedException
if (nlri != null && !nlri.isEmpty()) {
eventBuilder.setNlri(new NlriBuilder().setNlri(nlri).build());
}
- Update msg = eventBuilder.build();
+ final Update msg = eventBuilder.build();
LOG.debug("BGP Update message was parsed {}.", msg);
return msg;
}
@Override
- public void serializeMessage(Notification message, ByteBuf bytes) {
- if (message == null) {
- throw new IllegalArgumentException("BGPUpdate message cannot be null");
- }
+ public void serializeMessage(final Notification message, final ByteBuf bytes) {
+ Preconditions.checkArgument(message instanceof Update, "BGPUpdate message cannot be null");
LOG.trace("Started serializing update message: {}", message);
final Update update = (Update) message;
- ByteBuf messageBody = Unpooled.buffer();
- WithdrawnRoutes withdrawnRoutes = update.getWithdrawnRoutes();
+ final ByteBuf messageBody = Unpooled.buffer();
+ final WithdrawnRoutes withdrawnRoutes = update.getWithdrawnRoutes();
if (withdrawnRoutes != null) {
- ByteBuf withdrawnRoutesBuf = Unpooled.buffer();
- for (Ipv4Prefix withdrawnRoutePrefix : withdrawnRoutes.getWithdrawnRoutes()) {
- int prefixBits = Ipv4Util.getPrefixLength(withdrawnRoutePrefix.getValue());
- byte[] prefixBytes = ByteArray.subByte(Ipv4Util.bytesForPrefix(withdrawnRoutePrefix), 0,
- Ipv4Util.getPrefixLengthBytes(withdrawnRoutePrefix.getValue()));
- withdrawnRoutesBuf.writeByte(prefixBits);
- withdrawnRoutesBuf.writeBytes(prefixBytes);
+ final ByteBuf withdrawnRoutesBuf = Unpooled.buffer();
+ for (final Ipv4Prefix prefix : withdrawnRoutes.getWithdrawnRoutes()) {
+ withdrawnRoutesBuf.writeBytes(Ipv4Util.bytesForPrefixBegin(prefix));
}
messageBody.writeShort(withdrawnRoutesBuf.writerIndex());
messageBody.writeBytes(withdrawnRoutesBuf);
-
} else {
- messageBody.writeZero(2);
+ messageBody.writeZero(WITHDRAWN_ROUTES_LENGTH_SIZE);
}
if (update.getPathAttributes() != null) {
- ByteBuf pathAttributesBuf = Unpooled.buffer();
+ final ByteBuf pathAttributesBuf = Unpooled.buffer();
this.reg.serializeAttribute(update.getPathAttributes(), pathAttributesBuf);
- ClusterIdAttributeParser clusterIdAttributeParser = new ClusterIdAttributeParser();
- clusterIdAttributeParser.serializeAttribute(update.getPathAttributes(), pathAttributesBuf);
-
- OriginatorIdAttributeParser originatorIdAttributeParser = new OriginatorIdAttributeParser();
- originatorIdAttributeParser.serializeAttribute(update.getPathAttributes(), pathAttributesBuf);
-
messageBody.writeShort(pathAttributesBuf.writerIndex());
messageBody.writeBytes(pathAttributesBuf);
} else {
- messageBody.writeZero(2);
+ messageBody.writeZero(TOTAL_PATH_ATTR_LENGTH_SIZE);
}
- Nlri nlri = update.getNlri();
+ final Nlri nlri = update.getNlri();
if (nlri != null) {
- for (Ipv4Prefix ipv4Prefix : nlri.getNlri()) {
- int prefixBits = Ipv4Util.getPrefixLength(ipv4Prefix.getValue());
- byte[] prefixBytes = ByteArray.subByte(Ipv4Util.bytesForPrefix(ipv4Prefix), 0,
- Ipv4Util.getPrefixLengthBytes(ipv4Prefix.getValue()));
- messageBody.writeByte(prefixBits);
- messageBody.writeBytes(prefixBytes);
+ for (final Ipv4Prefix prefix : nlri.getNlri()) {
+ messageBody.writeBytes(Ipv4Util.bytesForPrefixBegin(prefix));
}
}
-
LOG.trace("Update message serialized to {}", ByteBufUtil.hexDump(messageBody));
-
- MessageUtil.formatMessage(TYPE,messageBody,bytes);
+ MessageUtil.formatMessage(TYPE, messageBody, bytes);
}
}