2
3
4
5
6
7
8
9
14# include <openssl/e_os2.h>
15# include <openssl/ossl_typ.h>
16# include <openssl/symhacks.h>
17# include <openssl/buffer.h>
18# include <openssl/evp.h>
19# include <openssl/bio.h>
20# include <openssl/asn1.h>
21# include <openssl/safestack.h>
22# include <openssl/ec.h>
25# include <openssl/rsa.h>
26# include <openssl/dsa.h>
27# include <openssl/dh.h>
30# include <openssl/sha.h>
31# include <openssl/x509err.h>
40# define X509_SIG_INFO_VALID 0x1
42# define X509_SIG_INFO_TLS 0x2
44# define X509_FILETYPE_PEM 1
45# define X509_FILETYPE_ASN1 2
46# define X509_FILETYPE_DEFAULT 3
48# define X509v3_KU_DIGITAL_SIGNATURE 0x0080
49# define X509v3_KU_NON_REPUDIATION 0x0040
50# define X509v3_KU_KEY_ENCIPHERMENT 0x0020
51# define X509v3_KU_DATA_ENCIPHERMENT 0x0010
52# define X509v3_KU_KEY_AGREEMENT 0x0008
53# define X509v3_KU_KEY_CERT_SIGN 0x0004
54# define X509v3_KU_CRL_SIGN 0x0002
55# define X509v3_KU_ENCIPHER_ONLY 0x0001
56# define X509v3_KU_DECIPHER_ONLY 0x8000
57# define X509v3_KU_UNDEF 0xffff
79# define X509_EX_V_NETSCAPE_HACK 0x8000
80# define X509_EX_V_INIT 0x0001
83typedef STACK_OF(X509_EXTENSION) X509_EXTENSIONS;
116# define X509_TRUST_DEFAULT 0
118# define X509_TRUST_COMPAT 1
119# define X509_TRUST_SSL_CLIENT 2
120# define X509_TRUST_SSL_SERVER 3
121# define X509_TRUST_EMAIL 4
122# define X509_TRUST_OBJECT_SIGN 5
123# define X509_TRUST_OCSP_SIGN 6
124# define X509_TRUST_OCSP_REQUEST 7
125# define X509_TRUST_TSA 8
128# define X509_TRUST_MIN 1
129# define X509_TRUST_MAX 8
132# define X509_TRUST_DYNAMIC (1U
<< 0
)
133# define X509_TRUST_DYNAMIC_NAME (1U
<< 1
)
135# define X509_TRUST_NO_SS_COMPAT (1U
<< 2
)
137# define X509_TRUST_DO_SS_COMPAT (1U
<< 3
)
139# define X509_TRUST_OK_ANY_EKU (1U
<< 4
)
143# define X509_TRUST_TRUSTED 1
144# define X509_TRUST_REJECTED 2
145# define X509_TRUST_UNTRUSTED 3
149# define X509_FLAG_COMPAT 0
150# define X509_FLAG_NO_HEADER 1L
151# define X509_FLAG_NO_VERSION (1L
<< 1
)
152# define X509_FLAG_NO_SERIAL (1L
<< 2
)
153# define X509_FLAG_NO_SIGNAME (1L
<< 3
)
154# define X509_FLAG_NO_ISSUER (1L
<< 4
)
155# define X509_FLAG_NO_VALIDITY (1L
<< 5
)
156# define X509_FLAG_NO_SUBJECT (1L
<< 6
)
157# define X509_FLAG_NO_PUBKEY (1L
<< 7
)
158# define X509_FLAG_NO_EXTENSIONS (1L
<< 8
)
159# define X509_FLAG_NO_SIGDUMP (1L
<< 9
)
160# define X509_FLAG_NO_AUX (1L
<< 10
)
161# define X509_FLAG_NO_ATTRIBUTES (1L
<< 11
)
162# define X509_FLAG_NO_IDS (1L
<< 12
)
168# define XN_FLAG_SEP_MASK (0xf
<< 16
)
170# define XN_FLAG_COMPAT 0
171# define XN_FLAG_SEP_COMMA_PLUS (1
<< 16
)
172# define XN_FLAG_SEP_CPLUS_SPC (2
<< 16
)
173# define XN_FLAG_SEP_SPLUS_SPC (3
<< 16
)
174# define XN_FLAG_SEP_MULTILINE (4
<< 16
)
176# define XN_FLAG_DN_REV (1
<< 20
)
180# define XN_FLAG_FN_MASK (0x3
<< 21
)
182# define XN_FLAG_FN_SN 0
183# define XN_FLAG_FN_LN (1
<< 21
)
184# define XN_FLAG_FN_OID (2
<< 21
)
185# define XN_FLAG_FN_NONE (3
<< 21
)
187# define XN_FLAG_SPC_EQ (1
<< 23
)
190
191
192
194# define XN_FLAG_DUMP_UNKNOWN_FIELDS (1
<< 24
)
196# define XN_FLAG_FN_ALIGN (1
<< 25
)
197
226typedef struct X509_crl_info_st X509_CRL_INFO;
230typedef struct private_key_st {
242 EVP_CIPHER_INFO cipher;
245typedef struct X509_info_st {
249 EVP_CIPHER_INFO enc_cipher;
257
258
260typedef struct Netscape_spkac_st {
265typedef struct Netscape_spki_st {
266 NETSCAPE_SPKAC *spkac;
272typedef struct Netscape_certificate_sequence {
275} NETSCAPE_CERT_SEQUENCE;
278
279
280
281
282
286typedef struct PBEPARAM_st {
293typedef struct PBE2PARAM_st {
298typedef struct PBKDF2PARAM_st {
306#ifndef OPENSSL_NO_SCRYPT
307typedef struct SCRYPT_PARAMS_st {
320# include <openssl/x509_vfy.h>
321# include <openssl/pkcs7.h>
327# define X509_EXT_PACK_UNKNOWN 1
328# define X509_EXT_PACK_STRING 2
330# define X509_extract_key(x) X509_get_pubkey(x)
331# define X509_REQ_extract_key(a) X509_REQ_get_pubkey(a)
332# define X509_name_cmp(a,b) X509_NAME_cmp((a),(b))
345void X509_CRL_set_meth_data(
X509_CRL *crl,
void *dat);
346void *X509_CRL_get_meth_data(
X509_CRL *crl);
348const char *X509_verify_cert_error_string(
long n);
354int NETSCAPE_SPKI_verify(NETSCAPE_SPKI *a,
EVP_PKEY *r);
356NETSCAPE_SPKI *NETSCAPE_SPKI_b64_decode(
const char *str,
int len);
357char *NETSCAPE_SPKI_b64_encode(NETSCAPE_SPKI *x);
358EVP_PKEY *NETSCAPE_SPKI_get_pubkey(NETSCAPE_SPKI *x);
359int NETSCAPE_SPKI_set_pubkey(NETSCAPE_SPKI *x,
EVP_PKEY *pkey);
361int NETSCAPE_SPKI_print(
BIO *out, NETSCAPE_SPKI *spki);
369# ifndef OPENSSL_NO_OCSP
376# ifndef OPENSSL_NO_OCSP
379int NETSCAPE_SPKI_sign(NETSCAPE_SPKI *x,
EVP_PKEY *pkey,
const EVP_MD *md);
381int X509_pubkey_digest(
const X509 *data,
const EVP_MD *type,
382 unsigned char *md,
unsigned int *len);
383int X509_digest(
const X509 *data,
const EVP_MD *type,
384 unsigned char *md,
unsigned int *len);
386 unsigned char *md,
unsigned int *len);
388 unsigned char *md,
unsigned int *len);
390 unsigned char *md,
unsigned int *len);
392# ifndef OPENSSL_NO_STDIO
394int i2d_X509_fp(FILE *fp,
X509 *x509);
398int i2d_X509_REQ_fp(FILE *fp,
X509_REQ *req);
399# ifndef OPENSSL_NO_RSA
400RSA *d2i_RSAPrivateKey_fp(FILE *fp,
RSA **rsa);
401int i2d_RSAPrivateKey_fp(FILE *fp,
RSA *rsa);
402RSA *d2i_RSAPublicKey_fp(FILE *fp,
RSA **rsa);
403int i2d_RSAPublicKey_fp(FILE *fp,
RSA *rsa);
404RSA *d2i_RSA_PUBKEY_fp(FILE *fp,
RSA **rsa);
405int i2d_RSA_PUBKEY_fp(FILE *fp,
RSA *rsa);
407# ifndef OPENSSL_NO_DSA
408DSA *d2i_DSA_PUBKEY_fp(FILE *fp,
DSA **dsa);
409int i2d_DSA_PUBKEY_fp(FILE *fp,
DSA *dsa);
410DSA *d2i_DSAPrivateKey_fp(FILE *fp,
DSA **dsa);
411int i2d_DSAPrivateKey_fp(FILE *fp,
DSA *dsa);
413# ifndef OPENSSL_NO_EC
415int i2d_EC_PUBKEY_fp(FILE *fp,
EC_KEY *eckey);
417int i2d_ECPrivateKey_fp(FILE *fp,
EC_KEY *eckey);
424int i2d_PKCS8PrivateKeyInfo_fp(FILE *fp,
EVP_PKEY *key);
437# ifndef OPENSSL_NO_RSA
439int i2d_RSAPrivateKey_bio(
BIO *bp,
RSA *rsa);
441int i2d_RSAPublicKey_bio(
BIO *bp,
RSA *rsa);
443int i2d_RSA_PUBKEY_bio(
BIO *bp,
RSA *rsa);
445# ifndef OPENSSL_NO_DSA
447int i2d_DSA_PUBKEY_bio(
BIO *bp,
DSA *dsa);
449int i2d_DSAPrivateKey_bio(
BIO *bp,
DSA *dsa);
451# ifndef OPENSSL_NO_EC
455int i2d_ECPrivateKey_bio(
BIO *bp,
EC_KEY *eckey);
477void X509_ALGOR_get0(
const ASN1_OBJECT **paobj,
int *pptype,
490 int offset_day,
long offset_sec, time_t *t);
493const char *X509_get_default_cert_area(
void);
494const char *X509_get_default_cert_dir(
void);
495const char *X509_get_default_cert_file(
void);
496const char *X509_get_default_cert_dir_env(
void);
497const char *X509_get_default_cert_file_env(
void);
498const char *X509_get_default_private_dir(
void);
516# ifndef OPENSSL_NO_RSA
517int i2d_RSA_PUBKEY(
RSA *a,
unsigned char **pp);
518RSA *d2i_RSA_PUBKEY(
RSA **a,
const unsigned char **pp,
long length);
520# ifndef OPENSSL_NO_DSA
521int i2d_DSA_PUBKEY(
DSA *a,
unsigned char **pp);
522DSA *d2i_DSA_PUBKEY(
DSA **a,
const unsigned char **pp,
long length);
524# ifndef OPENSSL_NO_EC
525int i2d_EC_PUBKEY(
EC_KEY *a,
unsigned char **pp);
526EC_KEY *d2i_EC_PUBKEY(
EC_KEY **a,
const unsigned char **pp,
long length);
539X509_ATTRIBUTE *X509_ATTRIBUTE_create(
int nid,
int atrtype,
void *value);
555#define X509_get_ex_new_index(l, p, newf, dupf, freef)
557int X509_set_ex_data(
X509 *r,
int idx,
void *arg);
558void *X509_get_ex_data(
X509 *r,
int idx);
559int i2d_X509_AUX(
X509 *a,
unsigned char **pp);
560X509 *d2i_X509_AUX(
X509 **a,
const unsigned char **pp,
long length);
562int i2d_re_X509_tbs(
X509 *x,
unsigned char **pp);
564int X509_SIG_INFO_get(
const X509_SIG_INFO *siginf,
int *mdnid,
int *pknid,
565 int *secbits, uint32_t *flags);
566void X509_SIG_INFO_set(
X509_SIG_INFO *siginf,
int mdnid,
int pknid,
567 int secbits, uint32_t flags);
569int X509_get_signature_info(
X509 *x,
int *mdnid,
int *pknid,
int *secbits,
574int X509_get_signature_nid(
const X509 *x);
576int X509_trusted(
const X509 *x);
577int X509_alias_set1(
X509 *x,
const unsigned char *name,
int len);
578int X509_keyid_set1(
X509 *x,
const unsigned char *id,
int len);
579unsigned char *X509_alias_get0(
X509 *x,
int *len);
580unsigned char *X509_keyid_get0(
X509 *x,
int *
len);
581int (*X509_TRUST_set_default(
int (*trust) (
int, X509 *,
int))) (
int,
X509 *,
583int X509_TRUST_set(
int *t,
int trust);
587void X509_reject_clear(
X509 *x);
590STACK_OF(ASN1_OBJECT) *X509_get0_reject_objects(
X509 *x);
597int X509_CRL_get0_by_serial(
X509_CRL *crl,
601X509_PKEY *X509_PKEY_new(
void);
602void X509_PKEY_free(X509_PKEY *a);
608X509_INFO *X509_INFO_new(
void);
609void X509_INFO_free(X509_INFO *a);
610char *X509_NAME_oneline(
const X509_NAME *a,
char *buf,
int size);
612int ASN1_verify(i2d_of_void *i2d,
X509_ALGOR *algor1,
615int ASN1_digest(i2d_of_void *i2d,
const EVP_MD *type,
char *data,
616 unsigned char *md,
unsigned int *len);
618int ASN1_sign(i2d_of_void *i2d,
X509_ALGOR *algor1,
622int ASN1_item_digest(
const ASN1_ITEM *it,
const EVP_MD *type,
void *data,
623 unsigned char *md,
unsigned int *len);
635long X509_get_version(
const X509 *x);
636int X509_set_version(
X509 *x,
long version);
652int X509_get_signature_type(
const X509 *x);
655# define X509_get_notBefore X509_getm_notBefore
656# define X509_get_notAfter X509_getm_notAfter
657# define X509_set_notBefore X509_set1_notBefore
658# define X509_set_notAfter X509_set1_notAfter
663
664
675int X509_certificate_type(
const X509 *x,
const EVP_PKEY *pubkey);
678int X509_REQ_set_version(
X509_REQ *x,
long version);
685int X509_REQ_get_signature_nid(
const X509_REQ *req);
686int i2d_re_X509_REQ_tbs(
X509_REQ *req,
unsigned char **pp);
691int X509_REQ_extension_nid(
int nid);
692int *X509_REQ_get_extension_nids(
void);
693void X509_REQ_set_extension_nids(
int *nids);
695int X509_REQ_add_extensions_nid(
X509_REQ *req,
STACK_OF(X509_EXTENSION) *exts,
699int X509_REQ_get_attr_by_NID(
const X509_REQ *req,
int nid,
int lastpos);
705int X509_REQ_add1_attr_by_OBJ(
X509_REQ *req,
707 const unsigned char *bytes,
int len);
708int X509_REQ_add1_attr_by_NID(
X509_REQ *req,
710 const unsigned char *bytes,
int len);
711int X509_REQ_add1_attr_by_txt(
X509_REQ *req,
712 const char *attrname,
int type,
713 const unsigned char *bytes,
int len);
715int X509_CRL_set_version(
X509_CRL *x,
long version);
723# define X509_CRL_set_lastUpdate X509_CRL_set1_lastUpdate
724# define X509_CRL_set_nextUpdate X509_CRL_set1_nextUpdate
737int X509_CRL_get_signature_nid(
const X509_CRL *crl);
738int i2d_re_X509_CRL_tbs(
X509_CRL *req,
unsigned char **pp);
753int X509_chain_check_suiteb(
int *perror_depth,
755 unsigned long flags);
759int X509_issuer_and_serial_cmp(
const X509 *a,
const X509 *b);
760unsigned long X509_issuer_and_serial_hash(
X509 *a);
762int X509_issuer_name_cmp(
const X509 *a,
const X509 *b);
763unsigned long X509_issuer_name_hash(
X509 *a);
765int X509_subject_name_cmp(
const X509 *a,
const X509 *b);
766unsigned long X509_subject_name_hash(
X509 *x);
768# ifndef OPENSSL_NO_MD5
769unsigned long X509_issuer_name_hash_old(
X509 *a);
770unsigned long X509_subject_name_hash_old(
X509 *x);
776unsigned long X509_NAME_hash_old(
X509_NAME *x);
780int X509_aux_print(
BIO *out,
X509 *x,
int indent);
781# ifndef OPENSSL_NO_STDIO
782int X509_print_ex_fp(FILE *bp,
X509 *x,
unsigned long nmflag,
783 unsigned long cflag);
784int X509_print_fp(FILE *bp,
X509 *x);
787int X509_NAME_print_ex_fp(FILE *fp,
const X509_NAME *nm,
int indent,
788 unsigned long flags);
792int X509_NAME_print_ex(
BIO *out,
const X509_NAME *nm,
int indent,
793 unsigned long flags);
794int X509_print_ex(
BIO *bp,
X509 *x,
unsigned long nmflag,
795 unsigned long cflag);
798int X509_CRL_print_ex(
BIO *out,
X509_CRL *x,
unsigned long nmflag);
800int X509_REQ_print_ex(
BIO *bp,
X509_REQ *x,
unsigned long nmflag,
801 unsigned long cflag);
805int X509_NAME_get_text_by_NID(
X509_NAME *name,
int nid,
char *buf,
int len);
810
811
813int X509_NAME_get_index_by_NID(
X509_NAME *name,
int nid,
int lastpos);
821 const unsigned char *bytes,
int len,
int loc,
823int X509_NAME_add_entry_by_NID(
X509_NAME *name,
int nid,
int type,
824 const unsigned char *bytes,
int len,
int loc,
827 const char *field,
int type,
828 const unsigned char *bytes,
832 const unsigned char *bytes,
834int X509_NAME_add_entry_by_txt(
X509_NAME *name,
const char *field,
int type,
835 const unsigned char *bytes,
int len,
int loc,
839 const unsigned char *bytes,
843 const unsigned char *bytes,
int len);
848int X509_NAME_get0_der(
X509_NAME *nm,
const unsigned char **pder,
851int X509v3_get_ext_count(
const STACK_OF(X509_EXTENSION) *x);
852int X509v3_get_ext_by_NID(
const STACK_OF(X509_EXTENSION) *x,
853 int nid,
int lastpos);
854int X509v3_get_ext_by_OBJ(
const STACK_OF(X509_EXTENSION) *x,
856int X509v3_get_ext_by_critical(
const STACK_OF(X509_EXTENSION) *x,
857 int crit,
int lastpos);
863int X509_get_ext_count(
const X509 *x);
864int X509_get_ext_by_NID(
const X509 *x,
int nid,
int lastpos);
866int X509_get_ext_by_critical(
const X509 *x,
int crit,
int lastpos);
870void *X509_get_ext_d2i(
const X509 *x,
int nid,
int *crit,
int *idx);
871int X509_add1_ext_i2d(
X509 *x,
int nid,
void *value,
int crit,
872 unsigned long flags);
875int X509_CRL_get_ext_by_NID(
const X509_CRL *x,
int nid,
int lastpos);
878int X509_CRL_get_ext_by_critical(
const X509_CRL *x,
int crit,
int lastpos);
882void *X509_CRL_get_ext_d2i(
const X509_CRL *x,
int nid,
int *crit,
int *idx);
883int X509_CRL_add1_ext_i2d(
X509_CRL *x,
int nid,
void *value,
int crit,
884 unsigned long flags);
887int X509_REVOKED_get_ext_by_NID(
const X509_REVOKED *x,
int nid,
int lastpos);
890int X509_REVOKED_get_ext_by_critical(
const X509_REVOKED *x,
int crit,
895void *X509_REVOKED_get_ext_d2i(
const X509_REVOKED *x,
int nid,
int *crit,
897int X509_REVOKED_add1_ext_i2d(
X509_REVOKED *x,
int nid,
void *value,
int crit,
898 unsigned long flags);
913int X509at_get_attr_count(
const STACK_OF(X509_ATTRIBUTE) *x);
914int X509at_get_attr_by_NID(
const STACK_OF(X509_ATTRIBUTE) *x,
int nid,
916int X509at_get_attr_by_OBJ(
const STACK_OF(X509_ATTRIBUTE) *sk,
925 const unsigned char *bytes,
928 **x,
int nid,
int type,
929 const unsigned char *bytes,
932 **x,
const char *attrname,
934 const unsigned char *bytes,
936void *X509at_get0_data_by_OBJ(
const STACK_OF(X509_ATTRIBUTE) *x,
939 int atrtype,
const void *data,
943 int atrtype,
const void *data,
946 const char *atrname,
int type,
947 const unsigned char *bytes,
951 const void *data,
int len);
952void *X509_ATTRIBUTE_get0_data(
X509_ATTRIBUTE *attr,
int idx,
int atrtype,
956ASN1_TYPE *X509_ATTRIBUTE_get0_type(
X509_ATTRIBUTE *attr,
int idx);
959int EVP_PKEY_get_attr_by_NID(
const EVP_PKEY *key,
int nid,
int lastpos);
965int EVP_PKEY_add1_attr_by_OBJ(
EVP_PKEY *key,
967 const unsigned char *bytes,
int len);
968int EVP_PKEY_add1_attr_by_NID(
EVP_PKEY *key,
970 const unsigned char *bytes,
int len);
971int EVP_PKEY_add1_attr_by_txt(
EVP_PKEY *key,
972 const char *attrname,
int type,
973 const unsigned char *bytes,
int len);
985#ifndef OPENSSL_NO_SCRYPT
989int PKCS5_pbe_set0_algor(
X509_ALGOR *algor,
int alg,
int iter,
990 const unsigned char *salt,
int saltlen);
993 const unsigned char *salt,
int saltlen);
995 unsigned char *salt,
int saltlen);
997 unsigned char *salt,
int saltlen,
998 unsigned char *aiv,
int prf_nid);
1000#ifndef OPENSSL_NO_SCRYPT
1002 const unsigned char *salt,
int saltlen,
1003 unsigned char *aiv, uint64_t N, uint64_t r,
1007X509_ALGOR *PKCS5_pbkdf2_set(
int iter,
unsigned char *salt,
int saltlen,
1008 int prf_nid,
int keylen);
1018 int version,
int ptype,
void *pval,
1019 unsigned char *penc,
int penclen);
1021 const unsigned char **pk,
int *ppklen,
1027 const unsigned char *bytes,
int len);
1030 int ptype,
void *pval,
1031 unsigned char *penc,
int penclen);
1033 const unsigned char **pk,
int *ppklen,
1036int X509_check_trust(
X509 *x,
int id,
int flags);
1037int X509_TRUST_get_count(
void);
1038X509_TRUST *X509_TRUST_get0(
int idx);
1039int X509_TRUST_get_by_id(
int id);
1040int X509_TRUST_add(
int id,
int flags,
int (*ck) (X509_TRUST *,
X509 *,
int),
1041 const char *name,
int arg1,
void *arg2);
1042void X509_TRUST_cleanup(
void);
1043int X509_TRUST_get_flags(
const X509_TRUST *xp);
1044char *X509_TRUST_get0_name(
const X509_TRUST *xp);
1045int X509_TRUST_get_trust(
const X509_TRUST *xp);
#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_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_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)
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)
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)
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)
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
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)
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)
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)
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))