RetroArch
x509_crt.h
Go to the documentation of this file.
1 
23 #ifndef MBEDTLS_X509_CRT_H
24 #define MBEDTLS_X509_CRT_H
25 
26 #if !defined(MBEDTLS_CONFIG_FILE)
27 #include "config.h"
28 #else
29 #include MBEDTLS_CONFIG_FILE
30 #endif
31 
32 #include "x509.h"
33 #include "x509_crl.h"
34 
40 #ifdef __cplusplus
41 extern "C" {
42 #endif
43 
52 typedef struct mbedtls_x509_crt
53 {
57  int version;
77  int ext_types;
78  int ca_istrue;
81  unsigned int key_usage;
85  unsigned char ns_cert_type;
90  void *sig_opts;
93 }
95 
100 #define MBEDTLS_X509_ID_FLAG( id ) ( 1 << ( id - 1 ) )
101 
107 typedef struct
108 {
113 }
115 
116 #define MBEDTLS_X509_CRT_VERSION_1 0
117 #define MBEDTLS_X509_CRT_VERSION_2 1
118 #define MBEDTLS_X509_CRT_VERSION_3 2
119 
120 #define MBEDTLS_X509_RFC5280_MAX_SERIAL_LEN 32
121 #define MBEDTLS_X509_RFC5280_UTC_TIME_LEN 15
122 
123 #if !defined( MBEDTLS_X509_MAX_FILE_PATH_LEN )
124 #define MBEDTLS_X509_MAX_FILE_PATH_LEN 512
125 #endif
126 
131 {
132  int version;
142 }
144 
145 #if defined(MBEDTLS_X509_CRT_PARSE_C)
146 
151 
157 
162 
173 int mbedtls_x509_crt_parse_der( mbedtls_x509_crt *chain, const unsigned char *buf,
174  size_t buflen );
175 
191 int mbedtls_x509_crt_parse( mbedtls_x509_crt *chain, const unsigned char *buf, size_t buflen );
192 
193 #if defined(MBEDTLS_FS_IO)
194 
207 int mbedtls_x509_crt_parse_file( mbedtls_x509_crt *chain, const char *path );
208 
222 int mbedtls_x509_crt_parse_path( mbedtls_x509_crt *chain, const char *path );
223 #endif /* MBEDTLS_FS_IO */
224 
237 int mbedtls_x509_crt_info( char *buf, size_t size, const char *prefix,
238  const mbedtls_x509_crt *crt );
239 
252 int mbedtls_x509_crt_verify_info( char *buf, size_t size, const char *prefix,
253  uint32_t flags );
254 
300  mbedtls_x509_crt *trust_ca,
301  mbedtls_x509_crl *ca_crl,
302  const char *cn, uint32_t *flags,
303  int (*f_vrfy)(void *, mbedtls_x509_crt *, int, uint32_t *),
304  void *p_vrfy );
305 
334  mbedtls_x509_crt *trust_ca,
335  mbedtls_x509_crl *ca_crl,
336  const mbedtls_x509_crt_profile *profile,
337  const char *cn, uint32_t *flags,
338  int (*f_vrfy)(void *, mbedtls_x509_crt *, int, uint32_t *),
339  void *p_vrfy );
340 
341 #if defined(MBEDTLS_X509_CHECK_KEY_USAGE)
342 
364  unsigned int usage );
365 #endif /* MBEDTLS_X509_CHECK_KEY_USAGE) */
366 
367 #if defined(MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE)
368 
381  const char *usage_oid,
382  size_t usage_len );
383 #endif /* MBEDTLS_X509_CHECK_EXTENDED_KEY_USAGE) */
384 
385 #if defined(MBEDTLS_X509_CRL_PARSE_C)
386 
396 #endif /* MBEDTLS_X509_CRL_PARSE_C */
397 
404 
411 #endif /* MBEDTLS_X509_CRT_PARSE_C */
412 
413 /* \} name */
414 /* \} addtogroup x509_module */
415 
416 #if defined(MBEDTLS_X509_CRT_WRITE_C)
417 
423 
433 
443 
459  const char *not_after );
460 
474  const char *issuer_name );
475 
489  const char *subject_name );
490 
498 
506 
515 
530  const char *oid, size_t oid_len,
531  int critical,
532  const unsigned char *val, size_t val_len );
533 
546  int is_ca, int max_pathlen );
547 
548 #if defined(MBEDTLS_SHA1_C)
549 
559 
570 #endif /* MBEDTLS_SHA1_C */
571 
582  unsigned int key_usage );
583 
594  unsigned char ns_cert_type );
595 
602 
623 int mbedtls_x509write_crt_der( mbedtls_x509write_cert *ctx, unsigned char *buf, size_t size,
624  int (*f_rng)(void *, unsigned char *, size_t),
625  void *p_rng );
626 
627 #if defined(MBEDTLS_PEM_WRITE_C)
628 
644 int mbedtls_x509write_crt_pem( mbedtls_x509write_cert *ctx, unsigned char *buf, size_t size,
645  int (*f_rng)(void *, unsigned char *, size_t),
646  void *p_rng );
647 #endif /* MBEDTLS_PEM_WRITE_C */
648 #endif /* MBEDTLS_X509_CRT_WRITE_C */
649 
650 #ifdef __cplusplus
651 }
652 #endif
653 
654 #endif /* mbedtls_x509_crt.h */
GLsizeiptr const GLvoid GLenum usage
Definition: glext.h:6559
int mbedtls_x509_crt_verify_info(char *buf, size_t size, const char *prefix, uint32_t flags)
Returns an informational string about the verification status of a certificate.
Definition: x509_crt.c:1522
int ext_types
Definition: x509_crt.h:77
mbedtls_x509_buf subject_raw
Definition: x509_crt.h:62
GLuint GLfloat * val
Definition: glext.h:7847
void mbedtls_x509_crt_free(mbedtls_x509_crt *crt)
Unallocate all certificate data.
Definition: x509_crt.c:2329
void mbedtls_x509write_crt_set_issuer_key(mbedtls_x509write_cert *ctx, mbedtls_pk_context *key)
Set the issuer key used for signing the certificate.
Definition: x509write_crt.c:83
Definition: x509_crt.h:52
Configuration options (set of defines)
int mbedtls_x509write_crt_set_extension(mbedtls_x509write_cert *ctx, const char *oid, size_t oid_len, int critical, const unsigned char *val, size_t val_len)
Generic function to add to or replace an extension in the CRT.
Definition: x509write_crt.c:126
Definition: x509.h:206
int max_pathlen
Definition: x509_crt.h:79
mbedtls_x509_buf sig_oid
Definition: x509_crt.h:59
mbedtls_x509_time valid_to
Definition: x509_crt.h:68
GLenum GLuint GLenum GLsizei const GLchar * buf
Definition: glext.h:8418
void mbedtls_x509write_crt_set_version(mbedtls_x509write_cert *ctx, int version)
Set the verion for a Certificate Default: MBEDTLS_X509_CRT_VERSION_3.
Definition: x509write_crt.c:68
int mbedtls_x509write_crt_der(mbedtls_x509write_cert *ctx, unsigned char *buf, size_t size, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng)
Write a built up certificate to a X509 DER structure Note: data is written at the end of the buffer!...
Definition: x509write_crt.c:292
GLsizei const GLchar ** path
Definition: glext.h:7901
int mbedtls_x509write_crt_set_key_usage(mbedtls_x509write_cert *ctx, unsigned int key_usage)
Set the Key Usage Extension flags (e.g. MBEDTLS_X509_KU_DIGITAL_SIGNATURE | MBEDTLS_X509_KU_KEY_CERT_...
Definition: x509write_crt.c:216
uint32_t allowed_curves
Definition: x509_crt.h:111
GLsizeiptr size
Definition: glext.h:6559
mbedtls_asn1_named_data * issuer
Definition: x509_crt.h:137
Definition: x509_crt.h:130
void mbedtls_x509write_crt_set_md_alg(mbedtls_x509write_cert *ctx, mbedtls_md_type_t md_alg)
Set the MD algorithm to use for the signature (e.g. MBEDTLS_MD_SHA1)
Definition: x509write_crt.c:73
mbedtls_x509_buf sig
Definition: x509_crt.h:87
mbedtls_x509_time valid_from
Definition: x509_crt.h:67
int mbedtls_x509_crt_is_revoked(const mbedtls_x509_crt *crt, const mbedtls_x509_crl *crl)
Verify the certificate revocation status.
Definition: x509_crt.c:1611
mbedtls_md_type_t sig_md
Definition: x509_crt.h:88
int mbedtls_x509write_crt_set_ns_cert_type(mbedtls_x509write_cert *ctx, unsigned char ns_cert_type)
Set the Netscape Cert Type flags (e.g. MBEDTLS_X509_NS_CERT_TYPE_SSL_CLIENT | MBEDTLS_X509_NS_CERT_TY...
Definition: x509write_crt.c:242
int mbedtls_x509write_crt_pem(mbedtls_x509write_cert *ctx, unsigned char *buf, size_t size, int(*f_rng)(void *, unsigned char *, size_t), void *p_rng)
Write a built up certificate to a X509 PEM string.
Definition: x509write_crt.c:431
Definition: asn1.h:118
int mbedtls_x509write_crt_set_basic_constraints(mbedtls_x509write_cert *ctx, int is_ca, int max_pathlen)
Set the basicConstraints extension for a CRT.
Definition: x509write_crt.c:135
struct mbedtls_x509_crt * next
Definition: x509_crt.h:92
mbedtls_pk_context * issuer_key
Definition: x509_crt.h:135
char not_after[MBEDTLS_X509_RFC5280_UTC_TIME_LEN+1]
Definition: x509_crt.h:140
mbedtls_md_type_t
Definition: md.h:39
mbedtls_md_type_t md_alg
Definition: x509_crt.h:138
mbedtls_pk_type_t
Public key types.
Definition: pk.h:71
int mbedtls_x509write_crt_set_issuer_name(mbedtls_x509write_cert *ctx, const char *issuer_name)
Set the issuer name for a Certificate Issuer names should contain a comma-separated list of OID types...
Definition: x509write_crt.c:94
int mbedtls_x509_crt_parse_file(mbedtls_x509_crt *chain, const char *path)
Load one or more certificates and add them to the chained list. Parses permissively....
Definition: x509_crt.c:1084
struct mbedtls_x509_crt mbedtls_x509_crt
int ca_istrue
Definition: x509_crt.h:78
int mbedtls_x509write_crt_set_validity(mbedtls_x509write_cert *ctx, const char *not_before, const char *not_after)
Set the validity period for a Certificate Timestamps should be in string format for UTC timezone i....
Definition: x509write_crt.c:110
mbedtls_pk_context * subject_key
Definition: x509_crt.h:134
AVFormatContext * ctx
Definition: record_ffmpeg.c:247
version
Definition: setup.py:6
char not_before[MBEDTLS_X509_RFC5280_UTC_TIME_LEN+1]
Definition: x509_crt.h:139
mbedtls_asn1_named_data * subject
Definition: x509_crt.h:136
int mbedtls_x509_crt_parse_der(mbedtls_x509_crt *chain, const unsigned char *buf, size_t buflen)
Parse a single DER formatted certificate and add it to the chained list.
Definition: x509_crt.c:918
mbedtls_x509_buf issuer_raw
Definition: x509_crt.h:61
mbedtls_x509_name issuer
Definition: x509_crt.h:64
int mbedtls_x509_crt_info(char *buf, size_t size, const char *prefix, const mbedtls_x509_crt *crt)
Returns an informational string about the certificate.
Definition: x509_crt.c:1361
mbedtls_x509_name subject
Definition: x509_crt.h:65
int mbedtls_x509write_crt_set_authority_key_identifier(mbedtls_x509write_cert *ctx)
Set the authorityKeyIdentifier extension for a CRT Requires that mbedtls_x509write_crt_set_issuer_key...
Definition: x509write_crt.c:189
int version
Definition: x509_crt.h:132
int mbedtls_x509write_crt_set_subject_name(mbedtls_x509write_cert *ctx, const char *subject_name)
Set the subject name for a Certificate Subject names should contain a comma-separated list of OID typ...
Definition: x509write_crt.c:88
const mbedtls_x509_crt_profile mbedtls_x509_crt_profile_suiteb
Definition: x509_crt.c:127
int mbedtls_x509_crt_verify(mbedtls_x509_crt *crt, mbedtls_x509_crt *trust_ca, mbedtls_x509_crl *ca_crl, const char *cn, uint32_t *flags, int(*f_vrfy)(void *, mbedtls_x509_crt *, int, uint32_t *), void *p_vrfy)
Verify the certificate signature.
Definition: x509_crt.c:2177
int mbedtls_x509_crt_check_extended_key_usage(const mbedtls_x509_crt *crt, const char *usage_oid, size_t usage_len)
Check usage of certificate against extentedJeyUsage.
Definition: x509_crt.c:1576
Definition: asn1.h:140
mbedtls_x509_buf issuer_id
Definition: x509_crt.h:72
int mbedtls_x509write_crt_set_subject_key_identifier(mbedtls_x509write_cert *ctx)
Set the subjectKeyIdentifier extension for a CRT Requires that mbedtls_x509write_crt_set_subject_key(...
Definition: x509write_crt.c:167
uint32_t allowed_pks
Definition: x509_crt.h:110
int version
Definition: x509_crt.h:57
mbedtls_x509_sequence subject_alt_names
Definition: x509_crt.h:75
void mbedtls_x509_crt_init(mbedtls_x509_crt *crt)
Initialize a certificate (chain)
Definition: x509_crt.c:2321
mbedtls_x509_sequence ext_key_usage
Definition: x509_crt.h:83
const mbedtls_x509_crt_profile mbedtls_x509_crt_profile_next
Definition: x509_crt.c:102
mbedtls_pk_type_t sig_pk
Definition: x509_crt.h:89
mbedtls_x509_buf v3_ext
Definition: x509_crt.h:74
int mbedtls_x509_crt_check_key_usage(const mbedtls_x509_crt *crt, unsigned int usage)
Check usage of certificate against keyUsage extension.
Definition: x509_crt.c:1551
MPI structure.
Definition: bignum.h:179
Definition: x509_crl.h:69
void mbedtls_x509write_crt_free(mbedtls_x509write_cert *ctx)
Free the contents of a CRT write context.
Definition: x509write_crt.c:57
mbedtls_x509_buf tbs
Definition: x509_crt.h:55
void mbedtls_x509write_crt_set_subject_key(mbedtls_x509write_cert *ctx, mbedtls_pk_context *key)
Set the subject public key for the certificate.
Definition: x509write_crt.c:78
unsigned int key_usage
Definition: x509_crt.h:81
void mbedtls_x509write_crt_init(mbedtls_x509write_cert *ctx)
Initialize a CRT writing context.
Definition: x509write_crt.c:49
mbedtls_x509_buf subject_id
Definition: x509_crt.h:73
Public key container.
Definition: pk.h:123
mbedtls_pk_context pk
Definition: x509_crt.h:70
struct mbedtls_x509write_cert mbedtls_x509write_cert
int mbedtls_x509_crt_parse_path(mbedtls_x509_crt *chain, const char *path)
Load one or more certificate files from a path and add them to the chained list. Parses permissively....
Definition: x509_crt.c:1101
Definition: asn1.h:150
#define MBEDTLS_X509_RFC5280_UTC_TIME_LEN
Definition: x509_crt.h:121
X.509 certificate revocation list parsing.
void * sig_opts
Definition: x509_crt.h:90
mbedtls_asn1_named_data * extensions
Definition: x509_crt.h:141
uint32_t rsa_min_bitlen
Definition: x509_crt.h:112
int mbedtls_x509_crt_parse(mbedtls_x509_crt *chain, const unsigned char *buf, size_t buflen)
Parse one or more certificates and add them to the chained list. Parses permissively....
Definition: x509_crt.c:969
uint32_t allowed_mds
Definition: x509_crt.h:109
int mbedtls_x509write_crt_set_serial(mbedtls_x509write_cert *ctx, const mbedtls_mpi *serial)
Set the serial number for a Certificate.
Definition: x509write_crt.c:100
int mbedtls_x509_crt_verify_with_profile(mbedtls_x509_crt *crt, mbedtls_x509_crt *trust_ca, mbedtls_x509_crl *ca_crl, const mbedtls_x509_crt_profile *profile, const char *cn, uint32_t *flags, int(*f_vrfy)(void *, mbedtls_x509_crt *, int, uint32_t *), void *p_vrfy)
Verify the certificate signature according to profile.
Definition: x509_crt.c:2192
GLbitfield flags
Definition: glext.h:7828
mbedtls_x509_buf serial
Definition: x509_crt.h:58
X.509 generic defines and structures.
mbedtls_x509_buf raw
Definition: x509_crt.h:54
unsigned int uint32_t
Definition: stdint.h:126
mbedtls_mpi serial
Definition: x509_crt.h:133
unsigned char ns_cert_type
Definition: x509_crt.h:85
Definition: x509_crt.h:107
const mbedtls_x509_crt_profile mbedtls_x509_crt_profile_default
Definition: x509_crt.c:83