1use libc::*;
2
3use super::*;
4
5#[repr(C)]
6pub struct GENERAL_NAME {
7 pub type_: c_int,
8 pub d: *mut c_void,
10}
11
12stack!(stack_st_GENERAL_NAME);
13
14pub const GEN_OTHERNAME: c_int = 0;
15pub const GEN_EMAIL: c_int = 1;
16pub const GEN_DNS: c_int = 2;
17pub const GEN_X400: c_int = 3;
18pub const GEN_DIRNAME: c_int = 4;
19pub const GEN_EDIPARTY: c_int = 5;
20pub const GEN_URI: c_int = 6;
21pub const GEN_IPADD: c_int = 7;
22pub const GEN_RID: c_int = 8;
23
24pub const X509_CHECK_FLAG_ALWAYS_CHECK_SUBJECT: c_uint = 0x1;
25pub const X509_CHECK_FLAG_NO_WILDCARDS: c_uint = 0x2;
26pub const X509_CHECK_FLAG_NO_PARTIAL_WILDCARDS: c_uint = 0x4;
27pub const X509_CHECK_FLAG_MULTI_LABEL_WILDCARDS: c_uint = 0x8;
28pub const X509_CHECK_FLAG_SINGLE_LABEL_SUBDOMAINS: c_uint = 0x10;
29#[cfg(ossl110)]
30pub const X509_CHECK_FLAG_NEVER_CHECK_SUBJECT: c_uint = 0x20;
31
32pub const X509V3_ADD_DEFAULT: c_ulong = 0;
33pub const X509V3_ADD_APPEND: c_ulong = 1;
34pub const X509V3_ADD_REPLACE: c_ulong = 2;
35pub const X509V3_ADD_REPLACE_EXISTING: c_ulong = 3;
36pub const X509V3_ADD_KEEP_EXISTING: c_ulong = 4;
37pub const X509V3_ADD_DELETE: c_ulong = 5;
38pub const X509V3_ADD_SILENT: c_ulong = 0x10;
39
40pub const EXFLAG_BCONS: u32 = 0x1;
41pub const EXFLAG_KUSAGE: u32 = 0x2;
42pub const EXFLAG_XKUSAGE: u32 = 0x4;
43pub const EXFLAG_NSCERT: u32 = 0x8;
44pub const EXFLAG_CA: u32 = 0x10;
45pub const EXFLAG_SI: u32 = 0x20;
46pub const EXFLAG_V1: u32 = 0x40;
47pub const EXFLAG_INVALID: u32 = 0x80;
48pub const EXFLAG_SET: u32 = 0x100;
49pub const EXFLAG_CRITICAL: u32 = 0x200;
50pub const EXFLAG_PROXY: u32 = 0x400;
51pub const EXFLAG_INVALID_POLICY: u32 = 0x800;
52pub const EXFLAG_FRESHEST: u32 = 0x1000;
53pub const EXFLAG_SS: u32 = 0x2000;
54
55pub const X509v3_KU_DIGITAL_SIGNATURE: u32 = 0x0080;
56pub const X509v3_KU_NON_REPUDIATION: u32 = 0x0040;
57pub const X509v3_KU_KEY_ENCIPHERMENT: u32 = 0x0020;
58pub const X509v3_KU_DATA_ENCIPHERMENT: u32 = 0x0010;
59pub const X509v3_KU_KEY_AGREEMENT: u32 = 0x0008;
60pub const X509v3_KU_KEY_CERT_SIGN: u32 = 0x0004;
61pub const X509v3_KU_CRL_SIGN: u32 = 0x0002;
62pub const X509v3_KU_ENCIPHER_ONLY: u32 = 0x0001;
63pub const X509v3_KU_DECIPHER_ONLY: u32 = 0x8000;
64pub const X509v3_KU_UNDEF: u32 = 0xffff;
65
66pub const XKU_SSL_SERVER: u32 = 0x1;
67pub const XKU_SSL_CLIENT: u32 = 0x2;
68pub const XKU_SMIME: u32 = 0x4;
69pub const XKU_CODE_SIGN: u32 = 0x8;
70pub const XKU_SGC: u32 = 0x10;
71pub const XKU_OCSP_SIGN: u32 = 0x20;
72pub const XKU_TIMESTAMP: u32 = 0x40;
73pub const XKU_DVCS: u32 = 0x80;
74#[cfg(ossl110)]
75pub const XKU_ANYEKU: u32 = 0x100;
76
77pub const X509_PURPOSE_SSL_CLIENT: c_int = 1;
78pub const X509_PURPOSE_SSL_SERVER: c_int = 2;
79pub const X509_PURPOSE_NS_SSL_SERVER: c_int = 3;
80pub const X509_PURPOSE_SMIME_SIGN: c_int = 4;
81pub const X509_PURPOSE_SMIME_ENCRYPT: c_int = 5;
82pub const X509_PURPOSE_CRL_SIGN: c_int = 6;
83pub const X509_PURPOSE_ANY: c_int = 7;
84pub const X509_PURPOSE_OCSP_HELPER: c_int = 8;
85pub const X509_PURPOSE_TIMESTAMP_SIGN: c_int = 9;
86#[cfg(ossl320)]
87pub const X509_PURPOSE_CODE_SIGN: c_int = 10;
88pub const X509_PURPOSE_MIN: c_int = 1;
89cfg_if! {
90 if #[cfg(ossl320)] {
91 pub const X509_PURPOSE_MAX: c_int = 10;
92 } else {
93 pub const X509_PURPOSE_MAX: c_int = 9;
94 }
95}
96
97pub const CRL_REASON_UNSPECIFIED: c_int = 0;
98pub const CRL_REASON_KEY_COMPROMISE: c_int = 1;
99pub const CRL_REASON_CA_COMPROMISE: c_int = 2;
100pub const CRL_REASON_AFFILIATION_CHANGED: c_int = 3;
101pub const CRL_REASON_SUPERSEDED: c_int = 4;
102pub const CRL_REASON_CESSATION_OF_OPERATION: c_int = 5;
103pub const CRL_REASON_CERTIFICATE_HOLD: c_int = 6;
104pub const CRL_REASON_REMOVE_FROM_CRL: c_int = 8;
105pub const CRL_REASON_PRIVILEGE_WITHDRAWN: c_int = 9;
106pub const CRL_REASON_AA_COMPROMISE: c_int = 10;