mirror of
https://github.com/openssl/openssl.git
synced 2025-01-12 13:36:28 +08:00
072328dddb
We now refactor the interface between ssl_lib.c frontend functions and the QUIC API Personality Layer so that the respective functions comprising the interface use SSL object pointers rather than raw QUIC_CONNECTION pointers. This is in preparation for stream support since once streams are supported, calls to e.g. ossl_quic_write() may be made on a QUIC_CONNECTION or a QUIC_XSO (that is, a stream object). Thus we take a uniform approach across all functions comprising the interface between the ssl_lib.c frontend and the QUIC API Personality Layer of using SSL pointers always. This provides a uniform approach and ensures that any function of the API personality layer can be easily adapted to support being called on a stream object in the future. Reviewed-by: Matt Caswell <matt@openssl.org> Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/20765)
87 lines
3.4 KiB
C
87 lines
3.4 KiB
C
/*
|
|
* 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_SSL_H
|
|
# define OSSL_QUIC_SSL_H
|
|
|
|
# include <openssl/ssl.h>
|
|
# include <openssl/bio.h>
|
|
# include "internal/quic_record_rx.h" /* OSSL_QRX */
|
|
# include "internal/quic_ackm.h" /* OSSL_ACKM */
|
|
|
|
# ifndef OPENSSL_NO_QUIC
|
|
|
|
__owur SSL *ossl_quic_new(SSL_CTX *ctx);
|
|
__owur int ossl_quic_init(SSL *s);
|
|
void ossl_quic_deinit(SSL *s);
|
|
void ossl_quic_free(SSL *s);
|
|
int ossl_quic_reset(SSL *s);
|
|
int ossl_quic_clear(SSL *s);
|
|
__owur int ossl_quic_accept(SSL *s);
|
|
__owur int ossl_quic_connect(SSL *s);
|
|
__owur int ossl_quic_read(SSL *s, void *buf, size_t len, size_t *readbytes);
|
|
__owur int ossl_quic_peek(SSL *s, void *buf, size_t len, size_t *readbytes);
|
|
__owur int ossl_quic_write(SSL *s, const void *buf, size_t len, size_t *written);
|
|
__owur long ossl_quic_ctrl(SSL *s, int cmd, long larg, void *parg);
|
|
__owur long ossl_quic_ctx_ctrl(SSL_CTX *ctx, int cmd, long larg, void *parg);
|
|
__owur long ossl_quic_callback_ctrl(SSL *s, int cmd, void (*fp) (void));
|
|
__owur long ossl_quic_ctx_callback_ctrl(SSL_CTX *ctx, int cmd, void (*fp) (void));
|
|
__owur size_t ossl_quic_pending(const SSL *s);
|
|
__owur int ossl_quic_num_ciphers(void);
|
|
__owur const SSL_CIPHER *ossl_quic_get_cipher(unsigned int u);
|
|
int ossl_quic_renegotiate_check(SSL *ssl, int initok);
|
|
|
|
typedef struct quic_conn_st QUIC_CONNECTION;
|
|
typedef struct quic_xso_st QUIC_XSO;
|
|
|
|
int ossl_quic_do_handshake(SSL *s);
|
|
void ossl_quic_set_connect_state(SSL *s);
|
|
void ossl_quic_set_accept_state(SSL *s);
|
|
|
|
__owur int ossl_quic_has_pending(const SSL *s);
|
|
__owur int ossl_quic_tick(SSL *s);
|
|
__owur int ossl_quic_get_tick_timeout(SSL *s, struct timeval *tv);
|
|
OSSL_TIME ossl_quic_get_tick_deadline(SSL *s);
|
|
__owur int ossl_quic_get_rpoll_descriptor(SSL *s, BIO_POLL_DESCRIPTOR *d);
|
|
__owur int ossl_quic_get_wpoll_descriptor(SSL *s, BIO_POLL_DESCRIPTOR *d);
|
|
__owur int ossl_quic_get_net_read_desired(SSL *s);
|
|
__owur int ossl_quic_get_net_write_desired(SSL *s);
|
|
__owur int ossl_quic_get_error(const SSL *s, int i);
|
|
__owur int ossl_quic_conn_get_blocking_mode(const SSL *s);
|
|
__owur int ossl_quic_conn_set_blocking_mode(SSL *s, int blocking);
|
|
__owur int ossl_quic_conn_shutdown(SSL *s, uint64_t flags,
|
|
const SSL_SHUTDOWN_EX_ARGS *args,
|
|
size_t args_len);
|
|
__owur int ossl_quic_conn_stream_conclude(SSL *s);
|
|
void ossl_quic_conn_set0_net_rbio(SSL *s, BIO *net_wbio);
|
|
void ossl_quic_conn_set0_net_wbio(SSL *s, BIO *net_wbio);
|
|
BIO *ossl_quic_conn_get_net_rbio(const SSL *s);
|
|
BIO *ossl_quic_conn_get_net_wbio(const SSL *s);
|
|
__owur int ossl_quic_conn_set_initial_peer_addr(SSL *s,
|
|
const BIO_ADDR *peer_addr);
|
|
|
|
/*
|
|
* Used to override ossl_time_now() for debug purposes. Must be called before
|
|
* connecting.
|
|
*/
|
|
void ossl_quic_conn_set_override_now_cb(SSL *s,
|
|
OSSL_TIME (*now_cb)(void *arg),
|
|
void *now_cb_arg);
|
|
|
|
/*
|
|
* Condvar waiting in the assist thread doesn't support time faking as it relies
|
|
* on the OS's notion of time, thus this is used in test code to force a
|
|
* spurious wakeup instead.
|
|
*/
|
|
void ossl_quic_conn_force_assist_thread_wake(SSL *s);
|
|
|
|
# endif
|
|
|
|
#endif
|