Remove last hardcode string I have check the soure 3more time after I found some...
[reactos.git] / reactos / w32api / include / schannel.h
1 #ifndef _SCHANNEL_H
2 #define _SCHANNEL_H
3 #if __GNUC__ >=3
4 #pragma GCC system_header
5 #endif
6
7 #include <wincrypt.h>
8
9 #ifdef __cplusplus
10 extern "C" {
11 #endif
12
13 #define SCHANNEL_CRED_VERSION 4
14 #define SCHANNEL_SHUTDOWN 1
15 /* ? Do these belong here or in wincrypt.h */
16 #define AUTHTYPE_CLIENT 1
17 #define AUTHTYPE_SERVER 2
18
19 #define SP_PROT_TLS1_CLIENT 128
20 #define SP_PROT_TLS1_SERVER 64
21 #define SP_PROT_SSL3_CLIENT 32
22 #define SP_PROT_SSL3_SERVER 16
23 #define SP_PROT_SSL2_CLIENT 8
24 #define SP_PROT_SSL2_SERVER 4
25 #define SP_PROT_PCT1_SERVER 1
26 #define SP_PROT_PCT1_CLIENT 2
27
28 #define SP_PROT_PCT1 (SP_PROT_PCT1_CLIENT|SP_PROT_PCT1_SERVER)
29 #define SP_PROT_TLS1 (SP_PROT_TLS1_CLIENT|SP_PROT_TLS1_SERVER)
30 #define SP_PROT_SSL2 (SP_PROT_SSL2_CLIENT|SP_PROT_SSL2_SERVER)
31 #define SP_PROT_SSL3 (SP_PROT_SSL3_CLIENT|SP_PROT_SSL3_SERVER)
32
33 #define SCH_CRED_NO_SYSTEM_MAPPER 2
34 #define SCH_CRED_NO_SERVERNAME_CHECK 4
35 #define SCH_CRED_MANUAL_CRED_VALIDATION 8
36 #define SCH_CRED_NO_DEFAULT_CREDS 16
37 #define SCH_CRED_AUTO_CRED_VALIDATION 32
38 #define SCH_CRED_REVOCATION_CHECK_CHAIN 512
39 #define SCH_CRED_REVOCATION_CHECK_END_CERT 256
40 #define SCH_CRED_REVOCATION_CHECK_CHAIN_EXCLUDE_ROOT 1024
41 #define SCH_CRED_IGNORE_NO_REVOCATION_CHECK 2048
42 #define SCH_CRED_IGNORE_REVOCATION_OFFLINE 4096
43 #define SCH_CRED_USE_DEFAULT_CREDS 64
44
45 typedef struct _SCHANNEL_CRED {
46 DWORD dwVersion;
47 DWORD cCreds;
48 PCCERT_CONTEXT* paCred;
49 HCERTSTORE hRootStore;
50 DWORD cMappers;
51 struct _HMAPPER** aphMappers;
52 DWORD cSupportedAlgs;
53 ALG_ID* palgSupportedAlgs;
54 DWORD grbitEnabledProtocols;
55 DWORD dwMinimumCypherStrength;
56 DWORD dwMaximumCypherStrength;
57 DWORD dwSessionLifespan;
58 DWORD dwFlags;
59 DWORD reserved;
60 } SCHANNEL_CRED, *PSCHANNEL_CRED;
61 typedef struct _SecPkgCred_SupportedAlgs {
62 DWORD cSupportedAlgs;
63 ALG_ID* palgSupportedAlgs;
64 } SecPkgCred_SupportedAlgs, *PSecPkgCred_SupportedAlgs;
65 typedef struct _SecPkgCred_CypherStrengths {
66 DWORD dwMinimumCypherStrength;
67 DWORD dwMaximumCypherStrength;
68 } SecPkgCred_CypherStrengths, *PSecPkgCred_CypherStrengths;
69 typedef struct _SecPkgCred_SupportedProtocols {
70 DWORD grbitProtocol;
71 } SecPkgCred_SupportedProtocols, *PSecPkgCred_SupportedProtocols;
72 typedef struct _SecPkgContext_IssuerListInfoEx {
73 PCERT_NAME_BLOB aIssuers;
74 DWORD cIssuers;
75 } SecPkgContext_IssuerListInfoEx, *PSecPkgContext_IssuerListInfoEx;
76 typedef struct _SecPkgContext_ConnectionInfo {
77 DWORD dwProtocol;
78 ALG_ID aiCipher;
79 DWORD dwCipherStrength;
80 ALG_ID aiHash;
81 DWORD dwHashStrength;
82 ALG_ID aiExch;
83 DWORD dwExchStrength;
84 } SecPkgContext_ConnectionInfo, *PSecPkgContext_ConnectionInfo;
85
86 #ifdef __cplusplus
87 }
88 #endif
89
90 #endif /* _SCHANNEL_H */