2022-11-22 21:45:18 +08:00
|
|
|
/*
|
|
|
|
* Copyright 2022 The OpenSSL Project Authors. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License 2.0 (the "License"). You may not use
|
|
|
|
* this file except in compliance with the License. You can obtain a copy
|
|
|
|
* in the file LICENSE in the source distribution or at
|
|
|
|
* https://www.openssl.org/source/license.html
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef OSSL_QUIC_TSERVER_H
|
|
|
|
# define OSSL_QUIC_TSERVER_H
|
|
|
|
|
|
|
|
# include <openssl/ssl.h>
|
|
|
|
# include "internal/quic_stream.h"
|
2022-12-02 00:37:47 +08:00
|
|
|
# include "internal/quic_channel.h"
|
2022-12-02 22:38:46 +08:00
|
|
|
# include "internal/statem.h"
|
2022-11-22 21:45:18 +08:00
|
|
|
|
|
|
|
# ifndef OPENSSL_NO_QUIC
|
|
|
|
|
|
|
|
/*
|
|
|
|
* QUIC Test Server Module
|
|
|
|
* =======================
|
|
|
|
*
|
|
|
|
* This implements a QUIC test server. Since full QUIC server support is not yet
|
|
|
|
* implemented this server is limited in features and scope. It exists to
|
|
|
|
* provide a target for our QUIC client to talk to for testing purposes.
|
|
|
|
*
|
|
|
|
* A given QUIC test server instance supports only one client at a time.
|
|
|
|
*
|
|
|
|
* Note that this test server is not suitable for production use because it does
|
|
|
|
* not implement address verification, anti-amplification or retry logic.
|
|
|
|
*/
|
|
|
|
typedef struct quic_tserver_st QUIC_TSERVER;
|
|
|
|
|
|
|
|
typedef struct quic_tserver_args_st {
|
|
|
|
OSSL_LIB_CTX *libctx;
|
|
|
|
const char *propq;
|
|
|
|
BIO *net_rbio, *net_wbio;
|
|
|
|
} QUIC_TSERVER_ARGS;
|
|
|
|
|
2022-11-29 19:26:08 +08:00
|
|
|
QUIC_TSERVER *ossl_quic_tserver_new(const QUIC_TSERVER_ARGS *args,
|
|
|
|
const char *certfile, const char *keyfile);
|
2022-11-22 21:45:18 +08:00
|
|
|
|
|
|
|
void ossl_quic_tserver_free(QUIC_TSERVER *srv);
|
|
|
|
|
2022-11-30 00:04:23 +08:00
|
|
|
/* Set mutator callbacks for test framework support */
|
2022-12-02 22:38:46 +08:00
|
|
|
int ossl_quic_tserver_set_plain_packet_mutator(QUIC_TSERVER *srv,
|
|
|
|
ossl_mutate_packet_cb mutatecb,
|
|
|
|
ossl_finish_mutate_cb finishmutatecb,
|
|
|
|
void *mutatearg);
|
|
|
|
|
|
|
|
int ossl_quic_tserver_set_handshake_mutator(QUIC_TSERVER *srv,
|
|
|
|
ossl_statem_mutate_handshake_cb mutate_handshake_cb,
|
|
|
|
ossl_statem_finish_mutate_handshake_cb finish_mutate_handshake_cb,
|
|
|
|
void *mutatearg);
|
2022-11-30 00:04:23 +08:00
|
|
|
|
2022-11-22 21:45:18 +08:00
|
|
|
/* Advances the state machine. */
|
|
|
|
int ossl_quic_tserver_tick(QUIC_TSERVER *srv);
|
|
|
|
|
2022-12-07 00:44:09 +08:00
|
|
|
/*
|
|
|
|
* Returns 1 if we have finished the TLS handshake
|
|
|
|
*/
|
2023-01-11 01:52:18 +08:00
|
|
|
int ossl_quic_tserver_is_handshake_confirmed(QUIC_TSERVER *srv);
|
2022-11-22 21:45:18 +08:00
|
|
|
|
2022-11-30 22:21:00 +08:00
|
|
|
/* Returns 1 if the server is in any terminating or terminated state */
|
2022-12-02 00:37:47 +08:00
|
|
|
int ossl_quic_tserver_is_term_any(QUIC_TSERVER *srv,
|
|
|
|
QUIC_TERMINATE_CAUSE *cause);
|
2022-11-30 22:21:00 +08:00
|
|
|
|
2022-12-02 00:37:47 +08:00
|
|
|
/* Returns 1 if the server is in a terminated state */
|
|
|
|
int ossl_quic_tserver_is_terminated(QUIC_TSERVER *srv,
|
|
|
|
QUIC_TERMINATE_CAUSE *cause);
|
2022-11-22 21:45:18 +08:00
|
|
|
/*
|
|
|
|
* Attempts to read from stream 0. Writes the number of bytes read to
|
|
|
|
* *bytes_read and returns 1 on success. If no bytes are available, 0 is written
|
|
|
|
* to *bytes_read and 1 is returned (this is considered a success case).
|
|
|
|
*
|
2022-12-13 20:28:54 +08:00
|
|
|
* Returns 0 if connection is not currently active. If the receive part of
|
|
|
|
* the stream has reached the end of stream condition, returns 0; call
|
|
|
|
* ossl_quic_tserver_has_read_ended() to identify this condition.
|
2022-11-22 21:45:18 +08:00
|
|
|
*/
|
|
|
|
int ossl_quic_tserver_read(QUIC_TSERVER *srv,
|
|
|
|
unsigned char *buf,
|
|
|
|
size_t buf_len,
|
|
|
|
size_t *bytes_read);
|
|
|
|
|
2022-12-13 20:28:54 +08:00
|
|
|
/*
|
|
|
|
* Returns 1 if the read part of the stream has ended normally.
|
|
|
|
*/
|
|
|
|
int ossl_quic_tserver_has_read_ended(QUIC_TSERVER *srv);
|
|
|
|
|
2022-11-22 21:45:18 +08:00
|
|
|
/*
|
|
|
|
* Attempts to write to stream 0. Writes the number of bytes consumed to
|
2023-01-18 19:07:58 +08:00
|
|
|
* *bytes_written and returns 1 on success. If there is no space currently
|
|
|
|
* available to write any bytes, 0 is written to *consumed and 1 is returned
|
|
|
|
* (this is considered a success case).
|
2022-11-22 21:45:18 +08:00
|
|
|
*
|
|
|
|
* Note that unlike libssl public APIs, this API always works in a 'partial
|
|
|
|
* write' mode.
|
|
|
|
*
|
|
|
|
* Returns 0 if connection is not currently active.
|
|
|
|
*/
|
|
|
|
int ossl_quic_tserver_write(QUIC_TSERVER *srv,
|
|
|
|
const unsigned char *buf,
|
|
|
|
size_t buf_len,
|
|
|
|
size_t *bytes_written);
|
|
|
|
|
2022-12-13 20:28:54 +08:00
|
|
|
/*
|
|
|
|
* Signals normal end of the stream.
|
|
|
|
*/
|
|
|
|
int ossl_quic_tserver_conclude(QUIC_TSERVER *srv);
|
|
|
|
|
2022-11-22 21:45:18 +08:00
|
|
|
# endif
|
|
|
|
|
|
|
|
#endif
|