| 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 */ |