No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.

x509_vfy.h 26 KiB

Unwind X509_LU_RETRY and fix a lot of type confusion. (This change will be sent upstream. Since the legacy X.509 stack is just kept around for compatibility, if they decide to fix it in a different way, we may wish to revert this and apply their fix.) Dating back to SSLeay, X509_LOOKUP_METHOD had this X509_LU_RETRY machinery. But it's not documented and it appears to have never worked. Problems with the existing logic: - X509_LU_* is not sure whether it is a type enum (to be passed into X509_LOOKUP_by_*) or a return enum (to be retained by those same functions). - X509_LOOKUP_by_* is not sure whether it returns 0/1 or an X509_LU_* value. Looking at the functions themselves, one might think it's the latter, but for X509_LOOKUP_by_subject returning both 0 and X509_LU_FAIL. But looking at the call sites, some expect 0/1 (such as X509_STORE_get1_certs) while others expect an X509_LU_* enum (such as X509_STORE_CTX_get1_issuer). It is very fortunate that FAIL happens to be 0 and X509 happens to be 1. These functions primarily call to X509_LOOKUP_METHOD hooks. Looking through OpenSSL itself and code checked into Google, I found no evidence that any hooks have been implemented except for get_by_subject in by_dir.c. We take that one as definitive and observe it believes it returns 0/1. Notably, it returns 1 on success even if asked for a type other than X509_LU_X509. (X509_LU_X509 = 1. Others are different.) I found another piece of third-party software which corroborates this worldview. - X509_STORE_get_by_subject's handling of X509_LU_RETRY (it's the j < 0 check) is broken. It saves j into vs->current_method where it probably meant to save i. (This bug has existed since SSLeay.) It also returns j (supposedly X509_LU_RETRY) while all callers of X509_STORE_get_by_subject expect it to return 0/1 by checking with ! instead of <= 0. (Note that all other codepaths return 0 and 1 so this function did not actually believe it returned X509_LU_* most of the time.) This, in turn, gives us a free of uninitialized pointers in X509_STORE_get1_certs and other functions which expect that *ret is filled in if X509_STORE_get_by_subject returns success. GCC 4.9 with optimizations from the Android NDK noticed this, which trigged this saga. (It's only reachable if any X509_LOOKUP_METHOD returned X509_LU_RETRY.) - Although the code which expects X509_STORE_get_by_subject return 0/1 does not date to SSLeay, the X509_STORE_get_by_subject call in X509_STORE_CTX_get1_issuer *does* (though, at the time, it was inline in X509_verify_cert. That code believes X509_STORE_get_by_subject returns an X509_LU_* enum, but it doesn't work either! It believes *ret is filled in on X509_LU_RETRY, thus freeing another uninitialized pointer (GCC noticed this too). Since this "retry" code has clearly never worked, from SSLeay onwards, unwind it completely rather than attempt to fix it. No X509_LOOKUP_METHOD can possibly have depended on it. Matching all non-broken codepaths X509_LOOKUP_by_* now returns 0/1 and X509_STORE_get_by_subject returns 0/1. X509_LU_* is purely a type enum with X509_LU_{REJECT,FAIL} being legacy constants to keep old code compiling. (Upstream is recommended to remove those values altogether for 1.1.0.) On the off chance any get_by_* X509_LOOKUP_METHOD implementations did not return 0/1 (I have found no evidence anywhere of this, and I believe it wouldn't have worked anyway), the X509_LOOKUP_by_* wrapper functions will coerce the return values back to 0/1 before passing up to the callers which want 0/1. This both avoids the error-prone -1/0/1 calling convention and, more importantly, avoids problems with third-party callers which expect a X509_LU_* return code. 0/1 collide with FAIL/X509 while -1 will collide with RETRY and might confuse things. Change-Id: I98ecf6fa7342866b9124dc6f0b422cb9ce4a1ae7 Reviewed-on: https://boringssl-review.googlesource.com/8303 Reviewed-by: Adam Langley <agl@google.com>
hace 8 años
Unwind X509_LU_RETRY and fix a lot of type confusion. (This change will be sent upstream. Since the legacy X.509 stack is just kept around for compatibility, if they decide to fix it in a different way, we may wish to revert this and apply their fix.) Dating back to SSLeay, X509_LOOKUP_METHOD had this X509_LU_RETRY machinery. But it's not documented and it appears to have never worked. Problems with the existing logic: - X509_LU_* is not sure whether it is a type enum (to be passed into X509_LOOKUP_by_*) or a return enum (to be retained by those same functions). - X509_LOOKUP_by_* is not sure whether it returns 0/1 or an X509_LU_* value. Looking at the functions themselves, one might think it's the latter, but for X509_LOOKUP_by_subject returning both 0 and X509_LU_FAIL. But looking at the call sites, some expect 0/1 (such as X509_STORE_get1_certs) while others expect an X509_LU_* enum (such as X509_STORE_CTX_get1_issuer). It is very fortunate that FAIL happens to be 0 and X509 happens to be 1. These functions primarily call to X509_LOOKUP_METHOD hooks. Looking through OpenSSL itself and code checked into Google, I found no evidence that any hooks have been implemented except for get_by_subject in by_dir.c. We take that one as definitive and observe it believes it returns 0/1. Notably, it returns 1 on success even if asked for a type other than X509_LU_X509. (X509_LU_X509 = 1. Others are different.) I found another piece of third-party software which corroborates this worldview. - X509_STORE_get_by_subject's handling of X509_LU_RETRY (it's the j < 0 check) is broken. It saves j into vs->current_method where it probably meant to save i. (This bug has existed since SSLeay.) It also returns j (supposedly X509_LU_RETRY) while all callers of X509_STORE_get_by_subject expect it to return 0/1 by checking with ! instead of <= 0. (Note that all other codepaths return 0 and 1 so this function did not actually believe it returned X509_LU_* most of the time.) This, in turn, gives us a free of uninitialized pointers in X509_STORE_get1_certs and other functions which expect that *ret is filled in if X509_STORE_get_by_subject returns success. GCC 4.9 with optimizations from the Android NDK noticed this, which trigged this saga. (It's only reachable if any X509_LOOKUP_METHOD returned X509_LU_RETRY.) - Although the code which expects X509_STORE_get_by_subject return 0/1 does not date to SSLeay, the X509_STORE_get_by_subject call in X509_STORE_CTX_get1_issuer *does* (though, at the time, it was inline in X509_verify_cert. That code believes X509_STORE_get_by_subject returns an X509_LU_* enum, but it doesn't work either! It believes *ret is filled in on X509_LU_RETRY, thus freeing another uninitialized pointer (GCC noticed this too). Since this "retry" code has clearly never worked, from SSLeay onwards, unwind it completely rather than attempt to fix it. No X509_LOOKUP_METHOD can possibly have depended on it. Matching all non-broken codepaths X509_LOOKUP_by_* now returns 0/1 and X509_STORE_get_by_subject returns 0/1. X509_LU_* is purely a type enum with X509_LU_{REJECT,FAIL} being legacy constants to keep old code compiling. (Upstream is recommended to remove those values altogether for 1.1.0.) On the off chance any get_by_* X509_LOOKUP_METHOD implementations did not return 0/1 (I have found no evidence anywhere of this, and I believe it wouldn't have worked anyway), the X509_LOOKUP_by_* wrapper functions will coerce the return values back to 0/1 before passing up to the callers which want 0/1. This both avoids the error-prone -1/0/1 calling convention and, more importantly, avoids problems with third-party callers which expect a X509_LU_* return code. 0/1 collide with FAIL/X509 while -1 will collide with RETRY and might confuse things. Change-Id: I98ecf6fa7342866b9124dc6f0b422cb9ce4a1ae7 Reviewed-on: https://boringssl-review.googlesource.com/8303 Reviewed-by: Adam Langley <agl@google.com>
hace 8 años
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624
  1. /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
  2. * All rights reserved.
  3. *
  4. * This package is an SSL implementation written
  5. * by Eric Young (eay@cryptsoft.com).
  6. * The implementation was written so as to conform with Netscapes SSL.
  7. *
  8. * This library is free for commercial and non-commercial use as long as
  9. * the following conditions are aheared to. The following conditions
  10. * apply to all code found in this distribution, be it the RC4, RSA,
  11. * lhash, DES, etc., code; not just the SSL code. The SSL documentation
  12. * included with this distribution is covered by the same copyright terms
  13. * except that the holder is Tim Hudson (tjh@cryptsoft.com).
  14. *
  15. * Copyright remains Eric Young's, and as such any Copyright notices in
  16. * the code are not to be removed.
  17. * If this package is used in a product, Eric Young should be given attribution
  18. * as the author of the parts of the library used.
  19. * This can be in the form of a textual message at program startup or
  20. * in documentation (online or textual) provided with the package.
  21. *
  22. * Redistribution and use in source and binary forms, with or without
  23. * modification, are permitted provided that the following conditions
  24. * are met:
  25. * 1. Redistributions of source code must retain the copyright
  26. * notice, this list of conditions and the following disclaimer.
  27. * 2. Redistributions in binary form must reproduce the above copyright
  28. * notice, this list of conditions and the following disclaimer in the
  29. * documentation and/or other materials provided with the distribution.
  30. * 3. All advertising materials mentioning features or use of this software
  31. * must display the following acknowledgement:
  32. * "This product includes cryptographic software written by
  33. * Eric Young (eay@cryptsoft.com)"
  34. * The word 'cryptographic' can be left out if the rouines from the library
  35. * being used are not cryptographic related :-).
  36. * 4. If you include any Windows specific code (or a derivative thereof) from
  37. * the apps directory (application code) you must include an acknowledgement:
  38. * "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
  39. *
  40. * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
  41. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  42. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  43. * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
  44. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  45. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  46. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  47. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  48. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  49. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  50. * SUCH DAMAGE.
  51. *
  52. * The licence and distribution terms for any publically available version or
  53. * derivative of this code cannot be changed. i.e. this code cannot simply be
  54. * copied and put under another distribution licence
  55. * [including the GNU Public Licence.]
  56. */
  57. #ifndef HEADER_X509_H
  58. #include <openssl/x509.h>
  59. /* openssl/x509.h ends up #include-ing this file at about the only
  60. * appropriate moment. */
  61. #endif
  62. #ifndef HEADER_X509_VFY_H
  63. #define HEADER_X509_VFY_H
  64. #include <openssl/bio.h>
  65. #include <openssl/lhash.h>
  66. #include <openssl/thread.h>
  67. #ifdef __cplusplus
  68. extern "C" {
  69. #endif
  70. #if 0
  71. /* Outer object */
  72. typedef struct x509_hash_dir_st
  73. {
  74. int num_dirs;
  75. char **dirs;
  76. int *dirs_type;
  77. int num_dirs_alloced;
  78. } X509_HASH_DIR_CTX;
  79. #endif
  80. typedef struct x509_file_st
  81. {
  82. int num_paths; /* number of paths to files or directories */
  83. int num_alloced;
  84. char **paths; /* the list of paths or directories */
  85. int *path_type;
  86. } X509_CERT_FILE_CTX;
  87. /*******************************/
  88. /*
  89. SSL_CTX -> X509_STORE
  90. -> X509_LOOKUP
  91. ->X509_LOOKUP_METHOD
  92. -> X509_LOOKUP
  93. ->X509_LOOKUP_METHOD
  94. SSL -> X509_STORE_CTX
  95. ->X509_STORE
  96. The X509_STORE holds the tables etc for verification stuff.
  97. A X509_STORE_CTX is used while validating a single certificate.
  98. The X509_STORE has X509_LOOKUPs for looking up certs.
  99. The X509_STORE then calls a function to actually verify the
  100. certificate chain.
  101. */
  102. /* The following are legacy constants that should not be used. */
  103. #define X509_LU_RETRY (-1)
  104. #define X509_LU_FAIL 0
  105. #define X509_LU_X509 1
  106. #define X509_LU_CRL 2
  107. #define X509_LU_PKEY 3
  108. typedef struct x509_object_st
  109. {
  110. /* one of the above types */
  111. int type;
  112. union {
  113. char *ptr;
  114. X509 *x509;
  115. X509_CRL *crl;
  116. EVP_PKEY *pkey;
  117. } data;
  118. } X509_OBJECT;
  119. DECLARE_STACK_OF(X509_LOOKUP)
  120. DECLARE_STACK_OF(X509_OBJECT)
  121. /* This is a static that defines the function interface */
  122. typedef struct x509_lookup_method_st
  123. {
  124. const char *name;
  125. int (*new_item)(X509_LOOKUP *ctx);
  126. void (*free)(X509_LOOKUP *ctx);
  127. int (*init)(X509_LOOKUP *ctx);
  128. int (*shutdown)(X509_LOOKUP *ctx);
  129. int (*ctrl)(X509_LOOKUP *ctx,int cmd,const char *argc,long argl,
  130. char **ret);
  131. int (*get_by_subject)(X509_LOOKUP *ctx,int type,X509_NAME *name,
  132. X509_OBJECT *ret);
  133. int (*get_by_issuer_serial)(X509_LOOKUP *ctx,int type,X509_NAME *name,
  134. ASN1_INTEGER *serial,X509_OBJECT *ret);
  135. int (*get_by_fingerprint)(X509_LOOKUP *ctx,int type,
  136. unsigned char *bytes,int len,
  137. X509_OBJECT *ret);
  138. int (*get_by_alias)(X509_LOOKUP *ctx,int type,char *str,int len,
  139. X509_OBJECT *ret);
  140. } X509_LOOKUP_METHOD;
  141. typedef struct X509_VERIFY_PARAM_ID_st X509_VERIFY_PARAM_ID;
  142. /* This structure hold all parameters associated with a verify operation
  143. * by including an X509_VERIFY_PARAM structure in related structures the
  144. * parameters used can be customized
  145. */
  146. struct X509_VERIFY_PARAM_st
  147. {
  148. char *name;
  149. time_t check_time; /* Time to use */
  150. unsigned long inh_flags; /* Inheritance flags */
  151. unsigned long flags; /* Various verify flags */
  152. int purpose; /* purpose to check untrusted certificates */
  153. int trust; /* trust setting to check */
  154. int depth; /* Verify depth */
  155. STACK_OF(ASN1_OBJECT) *policies; /* Permissible policies */
  156. X509_VERIFY_PARAM_ID *id; /* opaque ID data */
  157. };
  158. DECLARE_STACK_OF(X509_VERIFY_PARAM)
  159. /* This is used to hold everything. It is used for all certificate
  160. * validation. Once we have a certificate chain, the 'verify'
  161. * function is then called to actually check the cert chain. */
  162. struct x509_store_st
  163. {
  164. /* The following is a cache of trusted certs */
  165. int cache; /* if true, stash any hits */
  166. STACK_OF(X509_OBJECT) *objs; /* Cache of all objects */
  167. CRYPTO_MUTEX objs_lock;
  168. STACK_OF(X509) *additional_untrusted;
  169. /* These are external lookup methods */
  170. STACK_OF(X509_LOOKUP) *get_cert_methods;
  171. X509_VERIFY_PARAM *param;
  172. /* Callbacks for various operations */
  173. int (*verify)(X509_STORE_CTX *ctx); /* called to verify a certificate */
  174. int (*verify_cb)(int ok,X509_STORE_CTX *ctx); /* error callback */
  175. int (*get_issuer)(X509 **issuer, X509_STORE_CTX *ctx, X509 *x); /* get issuers cert from ctx */
  176. int (*check_issued)(X509_STORE_CTX *ctx, X509 *x, X509 *issuer); /* check issued */
  177. int (*check_revocation)(X509_STORE_CTX *ctx); /* Check revocation status of chain */
  178. int (*get_crl)(X509_STORE_CTX *ctx, X509_CRL **crl, X509 *x); /* retrieve CRL */
  179. int (*check_crl)(X509_STORE_CTX *ctx, X509_CRL *crl); /* Check CRL validity */
  180. int (*cert_crl)(X509_STORE_CTX *ctx, X509_CRL *crl, X509 *x); /* Check certificate against CRL */
  181. STACK_OF(X509) * (*lookup_certs)(X509_STORE_CTX *ctx, X509_NAME *nm);
  182. STACK_OF(X509_CRL) * (*lookup_crls)(X509_STORE_CTX *ctx, X509_NAME *nm);
  183. int (*cleanup)(X509_STORE_CTX *ctx);
  184. CRYPTO_refcount_t references;
  185. } /* X509_STORE */;
  186. OPENSSL_EXPORT int X509_STORE_set_depth(X509_STORE *store, int depth);
  187. #define X509_STORE_set_verify_cb_func(ctx,func) ((ctx)->verify_cb=(func))
  188. #define X509_STORE_set_verify_func(ctx,func) ((ctx)->verify=(func))
  189. /* This is the functions plus an instance of the local variables. */
  190. struct x509_lookup_st
  191. {
  192. int init; /* have we been started */
  193. int skip; /* don't use us. */
  194. X509_LOOKUP_METHOD *method; /* the functions */
  195. char *method_data; /* method data */
  196. X509_STORE *store_ctx; /* who owns us */
  197. } /* X509_LOOKUP */;
  198. /* This is a used when verifying cert chains. Since the
  199. * gathering of the cert chain can take some time (and have to be
  200. * 'retried', this needs to be kept and passed around. */
  201. struct x509_store_ctx_st /* X509_STORE_CTX */
  202. {
  203. X509_STORE *ctx;
  204. /* The following are set by the caller */
  205. X509 *cert; /* The cert to check */
  206. STACK_OF(X509) *untrusted; /* chain of X509s - untrusted - passed in */
  207. STACK_OF(X509_CRL) *crls; /* set of CRLs passed in */
  208. X509_VERIFY_PARAM *param;
  209. void *other_ctx; /* Other info for use with get_issuer() */
  210. /* Callbacks for various operations */
  211. int (*verify)(X509_STORE_CTX *ctx); /* called to verify a certificate */
  212. int (*verify_cb)(int ok,X509_STORE_CTX *ctx); /* error callback */
  213. int (*get_issuer)(X509 **issuer, X509_STORE_CTX *ctx, X509 *x); /* get issuers cert from ctx */
  214. int (*check_issued)(X509_STORE_CTX *ctx, X509 *x, X509 *issuer); /* check issued */
  215. int (*check_revocation)(X509_STORE_CTX *ctx); /* Check revocation status of chain */
  216. int (*get_crl)(X509_STORE_CTX *ctx, X509_CRL **crl, X509 *x); /* retrieve CRL */
  217. int (*check_crl)(X509_STORE_CTX *ctx, X509_CRL *crl); /* Check CRL validity */
  218. int (*cert_crl)(X509_STORE_CTX *ctx, X509_CRL *crl, X509 *x); /* Check certificate against CRL */
  219. int (*check_policy)(X509_STORE_CTX *ctx);
  220. STACK_OF(X509) * (*lookup_certs)(X509_STORE_CTX *ctx, X509_NAME *nm);
  221. STACK_OF(X509_CRL) * (*lookup_crls)(X509_STORE_CTX *ctx, X509_NAME *nm);
  222. int (*cleanup)(X509_STORE_CTX *ctx);
  223. /* The following is built up */
  224. int valid; /* if 0, rebuild chain */
  225. int last_untrusted; /* index of last untrusted cert */
  226. STACK_OF(X509) *chain; /* chain of X509s - built up and trusted */
  227. X509_POLICY_TREE *tree; /* Valid policy tree */
  228. int explicit_policy; /* Require explicit policy value */
  229. /* When something goes wrong, this is why */
  230. int error_depth;
  231. int error;
  232. X509 *current_cert;
  233. X509 *current_issuer; /* cert currently being tested as valid issuer */
  234. X509_CRL *current_crl; /* current CRL */
  235. int current_crl_score; /* score of current CRL */
  236. unsigned int current_reasons; /* Reason mask */
  237. X509_STORE_CTX *parent; /* For CRL path validation: parent context */
  238. CRYPTO_EX_DATA ex_data;
  239. } /* X509_STORE_CTX */;
  240. OPENSSL_EXPORT void X509_STORE_CTX_set_depth(X509_STORE_CTX *ctx, int depth);
  241. #define X509_STORE_CTX_set_app_data(ctx,data) \
  242. X509_STORE_CTX_set_ex_data(ctx,0,data)
  243. #define X509_STORE_CTX_get_app_data(ctx) \
  244. X509_STORE_CTX_get_ex_data(ctx,0)
  245. #define X509_L_FILE_LOAD 1
  246. #define X509_L_ADD_DIR 2
  247. #define X509_LOOKUP_load_file(x,name,type) \
  248. X509_LOOKUP_ctrl((x),X509_L_FILE_LOAD,(name),(long)(type),NULL)
  249. #define X509_LOOKUP_add_dir(x,name,type) \
  250. X509_LOOKUP_ctrl((x),X509_L_ADD_DIR,(name),(long)(type),NULL)
  251. #define X509_V_OK 0
  252. #define X509_V_ERR_UNSPECIFIED 1
  253. #define X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT 2
  254. #define X509_V_ERR_UNABLE_TO_GET_CRL 3
  255. #define X509_V_ERR_UNABLE_TO_DECRYPT_CERT_SIGNATURE 4
  256. #define X509_V_ERR_UNABLE_TO_DECRYPT_CRL_SIGNATURE 5
  257. #define X509_V_ERR_UNABLE_TO_DECODE_ISSUER_PUBLIC_KEY 6
  258. #define X509_V_ERR_CERT_SIGNATURE_FAILURE 7
  259. #define X509_V_ERR_CRL_SIGNATURE_FAILURE 8
  260. #define X509_V_ERR_CERT_NOT_YET_VALID 9
  261. #define X509_V_ERR_CERT_HAS_EXPIRED 10
  262. #define X509_V_ERR_CRL_NOT_YET_VALID 11
  263. #define X509_V_ERR_CRL_HAS_EXPIRED 12
  264. #define X509_V_ERR_ERROR_IN_CERT_NOT_BEFORE_FIELD 13
  265. #define X509_V_ERR_ERROR_IN_CERT_NOT_AFTER_FIELD 14
  266. #define X509_V_ERR_ERROR_IN_CRL_LAST_UPDATE_FIELD 15
  267. #define X509_V_ERR_ERROR_IN_CRL_NEXT_UPDATE_FIELD 16
  268. #define X509_V_ERR_OUT_OF_MEM 17
  269. #define X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT 18
  270. #define X509_V_ERR_SELF_SIGNED_CERT_IN_CHAIN 19
  271. #define X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT_LOCALLY 20
  272. #define X509_V_ERR_UNABLE_TO_VERIFY_LEAF_SIGNATURE 21
  273. #define X509_V_ERR_CERT_CHAIN_TOO_LONG 22
  274. #define X509_V_ERR_CERT_REVOKED 23
  275. #define X509_V_ERR_INVALID_CA 24
  276. #define X509_V_ERR_PATH_LENGTH_EXCEEDED 25
  277. #define X509_V_ERR_INVALID_PURPOSE 26
  278. #define X509_V_ERR_CERT_UNTRUSTED 27
  279. #define X509_V_ERR_CERT_REJECTED 28
  280. /* These are 'informational' when looking for issuer cert */
  281. #define X509_V_ERR_SUBJECT_ISSUER_MISMATCH 29
  282. #define X509_V_ERR_AKID_SKID_MISMATCH 30
  283. #define X509_V_ERR_AKID_ISSUER_SERIAL_MISMATCH 31
  284. #define X509_V_ERR_KEYUSAGE_NO_CERTSIGN 32
  285. #define X509_V_ERR_UNABLE_TO_GET_CRL_ISSUER 33
  286. #define X509_V_ERR_UNHANDLED_CRITICAL_EXTENSION 34
  287. #define X509_V_ERR_KEYUSAGE_NO_CRL_SIGN 35
  288. #define X509_V_ERR_UNHANDLED_CRITICAL_CRL_EXTENSION 36
  289. #define X509_V_ERR_INVALID_NON_CA 37
  290. #define X509_V_ERR_PROXY_PATH_LENGTH_EXCEEDED 38
  291. #define X509_V_ERR_KEYUSAGE_NO_DIGITAL_SIGNATURE 39
  292. #define X509_V_ERR_PROXY_CERTIFICATES_NOT_ALLOWED 40
  293. #define X509_V_ERR_INVALID_EXTENSION 41
  294. #define X509_V_ERR_INVALID_POLICY_EXTENSION 42
  295. #define X509_V_ERR_NO_EXPLICIT_POLICY 43
  296. #define X509_V_ERR_DIFFERENT_CRL_SCOPE 44
  297. #define X509_V_ERR_UNSUPPORTED_EXTENSION_FEATURE 45
  298. #define X509_V_ERR_UNNESTED_RESOURCE 46
  299. #define X509_V_ERR_PERMITTED_VIOLATION 47
  300. #define X509_V_ERR_EXCLUDED_VIOLATION 48
  301. #define X509_V_ERR_SUBTREE_MINMAX 49
  302. #define X509_V_ERR_APPLICATION_VERIFICATION 50
  303. #define X509_V_ERR_UNSUPPORTED_CONSTRAINT_TYPE 51
  304. #define X509_V_ERR_UNSUPPORTED_CONSTRAINT_SYNTAX 52
  305. #define X509_V_ERR_UNSUPPORTED_NAME_SYNTAX 53
  306. #define X509_V_ERR_CRL_PATH_VALIDATION_ERROR 54
  307. /* Suite B mode algorithm violation */
  308. #define X509_V_ERR_SUITE_B_INVALID_VERSION 56
  309. #define X509_V_ERR_SUITE_B_INVALID_ALGORITHM 57
  310. #define X509_V_ERR_SUITE_B_INVALID_CURVE 58
  311. #define X509_V_ERR_SUITE_B_INVALID_SIGNATURE_ALGORITHM 59
  312. #define X509_V_ERR_SUITE_B_LOS_NOT_ALLOWED 60
  313. #define X509_V_ERR_SUITE_B_CANNOT_SIGN_P_384_WITH_P_256 61
  314. /* Host, email and IP check errors */
  315. #define X509_V_ERR_HOSTNAME_MISMATCH 62
  316. #define X509_V_ERR_EMAIL_MISMATCH 63
  317. #define X509_V_ERR_IP_ADDRESS_MISMATCH 64
  318. /* Caller error */
  319. #define X509_V_ERR_INVALID_CALL 65
  320. /* Issuer lookup error */
  321. #define X509_V_ERR_STORE_LOOKUP 66
  322. /* Certificate verify flags */
  323. /* Send issuer+subject checks to verify_cb */
  324. #define X509_V_FLAG_CB_ISSUER_CHECK 0x1
  325. /* Use check time instead of current time */
  326. #define X509_V_FLAG_USE_CHECK_TIME 0x2
  327. /* Lookup CRLs */
  328. #define X509_V_FLAG_CRL_CHECK 0x4
  329. /* Lookup CRLs for whole chain */
  330. #define X509_V_FLAG_CRL_CHECK_ALL 0x8
  331. /* Ignore unhandled critical extensions */
  332. #define X509_V_FLAG_IGNORE_CRITICAL 0x10
  333. /* Disable workarounds for broken certificates */
  334. #define X509_V_FLAG_X509_STRICT 0x20
  335. /* Enable proxy certificate validation */
  336. #define X509_V_FLAG_ALLOW_PROXY_CERTS 0x40
  337. /* Enable policy checking */
  338. #define X509_V_FLAG_POLICY_CHECK 0x80
  339. /* Policy variable require-explicit-policy */
  340. #define X509_V_FLAG_EXPLICIT_POLICY 0x100
  341. /* Policy variable inhibit-any-policy */
  342. #define X509_V_FLAG_INHIBIT_ANY 0x200
  343. /* Policy variable inhibit-policy-mapping */
  344. #define X509_V_FLAG_INHIBIT_MAP 0x400
  345. /* Notify callback that policy is OK */
  346. #define X509_V_FLAG_NOTIFY_POLICY 0x800
  347. /* Extended CRL features such as indirect CRLs, alternate CRL signing keys */
  348. #define X509_V_FLAG_EXTENDED_CRL_SUPPORT 0x1000
  349. /* Delta CRL support */
  350. #define X509_V_FLAG_USE_DELTAS 0x2000
  351. /* Check selfsigned CA signature */
  352. #define X509_V_FLAG_CHECK_SS_SIGNATURE 0x4000
  353. /* Use trusted store first */
  354. #define X509_V_FLAG_TRUSTED_FIRST 0x8000
  355. /* Suite B 128 bit only mode: not normally used */
  356. #define X509_V_FLAG_SUITEB_128_LOS_ONLY 0x10000
  357. /* Suite B 192 bit only mode */
  358. #define X509_V_FLAG_SUITEB_192_LOS 0x20000
  359. /* Suite B 128 bit mode allowing 192 bit algorithms */
  360. #define X509_V_FLAG_SUITEB_128_LOS 0x30000
  361. /* Allow partial chains if at least one certificate is in trusted store */
  362. #define X509_V_FLAG_PARTIAL_CHAIN 0x80000
  363. /* If the initial chain is not trusted, do not attempt to build an alternative
  364. * chain. Alternate chain checking was introduced in 1.0.2b. Setting this flag
  365. * will force the behaviour to match that of previous versions. */
  366. #define X509_V_FLAG_NO_ALT_CHAINS 0x100000
  367. #define X509_VP_FLAG_DEFAULT 0x1
  368. #define X509_VP_FLAG_OVERWRITE 0x2
  369. #define X509_VP_FLAG_RESET_FLAGS 0x4
  370. #define X509_VP_FLAG_LOCKED 0x8
  371. #define X509_VP_FLAG_ONCE 0x10
  372. /* Internal use: mask of policy related options */
  373. #define X509_V_FLAG_POLICY_MASK (X509_V_FLAG_POLICY_CHECK \
  374. | X509_V_FLAG_EXPLICIT_POLICY \
  375. | X509_V_FLAG_INHIBIT_ANY \
  376. | X509_V_FLAG_INHIBIT_MAP)
  377. OPENSSL_EXPORT int X509_OBJECT_idx_by_subject(STACK_OF(X509_OBJECT) *h, int type,
  378. X509_NAME *name);
  379. OPENSSL_EXPORT X509_OBJECT *X509_OBJECT_retrieve_by_subject(STACK_OF(X509_OBJECT) *h,int type,X509_NAME *name);
  380. OPENSSL_EXPORT X509_OBJECT *X509_OBJECT_retrieve_match(STACK_OF(X509_OBJECT) *h, X509_OBJECT *x);
  381. OPENSSL_EXPORT int X509_OBJECT_up_ref_count(X509_OBJECT *a);
  382. OPENSSL_EXPORT void X509_OBJECT_free_contents(X509_OBJECT *a);
  383. OPENSSL_EXPORT X509_STORE *X509_STORE_new(void );
  384. OPENSSL_EXPORT int X509_STORE_up_ref(X509_STORE *store);
  385. OPENSSL_EXPORT void X509_STORE_free(X509_STORE *v);
  386. OPENSSL_EXPORT STACK_OF(X509)* X509_STORE_get1_certs(X509_STORE_CTX *st, X509_NAME *nm);
  387. OPENSSL_EXPORT STACK_OF(X509_CRL)* X509_STORE_get1_crls(X509_STORE_CTX *st, X509_NAME *nm);
  388. OPENSSL_EXPORT int X509_STORE_set_flags(X509_STORE *ctx, unsigned long flags);
  389. OPENSSL_EXPORT int X509_STORE_set_purpose(X509_STORE *ctx, int purpose);
  390. OPENSSL_EXPORT int X509_STORE_set_trust(X509_STORE *ctx, int trust);
  391. OPENSSL_EXPORT int X509_STORE_set1_param(X509_STORE *ctx, X509_VERIFY_PARAM *pm);
  392. /* X509_STORE_set0_additional_untrusted sets a stack of additional, untrusted
  393. * certificates that are available for chain building. This function does not
  394. * take ownership of the stack. */
  395. OPENSSL_EXPORT void X509_STORE_set0_additional_untrusted(
  396. X509_STORE *ctx, STACK_OF(X509) *untrusted);
  397. OPENSSL_EXPORT void X509_STORE_set_verify_cb(X509_STORE *ctx,
  398. int (*verify_cb)(int, X509_STORE_CTX *));
  399. OPENSSL_EXPORT void X509_STORE_set_lookup_crls_cb(X509_STORE *ctx,
  400. STACK_OF(X509_CRL)* (*cb)(X509_STORE_CTX *ctx, X509_NAME *nm));
  401. OPENSSL_EXPORT X509_STORE_CTX *X509_STORE_CTX_new(void);
  402. OPENSSL_EXPORT int X509_STORE_CTX_get1_issuer(X509 **issuer, X509_STORE_CTX *ctx, X509 *x);
  403. OPENSSL_EXPORT void X509_STORE_CTX_free(X509_STORE_CTX *ctx);
  404. OPENSSL_EXPORT int X509_STORE_CTX_init(X509_STORE_CTX *ctx, X509_STORE *store,
  405. X509 *x509, STACK_OF(X509) *chain);
  406. OPENSSL_EXPORT void X509_STORE_CTX_trusted_stack(X509_STORE_CTX *ctx, STACK_OF(X509) *sk);
  407. OPENSSL_EXPORT void X509_STORE_CTX_cleanup(X509_STORE_CTX *ctx);
  408. OPENSSL_EXPORT X509_STORE *X509_STORE_CTX_get0_store(X509_STORE_CTX *ctx);
  409. OPENSSL_EXPORT X509_LOOKUP *X509_STORE_add_lookup(X509_STORE *v, X509_LOOKUP_METHOD *m);
  410. OPENSSL_EXPORT X509_LOOKUP_METHOD *X509_LOOKUP_hash_dir(void);
  411. OPENSSL_EXPORT X509_LOOKUP_METHOD *X509_LOOKUP_file(void);
  412. OPENSSL_EXPORT int X509_STORE_add_cert(X509_STORE *ctx, X509 *x);
  413. OPENSSL_EXPORT int X509_STORE_add_crl(X509_STORE *ctx, X509_CRL *x);
  414. OPENSSL_EXPORT int X509_STORE_get_by_subject(X509_STORE_CTX *vs,int type,X509_NAME *name,
  415. X509_OBJECT *ret);
  416. OPENSSL_EXPORT int X509_LOOKUP_ctrl(X509_LOOKUP *ctx, int cmd, const char *argc,
  417. long argl, char **ret);
  418. #ifndef OPENSSL_NO_STDIO
  419. OPENSSL_EXPORT int X509_load_cert_file(X509_LOOKUP *ctx, const char *file, int type);
  420. OPENSSL_EXPORT int X509_load_crl_file(X509_LOOKUP *ctx, const char *file, int type);
  421. OPENSSL_EXPORT int X509_load_cert_crl_file(X509_LOOKUP *ctx, const char *file, int type);
  422. #endif
  423. OPENSSL_EXPORT X509_LOOKUP *X509_LOOKUP_new(X509_LOOKUP_METHOD *method);
  424. OPENSSL_EXPORT void X509_LOOKUP_free(X509_LOOKUP *ctx);
  425. OPENSSL_EXPORT int X509_LOOKUP_init(X509_LOOKUP *ctx);
  426. OPENSSL_EXPORT int X509_LOOKUP_by_subject(X509_LOOKUP *ctx, int type, X509_NAME *name,
  427. X509_OBJECT *ret);
  428. OPENSSL_EXPORT int X509_LOOKUP_by_issuer_serial(X509_LOOKUP *ctx, int type, X509_NAME *name,
  429. ASN1_INTEGER *serial, X509_OBJECT *ret);
  430. OPENSSL_EXPORT int X509_LOOKUP_by_fingerprint(X509_LOOKUP *ctx, int type,
  431. unsigned char *bytes, int len, X509_OBJECT *ret);
  432. OPENSSL_EXPORT int X509_LOOKUP_by_alias(X509_LOOKUP *ctx, int type, char *str,
  433. int len, X509_OBJECT *ret);
  434. OPENSSL_EXPORT int X509_LOOKUP_shutdown(X509_LOOKUP *ctx);
  435. #ifndef OPENSSL_NO_STDIO
  436. OPENSSL_EXPORT int X509_STORE_load_locations (X509_STORE *ctx,
  437. const char *file, const char *dir);
  438. OPENSSL_EXPORT int X509_STORE_set_default_paths(X509_STORE *ctx);
  439. #endif
  440. OPENSSL_EXPORT int X509_STORE_CTX_get_ex_new_index(long argl, void *argp, CRYPTO_EX_unused *unused,
  441. CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func);
  442. OPENSSL_EXPORT int X509_STORE_CTX_set_ex_data(X509_STORE_CTX *ctx,int idx,void *data);
  443. OPENSSL_EXPORT void * X509_STORE_CTX_get_ex_data(X509_STORE_CTX *ctx,int idx);
  444. OPENSSL_EXPORT int X509_STORE_CTX_get_error(X509_STORE_CTX *ctx);
  445. OPENSSL_EXPORT void X509_STORE_CTX_set_error(X509_STORE_CTX *ctx,int s);
  446. OPENSSL_EXPORT int X509_STORE_CTX_get_error_depth(X509_STORE_CTX *ctx);
  447. OPENSSL_EXPORT X509 * X509_STORE_CTX_get_current_cert(X509_STORE_CTX *ctx);
  448. OPENSSL_EXPORT X509 *X509_STORE_CTX_get0_current_issuer(X509_STORE_CTX *ctx);
  449. OPENSSL_EXPORT X509_CRL *X509_STORE_CTX_get0_current_crl(X509_STORE_CTX *ctx);
  450. OPENSSL_EXPORT X509_STORE_CTX *X509_STORE_CTX_get0_parent_ctx(X509_STORE_CTX *ctx);
  451. OPENSSL_EXPORT STACK_OF(X509) *X509_STORE_CTX_get_chain(X509_STORE_CTX *ctx);
  452. OPENSSL_EXPORT STACK_OF(X509) *X509_STORE_CTX_get1_chain(X509_STORE_CTX *ctx);
  453. OPENSSL_EXPORT void X509_STORE_CTX_set_cert(X509_STORE_CTX *c,X509 *x);
  454. OPENSSL_EXPORT void X509_STORE_CTX_set_chain(X509_STORE_CTX *c,STACK_OF(X509) *sk);
  455. OPENSSL_EXPORT void X509_STORE_CTX_set0_crls(X509_STORE_CTX *c,STACK_OF(X509_CRL) *sk);
  456. OPENSSL_EXPORT int X509_STORE_CTX_set_purpose(X509_STORE_CTX *ctx, int purpose);
  457. OPENSSL_EXPORT int X509_STORE_CTX_set_trust(X509_STORE_CTX *ctx, int trust);
  458. OPENSSL_EXPORT int X509_STORE_CTX_purpose_inherit(X509_STORE_CTX *ctx, int def_purpose,
  459. int purpose, int trust);
  460. OPENSSL_EXPORT void X509_STORE_CTX_set_flags(X509_STORE_CTX *ctx, unsigned long flags);
  461. OPENSSL_EXPORT void X509_STORE_CTX_set_time(X509_STORE_CTX *ctx, unsigned long flags,
  462. time_t t);
  463. OPENSSL_EXPORT void X509_STORE_CTX_set_verify_cb(X509_STORE_CTX *ctx,
  464. int (*verify_cb)(int, X509_STORE_CTX *));
  465. OPENSSL_EXPORT X509_POLICY_TREE *X509_STORE_CTX_get0_policy_tree(X509_STORE_CTX *ctx);
  466. OPENSSL_EXPORT int X509_STORE_CTX_get_explicit_policy(X509_STORE_CTX *ctx);
  467. OPENSSL_EXPORT X509_VERIFY_PARAM *X509_STORE_CTX_get0_param(X509_STORE_CTX *ctx);
  468. OPENSSL_EXPORT void X509_STORE_CTX_set0_param(X509_STORE_CTX *ctx, X509_VERIFY_PARAM *param);
  469. OPENSSL_EXPORT int X509_STORE_CTX_set_default(X509_STORE_CTX *ctx, const char *name);
  470. /* X509_VERIFY_PARAM functions */
  471. OPENSSL_EXPORT X509_VERIFY_PARAM *X509_VERIFY_PARAM_new(void);
  472. OPENSSL_EXPORT void X509_VERIFY_PARAM_free(X509_VERIFY_PARAM *param);
  473. OPENSSL_EXPORT int X509_VERIFY_PARAM_inherit(X509_VERIFY_PARAM *to,
  474. const X509_VERIFY_PARAM *from);
  475. OPENSSL_EXPORT int X509_VERIFY_PARAM_set1(X509_VERIFY_PARAM *to,
  476. const X509_VERIFY_PARAM *from);
  477. OPENSSL_EXPORT int X509_VERIFY_PARAM_set1_name(X509_VERIFY_PARAM *param, const char *name);
  478. OPENSSL_EXPORT int X509_VERIFY_PARAM_set_flags(X509_VERIFY_PARAM *param, unsigned long flags);
  479. OPENSSL_EXPORT int X509_VERIFY_PARAM_clear_flags(X509_VERIFY_PARAM *param,
  480. unsigned long flags);
  481. OPENSSL_EXPORT unsigned long X509_VERIFY_PARAM_get_flags(X509_VERIFY_PARAM *param);
  482. OPENSSL_EXPORT int X509_VERIFY_PARAM_set_purpose(X509_VERIFY_PARAM *param, int purpose);
  483. OPENSSL_EXPORT int X509_VERIFY_PARAM_set_trust(X509_VERIFY_PARAM *param, int trust);
  484. OPENSSL_EXPORT void X509_VERIFY_PARAM_set_depth(X509_VERIFY_PARAM *param, int depth);
  485. OPENSSL_EXPORT void X509_VERIFY_PARAM_set_time(X509_VERIFY_PARAM *param, time_t t);
  486. OPENSSL_EXPORT int X509_VERIFY_PARAM_add0_policy(X509_VERIFY_PARAM *param,
  487. ASN1_OBJECT *policy);
  488. OPENSSL_EXPORT int X509_VERIFY_PARAM_set1_policies(X509_VERIFY_PARAM *param,
  489. STACK_OF(ASN1_OBJECT) *policies);
  490. OPENSSL_EXPORT int X509_VERIFY_PARAM_set1_host(X509_VERIFY_PARAM *param,
  491. const char *name, size_t namelen);
  492. OPENSSL_EXPORT int X509_VERIFY_PARAM_add1_host(X509_VERIFY_PARAM *param,
  493. const char *name,
  494. size_t namelen);
  495. OPENSSL_EXPORT void X509_VERIFY_PARAM_set_hostflags(X509_VERIFY_PARAM *param,
  496. unsigned int flags);
  497. OPENSSL_EXPORT char *X509_VERIFY_PARAM_get0_peername(X509_VERIFY_PARAM *);
  498. OPENSSL_EXPORT int X509_VERIFY_PARAM_set1_email(X509_VERIFY_PARAM *param,
  499. const char *email, size_t emaillen);
  500. OPENSSL_EXPORT int X509_VERIFY_PARAM_set1_ip(X509_VERIFY_PARAM *param,
  501. const unsigned char *ip, size_t iplen);
  502. OPENSSL_EXPORT int X509_VERIFY_PARAM_set1_ip_asc(X509_VERIFY_PARAM *param, const char *ipasc);
  503. OPENSSL_EXPORT int X509_VERIFY_PARAM_get_depth(const X509_VERIFY_PARAM *param);
  504. OPENSSL_EXPORT const char *X509_VERIFY_PARAM_get0_name(const X509_VERIFY_PARAM *param);
  505. OPENSSL_EXPORT int X509_VERIFY_PARAM_add0_table(X509_VERIFY_PARAM *param);
  506. OPENSSL_EXPORT int X509_VERIFY_PARAM_get_count(void);
  507. OPENSSL_EXPORT const X509_VERIFY_PARAM *X509_VERIFY_PARAM_get0(int id);
  508. OPENSSL_EXPORT const X509_VERIFY_PARAM *X509_VERIFY_PARAM_lookup(const char *name);
  509. OPENSSL_EXPORT void X509_VERIFY_PARAM_table_cleanup(void);
  510. OPENSSL_EXPORT int X509_policy_check(X509_POLICY_TREE **ptree, int *pexplicit_policy,
  511. STACK_OF(X509) *certs,
  512. STACK_OF(ASN1_OBJECT) *policy_oids,
  513. unsigned int flags);
  514. OPENSSL_EXPORT void X509_policy_tree_free(X509_POLICY_TREE *tree);
  515. OPENSSL_EXPORT int X509_policy_tree_level_count(const X509_POLICY_TREE *tree);
  516. OPENSSL_EXPORT X509_POLICY_LEVEL *
  517. X509_policy_tree_get0_level(const X509_POLICY_TREE *tree, int i);
  518. OPENSSL_EXPORT STACK_OF(X509_POLICY_NODE) *
  519. X509_policy_tree_get0_policies(const X509_POLICY_TREE *tree);
  520. OPENSSL_EXPORT STACK_OF(X509_POLICY_NODE) *
  521. X509_policy_tree_get0_user_policies(const X509_POLICY_TREE *tree);
  522. OPENSSL_EXPORT int X509_policy_level_node_count(X509_POLICY_LEVEL *level);
  523. OPENSSL_EXPORT X509_POLICY_NODE *X509_policy_level_get0_node(X509_POLICY_LEVEL *level, int i);
  524. OPENSSL_EXPORT const ASN1_OBJECT *X509_policy_node_get0_policy(const X509_POLICY_NODE *node);
  525. OPENSSL_EXPORT STACK_OF(POLICYQUALINFO) *
  526. X509_policy_node_get0_qualifiers(const X509_POLICY_NODE *node);
  527. OPENSSL_EXPORT const X509_POLICY_NODE *
  528. X509_policy_node_get0_parent(const X509_POLICY_NODE *node);
  529. #ifdef __cplusplus
  530. }
  531. #endif
  532. #endif