net.luminis.quic.frame.QuicFrame Maven / Gradle / Ivy
/*
* Copyright © 2019, 2020, 2021, 2022, 2023, 2024 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.packet.QuicPacket;
import java.nio.ByteBuffer;
import java.time.Instant;
/**
* Base class for all classes that represent a QUIC frame.
* https://www.rfc-editor.org/rfc/rfc9000.html#frames
*/
public abstract class QuicFrame {
// https://www.rfc-editor.org/rfc/rfc9000.html#name-terms-and-definitions
// 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."
/**
* Returns whether the frame is ack eliciting
* https://www.rfc-editor.org/rfc/rfc9000.html#name-terms-and-definitions
* "Ack-eliciting packet: A QUIC packet that contains frames other than ACK, PADDING, and CONNECTION_CLOSE."
* @return true when the frame is ack-eliciting
*/
public boolean isAckEliciting() {
return true;
}
public abstract void accept(FrameProcessor frameProcessor, QuicPacket packet, Instant timeReceived);
public abstract int getFrameLength();
public abstract void serialize(ByteBuffer buffer);
}