Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

270 lines
7.3 KiB

//+---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1995.
//
// File: context.h
//
// Contents: Schannel context declarations.
//
// Classes:
//
// Functions:
//
// History: 09-23-97 jbanes Ported over SGC stuff from NT 4 tree.
//
//----------------------------------------------------------------------------
#include <sha.h>
#include <md5.h>
#include <ssl3.h>
#define SP_CONTEXT_MAGIC *(DWORD *)"!Tcp"
typedef struct _SPContext
{
DWORD Magic; /* tags structure */
DWORD State; /* the current state the connection is in */
DWORD Flags;
/* data for the context that can be used
* to start a new session */
PSessCacheItem RipeZombie; /* cacheable context that is being used */
PSPCredentialGroup pCredGroup;
PSPCredential pActiveClientCred;
LPWSTR pszTarget;
LPWSTR pszCredentialName;
DWORD dwProtocol;
DWORD dwClientEnabledProtocols;
CRED_THUMBPRINT ContextThumbprint;
// Pointers to cipher info used
// during transmission of bulk data.
PCipherInfo pCipherInfo;
PCipherInfo pReadCipherInfo;
PCipherInfo pWriteCipherInfo;
PHashInfo pHashInfo;
PHashInfo pReadHashInfo;
PHashInfo pWriteHashInfo;
PKeyExchangeInfo pKeyExchInfo;
/* functions pointing to the various handlers for this protocol */
SPDecryptMessageFn Decrypt;
SPEncryptMessageFn Encrypt;
SPProtocolHandlerFn ProtocolHandler;
SPDecryptHandlerFn DecryptHandler;
SPInitiateHelloFn InitiateHello;
SPGetHeaderSizeFn GetHeaderSize;
/* session crypto state */
// encryption key size.
DWORD KeySize;
// Encryption states
HCRYPTPROV hReadProv;
HCRYPTPROV hWriteProv;
HCRYPTKEY hReadKey;
HCRYPTKEY hWriteKey;
HCRYPTKEY hPendingReadKey;
HCRYPTKEY hPendingWriteKey;
HCRYPTKEY hReadMAC;
HCRYPTKEY hWriteMAC;
HCRYPTKEY hPendingReadMAC;
HCRYPTKEY hPendingWriteMAC;
// Packet Sequence counters.
DWORD ReadCounter;
DWORD WriteCounter;
DWORD cbConnectionID;
UCHAR pConnectionID[SP_MAX_CONNECTION_ID];
DWORD cbChallenge;
UCHAR pChallenge[SP_MAX_CHALLENGE];
// Save copy of client hello to hash for verification.
DWORD cbClientHello;
PUCHAR pClientHello;
DWORD dwClientHelloProtocol;
// Pending cipher info, used to generate keys
PCipherInfo pPendingCipherInfo;
PHashInfo pPendingHashInfo;
// SSL3 specific items.
UCHAR bAlertLevel; // Used for SSL3 & TLS1 alert messages
UCHAR bAlertNumber;
BOOL fAppProcess;
BOOL fExchKey; // Did we sent a Exchnage key message
BOOL fCertReq; //Did we request a certificatefor server and Should I need to send a cert for client
BOOL fInsufficientCred; //This will be TRUE when the pCred inside
//pContext doesn't match the CR list. from the server.
HCRYPTHASH hMd5Handshake;
HCRYPTHASH hShaHandshake;
PUCHAR pbIssuerList;
DWORD cbIssuerList;
PUCHAR pbEncryptedKey;
DWORD cbEncryptedKey;
PUCHAR pbServerKeyExchange;
DWORD cbServerKeyExchange;
WORD wS3CipherSuiteClient;
WORD wS3CipherSuiteServer;
DWORD dwPendingCipherSuiteIndex;
UCHAR rgbS3CRandom[CB_SSL3_RANDOM];
UCHAR rgbS3SRandom[CB_SSL3_RANDOM];
DWORD cSsl3ClientCertTypes;
DWORD Ssl3ClientCertTypes[SSL3_MAX_CLIENT_CERTS];
// Server Gated Crypto
DWORD dwRequestedCF;
// Allow cert chains for PCT1
BOOL fCertChainsAllowed;
} SPContext, * PSPContext;
typedef struct _SPPackedContext
{
DWORD Magic;
DWORD State;
DWORD Flags;
DWORD dwProtocol;
CRED_THUMBPRINT ContextThumbprint;
DWORD dwCipherInfo;
DWORD dwHashInfo;
DWORD dwKeyExchInfo;
DWORD dwExchStrength;
DWORD ReadCounter;
DWORD WriteCounter;
ULARGE_INTEGER hMasterProv;
ULARGE_INTEGER hReadKey;
ULARGE_INTEGER hWriteKey;
ULARGE_INTEGER hReadMAC;
ULARGE_INTEGER hWriteMAC;
ULARGE_INTEGER hLocator;
DWORD LocatorStatus;
DWORD cbSessionID;
UCHAR SessionID[SP_MAX_SESSION_ID];
} SPPackedContext, *PSPPackedContext;
/* Flags */
#define CONTEXT_FLAG_CLIENT 0x00000001
#define CONTEXT_FLAG_USE_SUPPLIED_CREDS 0x00000080 // Don't search for default credential.
#define CONTEXT_FLAG_MUTUAL_AUTH 0x00000100
#define CONTEXT_FLAG_EXT_ERR 0x00000200 /* Generate error message on error */
#define CONTEXT_FLAG_NO_INCOMPLETE_CRED_MSG 0x00000400 /* don't generate an INCOMPLETE CREDS message */
#define CONTEXT_FLAG_CONNECTION_MODE 0x00001000 /* as opposed to stream mode */
#define CONTEXT_FLAG_NOCACHE 0x00002000 /* do not look things up in the cache */
#define CONTEXT_FLAG_MANUAL_CRED_VALIDATION 0x00004000 // Don't validate server cert.
#define CONTEXT_FLAG_FULL_HANDSHAKE 0x00008000
#define CONTEXT_FLAG_MAPPED 0x40000000
#define CONTEXT_FLAG_SERIALIZED 0x80000000
#ifdef DBG
PSTR DbgGetNameOfCrypto(DWORD x);
#endif
PSPContext SPContextCreate(LPWSTR pszTarget);
BOOL
SPContextClean(PSPContext pContext);
BOOL SPContextDelete(PSPContext pContext);
SP_STATUS
SPContextSetCredentials(
PSPContext pContext,
PSPCredentialGroup pCred);
SP_STATUS
ContextInitCiphersFromCache(
SPContext *pContext);
SP_STATUS
ContextInitCiphers(
SPContext *pContext,
BOOL fRead,
BOOL fWrite);
SP_STATUS
SPContextDoMapping(
PSPContext pContext);
SP_STATUS
RemoveDuplicateIssuers(
PBYTE pbIssuers,
PDWORD pcbIssuers);
SP_STATUS
SPContextGetIssuers(
PSPCredentialGroup pCredGroup);
BOOL FGetServerIssuer(
PBYTE pbIssuer,
DWORD *pdwIssuer);
SP_STATUS
SPPickClientCertificate(
PSPContext pContext,
DWORD dwExchSpec);
SP_STATUS
SPPickServerCertificate(
PSPContext pContext,
DWORD dwExchSpec);
SP_STATUS DetermineClientCSP(PSPContext pContext);
typedef BOOL
(WINAPI * SERIALIZE_LOCATOR_FN)(
HLOCATOR Locator,
HLOCATOR * NewLocator);
SP_STATUS
SPContextSerialize(
PSPContext pContext,
SERIALIZE_LOCATOR_FN LocatorMove,
PBYTE * ppBuffer,
PDWORD pcbBuffer,
BOOL fDestroyKeys);
SP_STATUS
SPContextDeserialize(
PBYTE pbBuffer,
PSPContext *ppContext);
BOOL
LsaContextDelete(PSPContext pContext);