/* * Copyright © 2020, 2021, 2022, 2023 Peter Doornbosch * * This file is part of Agent15, an implementation of TLS 1.3 in Java. * * Agent15 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. * * Agent15 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.tls.handshake; import net.luminis.tls.ProtectionKeysType; import net.luminis.tls.TlsProtocolException; import java.io.IOException; public interface MessageProcessor { void received(ClientHello ch, ProtectionKeysType protectedBy) throws TlsProtocolException, IOException; void received(ServerHello sh, ProtectionKeysType protectedBy) throws TlsProtocolException, IOException; void received(EncryptedExtensions ee, ProtectionKeysType protectedBy) throws TlsProtocolException, IOException; void received(CertificateMessage cm, ProtectionKeysType protectedBy) throws TlsProtocolException, IOException; void received(CertificateVerifyMessage cv, ProtectionKeysType protectedBy) throws TlsProtocolException, IOException; void received(FinishedMessage fm, ProtectionKeysType protectedBy) throws TlsProtocolException, IOException; void received(NewSessionTicketMessage nst, ProtectionKeysType protectedBy) throws TlsProtocolException, IOException; void received(CertificateRequestMessage cr, ProtectionKeysType protectedBy) throws TlsProtocolException, IOException; }