wolfSSL SSL/TLS library, support up to TLS1.3

Dependents:   CyaSSL-Twitter-OAuth4Tw Example-client-tls-cert TwitterReader TweetTest ... more

Committer:
wolfSSL
Date:
Thu Jun 04 23:57:22 2020 +0000
Revision:
16:8e0d178b1d1e
Parent:
3:6f956bdb3073
wolfSSL 4.4.0

Who changed what in which revision?

UserRevisionLine numberNew contents of line
wolfSSL 16:8e0d178b1d1e 1 /* x509v3.h
wolfSSL 16:8e0d178b1d1e 2 *
wolfSSL 16:8e0d178b1d1e 3 * Copyright (C) 2006-2020 wolfSSL Inc.
wolfSSL 16:8e0d178b1d1e 4 *
wolfSSL 16:8e0d178b1d1e 5 * This file is part of wolfSSL.
wolfSSL 16:8e0d178b1d1e 6 *
wolfSSL 16:8e0d178b1d1e 7 * wolfSSL is free software; you can redistribute it and/or modify
wolfSSL 16:8e0d178b1d1e 8 * it under the terms of the GNU General Public License as published by
wolfSSL 16:8e0d178b1d1e 9 * the Free Software Foundation; either version 2 of the License, or
wolfSSL 16:8e0d178b1d1e 10 * (at your option) any later version.
wolfSSL 16:8e0d178b1d1e 11 *
wolfSSL 16:8e0d178b1d1e 12 * wolfSSL is distributed in the hope that it will be useful,
wolfSSL 16:8e0d178b1d1e 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
wolfSSL 16:8e0d178b1d1e 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
wolfSSL 16:8e0d178b1d1e 15 * GNU General Public License for more details.
wolfSSL 16:8e0d178b1d1e 16 *
wolfSSL 16:8e0d178b1d1e 17 * You should have received a copy of the GNU General Public License
wolfSSL 16:8e0d178b1d1e 18 * along with this program; if not, write to the Free Software
wolfSSL 16:8e0d178b1d1e 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
wolfSSL 16:8e0d178b1d1e 20 */
wolfSSL 16:8e0d178b1d1e 21
wolfSSL 16:8e0d178b1d1e 22 /* x509v3.h for openSSL */
wolfSSL 16:8e0d178b1d1e 23
wolfSSL 16:8e0d178b1d1e 24 #ifndef WOLFSSL_x509v3_H
wolfSSL 16:8e0d178b1d1e 25 #define WOLFSSL_x509v3_H
wolfSSL 16:8e0d178b1d1e 26
wolfSSL 16:8e0d178b1d1e 27 #include <wolfssl/openssl/conf.h>
wolfSSL 16:8e0d178b1d1e 28 #include <wolfssl/openssl/bio.h>
wolfSSL 16:8e0d178b1d1e 29
wolfSSL 16:8e0d178b1d1e 30 #ifdef __cplusplus
wolfSSL 16:8e0d178b1d1e 31 extern "C" {
wolfSSL 16:8e0d178b1d1e 32 #endif
wolfSSL 16:8e0d178b1d1e 33
wolfSSL 16:8e0d178b1d1e 34 #define X509_PURPOSE_SSL_CLIENT 0
wolfSSL 16:8e0d178b1d1e 35 #define X509_PURPOSE_SSL_SERVER 1
wolfSSL 16:8e0d178b1d1e 36
wolfSSL 16:8e0d178b1d1e 37 #define NS_SSL_CLIENT 0
wolfSSL 16:8e0d178b1d1e 38 #define NS_SSL_SERVER 1
wolfSSL 16:8e0d178b1d1e 39
wolfSSL 16:8e0d178b1d1e 40 /* Forward reference */
wolfSSL 16:8e0d178b1d1e 41
wolfSSL 16:8e0d178b1d1e 42 typedef void *(*X509V3_EXT_D2I)(void *, const unsigned char **, long);
wolfSSL 16:8e0d178b1d1e 43 typedef STACK_OF(CONF_VALUE) *(*X509V3_EXT_I2V) (
wolfSSL 16:8e0d178b1d1e 44 struct WOLFSSL_v3_ext_method *method,
wolfSSL 16:8e0d178b1d1e 45 void *ext, STACK_OF(CONF_VALUE) *extlist);
wolfSSL 16:8e0d178b1d1e 46 typedef char *(*X509V3_EXT_I2S)(struct WOLFSSL_v3_ext_method *method, void *ext);
wolfSSL 16:8e0d178b1d1e 47 typedef int (*X509V3_EXT_I2R) (struct WOLFSSL_v3_ext_method *method,
wolfSSL 16:8e0d178b1d1e 48 void *ext, BIO *out, int indent);
wolfSSL 16:8e0d178b1d1e 49 typedef struct WOLFSSL_v3_ext_method X509V3_EXT_METHOD;
wolfSSL 3:6f956bdb3073 50
wolfSSL 16:8e0d178b1d1e 51 struct WOLFSSL_v3_ext_method {
wolfSSL 16:8e0d178b1d1e 52 int ext_nid;
wolfSSL 16:8e0d178b1d1e 53 int ext_flags;
wolfSSL 16:8e0d178b1d1e 54 void *usr_data;
wolfSSL 16:8e0d178b1d1e 55 X509V3_EXT_D2I d2i;
wolfSSL 16:8e0d178b1d1e 56 X509V3_EXT_I2V i2v;
wolfSSL 16:8e0d178b1d1e 57 X509V3_EXT_I2S i2s;
wolfSSL 16:8e0d178b1d1e 58 X509V3_EXT_I2R i2r;
wolfSSL 16:8e0d178b1d1e 59 };
wolfSSL 16:8e0d178b1d1e 60
wolfSSL 16:8e0d178b1d1e 61 struct WOLFSSL_X509_EXTENSION {
wolfSSL 16:8e0d178b1d1e 62 WOLFSSL_ASN1_OBJECT *obj;
wolfSSL 16:8e0d178b1d1e 63 WOLFSSL_ASN1_BOOLEAN crit;
wolfSSL 16:8e0d178b1d1e 64 WOLFSSL_ASN1_STRING value;
wolfSSL 16:8e0d178b1d1e 65 WOLFSSL_v3_ext_method ext_method;
wolfSSL 16:8e0d178b1d1e 66 WOLFSSL_STACK* ext_sk; /* For extension specific data */
wolfSSL 16:8e0d178b1d1e 67 };
wolfSSL 16:8e0d178b1d1e 68
wolfSSL 16:8e0d178b1d1e 69 #define WOLFSSL_ASN1_BOOLEAN int
wolfSSL 16:8e0d178b1d1e 70 #define GEN_OTHERNAME 0
wolfSSL 16:8e0d178b1d1e 71 #define GEN_EMAIL 1
wolfSSL 16:8e0d178b1d1e 72 #define GEN_DNS 2
wolfSSL 16:8e0d178b1d1e 73 #define GEN_X400 3
wolfSSL 16:8e0d178b1d1e 74 #define GEN_DIRNAME 4
wolfSSL 16:8e0d178b1d1e 75 #define GEN_EDIPARTY 5
wolfSSL 16:8e0d178b1d1e 76 #define GEN_URI 6
wolfSSL 16:8e0d178b1d1e 77 #define GEN_IPADD 7
wolfSSL 16:8e0d178b1d1e 78 #define GEN_RID 8
wolfSSL 16:8e0d178b1d1e 79
wolfSSL 16:8e0d178b1d1e 80 #define GENERAL_NAME WOLFSSL_GENERAL_NAME
wolfSSL 16:8e0d178b1d1e 81
wolfSSL 16:8e0d178b1d1e 82 #define X509V3_CTX WOLFSSL_X509V3_CTX
wolfSSL 16:8e0d178b1d1e 83
wolfSSL 16:8e0d178b1d1e 84 typedef struct WOLFSSL_AUTHORITY_KEYID AUTHORITY_KEYID;
wolfSSL 16:8e0d178b1d1e 85 typedef struct WOLFSSL_BASIC_CONSTRAINTS BASIC_CONSTRAINTS;
wolfSSL 16:8e0d178b1d1e 86 typedef struct WOLFSSL_ACCESS_DESCRIPTION ACCESS_DESCRIPTION;
wolfSSL 16:8e0d178b1d1e 87 typedef WOLF_STACK_OF(WOLFSSL_ACCESS_DESCRIPTION) WOLFSSL_AUTHORITY_INFO_ACCESS;
wolfSSL 16:8e0d178b1d1e 88
wolfSSL 16:8e0d178b1d1e 89 WOLFSSL_API void wolfSSL_BASIC_CONSTRAINTS_free(WOLFSSL_BASIC_CONSTRAINTS *bc);
wolfSSL 16:8e0d178b1d1e 90 WOLFSSL_API void wolfSSL_AUTHORITY_KEYID_free(WOLFSSL_AUTHORITY_KEYID *id);
wolfSSL 16:8e0d178b1d1e 91 WOLFSSL_API const WOLFSSL_v3_ext_method* wolfSSL_X509V3_EXT_get(
wolfSSL 16:8e0d178b1d1e 92 WOLFSSL_X509_EXTENSION* ex);
wolfSSL 16:8e0d178b1d1e 93 WOLFSSL_API void* wolfSSL_X509V3_EXT_d2i(WOLFSSL_X509_EXTENSION* ex);
wolfSSL 16:8e0d178b1d1e 94 WOLFSSL_API char* wolfSSL_i2s_ASN1_STRING(WOLFSSL_v3_ext_method *method,
wolfSSL 16:8e0d178b1d1e 95 const WOLFSSL_ASN1_STRING *s);
wolfSSL 16:8e0d178b1d1e 96 WOLFSSL_API int wolfSSL_X509V3_EXT_print(WOLFSSL_BIO *out,
wolfSSL 16:8e0d178b1d1e 97 WOLFSSL_X509_EXTENSION *ext, unsigned long flag, int indent);
wolfSSL 16:8e0d178b1d1e 98
wolfSSL 16:8e0d178b1d1e 99 #define BASIC_CONSTRAINTS_free wolfSSL_BASIC_CONSTRAINTS_free
wolfSSL 16:8e0d178b1d1e 100 #define AUTHORITY_KEYID_free wolfSSL_AUTHORITY_KEYID_free
wolfSSL 16:8e0d178b1d1e 101 #define SSL_CTX_get_cert_store(x) wolfSSL_CTX_get_cert_store ((WOLFSSL_CTX*) (x))
wolfSSL 16:8e0d178b1d1e 102 #define ASN1_INTEGER WOLFSSL_ASN1_INTEGER
wolfSSL 16:8e0d178b1d1e 103 #define ASN1_OCTET_STRING WOLFSSL_ASN1_STRING
wolfSSL 16:8e0d178b1d1e 104 #define X509V3_EXT_get wolfSSL_X509V3_EXT_get
wolfSSL 16:8e0d178b1d1e 105 #define X509V3_EXT_d2i wolfSSL_X509V3_EXT_d2i
wolfSSL 16:8e0d178b1d1e 106 #define i2s_ASN1_OCTET_STRING wolfSSL_i2s_ASN1_STRING
wolfSSL 16:8e0d178b1d1e 107 #define X509V3_EXT_print wolfSSL_X509V3_EXT_print
wolfSSL 16:8e0d178b1d1e 108 #define X509V3_EXT_conf_nid wolfSSL_X509V3_EXT_conf_nid
wolfSSL 16:8e0d178b1d1e 109 #define X509V3_set_ctx wolfSSL_X509V3_set_ctx
wolfSSL 16:8e0d178b1d1e 110 #define X509V3_set_ctx_nodb wolfSSL_X509V3_set_ctx_nodb
wolfSSL 16:8e0d178b1d1e 111
wolfSSL 16:8e0d178b1d1e 112 #ifdef __cplusplus
wolfSSL 16:8e0d178b1d1e 113 }
wolfSSL 16:8e0d178b1d1e 114 #endif
wolfSSL 16:8e0d178b1d1e 115
wolfSSL 16:8e0d178b1d1e 116 #endif
wolfSSL 3:6f956bdb3073 117