Work around MinGW mangling of "host:/path"
[msysgit/historical-msysgit.git] / mingw / include / schannel.h
blobe01055517100fc035e94308faab236a1ff09e7ad
1 #ifndef _SCHANNEL_H
2 #define _SCHANNEL_H
3 #if __GNUC__ >=3
4 #pragma GCC system_header
5 #endif
7 #include <wincrypt.h>
9 #ifdef __cplusplus
10 extern "C" {
11 #endif
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
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
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)
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
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;
86 #ifdef __cplusplus
88 #endif
90 #endif /* _SCHANNEL_H */