ssltestlib.h 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. * Copyright 2016-2023 The OpenSSL Project Authors. All Rights Reserved.
  3. *
  4. * Licensed under the Apache License 2.0 (the "License"). You may not use
  5. * this file except in compliance with the License. You can obtain a copy
  6. * in the file LICENSE in the source distribution or at
  7. * https://www.openssl.org/source/license.html
  8. */
  9. #ifndef OSSL_TEST_SSLTESTLIB_H
  10. # define OSSL_TEST_SSLTESTLIB_H
  11. # include <openssl/ssl.h>
  12. #define TLS13_AES_128_GCM_SHA256_BYTES ((const unsigned char *)"\x13\x01")
  13. #define TLS13_AES_256_GCM_SHA384_BYTES ((const unsigned char *)"\x13\x02")
  14. #define TLS13_CHACHA20_POLY1305_SHA256_BYTES ((const unsigned char *)"\x13\x03")
  15. #define TLS13_AES_128_CCM_SHA256_BYTES ((const unsigned char *)"\x13\x04")
  16. #define TLS13_AES_128_CCM_8_SHA256_BYTES ((const unsigned char *)"\x13\05")
  17. int create_ssl_ctx_pair(OSSL_LIB_CTX *libctx, const SSL_METHOD *sm,
  18. const SSL_METHOD *cm, int min_proto_version,
  19. int max_proto_version, SSL_CTX **sctx, SSL_CTX **cctx,
  20. char *certfile, char *privkeyfile);
  21. int create_ssl_objects(SSL_CTX *serverctx, SSL_CTX *clientctx, SSL **sssl,
  22. SSL **cssl, BIO *s_to_c_fbio, BIO *c_to_s_fbio);
  23. int create_bare_ssl_connection(SSL *serverssl, SSL *clientssl, int want,
  24. int read, int listen);
  25. int create_ssl_objects2(SSL_CTX *serverctx, SSL_CTX *clientctx, SSL **sssl,
  26. SSL **cssl, int sfd, int cfd);
  27. int wait_until_sock_readable(int sock);
  28. int create_test_sockets(int *cfdp, int *sfdp, int socktype, BIO_ADDR *saddr);
  29. int create_ssl_connection(SSL *serverssl, SSL *clientssl, int want);
  30. void shutdown_ssl_connection(SSL *serverssl, SSL *clientssl);
  31. /* Note: Not thread safe! */
  32. const BIO_METHOD *bio_f_tls_dump_filter(void);
  33. void bio_f_tls_dump_filter_free(void);
  34. const BIO_METHOD *bio_s_mempacket_test(void);
  35. void bio_s_mempacket_test_free(void);
  36. const BIO_METHOD *bio_s_always_retry(void);
  37. void bio_s_always_retry_free(void);
  38. void set_always_retry_err_val(int err);
  39. /* Packet types - value 0 is reserved */
  40. #define INJECT_PACKET 1
  41. #define INJECT_PACKET_IGNORE_REC_SEQ 2
  42. /*
  43. * Mempacket BIO ctrls. We make them large enough to not clash with standard BIO
  44. * ctrl codes.
  45. */
  46. #define MEMPACKET_CTRL_SET_DROP_EPOCH (1 << 15)
  47. #define MEMPACKET_CTRL_SET_DROP_REC (2 << 15)
  48. #define MEMPACKET_CTRL_GET_DROP_REC (3 << 15)
  49. #define MEMPACKET_CTRL_SET_DUPLICATE_REC (4 << 15)
  50. int mempacket_swap_epoch(BIO *bio);
  51. int mempacket_move_packet(BIO *bio, int d, int s);
  52. int mempacket_test_inject(BIO *bio, const char *in, int inl, int pktnum,
  53. int type);
  54. typedef struct mempacket_st MEMPACKET;
  55. DEFINE_STACK_OF(MEMPACKET)
  56. SSL_SESSION *create_a_psk(SSL *ssl, size_t mdsize);
  57. #endif /* OSSL_TEST_SSLTESTLIB_H */