net.luminis.quic.frame.Padding Maven / Gradle / Ivy
/*
* Copyright © 2019, 2020, 2021, 2022, 2023 Peter Doornbosch
*
* This file is part of Kwik, an implementation of the QUIC protocol in Java.
*
* Kwik is free software: you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the
* Free Software Foundation, either version 3 of the License, or (at your option)
* any later version.
*
* Kwik is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
* more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see .
*/
package net.luminis.quic.frame;
import net.luminis.quic.log.Logger;
import net.luminis.quic.packet.QuicPacket;
import java.nio.ByteBuffer;
import java.time.Instant;
/**
* Represents a number of consecutive padding frames.
* https://www.rfc-editor.org/rfc/rfc9000.html#name-padding-frames
*
* Usually, padding will consist of multiple padding frames, each being exactly one (zero) byte. This class can
* represent an arbitrary number of consecutive padding frames, by recording padding length.
*/
public class Padding extends QuicFrame {
private int length;
public Padding() {
}
public Padding(int paddingSize) {
length = paddingSize;
}
@Override
public int getFrameLength() {
return length;
}
@Override
public void serialize(ByteBuffer buffer) {
buffer.put(new byte[length]);
}
/**
* Strictly speaking, a padding frame consists of one single byte. For convenience, here all subsequent padding
* bytes are collected in one padding object.
* @param buffer
* @param log
* @return
*/
public Padding parse(ByteBuffer buffer, Logger log) {
byte lastByte = 0;
while (buffer.position() < buffer.limit() && (lastByte = buffer.get()) == 0)
length++;
if (lastByte != 0) {
// Set back one position
buffer.position(buffer.position() - 1);
}
return this;
}
// https://tools.ietf.org/html/draft-ietf-quic-recovery-33#section-2
// "All frames other than ACK, PADDING, and CONNECTION_CLOSE are considered ack-eliciting."
@Override
public boolean isAckEliciting() {
return false;
}
@Override
public String toString() {
return "Padding(" + length + ")";
}
public int getLength() {
return length;
}
@Override
public void accept(FrameProcessor frameProcessor, QuicPacket packet, Instant timeReceived) {
frameProcessor.process(this, packet, timeReceived);
}
}