2
3
4
5
6
7
8
10#ifndef HEADER_ENVELOPE_H
11# define HEADER_ENVELOPE_H
13# include <openssl/opensslconf.h>
14# include <openssl/ossl_typ.h>
15# include <openssl/symhacks.h>
16# include <openssl/bio.h>
17# include <openssl/evperr.h>
19# define EVP_MAX_MD_SIZE 64
20# define EVP_MAX_KEY_LENGTH 64
21# define EVP_MAX_IV_LENGTH 16
22# define EVP_MAX_BLOCK_LENGTH 32
24# define PKCS5_SALT_LEN 8
26# define PKCS5_DEFAULT_ITER 2048
28# include <openssl/objects.h>
30# define EVP_PK_RSA 0x0001
31# define EVP_PK_DSA 0x0002
32# define EVP_PK_DH 0x0004
33# define EVP_PK_EC 0x0008
34# define EVP_PKT_SIGN 0x0010
35# define EVP_PKT_ENC 0x0020
36# define EVP_PKT_EXCH 0x0040
37# define EVP_PKS_RSA 0x0100
38# define EVP_PKS_DSA 0x0200
39# define EVP_PKS_EC 0x0400
70# define EVP_PKEY_MO_SIGN 0x0001
71# define EVP_PKEY_MO_VERIFY 0x0002
72# define EVP_PKEY_MO_ENCRYPT 0x0004
73# define EVP_PKEY_MO_DECRYPT 0x0008
113# define EVP_MD_FLAG_ONESHOT 0x0001
116# define EVP_MD_FLAG_XOF 0x0002
120# define EVP_MD_FLAG_DIGALGID_MASK 0x0018
124# define EVP_MD_FLAG_DIGALGID_NULL 0x0000
128# define EVP_MD_FLAG_DIGALGID_ABSENT 0x0008
132# define EVP_MD_FLAG_DIGALGID_CUSTOM 0x0018
135# define EVP_MD_FLAG_FIPS 0x0400
139# define EVP_MD_CTRL_DIGALGID 0x1
140# define EVP_MD_CTRL_MICALG 0x2
141# define EVP_MD_CTRL_XOF_LEN 0x3
145# define EVP_MD_CTRL_ALG_CTRL 0x1000
151# define EVP_MD_CTX_FLAG_ONESHOT 0x0001
153# define EVP_MD_CTX_FLAG_CLEANED 0x0002
154
155# define EVP_MD_CTX_FLAG_REUSE 0x0004
156
158
160
162# define EVP_MD_CTX_FLAG_NON_FIPS_ALLOW 0x0008
163
170# define EVP_MD_CTX_FLAG_PAD_MASK 0xF0
171# define EVP_MD_CTX_FLAG_PAD_PKCS1 0x00
172# define EVP_MD_CTX_FLAG_PAD_X931 0x10
173# define EVP_MD_CTX_FLAG_PAD_PSS 0x20
175# define EVP_MD_CTX_FLAG_NO_INIT 0x0100
177
179
180
182# define EVP_MD_CTX_FLAG_FINALISE 0x0200
185EVP_CIPHER *EVP_CIPHER_meth_new(
int cipher_type,
int block_size,
int key_len);
189int EVP_CIPHER_meth_set_iv_length(
EVP_CIPHER *cipher,
int iv_len);
190int EVP_CIPHER_meth_set_flags(
EVP_CIPHER *cipher,
unsigned long flags);
191int EVP_CIPHER_meth_set_impl_ctx_size(
EVP_CIPHER *cipher,
int ctx_size);
192int EVP_CIPHER_meth_set_init(
EVP_CIPHER *cipher,
194 const unsigned char *key,
195 const unsigned char *iv,
197int EVP_CIPHER_meth_set_do_cipher(
EVP_CIPHER *cipher,
200 const unsigned char *in,
202int EVP_CIPHER_meth_set_cleanup(
EVP_CIPHER *cipher,
204int EVP_CIPHER_meth_set_set_asn1_params(
EVP_CIPHER *cipher,
207int EVP_CIPHER_meth_set_get_asn1_params(
EVP_CIPHER *cipher,
212 int arg,
void *ptr));
215 const unsigned char *key,
216 const unsigned char *iv,
220 const unsigned char *in,
222int (*EVP_CIPHER_meth_get_cleanup(
const EVP_CIPHER *cipher))(
EVP_CIPHER_CTX *);
225int (*EVP_CIPHER_meth_get_get_asn1_params(
const EVP_CIPHER *cipher))(
EVP_CIPHER_CTX *,
227int (*EVP_CIPHER_meth_get_ctrl(
const EVP_CIPHER *cipher))(
EVP_CIPHER_CTX *,
235# define EVP_CIPH_STREAM_CIPHER 0x0
236# define EVP_CIPH_ECB_MODE 0x1
237# define EVP_CIPH_CBC_MODE 0x2
238# define EVP_CIPH_CFB_MODE 0x3
239# define EVP_CIPH_OFB_MODE 0x4
240# define EVP_CIPH_CTR_MODE 0x5
241# define EVP_CIPH_GCM_MODE 0x6
242# define EVP_CIPH_CCM_MODE 0x7
243# define EVP_CIPH_XTS_MODE 0x10001
244# define EVP_CIPH_WRAP_MODE 0x10002
245# define EVP_CIPH_OCB_MODE 0x10003
246# define EVP_CIPH_MODE 0xF0007
248# define EVP_CIPH_VARIABLE_LENGTH 0x8
250# define EVP_CIPH_CUSTOM_IV 0x10
252# define EVP_CIPH_ALWAYS_CALL_INIT 0x20
254# define EVP_CIPH_CTRL_INIT 0x40
256# define EVP_CIPH_CUSTOM_KEY_LENGTH 0x80
258# define EVP_CIPH_NO_PADDING 0x100
260# define EVP_CIPH_RAND_KEY 0x200
262# define EVP_CIPH_CUSTOM_COPY 0x400
264# define EVP_CIPH_CUSTOM_IV_LENGTH 0x800
266# define EVP_CIPH_FLAG_DEFAULT_ASN1 0x1000
268# define EVP_CIPH_FLAG_LENGTH_BITS 0x2000
270# define EVP_CIPH_FLAG_FIPS 0x4000
272# define EVP_CIPH_FLAG_NON_FIPS_ALLOW 0x8000
275
276# define EVP_CIPH_FLAG_CUSTOM_CIPHER 0x100000
277# define EVP_CIPH_FLAG_AEAD_CIPHER 0x200000
278# define EVP_CIPH_FLAG_TLS1_1_MULTIBLOCK 0x400000
280# define EVP_CIPH_FLAG_PIPELINE 0X800000
284
285
287# define EVP_CIPHER_CTX_FLAG_WRAP_ALLOW 0x1
291# define EVP_CTRL_INIT 0x0
292# define EVP_CTRL_SET_KEY_LENGTH 0x1
293# define EVP_CTRL_GET_RC2_KEY_BITS 0x2
294# define EVP_CTRL_SET_RC2_KEY_BITS 0x3
295# define EVP_CTRL_GET_RC5_ROUNDS 0x4
296# define EVP_CTRL_SET_RC5_ROUNDS 0x5
297# define EVP_CTRL_RAND_KEY 0x6
298# define EVP_CTRL_PBE_PRF_NID 0x7
299# define EVP_CTRL_COPY 0x8
300# define EVP_CTRL_AEAD_SET_IVLEN 0x9
301# define EVP_CTRL_AEAD_GET_TAG 0x10
302# define EVP_CTRL_AEAD_SET_TAG 0x11
303# define EVP_CTRL_AEAD_SET_IV_FIXED 0x12
308# define EVP_CTRL_GCM_IV_GEN 0x13
313# define EVP_CTRL_CCM_SET_L 0x14
314# define EVP_CTRL_CCM_SET_MSGLEN 0x15
317
319
320# define EVP_CTRL_AEAD_TLS1_AAD 0x16
322# define EVP_CTRL_AEAD_SET_MAC_KEY 0x17
324# define EVP_CTRL_GCM_SET_IV_INV 0x18
326# define EVP_CTRL_TLS1_1_MULTIBLOCK_AAD 0x19
327# define EVP_CTRL_TLS1_1_MULTIBLOCK_ENCRYPT 0x1a
328# define EVP_CTRL_TLS1_1_MULTIBLOCK_DECRYPT 0x1b
329# define EVP_CTRL_TLS1_1_MULTIBLOCK_MAX_BUFSIZE 0x1c
331# define EVP_CTRL_SSL3_MASTER_SECRET 0x1d
334# define EVP_CTRL_SET_SBOX 0x1e
336
337
338
339# define EVP_CTRL_SBOX_USED 0x1f
342
343# define EVP_CTRL_KEY_MESH 0x20
345# define EVP_CTRL_BLOCK_PADDING_MODE 0x21
348# define EVP_CTRL_SET_PIPELINE_OUTPUT_BUFS 0x22
350# define EVP_CTRL_SET_PIPELINE_INPUT_BUFS 0x23
352# define EVP_CTRL_SET_PIPELINE_INPUT_LENS 0x24
354# define EVP_CTRL_GET_IVLEN 0x25
357#define EVP_PADDING_PKCS7 1
358#define EVP_PADDING_ISO7816_4 2
359#define EVP_PADDING_ANSI923 3
360#define EVP_PADDING_ISO10126 4
361#define EVP_PADDING_ZERO 5
364# define EVP_AEAD_TLS1_AAD_LEN 13
368 const unsigned char *inp;
370 unsigned int interleave;
371} EVP_CTRL_TLS1_1_MULTIBLOCK_PARAM;
375# define EVP_GCM_TLS_FIXED_IV_LEN 4
377# define EVP_GCM_TLS_EXPLICIT_IV_LEN 8
379# define EVP_GCM_TLS_TAG_LEN 16
383# define EVP_CCM_TLS_FIXED_IV_LEN 4
385# define EVP_CCM_TLS_EXPLICIT_IV_LEN 8
387# define EVP_CCM_TLS_IV_LEN 12
389# define EVP_CCM_TLS_TAG_LEN 16
391# define EVP_CCM8_TLS_TAG_LEN 8
394# define EVP_CHACHAPOLY_TLS_TAG_LEN 16
396typedef struct evp_cipher_info_st {
403typedef int (EVP_PBE_KEYGEN) (
EVP_CIPHER_CTX *ctx,
const char *pass,
404 int passlen, ASN1_TYPE *param,
408# ifndef OPENSSL_NO_RSA
409# define EVP_PKEY_assign_RSA(pkey,rsa) EVP_PKEY_assign((pkey),EVP_PKEY_RSA,
413# ifndef OPENSSL_NO_DSA
414# define EVP_PKEY_assign_DSA(pkey,dsa) EVP_PKEY_assign((pkey),EVP_PKEY_DSA,
418# ifndef OPENSSL_NO_DH
419# define EVP_PKEY_assign_DH(pkey,dh) EVP_PKEY_assign((pkey),EVP_PKEY_DH,
423# ifndef OPENSSL_NO_EC
424# define EVP_PKEY_assign_EC_KEY(pkey,eckey) EVP_PKEY_assign((pkey),EVP_PKEY_EC,
427# ifndef OPENSSL_NO_SIPHASH
428# define EVP_PKEY_assign_SIPHASH(pkey,shkey) EVP_PKEY_assign((pkey),EVP_PKEY_SIPHASH,
432# ifndef OPENSSL_NO_POLY1305
433# define EVP_PKEY_assign_POLY1305(pkey,polykey) EVP_PKEY_assign((pkey),EVP_PKEY_POLY1305,
438# define EVP_get_digestbynid(a) EVP_get_digestbyname(OBJ_nid2sn(a))
440# define EVP_get_cipherbynid(a) EVP_get_cipherbyname(OBJ_nid2sn(a))
444# define EVP_MD_nid(e) EVP_MD_type(e)
446int EVP_MD_pkey_type(
const EVP_MD *md);
449unsigned long EVP_MD_flags(
const EVP_MD *md);
452int (*EVP_MD_CTX_update_fn(EVP_MD_CTX *ctx))(
EVP_MD_CTX *ctx,
453 const void *data, size_t count);
456 const void *data, size_t count));
457# define EVP_MD_CTX_size(e) EVP_MD_size(EVP_MD_CTX_md(e))
458# define EVP_MD_CTX_block_size(e) EVP_MD_block_size(EVP_MD_CTX_md(e))
459# define EVP_MD_CTX_type(e) EVP_MD_type(EVP_MD_CTX_md(e))
465# define EVP_CIPHER_name(e) OBJ_nid2sn(EVP_CIPHER_nid(e))
468int EVP_CIPHER_key_length(
const EVP_CIPHER *cipher);
489void *EVP_CIPHER_CTX_set_cipher_data(
EVP_CIPHER_CTX *ctx,
void *cipher_data);
490# define EVP_CIPHER_CTX_type(c) EVP_CIPHER_type(EVP_CIPHER_CTX_cipher(c))
492# define EVP_CIPHER_CTX_flags(c) EVP_CIPHER_flags(EVP_CIPHER_CTX_cipher(c))
494# define EVP_CIPHER_CTX_mode(c) EVP_CIPHER_mode(EVP_CIPHER_CTX_cipher(c))
496# define EVP_ENCODE_LENGTH(l) ((((l)+2
)/3
*4
)+((l)/48
+1
)*2
+80
)
497# define EVP_DECODE_LENGTH(l) (((l)+3
)/4
*3
+80
)
499# define EVP_SignInit_ex(a,b,c) EVP_DigestInit_ex(a,b,c)
500# define EVP_SignInit(a,b) EVP_DigestInit(a,b)
501# define EVP_SignUpdate(a,b,c) EVP_DigestUpdate(a,b,c)
502# define EVP_VerifyInit_ex(a,b,c) EVP_DigestInit_ex(a,b,c)
503# define EVP_VerifyInit(a,b) EVP_DigestInit(a,b)
504# define EVP_VerifyUpdate(a,b,c) EVP_DigestUpdate(a,b,c)
505# define EVP_OpenUpdate(a,b,c,d,e) EVP_DecryptUpdate(a,b,c,d,e)
506# define EVP_SealUpdate(a,b,c,d,e) EVP_EncryptUpdate(a,b,c,d,e)
507# define EVP_DigestSignUpdate(a,b,c) EVP_DigestUpdate(a,b,c)
508# define EVP_DigestVerifyUpdate(a,b,c) EVP_DigestUpdate(a,b,c)
511void BIO_set_md(BIO *,
const EVP_MD *md);
513# define BIO_set_md(b,md) BIO_ctrl(b,BIO_C_SET_MD,0
,(char *)(md))
515# define BIO_get_md(b,mdp) BIO_ctrl(b,BIO_C_GET_MD,0
,(char *)(mdp))
526 const unsigned char *in,
unsigned int inl);
528# define EVP_add_cipher_alias(n,alias)
530# define EVP_add_digest_alias(n,alias)
532# define EVP_delete_cipher_alias(alias)
534# define EVP_delete_digest_alias(alias)
537int EVP_MD_CTX_ctrl(
EVP_MD_CTX *ctx,
int cmd,
int p1,
void *p2);
541# define EVP_MD_CTX_create() EVP_MD_CTX_new()
542# define EVP_MD_CTX_init(ctx) EVP_MD_CTX_reset((ctx))
543# define EVP_MD_CTX_destroy(ctx) EVP_MD_CTX_free((ctx))
545void EVP_MD_CTX_set_flags(
EVP_MD_CTX *ctx,
int flags);
547int EVP_MD_CTX_test_flags(
const EVP_MD_CTX *ctx,
int flags);
554__owur int EVP_Digest(
const void *data, size_t count,
555 unsigned char *md,
unsigned int *size,
565int EVP_read_pw_string(
char *buf,
int length,
const char *prompt,
int verify);
566int EVP_read_pw_string_min(
char *buf,
int minlen,
int maxlen,
567 const char *prompt,
int verify);
568void EVP_set_pw_prompt(
const char *prompt);
569char *EVP_get_pw_prompt(
void);
572 const unsigned char *salt,
573 const unsigned char *data,
int datal,
int count,
574 unsigned char *key,
unsigned char *iv);
581 const unsigned char *key,
const unsigned char *iv);
584 const unsigned char *key,
585 const unsigned char *iv);
587 int *outl,
const unsigned char *in,
int inl);
594 const unsigned char *key,
const unsigned char *iv);
597 const unsigned char *key,
598 const unsigned char *iv);
600 int *outl,
const unsigned char *in,
int inl);
607 const unsigned char *key,
const unsigned char *iv,
611 const unsigned char *key,
612 const unsigned char *iv,
int enc);
614 int *outl,
const unsigned char *in,
int inl);
620__owur int EVP_SignFinal(
EVP_MD_CTX *ctx,
unsigned char *md,
unsigned int *s,
624 size_t *siglen,
const unsigned char *tbs,
628 unsigned int siglen,
EVP_PKEY *pkey);
631 size_t siglen,
const unsigned char *tbs,
646# ifndef OPENSSL_NO_RSA
648 const unsigned char *ek,
int ekl,
649 const unsigned char *iv,
EVP_PKEY *priv);
653 unsigned char **ek,
int *ekl,
unsigned char *iv,
663int EVP_EncodeUpdate(
EVP_ENCODE_CTX *ctx,
unsigned char *out,
int *outl,
664 const unsigned char *in,
int inl);
666int EVP_EncodeBlock(
unsigned char *t,
const unsigned char *f,
int n);
670 const unsigned char *in,
int inl);
672 char *out,
int *outl);
673int EVP_DecodeBlock(
unsigned char *t,
const unsigned char *f,
int n);
676# define EVP_CIPHER_CTX_init(c) EVP_CIPHER_CTX_reset(c)
677# define EVP_CIPHER_CTX_cleanup(c) EVP_CIPHER_CTX_reset(c)
687const BIO_METHOD *BIO_f_md(
void);
688const BIO_METHOD *BIO_f_base64(
void);
689const BIO_METHOD *BIO_f_cipher(
void);
690const BIO_METHOD *BIO_f_reliable(
void);
692 const unsigned char *i,
int enc);
694const EVP_MD *EVP_md_null(
void);
696const EVP_MD *EVP_md2(
void);
698# ifndef OPENSSL_NO_MD4
701# ifndef OPENSSL_NO_MD5
705# ifndef OPENSSL_NO_BLAKE2
718const EVP_MD *EVP_sha3_384(
void);
720const EVP_MD *EVP_shake128(
void);
721const EVP_MD *EVP_shake256(
void);
722# ifndef OPENSSL_NO_MDC2
723const EVP_MD *EVP_mdc2(
void);
725# ifndef OPENSSL_NO_RMD160
726const EVP_MD *EVP_ripemd160(
void);
728# ifndef OPENSSL_NO_WHIRLPOOL
729const EVP_MD *EVP_whirlpool(
void);
731# ifndef OPENSSL_NO_SM3
735# ifndef OPENSSL_NO_DES
742# define EVP_des_cfb EVP_des_cfb64
746# define EVP_des_ede_cfb EVP_des_ede_cfb64
748# define EVP_des_ede3_cfb EVP_des_ede3_cfb64
760
761
765# ifndef OPENSSL_NO_RC4
768# ifndef OPENSSL_NO_MD5
772# ifndef OPENSSL_NO_IDEA
775# define EVP_idea_cfb EVP_idea_cfb64
779# ifndef OPENSSL_NO_RC2
785# define EVP_rc2_cfb EVP_rc2_cfb64
788# ifndef OPENSSL_NO_BF
792# define EVP_bf_cfb EVP_bf_cfb64
795# ifndef OPENSSL_NO_CAST
799# define EVP_cast5_cfb EVP_cast5_cfb64
803const EVP_CIPHER *EVP_rc5_32_12_16_cbc(
void);
804const EVP_CIPHER *EVP_rc5_32_12_16_ecb(
void);
805const EVP_CIPHER *EVP_rc5_32_12_16_cfb64(
void);
806# define EVP_rc5_32_12_16_cfb EVP_rc5_32_12_16_cfb64
807const EVP_CIPHER *EVP_rc5_32_12_16_ofb(
void);
814# define EVP_aes_128_cfb EVP_aes_128_cfb128
822# ifndef OPENSSL_NO_OCB
830# define EVP_aes_192_cfb EVP_aes_192_cfb128
837# ifndef OPENSSL_NO_OCB
845# define EVP_aes_256_cfb EVP_aes_256_cfb128
853# ifndef OPENSSL_NO_OCB
856const EVP_CIPHER *EVP_aes_128_cbc_hmac_sha1(
void);
860# ifndef OPENSSL_NO_ARIA
866# define EVP_aria_128_cfb EVP_aria_128_cfb128
876# define EVP_aria_192_cfb EVP_aria_192_cfb128
886# define EVP_aria_256_cfb EVP_aria_256_cfb128
892# ifndef OPENSSL_NO_CAMELLIA
898# define EVP_camellia_128_cfb EVP_camellia_128_cfb128
906# define EVP_camellia_192_cfb EVP_camellia_192_cfb128
913const EVP_CIPHER *EVP_camellia_256_cfb128(
void);
914# define EVP_camellia_256_cfb EVP_camellia_256_cfb128
918# ifndef OPENSSL_NO_CHACHA
920# ifndef OPENSSL_NO_POLY1305
925# ifndef OPENSSL_NO_SEED
929# define EVP_seed_cfb EVP_seed_cfb128
933# ifndef OPENSSL_NO_SM4
937# define EVP_sm4_cfb EVP_sm4_cfb128
943# define OPENSSL_add_all_algorithms_conf()
947# define OPENSSL_add_all_algorithms_noconf()
951# ifdef OPENSSL_LOAD_CONF
952# define OpenSSL_add_all_algorithms() OPENSSL_add_all_algorithms_conf()
957# define OpenSSL_add_all_ciphers()
959# define OpenSSL_add_all_digests()
962# define EVP_cleanup() while(0
) continue
966int EVP_add_digest(
const EVP_MD *digest);
968const EVP_CIPHER *EVP_get_cipherbyname(
const char *name);
969const EVP_MD *EVP_get_digestbyname(
const char *name);
971void EVP_CIPHER_do_all(
void (*fn) (
const EVP_CIPHER *ciph,
972 const char *from,
const char *to,
void *x),
974void EVP_CIPHER_do_all_sorted(
void (*fn)
976 const char *to,
void *x),
void *arg);
978void EVP_MD_do_all(
void (*fn) (
const EVP_MD *ciph,
979 const char *from,
const char *to,
void *x),
981void EVP_MD_do_all_sorted(
void (*fn)
982 (
const EVP_MD *ciph,
const char *from,
983 const char *to,
void *x),
void *arg);
985int EVP_PKEY_decrypt_old(
unsigned char *dec_key,
986 const unsigned char *enc_key,
int enc_key_len,
988int EVP_PKEY_encrypt_old(
unsigned char *enc_key,
989 const unsigned char *key,
int key_len,
991int EVP_PKEY_type(
int type);
996int EVP_PKEY_size(
const EVP_PKEY *pkey);
998int EVP_PKEY_set_type_str(
EVP_PKEY *pkey,
const char *str,
int len);
999int EVP_PKEY_set_alias_type(
EVP_PKEY *pkey,
int type);
1000# ifndef OPENSSL_NO_ENGINE
1004int EVP_PKEY_assign(
EVP_PKEY *pkey,
int type,
void *key);
1005void *EVP_PKEY_get0(
const EVP_PKEY *pkey);
1006const unsigned char *EVP_PKEY_get0_hmac(
const EVP_PKEY *pkey, size_t *len);
1007# ifndef OPENSSL_NO_POLY1305
1008const unsigned char *EVP_PKEY_get0_poly1305(
const EVP_PKEY *pkey, size_t *len);
1010# ifndef OPENSSL_NO_SIPHASH
1011const unsigned char *EVP_PKEY_get0_siphash(
const EVP_PKEY *pkey, size_t *len);
1014# ifndef OPENSSL_NO_RSA
1016int EVP_PKEY_set1_RSA(
EVP_PKEY *pkey,
struct rsa_st *key);
1017struct rsa_st *EVP_PKEY_get0_RSA(
EVP_PKEY *pkey);
1020# ifndef OPENSSL_NO_DSA
1022int EVP_PKEY_set1_DSA(
EVP_PKEY *pkey,
struct dsa_st *key);
1023struct dsa_st *EVP_PKEY_get0_DSA(
EVP_PKEY *pkey);
1026# ifndef OPENSSL_NO_DH
1028int EVP_PKEY_set1_DH(
EVP_PKEY *pkey,
struct dh_st *key);
1029struct dh_st *EVP_PKEY_get0_DH(
EVP_PKEY *pkey);
1032# ifndef OPENSSL_NO_EC
1034int EVP_PKEY_set1_EC_KEY(
EVP_PKEY *pkey,
struct ec_key_st *key);
1040int EVP_PKEY_up_ref(
EVP_PKEY *pkey);
1055int EVP_PKEY_save_parameters(
EVP_PKEY *pkey,
int mode);
1062int EVP_PKEY_print_private(
BIO *out,
const EVP_PKEY *pkey,
1064int EVP_PKEY_print_params(
BIO *out,
const EVP_PKEY *pkey,
1067int EVP_PKEY_get_default_digest_nid(
EVP_PKEY *pkey,
int *pnid);
1070 const unsigned char *pt, size_t ptlen);
1071size_t EVP_PKEY_get1_tls_encodedpoint(
EVP_PKEY *pkey,
unsigned char **ppt);
1084int PKCS5_PBE_keyivgen(
EVP_CIPHER_CTX *ctx,
const char *pass,
int passlen,
1087int PKCS5_PBKDF2_HMAC_SHA1(
const char *pass,
int passlen,
1088 const unsigned char *salt,
int saltlen,
int iter,
1089 int keylen,
unsigned char *out);
1090int PKCS5_PBKDF2_HMAC(
const char *pass,
int passlen,
1091 const unsigned char *salt,
int saltlen,
int iter,
1092 const EVP_MD *digest,
int keylen,
unsigned char *out);
1093int PKCS5_v2_PBE_keyivgen(
EVP_CIPHER_CTX *ctx,
const char *pass,
int passlen,
1095 const EVP_MD *md,
int en_de);
1097#ifndef OPENSSL_NO_SCRYPT
1098int EVP_PBE_scrypt(
const char *pass, size_t passlen,
1099 const unsigned char *salt, size_t saltlen,
1100 uint64_t N, uint64_t r, uint64_t p, uint64_t maxmem,
1101 unsigned char *key, size_t keylen);
1103int PKCS5_v2_scrypt_keyivgen(
EVP_CIPHER_CTX *ctx,
const char *pass,
1104 int passlen, ASN1_TYPE *param,
1108void PKCS5_PBE_add(
void);
1110int EVP_PBE_CipherInit(
ASN1_OBJECT *pbe_obj,
const char *pass,
int passlen,
1116# define EVP_PBE_TYPE_OUTER 0x0
1118# define EVP_PBE_TYPE_PRF 0x1
1120# define EVP_PBE_TYPE_KDF 0x2
1122int EVP_PBE_alg_add_type(
int pbe_type,
int pbe_nid,
int cipher_nid,
1123 int md_nid, EVP_PBE_KEYGEN *keygen);
1125 EVP_PBE_KEYGEN *keygen);
1126int EVP_PBE_find(
int type,
int pbe_nid,
int *pcnid,
int *pmnid,
1127 EVP_PBE_KEYGEN **pkeygen);
1128void EVP_PBE_cleanup(
void);
1129int EVP_PBE_get(
int *ptype,
int *ppbe_nid, size_t num);
1131# define ASN1_PKEY_ALIAS 0x1
1132# define ASN1_PKEY_DYNAMIC 0x2
1133# define ASN1_PKEY_SIGPARAM_NULL 0x4
1135# define ASN1_PKEY_CTRL_PKCS7_SIGN 0x1
1136# define ASN1_PKEY_CTRL_PKCS7_ENCRYPT 0x2
1137# define ASN1_PKEY_CTRL_DEFAULT_MD_NID 0x3
1138# define ASN1_PKEY_CTRL_CMS_SIGN 0x5
1139# define ASN1_PKEY_CTRL_CMS_ENVELOPE 0x7
1140# define ASN1_PKEY_CTRL_CMS_RI_TYPE 0x8
1142# define ASN1_PKEY_CTRL_SET1_TLS_ENCPT 0x9
1143# define ASN1_PKEY_CTRL_GET1_TLS_ENCPT 0xa
1145int EVP_PKEY_asn1_get_count(
void);
1149 const char *str,
int len);
1151int EVP_PKEY_asn1_add_alias(
int to,
int from);
1152int EVP_PKEY_asn1_get0_info(
int *ppkey_id,
int *pkey_base_id,
1153 int *ppkey_flags,
const char **pinfo,
1154 const char **ppem_str,
1159 const char *pem_str,
1171 int (*pub_print) (
BIO *out,
1174 int (*pkey_size) (
const EVP_PKEY *pk),
1175 int (*pkey_bits) (
const EVP_PKEY *pk));
1187 int (*param_decode) (
EVP_PKEY *pkey,
1188 const unsigned char **pder,
1190 int (*param_encode) (
const EVP_PKEY *pkey,
1191 unsigned char **pder),
1192 int (*param_missing) (
const EVP_PKEY *pk),
1195 int (*param_cmp) (
const EVP_PKEY *a,
1197 int (*param_print) (
BIO *out,
1205 int (*pkey_ctrl) (
EVP_PKEY *pkey,
int op,
1206 long arg1,
void *arg2));
1227 int (*pkey_check) (
const EVP_PKEY *pk));
1230 int (*pkey_pub_check) (
const EVP_PKEY *pk));
1233 int (*pkey_param_check) (
const EVP_PKEY *pk));
1242 const unsigned char *pub,
1245 int (*get_priv_key) (
const EVP_PKEY *pk,
1246 unsigned char *priv,
1257# define EVP_PKEY_OP_UNDEFINED 0
1258# define EVP_PKEY_OP_PARAMGEN (1
<<1
)
1259# define EVP_PKEY_OP_KEYGEN (1
<<2
)
1260# define EVP_PKEY_OP_SIGN (1
<<3
)
1261# define EVP_PKEY_OP_VERIFY (1
<<4
)
1262# define EVP_PKEY_OP_VERIFYRECOVER (1
<<5
)
1263# define EVP_PKEY_OP_SIGNCTX (1
<<6
)
1264# define EVP_PKEY_OP_VERIFYCTX (1
<<7
)
1265# define EVP_PKEY_OP_ENCRYPT (1
<<8
)
1266# define EVP_PKEY_OP_DECRYPT (1
<<9
)
1267# define EVP_PKEY_OP_DERIVE (1
<<10
)
1269# define EVP_PKEY_OP_TYPE_SIG
1273# define EVP_PKEY_OP_TYPE_CRYPT
1276# define EVP_PKEY_OP_TYPE_NOGEN
1279# define EVP_PKEY_OP_TYPE_GEN
1282# define EVP_PKEY_CTX_set_signature_md(ctx, md)
1286# define EVP_PKEY_CTX_get_signature_md(ctx, pmd)
1290# define EVP_PKEY_CTX_set_mac_key(ctx, key, len)
1294# define EVP_PKEY_CTRL_MD 1
1295# define EVP_PKEY_CTRL_PEER_KEY 2
1297# define EVP_PKEY_CTRL_PKCS7_ENCRYPT 3
1298# define EVP_PKEY_CTRL_PKCS7_DECRYPT 4
1300# define EVP_PKEY_CTRL_PKCS7_SIGN 5
1302# define EVP_PKEY_CTRL_SET_MAC_KEY 6
1304# define EVP_PKEY_CTRL_DIGESTINIT 7
1307# define EVP_PKEY_CTRL_SET_IV 8
1309# define EVP_PKEY_CTRL_CMS_ENCRYPT 9
1310# define EVP_PKEY_CTRL_CMS_DECRYPT 10
1311# define EVP_PKEY_CTRL_CMS_SIGN 11
1313# define EVP_PKEY_CTRL_CIPHER 12
1315# define EVP_PKEY_CTRL_GET_MD 13
1317# define EVP_PKEY_CTRL_SET_DIGEST_SIZE 14
1319# define EVP_PKEY_ALG_CTRL 0x1000
1321# define EVP_PKEY_FLAG_AUTOARGLEN 2
1325# define EVP_PKEY_FLAG_SIGCTX_CUSTOM 4
1329void EVP_PKEY_meth_get0_info(
int *ppkey_id,
int *pflags,
1335size_t EVP_PKEY_meth_get_count(
void);
1344 int cmd,
int p1,
void *p2);
1345int EVP_PKEY_CTX_ctrl_str(
EVP_PKEY_CTX *ctx,
const char *type,
1348 int cmd, uint64_t value);
1350int EVP_PKEY_CTX_str2ctrl(
EVP_PKEY_CTX *ctx,
int cmd,
const char *str);
1353int EVP_PKEY_CTX_md(
EVP_PKEY_CTX *ctx,
int optype,
int cmd,
const char *md);
1356void EVP_PKEY_CTX_set0_keygen_info(
EVP_PKEY_CTX *ctx,
int *dat,
int datlen);
1359 const unsigned char *key,
int keylen);
1361 const unsigned char *priv,
1364 const unsigned char *pub,
1366int EVP_PKEY_get_raw_private_key(
const EVP_PKEY *pkey,
unsigned char *priv,
1368int EVP_PKEY_get_raw_public_key(
const EVP_PKEY *pkey,
unsigned char *pub,
1385 unsigned char *sig, size_t *siglen,
1386 const unsigned char *tbs, size_t tbslen);
1389 const unsigned char *sig, size_t siglen,
1390 const unsigned char *tbs, size_t tbslen);
1393 unsigned char *rout, size_t *routlen,
1394 const unsigned char *sig, size_t siglen);
1397 unsigned char *out, size_t *outlen,
1398 const unsigned char *in, size_t inlen);
1401 unsigned char *out, size_t *outlen,
1402 const unsigned char *in, size_t inlen);
1418void EVP_PKEY_CTX_set_cb(
EVP_PKEY_CTX *ctx, EVP_PKEY_gen_cb *cb);
1421int EVP_PKEY_CTX_get_keygen_info(
EVP_PKEY_CTX *ctx,
int idx);
1446 unsigned char *sig, size_t *siglen,
1447 const unsigned char *tbs,
1453 const unsigned char *sig,
1455 const unsigned char *tbs,
1482 const unsigned char *sig,
1491 const unsigned char *in,
1499 const unsigned char *in,
1513 const char *value));
1519 const unsigned char *tbs,
1524 const unsigned char *sig,
1526 const unsigned char *tbs,
1565 unsigned char *sig, size_t *siglen,
1566 const unsigned char *tbs,
1572 const unsigned char *sig,
1574 const unsigned char *tbs,
1601 const unsigned char *sig,
1610 const unsigned char *in,
1618 const unsigned char *in,
1632 const char *value));
1638 const unsigned char *tbs,
1643 const unsigned char *sig,
1645 const unsigned char *tbs,
1660void EVP_add_alg_module(
void);
#define poco_unexpected()
#define poco_assert_dbg(cond)
#define POCO_EXTERNAL_OPENSSL
#define POCO_DECLARE_EXCEPTION(API, CLS, BASE)
#define POCO_DECLARE_EXCEPTION_CODE(API, CLS, BASE, CODE)
#define POCO_DO_JOIN2(X, Y)
#define POCO_DO_JOIN(X, Y)
#define OPENSSL_VERSION_PREREQ(maj, min)
RSAPaddingMode
The padding mode used for RSA public key encryption.
@ RSA_PADDING_PKCS1_OAEP
PKCS #1 v1.5 padding. This currently is the most widely used mode.
#define POCO_EXTERNAL_OPENSSL_SLPRO
#define ASN1_STRFLGS_ESC_QUOTE
#define ASN1_STRFLGS_ESC_CTRL
#define ASN1_STRFLGS_ESC_MSB
#define ASN1_d2i_bio_of(type, xnew, d2i, in, x)
#define DECLARE_ASN1_FUNCTIONS(type)
#define ASN1_STRFLGS_RFC2253
#define DECLARE_ASN1_ENCODE_FUNCTIONS(type, itname, name)
#define ASN1_i2d_bio_of(type, i2d, out, x)
#define BIO_C_SET_WRITE_BUF_SIZE
#define BIO_C_GET_READ_REQUEST
int(*)(BIO *, char *, size_t, size_t *) BIO_meth_get_read_ex(const BIO_METHOD *biom)
#define BIO_C_GET_CIPHER_STATUS
#define BIO_C_MAKE_BIO_PAIR
#define BIO_C_SET_BUFF_SIZE
#define BIO_C_SET_BUFF_READ_DATA
int(*)(BIO *, char *, int) BIO_meth_get_read(const BIO_METHOD *biom)
#define BIO_TYPE_DESCRIPTOR
#define BIO_C_SET_SSL_RENEGOTIATE_TIMEOUT
#define BIO_CTRL_DGRAM_GET_MTU_OVERHEAD
#define BIO_TYPE_SOURCE_SINK
#define BIO_C_DO_STATE_MACHINE
#define BIO_C_GET_WRITE_BUF_SIZE
#define BIO_CTRL_SET_CLOSE
#define BIO_C_SET_CONNECT_MODE
int(*)(BIO *, const char *) BIO_meth_get_puts(const BIO_METHOD *biom)
#define BIO_FLAGS_IO_SPECIAL
int(*)(BIO *) BIO_meth_get_destroy(const BIO_METHOD *biom)
#define BIO_CTRL_WPENDING
int(*)(BIO *) BIO_meth_get_create(const BIO_METHOD *bion)
#define BIO_CTRL_SET_CALLBACK
#define BIO_C_SET_CONNECT
#define BIO_C_GET_WRITE_GUARANTEE
#define BIO_do_handshake(b)
#define BIO_CTRL_DGRAM_GET_RECV_TIMER_EXP
#define BIO_C_SET_BIND_MODE
#define BIO_C_GET_BIND_MODE
#define ossl_bio__attr__(x)
#define BIO_C_GET_SSL_NUM_RENEGOTIATES
#define BIO_C_GET_BUF_MEM_PTR
#define BIO_C_SET_FILE_PTR
#define BIO_CTRL_DGRAM_SET_PEER
#define BIO_C_GET_CONNECT
#define BIO_C_DESTROY_BIO_PAIR
#define BIO_SOCK_REUSEADDR
#define BIO_C_SET_SSL_RENEGOTIATE_BYTES
#define BIO_C_GET_BUFF_NUM_LINES
#define BIO_CTRL_DGRAM_GET_PEER
#define BIO_CTRL_GET_CLOSE
#define BIO_C_SET_BUF_MEM_EOF_RETURN
#define BIO_CTRL_DGRAM_GET_SEND_TIMER_EXP
#define BIO_C_SHUTDOWN_WR
#define BIO_C_SET_FILENAME
#define BIO_CTRL_DGRAM_CONNECT
#define BIO_CTRL_DGRAM_SET_CONNECTED
#define BIO_C_GET_CIPHER_CTX
#define BIO_C_GET_FILE_PTR
int(*)(BIO *, char *, int) BIO_meth_get_gets(const BIO_METHOD *biom)
#define BIO_C_SET_BUF_MEM
#define BIO_FLAGS_SHOULD_RETRY
long(*)(BIO *, int, BIO_info_cb *) BIO_meth_get_callback_ctrl(const BIO_METHOD *biom)
#define BIO_CTRL_GET_CALLBACK
int ERR_load_BIO_strings(void)
int ERR_load_BUF_strings(void)
virtual std::unique_ptr< ArkApi::ICommands > & GetCommands()=0
void WriteRequest(std::function< void(bool, std::string)> callback, bool success, std::string result)
std::string GetResponse(Poco::Net::HTTPClientSession *session, Poco::Net::HTTPResponse &response)
Poco::Net::HTTPRequest ConstructRequest(const std::string &url, Poco::Net::HTTPClientSession *&session, const std::vector< std::string > &headers, const std::string &request_type)
std::vector< RequestData > RequestsVec_
Requests(Requests &&)=delete
ARK_API bool CreateGetRequest(const std::string &url, const std::function< void(bool, std::string)> &callback, std::vector< std::string > headers={})
Creates an async GET Request that runs in another thread but calls the callback from the main thread.
ARK_API bool CreatePostRequest(const std::string &url, const std::function< void(bool, std::string)> &callback, const std::vector< std::string > &post_ids, const std::vector< std::string > &post_data, std::vector< std::string > headers={})
Creates an async POST Request that runs in another thread but calls the callback from the main thread...
Requests & operator=(Requests &&)=delete
ARK_API bool CreateDeleteRequest(const std::string &url, const std::function< void(bool, std::string)> &callback, std::vector< std::string > headers={})
Creates an async DELETE Request that runs in another thread but calls the callback from the main thre...
Requests & operator=(const Requests &)=delete
ARK_API bool CreatePostRequest(const std::string &url, const std::function< void(bool, std::string)> &callback, const std::string &post_data, std::vector< std::string > headers={})
Creates an async POST Request with application/x-www-form-urlencoded content type that runs in anothe...
static ARK_API Requests & Get()
ARK_API bool CreatePostRequest(const std::string &url, const std::function< void(bool, std::string)> &callback, const std::string &post_data, const std::string &content_type, std::vector< std::string > headers={})
Creates an async POST Request that runs in another thread but calls the callback from the main thread...
std::unique_ptr< impl > pimpl
Requests(const Requests &)=delete
virtual void AddOnTickCallback(const FString &id, const std::function< void(float)> &callback)=0
Added function will be called every frame.
virtual bool RemoveOnTickCallback(const FString &id)=0
Removes a on-tick callback.
static std::shared_ptr< spdlog::logger > & GetLog()
ValueType operator--()
Increments the counter and returns the previous value.
ValueType operator++()
Returns the value of the counter.
ValueType operator++(int)
Increments the counter and returns the result.
AtomicCounter(ValueType initialValue)
Creates a new AtomicCounter and initializes it to zero.
operator ValueType() const
Assigns a value to the counter.
ValueType operator--(int)
Decrements the counter and returns the result.
ValueType value() const
Converts the AtomicCounter to ValueType.
AtomicCounter & operator=(const AtomicCounter &counter)
Destroys the AtomicCounter.
AtomicCounter & operator=(ValueType value)
Assigns the value of another AtomicCounter.
AtomicCounter()
The underlying integer type.
bool operator!() const
Decrements the counter and returns the previous value.
AtomicCounter(const AtomicCounter &counter)
~AtomicCounter()
Creates the counter by copying another one.
std::atomic< int > _counter
Returns true if the counter is zero, false otherwise.
static std::string what(const char *msg, const char *file, int line, const char *text=0)
static void bugcheck(const char *msg, const char *file, int line)
static void nullPointer(const char *ptr, const char *file, int line)
static void debugger(const char *msg, const char *file, int line)
static void debugger(const char *file, int line)
static void bugcheck(const char *file, int line)
static void assertion(const char *cond, const char *file, int line, const char *text=0)
static void unexpected(const char *file, int line)
static struct CRYPTO_dynlock_value * dynlockCreate(const char *file, int line)
static void uninitialize()
Initializes the OpenSSL machinery.
static void initialize()
Automatically shut down OpenSSL on exit.
~OpenSSLInitializer()
Automatically initialize OpenSSL on startup.
static void lock(int mode, int n, const char *file, int line)
static unsigned long id()
static Poco::AtomicCounter _rc
static void enableFIPSMode(bool enabled)
static Poco::FastMutex * _mutexes
static void dynlock(int mode, struct CRYPTO_dynlock_value *lock, const char *file, int line)
static bool isFIPSEnabled()
Shuts down the OpenSSL machinery.
static void dynlockDestroy(struct CRYPTO_dynlock_value *lock, const char *file, int line)
This class represents a X509 Certificate.
void swap(X509Certificate &cert)
Move assignment.
std::string subjectName(NID nid) const
Returns the certificate subject's distinguished name.
bool equals(const X509Certificate &otherCertificate) const
const X509 * certificate() const
Poco::DateTime expiresOn() const
Returns the date and time the certificate is valid from.
X509Certificate(X509 *pCert, bool shared)
@ NID_PKCS9_EMAIL_ADDRESS
@ NID_ORGANIZATION_UNIT_NAME
std::string issuerName(NID nid) const
Returns the certificate issuer's distinguished name.
const std::string & subjectName() const
X509Certificate(const X509Certificate &cert)
const std::string & serialNumber() const
Returns the version of the certificate.
X509Certificate & operator=(const X509Certificate &cert)
Creates the certificate by moving another one.
X509 * dup() const
Returns the underlying OpenSSL certificate.
~X509Certificate()
Exchanges the certificate with another one.
bool issuedBy(const X509Certificate &issuerCertificate) const
const std::string & issuerName() const
X509Certificate(X509 *pCert)
long version() const
Destroys the X509Certificate.
X509Certificate(X509Certificate &&cert) noexcept
Creates the certificate by copying another one.
void load(std::istream &stream)
Writes the list of certificates to the specified PEM file.
std::string signatureAlgorithm() const
void print(std::ostream &out) const
Returns the certificate signature algorithm long name.
Poco::DateTime validFrom() const
X509Certificate(std::istream &istr)
std::string commonName() const
void save(std::ostream &stream) const
OpenSSLInitializer _openSSLInitializer
std::string _serialNumber
X509Certificate & operator=(X509Certificate &&cert) noexcept
Assigns a certificate.
void swap(DateTime &dateTime)
bool operator<=(const DateTime &dateTime) const
DateTime & operator-=(const Timespan &span)
int millisecond() const
Returns the second (0 to 59).
static bool isValid(int year, int month, int day, int hour=0, int minute=0, int second=0, int millisecond=0, int microsecond=0)
bool operator!=(const DateTime &dateTime) const
static bool isLeapYear(int year)
Converts a UTC time into a local time, by applying the given time zone differential.
void makeUTC(int tzd)
Converts DateTime to tm struct.
DateTime(double julianDay)
int microsecond() const
Returns the millisecond (0 to 999)
Timestamp::UtcTimeVal utcTime() const
Returns the date and time expressed as a Timestamp.
Months
Symbolic names for month numbers (1 to 12).
bool operator<(const DateTime &dateTime) const
DateTime & operator=(double julianDay)
Assigns a Timestamp.
bool operator>(const DateTime &dateTime) const
bool operator>=(const DateTime &dateTime) const
bool isPM() const
Returns true if hour < 12;.
int hourAMPM() const
Returns the hour (0 to 23).
double julianDay() const
Returns the microsecond (0 to 999)
static double toJulianDay(int year, int month, int day, int hour=0, int minute=0, int second=0, int millisecond=0, int microsecond=0)
Computes the Julian day for an UTC time.
DaysOfWeek
Symbolic names for week day numbers (0 to 6).
DateTime & operator=(const DateTime &dateTime)
Destroys the DateTime.
void makeLocal(int tzd)
Converts a local time into UTC, by applying the given time zone differential.
DateTime(const Timestamp ×tamp)
Creates a DateTime from tm struct.
static double toJulianDay(Timestamp::UtcTimeVal utcTime)
Timespan operator-(const DateTime &dateTime) const
DateTime operator-(const Timespan &span) const
DateTime & operator+=(const Timespan &span)
static Timestamp::UtcTimeVal toUtcTime(double julianDay)
Timestamp timestamp() const
Returns the julian day for the date and time.
int week(int firstDayOfWeek=MONDAY) const
Returns the month (1 to 12).
int second() const
Returns the minute (0 to 59).
~DateTime()
Copy constructor. Creates the DateTime from another one.
bool operator==(const DateTime &dateTime) const
int year() const
Swaps the DateTime with another one.
static int daysOfMonth(int year, int month)
void computeGregorian(double julianDay)
Computes the UTC time for a Julian day.
int dayOfWeek() const
Returns the day within the month (1 to 31).
DateTime & assign(int year, int month, int day, int hour=0, int minute=0, int second=0, int millisecond=0, int microseconds=0)
Assigns a Julian day.
void checkLimit(short &lower, short &higher, short limit)
Extracts the daytime (hours, minutes, seconds, etc.) from the stored utcTime.
DateTime(const DateTime &dateTime)
Timestamp::UtcTimeVal _utcTime
utility functions used to correct the overflow in computeGregorian
int month() const
Returns the year.
DateTime(int year, int month, int day, int hour=0, int minute=0, int second=0, int millisecond=0, int microsecond=0)
DateTime(const tm &tmStruct)
Creates a DateTime for the current date and time.
DateTime(Timestamp::UtcTimeVal utcTime, Timestamp::TimeDiff diff)
Creates a DateTime for the given Julian day.
DateTime & operator=(const Timestamp ×tamp)
Assigns another DateTime.
DateTime operator+(const Timespan &span) const
int minute() const
Returns true if hour >= 12.
bool isAM() const
Returns the hour (0 to 12).
virtual void updateImpl(const void *data, std::size_t length)=0
virtual const Digest & digest()=0
DigestEngine & operator=(const DigestEngine &)
virtual std::size_t digestLength() const =0
Updates the digest with the given data.
DigestEngine(const DigestEngine &)
void update(const void *data, std::size_t length)
virtual void reset()=0
Returns the length of the digest in bytes.
Exception(const Exception &exc)
virtual const char * what() const noexcept
Returns the name of the exception class.
const std::string & message() const
void message(const std::string &msg)
Standard constructor.
Exception(const std::string &msg, const Exception &nested, int code=0)
Creates an exception.
std::string _msg
Sets the extended message for the exception.
Exception(const std::string &msg, const std::string &arg, int code=0)
Creates an exception.
const Exception * nested() const
virtual Exception * clone() const
Exception & operator=(const Exception &exc)
Destroys the exception and deletes the nested exception.
virtual void rethrow() const
void extendedMessage(const std::string &arg)
Sets the message for the exception.
virtual const char * name() const noexcept
Assignment operator.
int code() const
Returns the message text.
~Exception() noexcept
Copy constructor.
std::string displayText() const
Returns the exception code if defined.
Exception(const std::string &msg, int code=0)
virtual const char * className() const noexcept
Returns a static string describing the exception.
bool tryLock(long milliseconds)
~FastMutex()
creates the Mutex.
void lock()
destroys the Mutex.
FastMutex(const FastMutex &)
void lock(long milliseconds)
FastMutex & operator=(const FastMutex &)
bool tryLock(long milliseconds)
void lock(long milliseconds)
void lock()
destroys the Mutex.
Mutex & operator=(const Mutex &)
~Mutex()
creates the Mutex.
bool tryLockImpl(long milliseconds)
void init(const Params ¶ms)
void setSessionCacheSize(std::size_t size)
Returns true iff the session cache is enabled.
std::size_t getSessionCacheSize() const
Context::VerificationMode verificationMode() const
Returns true iff the context is for use by a server.
void requireMinimumProtocol(Protocols protocol)
void enableExtendedCertificateVerification(bool flag=true)
void setInvalidCertificateHandler(InvalidCertificateHandlerPtr pInvalidCertificageHandler)
Usage _usage
Create a SSL_CTX object according to Context configuration.
Usage usage() const
Returns the underlying OpenSSL SSL Context object.
SSL_CTX * sslContext() const
long getSessionTimeout() const
void usePrivateKey(const Poco::Crypto::RSAKey &key)
Add one trusted certification authority to be used by the Context.
void enableSessionCache(bool flag=true)
Returns the verification mode.
void addCertificateAuthority(const Poco::Crypto::X509Certificate &certificate)
Adds a certificate for certificate chain validation.
void usePrivateKey(const Poco::Crypto::EVPPKey &pkey)
bool extendedCertificateVerificationEnabled() const
bool isForServerUse() const
void addChainCertificate(const Poco::Crypto::X509Certificate &certificate)
bool _ocspStaplingResponseVerification
bool ocspStaplingResponseVerificationEnabled() const
bool _extendedCertificateVerification
@ SERVER_USE
DEPRECATED. Context is used by a client.
@ TLSV1_2_CLIENT_USE
DEPRECATED. Context is used by a server requiring TLSv1.1 (OpenSSL 1.0.0 or newer).
@ TLSV1_CLIENT_USE
DEPRECATED. Context is used by a server.
@ TLSV1_3_SERVER_USE
DEPRECATED. Context is used by a client requiring TLSv1.3 (OpenSSL 1.1.1 or newer).
@ CLIENT_USE
Context is used by a client for TLSv1 or higher. Use requireMinimumProtocol() or disableProtocols() t...
@ TLSV1_2_SERVER_USE
DEPRECATED. Context is used by a client requiring TLSv1.2 (OpenSSL 1.0.1 or newer).
@ TLSV1_SERVER_USE
DEPRECATED. Context is used by a client requiring TLSv1.
@ TLSV1_3_CLIENT_USE
DEPRECATED. Context is used by a server requiring TLSv1.2 (OpenSSL 1.0.1 or newer).
@ TLS_SERVER_USE
Context is used by a client for TLSv1 or higher. Use requireMinimumProtocol() or disableProtocols() t...
@ TLSV1_1_CLIENT_USE
DEPRECATED. Context is used by a server requiring TLSv1.
@ TLSV1_1_SERVER_USE
DEPRECATED. Context is used by a client requiring TLSv1.1 (OpenSSL 1.0.0 or newer).
void useCertificate(const Poco::Crypto::X509Certificate &certificate)
Destroys the Context.
void preferServerCiphers()
Context(Usage usage, const Params ¶ms)
InvalidCertificateHandlerPtr _pInvalidCertificateHandler
void setSessionTimeout(long seconds)
InvalidCertificateHandlerPtr getInvalidCertificateHandler() const
void disableStatelessSessionResumption()
bool sessionCacheEnabled() const
void disableProtocols(int protocols)
virtual std::istream & receiveResponse(HTTPResponse &response)
virtual std::ostream & sendRequest(HTTPRequest &request)
Returns the connection timeout for HTTP connections.
static const std::string HTTP_1_1
void setContentLength(std::streamsize length)
Returns the HTTP version for this message.
HTTPRequest(const std::string &method, const std::string &uri, const std::string &version)
Creates a HTTP/1.0 request with the given method and URI.
static const std::string HTTP_GET
static const std::string HTTP_DELETE
static const std::string HTTP_POST
const std::string & getReason() const
Sets the HTTP reason phrase.
HTTPResponse(HTTPStatus status)
HTTPStatus getStatus() const
HTTPSClientSession(const std::string &host, Poco::UInt16 port, Context::Ptr pContext, Session::Ptr pSession)
std::string proxyRequestPrefix() const
Sends the given HTTPRequest over an existing connection.
HTTPSClientSession(Context::Ptr pContext, Session::Ptr pSession)
Session::Ptr sslSession()
HTTPSClientSession(Context::Ptr pContext)
Creates a HTTPSClientSession using the given host and port.
void proxyAuthenticate(HTTPRequest &request)
Checks if we can reuse a persistent connection.
int read(char *buffer, std::streamsize length)
HTTPSClientSession(const HTTPSClientSession &)
void connect(const SocketAddress &address)
Refills the internal buffer.
HTTPSClientSession(const SecureStreamSocket &socket, Session::Ptr pSession)
X509Certificate serverCertificate()
HTTPSClientSession & operator=(const HTTPSClientSession &)
HTTPSClientSession(const std::string &host, Poco::UInt16 port=HTTPS_PORT)
HTTPSClientSession(const SecureStreamSocket &socket)
Creates an unconnected HTTPSClientSession.
HTTPSClientSession(const std::string &host, Poco::UInt16 port, Context::Ptr pContext)
bool _handleErrorsOnServerSide
InvalidCertificateHandler(bool handleErrorsOnServerSide)
virtual void onInvalidCertificate(const void *pSender, VerificationErrorArgs &errorCert)=0
Destroys the InvalidCertificateHandler.
virtual ~InvalidCertificateHandler()
RejectCertificateHandler(bool handleErrorsOnServerSide)
void initializeClient(PrivateKeyPassphraseHandlerPtr ptrPassphraseHandler, InvalidCertificateHandlerPtr ptrHandler, Context::Ptr ptrContext)
static SSLManager & instance()
static std::string convertCertificateError(long errCode)
static std::string getLastError()
Converts an SSL certificate handling error code into an error message.
static void clearErrorStack()
Returns the last error from the error stack.
A utility class for certificate error handling.
void unlock()
Does nothing.
void lock(long)
Does nothing.
NullMutex()
Creates the NullMutex.
bool tryLock()
Does nothing and always returns true.
~NullMutex()
Destroys the NullMutex.
bool tryLock(long)
Does nothing and always returns true.
This stream discards all characters written to it.
Simple ReferenceCounter object, does not delete itself when count reaches 0.
int referenceCount() const
The release policy for SharedPtr holding arrays.
static void release(C *pObj) noexcept
static void release(C *pObj) noexcept
ScopedLock(M &mutex, long milliseconds)
ScopedLock(const ScopedLock &)
ScopedLock & operator=(const ScopedLock &)
ScopedLockWithUnlock(M &mutex)
ScopedLockWithUnlock & operator=(const ScopedLockWithUnlock &)
ScopedLockWithUnlock(const ScopedLockWithUnlock &)
ScopedLockWithUnlock(M &mutex, long milliseconds)
bool operator!=(const SharedPtr &ptr) const
SharedPtr(SharedPtr &&ptr) noexcept
SharedPtr & operator=(SharedPtr &&ptr) noexcept
SharedPtr< Other, RC, RP > cast() const
bool operator<=(C *ptr) const
bool operator<(const C *ptr) const
bool operator<=(const C *ptr) const
bool operator>=(C *ptr) const
void swap(SharedPtr &ptr)
SharedPtr(const SharedPtr< Other, RC, OtherRP > &ptr)
void reset(const SharedPtr< Other, RC, OtherRP > &ptr)
bool operator==(const SharedPtr &ptr) const
bool operator>=(const C *ptr) const
bool operator!=(const C *ptr) const
bool operator>(C *ptr) const
bool operator>(const C *ptr) const
void reset(const SharedPtr &ptr)
bool operator==(C *ptr) const
bool operator<=(const SharedPtr &ptr) const
bool operator!=(C *ptr) const
bool operator>=(const SharedPtr &ptr) const
bool operator==(std::nullptr_t ptr) const
SharedPtr(const SharedPtr &ptr)
SharedPtr(RC *pCounter, C *ptr)
SharedPtr< Other, RC, RP > unsafeCast() const
SharedPtr & assign(const SharedPtr &ptr)
SharedPtr & operator=(const SharedPtr &ptr)
operator const C *() const
SharedPtr & assign(C *ptr)
const C & operator*() const
const C * operator->() const
int referenceCount() const
SharedPtr & assign(const SharedPtr< Other, RC, OtherRP > &ptr)
bool operator==(const C *ptr) const
bool operator>(const SharedPtr &ptr) const
SharedPtr & operator=(const SharedPtr< Other, RC, OtherRP > &ptr)
bool operator<(const SharedPtr &ptr) const
SharedPtr & operator=(C *ptr)
bool operator<(C *ptr) const
bool operator!=(std::nullptr_t ptr) const
static std::streamsize copyStream(std::istream &istr, std::ostream &ostr, std::size_t bufferSize=8192)
A class that represents time spans up to microsecond resolution.
Timespan(const Timespan ×pan)
Creates a Timespan.
int totalMinutes() const
Returns the number of minutes (0 to 59).
static const TimeDiff SECONDS
The number of microseconds in a millisecond.
bool operator>=(TimeDiff microSeconds) const
bool operator>(TimeDiff microSeconds) const
int seconds() const
Returns the total number of minutes.
Timespan(int days, int hours, int minutes, int seconds, int microSeconds)
Timespan & operator=(TimeDiff microseconds)
Assignment operator.
Timespan operator-(TimeDiff microSeconds) const
bool operator<=(const Timespan &ts) const
static const TimeDiff HOURS
The number of microseconds in a minute.
Timespan & assign(long seconds, long microseconds)
Assigns a new span.
bool operator==(const Timespan &ts) const
Swaps the Timespan with another one.
void swap(Timespan ×pan)
bool operator==(TimeDiff microSeconds) const
TimeDiff _span
The number of microseconds in a day.
Timespan & operator-=(TimeDiff microSeconds)
Timespan(long seconds, long microseconds)
Creates a Timespan.
TimeDiff totalMicroseconds() const
int totalHours() const
Returns the number of hours (0 to 23).
Timespan & operator=(const Timespan ×pan)
Destroys the Timespan.
int totalSeconds() const
Returns the number of seconds (0 to 59).
TimeDiff totalMilliseconds() const
Returns the number of milliseconds (0 to 999).
Timespan & operator-=(const Timespan &d)
bool operator>=(const Timespan &ts) const
int hours() const
Returns the number of days.
Timespan(TimeDiff microseconds)
Creates a zero Timespan.
int minutes() const
Returns the total number of hours.
bool operator!=(const Timespan &ts) const
Timespan operator+(TimeDiff microSeconds) const
bool operator>(const Timespan &ts) const
bool operator<(TimeDiff microSeconds) const
static const TimeDiff DAYS
The number of microseconds in a hour.
int microseconds() const
Returns the total number of milliseconds.
int milliseconds() const
Returns the total number of seconds.
Timespan & operator+=(TimeDiff microSeconds)
static const TimeDiff MINUTES
The number of microseconds in a second.
~Timespan()
Creates a Timespan from another one.
Timespan & operator+=(const Timespan &d)
static const TimeDiff MILLISECONDS
Returns the total number of microseconds.
bool operator<(const Timespan &ts) const
Timespan operator-(const Timespan &d) const
Timespan & assign(int days, int hours, int minutes, int seconds, int microSeconds)
Assignment operator.
Timespan operator+(const Timespan &d) const
bool operator<=(TimeDiff microSeconds) const
bool operator!=(TimeDiff microSeconds) const
Timestamp & operator=(const Timestamp &other)
Destroys the timestamp.
Timestamp & operator+=(TimeDiff d)
Timestamp & operator-=(TimeDiff d)
Timestamp(TimeVal tv)
Creates a timestamp with the current time.
Timestamp & operator=(TimeVal tv)
bool isElapsed(TimeDiff interval) const
static const TimeVal TIMEVAL_MIN
Difference between two TimeVal values in microseconds.
TimeVal epochMicroseconds() const
static Timestamp fromUtcTime(UtcTimeVal val)
Creates a timestamp from a std::time_t.
static TimeDiff resolution()
bool operator<=(const Timestamp &ts) const
Timestamp operator+(const Timespan &span) const
std::time_t epochTime() const
~Timestamp()
Copy constructor.
Timestamp operator-(const Timespan &span) const
bool operator==(const Timestamp &ts) const
Updates the Timestamp with the current time.
bool operator>=(const Timestamp &ts) const
Timestamp & operator-=(const Timespan &span)
UtcTimeVal utcTime() const
Timestamp operator+(TimeDiff d) const
bool operator<(const Timestamp &ts) const
static Timestamp fromEpochTime(std::time_t t)
Timestamp()
Maximum timestamp value.
bool operator!=(const Timestamp &ts) const
static const TimeVal TIMEVAL_MAX
Minimum timestamp value.
TimeDiff operator-(const Timestamp &ts) const
Timestamp & operator+=(const Timespan &span)
bool operator>(const Timestamp &ts) const
Timestamp(const Timestamp &other)
void swap(Timestamp ×tamp)
Timestamp operator-(TimeDiff d) const
void update()
Swaps the Timestamp with another one.
const std::string & getHost() const
Sets the user-info part of the URI.
const std::string & getScheme() const
URI(const std::string &uri)
Creates an empty URI.
unsigned short getPort() const
Sets the host part of the URI.
std::string getPathAndQuery() const
Returns the encoded path, query and fragment parts of the URI.
int COMP_CTX_get_type(const COMP_CTX *comp)
int COMP_expand_block(COMP_CTX *ctx, unsigned char *out, int olen, unsigned char *in, int ilen)
int COMP_get_type(const COMP_METHOD *meth)
int COMP_compress_block(COMP_CTX *ctx, unsigned char *out, int olen, unsigned char *in, int ilen)
const COMP_METHOD * COMP_CTX_get_method(const COMP_CTX *ctx)
const char * COMP_get_name(const COMP_METHOD *meth)
COMP_CTX * COMP_CTX_new(COMP_METHOD *meth)
void COMP_CTX_free(COMP_CTX *ctx)
COMP_METHOD * COMP_zlib(void)
int ERR_load_COMP_strings(void)
int ERR_load_CRYPTO_strings(void)
int(*)(EVP_MD_CTX *ctx) EVP_MD_meth_get_cleanup(const EVP_MD *md)
int(*)(EVP_CIPHER_CTX *ctx, unsigned char *out, const unsigned char *in, size_t inl) EVP_CIPHER_meth_get_do_cipher(const EVP_CIPHER *cipher)
int EVP_MD_meth_set_app_datasize(EVP_MD *md, int datasize)
#define EVP_get_cipherbynid(a)
#define EVP_PKEY_OP_DECRYPT
EVP_MD * EVP_MD_meth_new(int md_type, int pkey_type)
#define EVP_PKEY_OP_ENCRYPT
int(*)(EVP_CIPHER_CTX *ctx, const unsigned char *key, const unsigned char *iv, int enc) EVP_CIPHER_meth_get_init(const EVP_CIPHER *cipher)
int EVP_MD_meth_get_app_datasize(const EVP_MD *md)
#define EVP_CTRL_AEAD_SET_IVLEN
#define EVP_PKEY_OP_KEYGEN
int EVP_MD_meth_set_flags(EVP_MD *md, unsigned long flags)
int(*)(EVP_MD_CTX *ctx, const void *data, size_t count) EVP_MD_CTX_update_fn(EVP_MD_CTX *ctx)
int EVP_MD_meth_set_cleanup(EVP_MD *md, int(*cleanup)(EVP_MD_CTX *ctx))
int EVP_MD_meth_set_ctrl(EVP_MD *md, int(*ctrl)(EVP_MD_CTX *ctx, int cmd, int p1, void *p2))
EVP_MD * EVP_MD_meth_dup(const EVP_MD *md)
int EVP_MD_meth_set_final(EVP_MD *md, int(*final)(EVP_MD_CTX *ctx, unsigned char *md))
int EVP_MD_meth_get_result_size(const EVP_MD *md)
int(*)(EVP_MD_CTX *ctx) EVP_MD_meth_get_init(const EVP_MD *md)
unsigned long EVP_MD_meth_get_flags(const EVP_MD *md)
#define EVP_MAX_IV_LENGTH
int EVP_MD_meth_set_copy(EVP_MD *md, int(*copy)(EVP_MD_CTX *to, const EVP_MD_CTX *from))
int EVP_MD_meth_set_result_size(EVP_MD *md, int resultsize)
#define EVP_CIPHER_mode(e)
int(*)(EVP_MD_CTX *ctx, unsigned char *md) EVP_MD_meth_get_final(const EVP_MD *md)
int EVP_MD_meth_set_init(EVP_MD *md, int(*init)(EVP_MD_CTX *ctx))
#define EVP_PKEY_OP_VERIFYCTX
int EVP_MD_meth_set_update(EVP_MD *md, int(*update)(EVP_MD_CTX *ctx, const void *data, size_t count))
int(*)(EVP_MD_CTX *to, const EVP_MD_CTX *from) EVP_MD_meth_get_copy(const EVP_MD *md)
#define EVP_PKEY_OP_VERIFY
int(*)(EVP_MD_CTX *ctx, const void *data, size_t count) EVP_MD_meth_get_update(const EVP_MD *md)
int EVP_MD_meth_get_input_blocksize(const EVP_MD *md)
#define EVP_PKEY_CTRL_SET_MAC_KEY
int(*)(EVP_MD_CTX *ctx, int cmd, int p1, void *p2) EVP_MD_meth_get_ctrl(const EVP_MD *md)
int EVP_MD_meth_set_input_blocksize(EVP_MD *md, int blocksize)
#define OPENSSL_add_all_algorithms_noconf()
#define EVP_CTRL_AEAD_GET_TAG
int(*)(EVP_CIPHER_CTX *, int type, int arg, void *ptr) EVP_CIPHER_meth_get_ctrl(const EVP_CIPHER *cipher)
#define EVP_PKEY_OP_TYPE_CRYPT
#define EVP_PKEY_OP_VERIFYRECOVER
#define EVP_CTRL_AEAD_SET_TAG
int(*)(EVP_CIPHER_CTX *) EVP_CIPHER_meth_get_cleanup(const EVP_CIPHER *cipher)
void EVP_MD_meth_free(EVP_MD *md)
#define EVP_PKEY_CTRL_GET_MD
#define EVP_PKEY_OP_TYPE_SIG
#define EVP_PKEY_OP_DERIVE
#define EVP_CTRL_AEAD_SET_IV_FIXED
#define EVP_get_digestbynid(a)
#define EVP_PKEY_POLY1305
#define EVP_PKEY_OP_SIGNCTX
#define EVP_PKEY_OP_PARAMGEN
std::unique_ptr< IBaseApi > game_api
void Crypto_API uninitializeCrypto()
void Crypto_API initializeCrypto()
std::vector< SocketBuf > SocketBufVec
void NetSSL_API initializeSSL()
void Net_API uninitializeNetwork()
void Net_API initializeNetwork()
void NetSSL_API uninitializeSSL()
void swap(Timestamp &s1, Timestamp &s2)
void swap(SharedPtr< C, RC, RP > &p1, SharedPtr< C, RC, RP > &p2)
void swap(DateTime &d1, DateTime &d2)
void swap(Timespan &s1, Timespan &s2)
SharedPtr< T, ReferenceCounter, ReleaseArrayPolicy< T > > makeSharedArray(std::size_t size)
SharedPtr< T > makeShared(Args &&... args)
void format_arg(BasicFormatter< char, ArgFormatter > &f, const char *&format_str, const std::tm &tm)
#define NID_X9_62_id_ecPublicKey
#define NID_dhKeyAgreement
#define NID_dhpublicnumber
#define NID_dsaWithSHA1_2
#define NID_rsaEncryption
#define OBJ_NAME_TYPE_CIPHER_METH
#define OBJ_NAME_TYPE_MD_METH
BUF_MEM * BUF_MEM_new_ex(unsigned long flags)
void BUF_MEM_free(BUF_MEM *a)
BUF_MEM * BUF_MEM_new(void)
size_t BUF_MEM_grow(BUF_MEM *str, size_t len)
size_t BUF_MEM_grow_clean(BUF_MEM *str, size_t len)
void BUF_reverse(unsigned char *out, const unsigned char *in, size_t siz)
int CRYPTO_secure_malloc_done(void)
int CRYPTO_THREAD_compare_id(CRYPTO_THREAD_ID a, CRYPTO_THREAD_ID b)
void OPENSSL_thread_stop(void)
void CRYPTO_free_ex_data(int class_index, void *obj, CRYPTO_EX_DATA *ad)
int CRYPTO_atomic_add(int *val, int amount, int *ret, CRYPTO_RWLOCK *lock)
void CRYPTO_EX_new(void *parent, void *ptr, CRYPTO_EX_DATA *ad, int idx, long argl, void *argp)
size_t OPENSSL_strlcpy(char *dst, const char *src, size_t siz)
int CRYPTO_THREAD_read_lock(CRYPTO_RWLOCK *lock)
void * CRYPTO_get_ex_data(const CRYPTO_EX_DATA *ad, int idx)
int CRYPTO_mem_ctrl(int mode)
void * CRYPTO_clear_realloc(void *addr, size_t old_num, size_t num, const char *file, int line)
void OPENSSL_INIT_set_config_file_flags(OPENSSL_INIT_SETTINGS *settings, unsigned long flags)
int CRYPTO_set_mem_functions(void *(*m)(size_t, const char *, int), void *(*r)(void *, size_t, const char *, int), void(*f)(void *, const char *, int))
#define OPENSSL_INIT_ENGINE_PADLOCK
int OPENSSL_gmtime_adj(struct tm *tm, int offset_day, long offset_sec)
#define OPENSSL_INIT_ENGINE_RDRAND
void OPENSSL_cleanse(void *ptr, size_t len)
int CRYPTO_new_ex_data(int class_index, void *obj, CRYPTO_EX_DATA *ad)
unsigned long OpenSSL_version_num(void)
int OPENSSL_isservice(void)
int CRYPTO_THREAD_init_local(CRYPTO_THREAD_LOCAL *key, void(*cleanup)(void *))
void CRYPTO_free(void *ptr, const char *file, int line)
int OPENSSL_INIT_set_config_filename(OPENSSL_INIT_SETTINGS *settings, const char *config_filename)
size_t OPENSSL_strnlen(const char *str, size_t maxlen)
int CRYPTO_THREAD_write_lock(CRYPTO_RWLOCK *lock)
unsigned char * OPENSSL_hexstr2buf(const char *str, long *len)
int OPENSSL_init_crypto(uint64_t opts, const OPENSSL_INIT_SETTINGS *settings)
#define CRYPTO_EX_INDEX_SSL_CTX
#define OPENSSL_INIT_LOAD_CRYPTO_STRINGS
int CRYPTO_THREAD_set_local(CRYPTO_THREAD_LOCAL *key, void *val)
void CRYPTO_get_mem_functions(void *(**m)(size_t, const char *, int), void *(**r)(void *, size_t, const char *, int), void(**f)(void *, const char *, int))
int OPENSSL_atexit(void(*handler)(void))
void * CRYPTO_malloc(size_t num, const char *file, int line)
int CRYPTO_THREAD_cleanup_local(CRYPTO_THREAD_LOCAL *key)
int CRYPTO_secure_allocated(const void *ptr)
#define OPENSSL_strndup(str, n)
int CRYPTO_secure_malloc_init(size_t sz, int minsize)
int CRYPTO_THREAD_run_once(CRYPTO_ONCE *once, void(*init)(void))
char * CRYPTO_strdup(const char *str, const char *file, int line)
char * CRYPTO_strndup(const char *str, size_t s, const char *file, int line)
size_t CRYPTO_secure_actual_size(void *ptr)
void * CRYPTO_secure_malloc(size_t num, const char *file, int line)
#define CRYPTO_ONCE_STATIC_INIT
int CRYPTO_free_ex_index(int class_index, int idx)
#define CRYPTO_EX_INDEX_SSL_SESSION
#define OPENSSL_INIT_LOAD_CONFIG
void CRYPTO_clear_free(void *ptr, size_t num, const char *file, int line)
void * CRYPTO_memdup(const void *str, size_t siz, const char *file, int line)
void CRYPTO_EX_free(void *parent, void *ptr, CRYPTO_EX_DATA *ad, int idx, long argl, void *argp)
size_t CRYPTO_secure_used(void)
int CRYPTO_EX_dup(CRYPTO_EX_DATA *to, const CRYPTO_EX_DATA *from, void *from_d, int idx, long argl, void *argp)
int CRYPTO_THREAD_unlock(CRYPTO_RWLOCK *lock)
#define OPENSSL_INIT_ADD_ALL_DIGESTS
void * CRYPTO_secure_zalloc(size_t num, const char *file, int line)
int CRYPTO_memcmp(const void *in_a, const void *in_b, size_t len)
void OPENSSL_INIT_free(OPENSSL_INIT_SETTINGS *settings)
CRYPTO_THREAD_ID CRYPTO_THREAD_get_current_id(void)
char * OPENSSL_buf2hexstr(const unsigned char *buffer, long len)
size_t OPENSSL_strlcat(char *dst, const char *src, size_t siz)
#define OPENSSL_INIT_ENGINE_CAPI
#define CRYPTO_EX_INDEX_X509
int CRYPTO_dup_ex_data(int class_index, CRYPTO_EX_DATA *to, const CRYPTO_EX_DATA *from)
__owur int CRYPTO_get_ex_new_index(int class_index, long argl, void *argp, CRYPTO_EX_new *new_func, CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func)
#define OPENSSL_strdup(str)
void CRYPTO_THREAD_lock_free(CRYPTO_RWLOCK *lock)
void OPENSSL_cleanup(void)
#define CRYPTO_EX_INDEX_SSL
void * CRYPTO_realloc(void *addr, size_t num, const char *file, int line)
OPENSSL_INIT_SETTINGS * OPENSSL_INIT_new(void)
void * CRYPTO_THREAD_get_local(CRYPTO_THREAD_LOCAL *key)
int CRYPTO_set_mem_debug(int flag)
int OPENSSL_INIT_set_config_appname(OPENSSL_INIT_SETTINGS *settings, const char *config_appname)
int OPENSSL_hexchar2int(unsigned char c)
#define OPENSSL_memdup(str, s)
#define OPENSSL_INIT_ADD_ALL_CIPHERS
int CRYPTO_set_ex_data(CRYPTO_EX_DATA *ad, int idx, void *val)
CRYPTO_RWLOCK * CRYPTO_THREAD_lock_new(void)
int OPENSSL_issetugid(void)
#define OPENSSL_INIT_ENGINE_DYNAMIC
void CRYPTO_secure_free(void *ptr, const char *file, int line)
void * CRYPTO_zalloc(size_t num, const char *file, int line)
#define CRYPTO_EX_INDEX_BIO
int CRYPTO_secure_malloc_initialized(void)
ossl_noreturn void OPENSSL_die(const char *assertion, const char *file, int line)
int OPENSSL_gmtime_diff(int *pday, int *psec, const struct tm *from, const struct tm *to)
const char * OpenSSL_version(int type)
#define OPENSSL_INIT_ENGINE_CRYPTODEV
struct tm * OPENSSL_gmtime(const time_t *timer, struct tm *result)
void CRYPTO_secure_clear_free(void *ptr, size_t num, const char *file, int line)
#define OPENSSL_EXPORT_VAR_AS_FUNCTION
#define OPENSSL_API_COMPAT
#define DEPRECATEDIN_1_1_0(f)
#define DECLARE_DEPRECATED(f)
#define OPENSSL_NO_HEARTBEATS
#define OPENSSL_NO_UNIT_TEST
#define OPENSSL_NO_CRYPTO_MDEBUG
#define OPENSSL_NO_SSL3_METHOD
#define OPENSSL_NO_SSL_TRACE
#define OPENSSL_VERSION_NUMBER
struct x509_lookup_method_st X509_LOOKUP_METHOD
struct asn1_string_st ASN1_PRINTABLESTRING
struct asn1_string_st ASN1_IA5STRING
struct evp_md_ctx_st EVP_MD_CTX
struct ocsp_response_st OCSP_RESPONSE
struct asn1_string_st ASN1_UNIVERSALSTRING
struct ssl_ctx_st SSL_CTX
struct asn1_string_st ASN1_T61STRING
struct AUTHORITY_KEYID_st AUTHORITY_KEYID
struct ctlog_store_st CTLOG_STORE
struct evp_pkey_st EVP_PKEY
struct bn_blinding_st BN_BLINDING
struct v3_ext_ctx X509V3_CTX
struct x509_store_st X509_STORE
struct X509_POLICY_TREE_st X509_POLICY_TREE
struct DIST_POINT_st DIST_POINT
struct asn1_string_st ASN1_ENUMERATED
struct X509_POLICY_NODE_st X509_POLICY_NODE
struct evp_cipher_st EVP_CIPHER
struct rsa_meth_st RSA_METHOD
struct X509_name_st X509_NAME
struct dh_method DH_METHOD
struct sct_ctx_st SCT_CTX
struct bn_recp_ctx_st BN_RECP_CTX
struct dsa_method DSA_METHOD
struct asn1_sctx_st ASN1_SCTX
struct NAME_CONSTRAINTS_st NAME_CONSTRAINTS
struct evp_Encode_Ctx_st EVP_ENCODE_CTX
struct asn1_string_st ASN1_GENERALSTRING
struct ossl_store_info_st OSSL_STORE_INFO
struct rsa_pss_params_st RSA_PSS_PARAMS
struct evp_pkey_method_st EVP_PKEY_METHOD
struct x509_revoked_st X509_REVOKED
struct crypto_ex_data_st CRYPTO_EX_DATA
struct asn1_pctx_st ASN1_PCTX
struct ocsp_responder_id_st OCSP_RESPID
struct ct_policy_eval_ctx_st CT_POLICY_EVAL_CTX
struct X509_pubkey_st X509_PUBKEY
struct X509_POLICY_LEVEL_st X509_POLICY_LEVEL
struct ISSUING_DIST_POINT_st ISSUING_DIST_POINT
struct comp_ctx_st COMP_CTX
struct ossl_init_settings_st OPENSSL_INIT_SETTINGS
struct comp_method_st COMP_METHOD
struct hmac_ctx_st HMAC_CTX
struct X509_algor_st X509_ALGOR
struct evp_pkey_ctx_st EVP_PKEY_CTX
struct evp_cipher_ctx_st EVP_CIPHER_CTX
struct buf_mem_st BUF_MEM
struct pkcs8_priv_key_info_st PKCS8_PRIV_KEY_INFO
struct x509_crl_method_st X509_CRL_METHOD
struct asn1_string_st ASN1_BMPSTRING
struct asn1_string_st ASN1_GENERALIZEDTIME
struct ossl_store_search_st OSSL_STORE_SEARCH
struct X509_crl_st X509_CRL
struct X509_POLICY_CACHE_st X509_POLICY_CACHE
struct ssl_dane_st SSL_DANE
struct asn1_string_st ASN1_STRING
struct evp_pkey_asn1_method_st EVP_PKEY_ASN1_METHOD
struct asn1_string_st ASN1_UTF8STRING
struct X509_VERIFY_PARAM_st X509_VERIFY_PARAM
struct x509_object_st X509_OBJECT
struct asn1_string_st ASN1_TIME
struct rand_drbg_st RAND_DRBG
struct bn_gencb_st BN_GENCB
struct ui_method_st UI_METHOD
struct asn1_object_st ASN1_OBJECT
struct x509_store_ctx_st X509_STORE_CTX
unsigned long ossl_uintmax_t
struct ASN1_ITEM_st ASN1_ITEM
struct rand_meth_st RAND_METHOD
struct bn_mont_ctx_st BN_MONT_CTX
struct x509_sig_info_st X509_SIG_INFO
struct asn1_string_st ASN1_INTEGER
struct asn1_string_st ASN1_BIT_STRING
struct ocsp_req_ctx_st OCSP_REQ_CTX
struct asn1_string_st ASN1_UTCTIME
struct asn1_string_st ASN1_OCTET_STRING
struct ec_key_method_st EC_KEY_METHOD
struct asn1_string_st ASN1_VISIBLESTRING
struct x509_lookup_st X509_LOOKUP
int pem_password_cb(char *buf, int size, int rwflag, void *userdata)
#define DECLARE_PEM_rw(name, type)
#define DEFINE_SPECIAL_STACK_OF(t1, t2)
#define SKM_DEFINE_STACK_OF(t1, t2, t3)
const char * OPENSSL_CSTRING
#define DEFINE_STACK_OF(t)
#define DEFINE_SPECIAL_STACK_OF_CONST(t1, t2)
#define DEFINE_STACK_OF_CONST(t)
#define SSL3_AD_HANDSHAKE_FAILURE
#define SSL3_AD_NO_CERTIFICATE
#define SSL3_AD_CLOSE_NOTIFY
#define SSL3_AD_UNSUPPORTED_CERTIFICATE
#define SSL3_AD_CERTIFICATE_UNKNOWN
#define SSL3_AD_BAD_RECORD_MAC
#define SSL3_AD_CERTIFICATE_EXPIRED
#define SSL3_AD_DECOMPRESSION_FAILURE
#define SSL3_AD_ILLEGAL_PARAMETER
#define SSL3_AD_BAD_CERTIFICATE
#define SSL3_AD_UNEXPECTED_MESSAGE
#define SSL3_AD_CERTIFICATE_REVOKED
#define SSL_get_shared_group(s, n)
void SSL_CTX_set_psk_client_callback(SSL_CTX *ctx, SSL_psk_client_cb_func cb)
void(* SSL_custom_ext_free_cb_ex)(SSL *s, unsigned int ext_type, unsigned int context, const unsigned char *out, void *add_arg)
#define SSL_CTRL_GET_TOTAL_RENEGOTIATIONS
#define SSL_SECOP_OTHER_CURVE
#define SSL_CTRL_CERT_FLAGS
#define SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS
#define SSL_CTRL_SET_TMP_DH
void SSL_CTX_sess_set_new_cb(SSL_CTX *ctx, int(*new_session_cb)(struct ssl_st *ssl, SSL_SESSION *sess))
__owur int SSL_CTX_set_client_cert_engine(SSL_CTX *ctx, ENGINE *e)
#define SSL_CTX_set1_groups(ctx, glist, glistlen)
void(* SSL_CTX_keylog_cb_func)(const SSL *ssl, const char *line)
__owur int SSL_CTX_set_alpn_protos(SSL_CTX *ctx, const unsigned char *protos, unsigned int protos_len)
__owur int SSL_extension_supported(unsigned int ext_type)
#define DTLS_CTRL_SET_LINK_MTU
int SSL_in_before(const SSL *s)
#define SSL_CTRL_GET_RI_SUPPORT
#define SSL_CTRL_SET_TMP_ECDH
#define SSL_OP_NO_TLSv1_3
#define SSL_CTRL_CHAIN_CERT
#define SSL_CTRL_SET_SPLIT_SEND_FRAGMENT
unsigned long SSL_CTX_clear_options(SSL_CTX *ctx, unsigned long op)
#define SSL_CTRL_SET_CLIENT_CERT_TYPES
int(*)(const SSL *s, const SSL_CTX *ctx, int op, int bits, int nid, void *other, void *ex) SSL_get_security_callback(const SSL *s)
void SSL_CTX_set_client_cert_cb(SSL_CTX *ctx, int(*client_cert_cb)(SSL *ssl, X509 **x509, EVP_PKEY **pkey))
#define SSL_CTRL_GET_RAW_CIPHERLIST
#define SSL_CTRL_CLEAR_CERT_FLAGS
__owur int SSL_CTX_add_client_custom_ext(SSL_CTX *ctx, unsigned int ext_type, custom_ext_add_cb add_cb, custom_ext_free_cb free_cb, void *add_arg, custom_ext_parse_cb parse_cb, void *parse_arg)
#define SSL_CTRL_GET_NUM_RENEGOTIATIONS
#define SSL_OP_TLSEXT_PADDING
#define SSL_CTX_set1_groups_list(ctx, s)
#define SSL_OP_NO_DTLSv1_2
uint32_t SSL_get_recv_max_early_data(const SSL *s)
#define SSL_CTRL_SET_SIGALGS
void SSL_CTX_sess_set_remove_cb(SSL_CTX *ctx, void(*remove_session_cb)(struct ssl_ctx_st *ctx, SSL_SESSION *sess))
int SSL_in_init(const SSL *s)
__owur int SSL_set_alpn_protos(SSL *ssl, const unsigned char *protos, unsigned int protos_len)
#define SSL_set1_groups_list(s, str)
#define SSL_CTRL_EXTRA_CHAIN_CERT
void SSL_get0_next_proto_negotiated(const SSL *s, const unsigned char **data, unsigned *len)
#define SSL_CTRL_GET_PEER_SIGNATURE_NID
void SSL_CTX_set_stateless_cookie_generate_cb(SSL_CTX *ctx, int(*gen_stateless_cookie_cb)(SSL *ssl, unsigned char *cookie, size_t *cookie_len))
#define SSL_CTRL_GET_CLIENT_CERT_TYPES
struct ssl_conf_ctx_st SSL_CONF_CTX
#define SSL_VERIFY_FAIL_IF_NO_PEER_CERT
void SSL_CTX_set_stateless_cookie_verify_cb(SSL_CTX *ctx, int(*verify_stateless_cookie_cb)(SSL *ssl, const unsigned char *cookie, size_t cookie_len))
void SSL_set_psk_server_callback(SSL *ssl, SSL_psk_server_cb_func cb)
void SSL_CTX_set_next_proto_select_cb(SSL_CTX *s, SSL_CTX_npn_select_cb_func cb, void *arg)
#define SSL_CTRL_SESS_HIT
void SSL_set_psk_client_callback(SSL *ssl, SSL_psk_client_cb_func cb)
#define SSL_CTX_set_read_ahead(ctx, m)
int SSL_CTX_set_recv_max_early_data(SSL_CTX *ctx, uint32_t recv_max_early_data)
#define SSL_CTRL_SESS_TIMEOUTS
#define SSL_OP_SAFARI_ECDHE_ECDSA_BUG
#define SSL_CTRL_GET_TMP_KEY
size_t SSL_get_peer_finished(const SSL *s, void *buf, size_t count)
int(* SSL_psk_find_session_cb_func)(SSL *ssl, const unsigned char *identity, size_t identity_len, SSL_SESSION **sess)
size_t SSL_get_finished(const SSL *s, void *buf, size_t count)
#define SSL_CTRL_SET_VERIFY_CERT_STORE
struct ssl_comp_st SSL_COMP
int(* SSL_custom_ext_parse_cb_ex)(SSL *s, unsigned int ext_type, unsigned int context, const unsigned char *in, size_t inlen, X509 *x, size_t chainidx, int *al, void *parse_arg)
#define SSL_CTRL_SET_SESS_CACHE_SIZE
#define SSL_CTRL_GET_CHAIN_CERTS
#define SSL_SECOP_OTHER_NONE
#define SSL_CTRL_SESS_ACCEPT
#define SSL_OP_LEGACY_SERVER_CONNECT
#define SSL_CTRL_SET_MAX_SEND_FRAGMENT
struct ssl_cipher_st SSL_CIPHER
__owur int SSL_select_next_proto(unsigned char **out, unsigned char *outlen, const unsigned char *in, unsigned int inlen, const unsigned char *client, unsigned int client_len)
#define SSL_SECOP_OTHER_PKEY
#define SSL_CTRL_SESS_CONNECT_GOOD
void SSL_set_psk_use_session_callback(SSL *s, SSL_psk_use_session_cb_func cb)
int SSL_CTX_set_max_early_data(SSL_CTX *ctx, uint32_t max_early_data)
#define SSL_SECOP_OTHER_CERT
#define SSL_CTRL_SET_READ_AHEAD
#define SSL_SECOP_OTHER_CIPHER
unsigned int(* SSL_psk_client_cb_func)(SSL *ssl, const char *hint, char *identity, unsigned int max_identity_len, unsigned char *psk, unsigned int max_psk_len)
#define SSL_CTRL_GET_SESS_CACHE_MODE
#define SSL_get1_groups(s, glist)
int(* GEN_SESSION_CB)(SSL *ssl, unsigned char *id, unsigned int *id_len)
int(* SSL_psk_use_session_cb_func)(SSL *ssl, const EVP_MD *md, const unsigned char **id, size_t *idlen, SSL_SESSION **sess)
int(* SSL_CTX_npn_advertised_cb_func)(SSL *ssl, const unsigned char **out, unsigned int *outlen, void *arg)
void SSL_get0_alpn_selected(const SSL *ssl, const unsigned char **data, unsigned int *len)
__owur int SSL_CTX_has_client_custom_ext(const SSL_CTX *ctx, unsigned int ext_type)
#define SSL_set0_chain(s, sk)
__owur int SSL_SRP_CTX_init(SSL *s)
#define SSL_CTRL_GET_SHARED_GROUP
int SSL_SRP_CTX_free(SSL *ctx)
struct tls_session_ticket_ext_st TLS_SESSION_TICKET_EXT
@ DTLS_ST_SW_HELLO_VERIFY_REQUEST
@ TLS_ST_SW_SESSION_TICKET
@ TLS_ST_PENDING_EARLY_DATA_END
@ DTLS_ST_CR_HELLO_VERIFY_REQUEST
@ TLS_ST_CR_ENCRYPTED_EXTENSIONS
@ TLS_ST_CW_END_OF_EARLY_DATA
@ TLS_ST_CR_SESSION_TICKET
@ TLS_ST_SW_ENCRYPTED_EXTENSIONS
@ TLS_ST_SR_END_OF_EARLY_DATA
#define SSL_CTRL_GET_READ_AHEAD
struct ssl_method_st SSL_METHOD
__owur int SSL_srp_server_param_with_username(SSL *s, int *ad)
__owur int SSL_CTX_add_custom_ext(SSL_CTX *ctx, unsigned int ext_type, unsigned int context, SSL_custom_ext_add_cb_ex add_cb, SSL_custom_ext_free_cb_ex free_cb, void *add_arg, SSL_custom_ext_parse_cb_ex parse_cb, void *parse_arg)
#define SSL_CTRL_SESS_CB_HIT
void SSL_CTX_set_psk_server_callback(SSL_CTX *ctx, SSL_psk_server_cb_func cb)
int(*)(struct ssl_st *ssl, SSL_SESSION *sess) SSL_CTX_sess_get_new_cb(SSL_CTX *ctx)
#define SSL_SESS_CACHE_NO_INTERNAL_LOOKUP
void SSL_CTX_set_cookie_generate_cb(SSL_CTX *ctx, int(*app_gen_cookie_cb)(SSL *ssl, unsigned char *cookie, unsigned int *cookie_len))
#define SSL_VERIFY_CLIENT_ONCE
__owur int SSL_CTX_use_psk_identity_hint(SSL_CTX *ctx, const char *identity_hint)
#define SSL_CTRL_SET_CURRENT_CERT
#define SSL_get_peer_tmp_key(s, pk)
#define SSL_OP_CRYPTOPRO_TLSEXT_BUG
#define SSL_CTRL_SET_MAX_PROTO_VERSION
struct ssl_st * ssl_crock_st
int(* tls_session_ticket_ext_cb_fn)(SSL *s, const unsigned char *data, int len, void *arg)
#define DTLS_CTRL_GET_LINK_MIN_MTU
#define SSL_CTRL_SESS_CONNECT
#define DTLS_CTRL_GET_TIMEOUT
void SSL_CTX_set_info_callback(SSL_CTX *ctx, void(*cb)(const SSL *ssl, int type, int val))
uint32_t SSL_CTX_get_recv_max_early_data(const SSL_CTX *ctx)
unsigned long SSL_set_options(SSL *s, unsigned long op)
uint32_t SSL_get_max_early_data(const SSL *s)
#define SSL_CTRL_GET_PEER_TMP_KEY
#define SSL_CTRL_GET_GROUPS
#define SSL_CTRL_SESS_NUMBER
struct ssl_session_st SSL_SESSION
void SSL_CTX_set_next_protos_advertised_cb(SSL_CTX *s, SSL_CTX_npn_advertised_cb_func cb, void *arg)
void SSL_CTX_set_msg_callback(SSL_CTX *ctx, void(*cb)(int write_p, int version, int content_type, const void *buf, size_t len, SSL *ssl, void *arg))
#define SSL_OP_NO_TLSv1_2
#define SSL_CTX_set0_chain(ctx, sk)
#define SSL_CTRL_GET_EXTRA_CHAIN_CERTS
int(* SSL_CTX_alpn_select_cb_func)(SSL *ssl, const unsigned char **out, unsigned char *outlen, const unsigned char *in, unsigned int inlen, void *arg)
#define DTLS_CTRL_HANDLE_TIMEOUT
#define SSL_CTRL_SET_SESS_CACHE_MODE
#define SSL_CTRL_SET_CLIENT_SIGALGS_LIST
unsigned long SSL_get_options(const SSL *s)
#define SSL_CLIENT_HELLO_CB
void SSL_set_msg_callback(SSL *ssl, void(*cb)(int write_p, int version, int content_type, const void *buf, size_t len, SSL *ssl, void *arg))
void SSL_CTX_set_psk_use_session_callback(SSL_CTX *ctx, SSL_psk_use_session_cb_func cb)
int(*)(SSL *ssl, X509 **x509, EVP_PKEY **pkey) SSL_CTX_get_client_cert_cb(SSL_CTX *ctx)
unsigned long SSL_CTX_set_options(SSL_CTX *ctx, unsigned long op)
#define SSL_CTRL_GET_MIN_PROTO_VERSION
void(* custom_ext_free_cb)(SSL *s, unsigned int ext_type, const unsigned char *out, void *add_arg)
const char * SSL_get_psk_identity(const SSL *s)
#define SSL_CTRL_SESS_CACHE_FULL
#define SSL_CTRL_GET_MAX_CERT_LIST
void(*)(const SSL *ssl, int type, int val) SSL_CTX_get_info_callback(SSL_CTX *ctx)
const char * SSL_get_psk_identity_hint(const SSL *s)
#define SSL_CTRL_CLEAR_EXTRA_CHAIN_CERTS
int SSL_is_init_finished(const SSL *s)
#define SSL_CTRL_GET_MAX_PROTO_VERSION
#define SSL_CTRL_SELECT_CURRENT_CERT
#define SSL_CTRL_SESS_ACCEPT_GOOD
#define SSL_CTX_get_read_ahead(ctx)
#define SSL_CTRL_GET_SIGNATURE_NID
#define SSL_CTRL_SESS_ACCEPT_RENEGOTIATE
#define SSL_CTRL_SESS_MISSES
#define SSL_CTRL_SET_MSG_CALLBACK_ARG
int(* custom_ext_parse_cb)(SSL *s, unsigned int ext_type, const unsigned char *in, size_t inlen, int *al, void *parse_arg)
#define SSL_CTRL_SET_SIGALGS_LIST
SSL_CTX_keylog_cb_func SSL_CTX_get_keylog_callback(const SSL_CTX *ctx)
#define SSL_CTRL_SET_GROUPS_LIST
void SSL_set_psk_find_session_callback(SSL *s, SSL_psk_find_session_cb_func cb)
#define SSL_SESS_CACHE_SERVER
void SSL_CTX_set_keylog_callback(SSL_CTX *ctx, SSL_CTX_keylog_cb_func cb)
#define SSL_CTRL_SESS_CONNECT_RENEGOTIATE
#define SSL_CTRL_SET_GROUPS
#define SSL_CTRL_SET_MAX_CERT_LIST
#define SSL_CTRL_GET_EC_POINT_FORMATS
void(*)(struct ssl_ctx_st *ctx, SSL_SESSION *sess) SSL_CTX_sess_get_remove_cb(SSL_CTX *ctx)
#define SSL_SESS_CACHE_NO_INTERNAL_STORE
#define SSL_CTRL_SET_CLIENT_SIGALGS
int(* SSL_custom_ext_add_cb_ex)(SSL *s, unsigned int ext_type, unsigned int context, const unsigned char **out, size_t *outlen, X509 *x, size_t chainidx, int *al, void *add_arg)
void SSL_CTX_sess_set_get_cb(SSL_CTX *ctx, SSL_SESSION *(*get_session_cb)(struct ssl_st *ssl, const unsigned char *data, int len, int *copy))
#define SSL_CTRL_GET_SESS_CACHE_SIZE
#define SSL_CTRL_SET_MIN_PROTO_VERSION
unsigned long SSL_CTX_get_options(const SSL_CTX *ctx)
#define SSL_CTRL_BUILD_CERT_CHAIN
int(* tls_session_secret_cb_fn)(SSL *s, void *secret, int *secret_len, STACK_OF(SSL_CIPHER) *peer_ciphers, const SSL_CIPHER **cipher, void *arg)
__owur int SRP_Calc_A_param(SSL *s)
#define SSL_CTRL_CLEAR_MODE
struct tls_sigalgs_st TLS_SIGALGS
void SSL_CTX_set_psk_find_session_callback(SSL_CTX *ctx, SSL_psk_find_session_cb_func cb)
uint32_t SSL_CTX_get_max_early_data(const SSL_CTX *ctx)
unsigned long SSL_clear_options(SSL *s, unsigned long op)
int SSL_set_recv_max_early_data(SSL *s, uint32_t recv_max_early_data)
#define SSL_CTRL_SET_CHAIN_CERT_STORE
#define SSL_ASYNC_NO_JOBS
unsigned int(* SSL_psk_server_cb_func)(SSL *ssl, const char *identity, unsigned char *psk, unsigned int max_psk_len)
__owur int SSL_CTX_add_server_custom_ext(SSL_CTX *ctx, unsigned int ext_type, custom_ext_add_cb add_cb, custom_ext_free_cb free_cb, void *add_arg, custom_ext_parse_cb parse_cb, void *parse_arg)
void SSL_CTX_set_cookie_verify_cb(SSL_CTX *ctx, int(*app_verify_cookie_cb)(SSL *ssl, const unsigned char *cookie, unsigned int cookie_len))
#define SSL_CTRL_SET_MAX_PIPELINES
void(*)(const SSL *ssl, int type, int val) SSL_get_info_callback(const SSL *ssl)
#define SSL_library_init()
#define SSL_CTRL_CLEAR_NUM_RENEGOTIATIONS
__owur int SSL_CTX_SRP_CTX_init(SSL_CTX *ctx)
#define SSL_CTRL_SET_DH_AUTO
#define OPENSSL_INIT_LOAD_SSL_STRINGS
void SSL_CTX_set_alpn_select_cb(SSL_CTX *ctx, SSL_CTX_alpn_select_cb_func cb, void *arg)
int SSL_set_max_early_data(SSL *s, uint32_t max_early_data)
int(* custom_ext_add_cb)(SSL *s, unsigned int ext_type, const unsigned char **out, size_t *outlen, int *al, void *add_arg)
#define SSL_CTRL_GET_EXTMS_SUPPORT
int(* SSL_CTX_npn_select_cb_func)(SSL *s, unsigned char **out, unsigned char *outlen, const unsigned char *in, unsigned int inlen, void *arg)
#define SSL_OP_NO_TLSv1_1
#define SSL_SECOP_OTHER_SIGALG
#define SSL_set1_groups(s, glist, glistlen)
int SSL_CTX_SRP_CTX_free(SSL_CTX *ctx)
__owur int SSL_use_psk_identity_hint(SSL *s, const char *identity_hint)
#define SSL_SESS_CACHE_CLIENT
int(* SSL_verify_cb)(int preverify_ok, X509_STORE_CTX *x509_ctx)
void(* OPENSSL_sk_freefunc)(void *)
void * OPENSSL_sk_delete_ptr(OPENSSL_STACK *st, const void *p)
void * OPENSSL_sk_delete(OPENSSL_STACK *st, int loc)
int OPENSSL_sk_reserve(OPENSSL_STACK *st, int n)
void OPENSSL_sk_zero(OPENSSL_STACK *st)
OPENSSL_STACK * OPENSSL_sk_deep_copy(const OPENSSL_STACK *, OPENSSL_sk_copyfunc c, OPENSSL_sk_freefunc f)
int OPENSSL_sk_is_sorted(const OPENSSL_STACK *st)
OPENSSL_STACK * OPENSSL_sk_new(OPENSSL_sk_compfunc cmp)
OPENSSL_STACK * OPENSSL_sk_new_null(void)
struct stack_st OPENSSL_STACK
int OPENSSL_sk_find(OPENSSL_STACK *st, const void *data)
int(* OPENSSL_sk_compfunc)(const void *, const void *)
OPENSSL_sk_compfunc OPENSSL_sk_set_cmp_func(OPENSSL_STACK *sk, OPENSSL_sk_compfunc cmp)
OPENSSL_STACK * OPENSSL_sk_dup(const OPENSSL_STACK *st)
int OPENSSL_sk_insert(OPENSSL_STACK *sk, const void *data, int where)
void * OPENSSL_sk_set(OPENSSL_STACK *st, int i, const void *data)
int OPENSSL_sk_push(OPENSSL_STACK *st, const void *data)
int OPENSSL_sk_unshift(OPENSSL_STACK *st, const void *data)
void * OPENSSL_sk_pop(OPENSSL_STACK *st)
int OPENSSL_sk_find_ex(OPENSSL_STACK *st, const void *data)
int OPENSSL_sk_num(const OPENSSL_STACK *)
void *(* OPENSSL_sk_copyfunc)(const void *)
void OPENSSL_sk_pop_free(OPENSSL_STACK *st, void(*func)(void *))
void * OPENSSL_sk_shift(OPENSSL_STACK *st)
void OPENSSL_sk_sort(OPENSSL_STACK *st)
OPENSSL_STACK * OPENSSL_sk_new_reserve(OPENSSL_sk_compfunc c, int n)
void * OPENSSL_sk_value(const OPENSSL_STACK *, int)
void OPENSSL_sk_free(OPENSSL_STACK *)
std::function< void(bool, std::string)> callback
Family
Possible address families for socket addresses.
std::string privateKeyFile
Initializes the struct with default values.
std::string certificateFile
bool ocspStaplingVerification
VerificationMode verificationMode
static std::string escape(const std::string &s, bool strictJSON=false)
int(* check_trust)(struct x509_trust_st *, X509 *, int)
#define TLS1_AD_RECORD_OVERFLOW
#define TLS1_AD_EXPORT_RESTRICTION
#define TLS1_AD_UNKNOWN_CA
#define TLS13_AD_MISSING_EXTENSION
#define TLS1_AD_NO_RENEGOTIATION
#define TLS1_AD_BAD_CERTIFICATE_STATUS_RESPONSE
#define TLS1_AD_UNKNOWN_PSK_IDENTITY
#define TLS1_AD_INSUFFICIENT_SECURITY
#define TLS1_AD_PROTOCOL_VERSION
#define TLS1_AD_USER_CANCELLED
#define TLS1_AD_INTERNAL_ERROR
#define TLS1_AD_NO_APPLICATION_PROTOCOL
#define TLS1_AD_CERTIFICATE_UNOBTAINABLE
#define TLS1_AD_UNSUPPORTED_EXTENSION
#define TLS1_AD_ACCESS_DENIED
#define TLS1_AD_DECODE_ERROR
#define TLS1_AD_UNRECOGNIZED_NAME
#define TLS1_AD_DECRYPT_ERROR
#define TLS13_AD_CERTIFICATE_REQUIRED
#define TLS1_AD_INAPPROPRIATE_FALLBACK
#define TLS1_AD_DECRYPTION_FAILED
#define TLS1_AD_BAD_CERTIFICATE_HASH_VALUE
#define X509_FILETYPE_PEM
#define X509_FILETYPE_ASN1
struct X509_name_entry_st X509_NAME_ENTRY
#define XN_FLAG_DUMP_UNKNOWN_FIELDS
struct X509_req_info_st X509_REQ_INFO
struct X509_req_st X509_REQ
#define XN_FLAG_SEP_CPLUS_SPC
#define XN_FLAG_SEP_MULTILINE
struct x509_cinf_st X509_CINF
struct X509_sig_st X509_SIG
struct X509_extension_st X509_EXTENSION
struct x509_cert_aux_st X509_CERT_AUX
struct x509_attributes_st X509_ATTRIBUTE
#define XN_FLAG_SEP_COMMA_PLUS
int(*)(int, X509 *, int) X509_TRUST_set_default(int(*trust)(int, X509 *, int))