org.opensearch.migrations.replay.HttpMessageAndTimestamp Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of trafficReplayer Show documentation
Show all versions of trafficReplayer Show documentation
Everything opensearch migrations
package org.opensearch.migrations.replay;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.time.Instant;
import java.util.Optional;
import java.util.stream.Stream;
import org.opensearch.migrations.replay.datatypes.RawPackets;
import org.opensearch.migrations.replay.util.NettyUtils;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Lombok;
import lombok.Setter;
import lombok.extern.slf4j.Slf4j;
@Slf4j
@EqualsAndHashCode(exclude = "currentSegmentBytes")
public class HttpMessageAndTimestamp {
public static class Request extends HttpMessageAndTimestamp {
public Request(Instant firstPacketTimestamp) {
super(firstPacketTimestamp);
}
@Override
public String toString() {
return super.format(Optional.of(HttpByteBufFormatter.HttpMessageType.REQUEST));
}
}
public static class Response extends HttpMessageAndTimestamp {
public Response(Instant firstPacketTimestamp) {
super(firstPacketTimestamp);
}
@Override
public String toString() {
return super.format(Optional.of(HttpByteBufFormatter.HttpMessageType.REQUEST));
}
}
@Getter
private Instant firstPacketTimestamp;
@Getter
@Setter
private Instant lastPacketTimestamp;
public final RawPackets packetBytes;
ByteArrayOutputStream currentSegmentBytes;
public HttpMessageAndTimestamp(Instant firstPacketTimestamp) {
this.firstPacketTimestamp = firstPacketTimestamp;
this.packetBytes = new RawPackets();
}
public ByteBuf asByteBuf() {
var compositeBuf = Unpooled.compositeBuffer();
packetBytes.stream()
.map(Unpooled::wrappedBuffer)
.forEach(buffer -> compositeBuf.addComponent(true, buffer));
return compositeBuf.asReadOnly();
}
public boolean hasInProgressSegment() {
return currentSegmentBytes != null;
}
public void add(byte[] b) {
packetBytes.add(b);
}
public Stream stream() {
return packetBytes.stream();
}
public String format(Optional messageTypeOp) {
try (var bufStream = NettyUtils.createRefCntNeutralCloseableByteBufStream(packetBytes)) {
var packetBytesAsStr = messageTypeOp.map(
mt -> HttpByteBufFormatter.httpPacketBytesToString(
mt,
packetBytes,
HttpByteBufFormatter.LF_LINE_DELIMITER
)
).orElseGet(() -> HttpByteBufFormatter.httpPacketBufsToString(bufStream, Utils.MAX_PAYLOAD_BYTES_TO_PRINT));
final StringBuilder sb = new StringBuilder("HttpMessageAndTimestamp{");
sb.append("firstPacketTimestamp=").append(firstPacketTimestamp);
sb.append(", lastPacketTimestamp=").append(lastPacketTimestamp);
sb.append(", message=[").append(packetBytesAsStr);
sb.append("]}");
return sb.toString();
}
}
public void addSegment(byte[] data) {
if (currentSegmentBytes == null) {
currentSegmentBytes = new ByteArrayOutputStream();
}
try {
currentSegmentBytes.write(data);
} catch (IOException e) {
throw Lombok.sneakyThrow(e);
}
}
public void finalizeRequestSegments(Instant timestamp) {
packetBytes.add(currentSegmentBytes.toByteArray());
this.lastPacketTimestamp = timestamp;
currentSegmentBytes = null;
}
@Override
public String toString() {
return format(Optional.empty());
}
}