//+----------------------------------------------------------------------- // // File: kerbcomm.h // // Contents: prototypes for common kerberos routines // // // History: 15-May-1996 Created MikeSw // //------------------------------------------------------------------------ #ifndef _KERBCOMM_H_ #define _KERBCOMM_H_ #ifdef __cplusplus extern "C" { #endif // __cplusplus #include #include #ifndef WIN32_CHICAGO #include #endif // WIN32_CHICAGO #include #include #include #include #include #include #include #ifdef __cplusplus } #endif // _cplusplus #include #include #include #include #ifndef WIN32_CHICAGO // SECURITY_WIN32 is already defined #include #endif // WIN32_CHICAGO // // HACK HACK HACK on xp sp1, we can not have STATUS_USER2USER_REQUIRED in ntstatus.mc! // // // MessageId: STATUS_USER2USER_REQUIRED // // MessageText: // // Kerberos sub-protocol User2User is required. // #define STATUS_USER2USER_REQUIRED ((NTSTATUS)0xC0000408L) ////////////////////////////////////////////////////////////////////////// // // Definitions (for lack of a better place) // ////////////////////////////////////////////////////////////////////////// // // Message types // #define KRB_AS_REQ 10 // Request for initial authentication #define KRB_AS_REP 11 // Response to KRB_AS_REQ request #define KRB_TGS_REQ 12 // Request for authentication based on TGT #define KRB_TGS_REP 13 // Response to KRB_TGS_REQ request #define KRB_AP_REQ 14 // application request to server #define KRB_AP_REP 15 // Response to KRB_AP_REQ_MUTUAL #define KRB_TGT_REQ 16 // Request for TGT for user-to-user #define KRB_TGT_REP 17 // Reply to TGT request #define KRB_SAFE 20 // Safe (checksummed) application message #define KRB_PRIV 21 // Private (encrypted) application message #define KRB_CRED 22 // Private (encrypted) message to forward // credentials #define KRB_ERROR 30 // Error response // // Pre-auth data types #define KRB5_PADATA_NONE 0 #define KRB5_PADATA_AP_REQ 1 #define KRB5_PADATA_TGS_REQ KRB5_PADATA_AP_REQ #define KRB5_PADATA_ENC_TIMESTAMP 2 #define KRB5_PADATA_PW_SALT 3 #define KRB5_PADATA_ENC_UNIX_TIME 5 /* timestamp encrypted in key */ #define KRB5_PADATA_ENC_SANDIA_SECURID 6 /* SecurId passcode */ #define KRB5_PADATA_SESAME 7 /* Sesame project */ #define KRB5_PADATA_OSF_DCE 8 /* OSF DCE */ #define KRB5_CYBERSAFE_SECUREID 9 /* Cybersafe */ #define KRB5_PADATA_AFS3_SALT 10 /* Cygnus */ #define KRB5_PADATA_ETYPE_INFO 11 /* Etype info for preauth */ #define KRB5_PADATA_SAM_CHALLENGE 12 /* draft challenge system */ #define KRB5_PADATA_SAM_RESPONSE 13 /* draft challenge system response */ #define KRB5_PADATA_PK_AS_REQ 14 /* pkinit */ #define KRB5_PADATA_PK_AS_REP 15 /* pkinit */ #define KRB5_PADATA_PK_AS_SIGN 16 /* pkinit */ #define KRB5_PADATA_PK_KEY_REQ 17 /* pkinit */ #define KRB5_PADATA_PK_KEY_REP 18 /* pkinit */ #define KRB5_PADATA_REFERRAL_INFO 20 /* referral names for canonicalization */ #define KRB5_PADATA_S4U 21 #define KRB5_PADATA_PAC_REQUEST 128 /* allow client do request or ignore PAC */ // // Authorization data types // #define KERB_AUTH_OSF_DCE 64 #define KERB_AUTH_SESAME 65 // // NT authorization data type definitions // #define KERB_AUTH_DATA_PAC 128 // entry id for a PAC in authorization data #define KERB_AUTH_PROXY_ANNOTATION 139 // entry id for a proxy logon annotation string #define KERB_AUTH_DATA_IF_RELEVANT 1 // entry id for optional auth data #define KERB_AUTH_DATA_KDC_ISSUED 4 // entry id for data generated & signed by KDC #define KERB_AUTH_DATA_TOKEN_RESTRICTIONS 141 // entry id for token restrictions // // Transited realm compression types: // #define DOMAIN_X500_COMPRESS 1 // // Certificate types for PKINIT // #define KERB_CERTIFICATE_TYPE_X509 1 #define KERB_CERTIFICATE_TYPE_PGP 2 // // Signature & seal types used by PKINIT // #define KERB_PKINIT_SIGNATURE_ALG CALG_MD5 #define KERB_PKINIT_EXPORT_SEAL_OID szOID_RSA_RC2CBC #define KERB_PKINIT_EXPORT_SEAL_ETYPE KERB_ETYPE_RC2_CBC_ENV #define KERB_PKINIT_SEAL_ETYPE KERB_ETYPE_DES_EDE3_CBC_ENV #define KERB_PKINIT_SEAL_OID szOID_RSA_DES_EDE3_CBC #define KERB_PKINIT_SIGNATURE_OID szOID_RSA_MD5RSA #define KERB_PKINIT_KDC_CERT_TYPE szOID_PKIX_KP_SERVER_AUTH #ifdef szOID_KP_SMARTCARD_LOGON #define KERB_PKINIT_CLIENT_CERT_TYPE szOID_KP_SMARTCARD_LOGON #else #define KERB_PKINIT_CLIENT_CERT_TYPE "1.3.6.1.4.1.311.20.2.2" #endif // // Transport information // #define KERB_KDC_PORT 88 #define KERB_KPASSWD_PORT 464 // // KDC service principal // #define KDC_PRINCIPAL_NAME L"krbtgt" #define KDC_PRINCIPAL_NAME_A "krbtgt" #define KERB_HOST_STRING_A "host" #define KERB_HOST_STRING L"host" #define KERB_KPASSWD_FIRST_NAME L"kadmin" #define KERB_KPASSWD_SECOND_NAME L"changepw" // // address types - corresponds to GSS types // #define KERB_ADDRTYPE_UNSPEC 0x0 #define KERB_ADDRTYPE_LOCAL 0x1 #define KERB_ADDRTYPE_INET 0x2 #define KERB_ADDRTYPE_IMPLINK 0x3 #define KERB_ADDRTYPE_PUP 0x4 #define KERB_ADDRTYPE_CHAOS 0x5 #define KERB_ADDRTYPE_NS 0x6 #define KERB_ADDRTYPE_NBS 0x7 #define KERB_ADDRTYPE_ECMA 0x8 #define KERB_ADDRTYPE_DATAKIT 0x9 #define KERB_ADDRTYPE_CCITT 0xA #define KERB_ADDRTYPE_SNA 0xB #define KERB_ADDRTYPE_DECnet 0xC #define KERB_ADDRTYPE_DLI 0xD #define KERB_ADDRTYPE_LAT 0xE #define KERB_ADDRTYPE_HYLINK 0xF #define KERB_ADDRTYPE_APPLETALK 0x10 #define KERB_ADDRTYPE_BSC 0x11 #define KERB_ADDRTYPE_DSS 0x12 #define KERB_ADDRTYPE_OSI 0x13 #define KERB_ADDRTYPE_NETBIOS 0x14 #define KERB_ADDRTYPE_X25 0x15 // // Misc. Flags // #define KERB_EXPORT_KEY_FLAG 0x20000000 // // SALT flags for encryption, from rfc1510 update 3des enctype // #define KERB_ENC_TIMESTAMP_SALT 1 #define KERB_TICKET_SALT 2 #define KERB_AS_REP_SALT 3 #define KERB_TGS_REQ_SESSKEY_SALT 4 #define KERB_TGS_REQ_SUBKEY_SALT 5 #define KERB_TGS_REQ_AP_REQ_AUTH_CKSUM_SALT 6 #define KERB_TGS_REQ_AP_REQ_AUTH_SALT 7 #define KERB_TGS_REP_SALT 8 #define KERB_TGS_REP_SUBKEY_SALT 9 #define KERB_AP_REQ_AUTH_CKSUM_SALT 10 #define KERB_AP_REQ_AUTH_SALT 11 #define KERB_AP_REP_SALT 12 #define KERB_PRIV_SALT 13 #define KERB_CRED_SALT 14 #define KERB_SAFE_SALT 15 #define KERB_NON_KERB_SALT 16 #define KERB_NON_KERB_CKSUM_SALT 17 #define KERB_KERB_ERROR_SALT 18 #define KERB_KDC_ISSUED_CKSUM_SALT 19 #define KERB_MANDATORY_TKT_EXT_CKSUM_SALT 20 #define KERB_AUTH_DATA_TKT_EXT_CKSUM_SALT 21 // // Types for AP error data // #define KERB_AP_ERR_TYPE_NTSTATUS 1 #define KERB_AP_ERR_TYPE_SKEW_RECOVERY 2 // // Types for extended errors // #define KERB_ERR_TYPE_EXTENDED 3 #define TD_MUST_USE_USER2USER -128 #define TD_EXTENDED_ERROR -129 // // PKINIT method errors // #define KERB_PKINIT_UNSPEC_ERROR 0 // not specified #define KERB_PKINIT_BAD_PUBLIC_KEY 1 // cannot verify public key #define KERB_PKINIT_INVALID_CERT 2 // invalid certificate #define KERB_PKINIT_REVOKED_CERT 3 // revoked certificate #define KERB_PKINIT_INVALID_KDC_NAME 4 // invalid KDC name #define KERB_PKINIT_CLIENT_NAME_MISMATCH 5 // client name mismatch // // Flag bit defines for use with the LogonRestrictionsFlag parameter // passed to the KerbCheckLogonRestrictions function // #define KDC_RESTRICT_PKINIT_USED 1 #define KDC_RESTRICT_IGNORE_PW_EXPIRATION 2 // // HACK for MAX_UNICODE_STRING, as KerbDuplicateString & others add a NULL // terminator when doing the duplication // #define KERB_MAX_UNICODE_STRING (UNICODE_STRING_MAX_BYTES - sizeof(WCHAR)) #define KERB_MAX_STRING (UNICODE_STRING_MAX_BYTES - sizeof(CHAR)) ////////////////////////////////////////////////////////////////////////// // // Structures // ////////////////////////////////////////////////////////////////////////// typedef struct _KERB_PREAUTH_DATA { ULONG Flags; } KERB_PREAUTH_DATA, *PKERB_PREAUTH_DATA; #define KERBFLAG_LOGON 0x1 #define KERBFLAG_INTERACTIVE 0x2 // // KDC-Kerberos interaction // #define KDC_START_EVENT L"\\Security\\KdcStartEvent" #define KERB_MAX_CRYPTO_SYSTEMS 20 #define KERB_MAX_CRYPTO_SYSTEMS_SLOWBUFF 100 #define KERB_DEFAULT_AP_REQ_CSUM KERB_CHECKSUM_MD5 #define KERB_DEFAULT_PREAUTH_TYPE 0 // // Registry parameters // #define KERB_PARAMETER_PATH L"System\\CurrentControlSet\\Control\\Lsa\\Kerberos" #define KERB_PARAMETER_SKEWTIME L"SkewTime" #define KERB_PARAMETER_MAX_UDP_PACKET L"MaxPacketSize" #define KERB_PARAMETER_START_TIME L"StartupTime" #define KERB_PARAMETER_KDC_CALL_TIMEOUT L"KdcWaitTime" #define KERB_PARAMETER_KDC_BACKOFF_TIME L"KdcBackoffTime" #define KERB_PARAMETER_KDC_SEND_RETRIES L"KdcSendRetries" #define KERB_PARAMETER_USE_SID_CACHE L"UseSidCache" #define KERB_PARAMETER_LOG_LEVEL L"LogLevel" #define KERB_PARAMETER_DEFAULT_ETYPE L"DefaultEncryptionType" #define KERB_PARAMETER_FAR_KDC_TIMEOUT L"FarKdcTimeout" #define KERB_PARAMETER_NEAR_KDC_TIMEOUT L"NearKdcTimeout" #define KERB_PARAMETER_STRONG_ENC_DG L"StronglyEncryptDatagram" #define KERB_PARAMETER_MAX_REFERRAL_COUNT L"MaxReferralCount" #define KERB_PARAMETER_MAX_TOKEN_SIZE L"MaxTokenSize" #define KERB_PARAMETER_SPN_CACHE_TIMEOUT L"SpnCacheTimeout" #define KERB_PARAMETER_RETRY_PDC L"RetryPDC" #define KERB_PARAMETER_REQUEST_OPTIONS L"RequestOptions" #define KERB_PARAMETER_CLIENT_IP_ADDRESSES L"ClientIpAddresses" #define KERB_PARAMETER_TGT_RENEWAL_INTERVAL L"TgtRenewalInterval" // // Registry defaults // #define KERB_DEFAULT_LOGLEVEL 0 #define KERB_DEFAULT_USE_SIDCACHE FALSE #define KERB_DEFAULT_USE_STRONG_ENC_DG FALSE #define KERB_DEFAULT_CLIENT_IP_ADDRESSES 0 #define KERB_DEFAULT_TGT_RENEWAL_INTERVAL ( 10 * 60 - 5 ) // // These are arbitrary sizes for max request and responses sizes for datagram // requests. // #define KERB_MAX_KDC_RESPONSE_SIZE 4000 #define KERB_MAX_KDC_REQUEST_SIZE 4000 #define KERB_MAX_DATAGRAM_SIZE 2000 #define KERB_MAX_RETRIES 3 #define KERB_MAX_REFERRAL_COUNT 10 // // timeout values in minutes // #define KERB_BINDING_FAR_DC_TIMEOUT 10 #define KERB_BINDING_NEAR_DC_TIMEOUT 30 #define KERB_SPN_CACHE_TIMEOUT 15 #define KERB_DEFAULT_SKEWTIME 5 // // Network service session timer callback frequency // #define KERB_SKLIST_CALLBACK_FEQ 10 // // timeout values in seconds // #define KERB_KDC_CALL_TIMEOUT 5 #define KERB_KDC_CALL_TIMEOUT_BACKOFF 5 #define KERB_KDC_WAIT_TIME 120 // // BER encoding values // #define KERB_BER_APPLICATION_TAG 0xc0 #define KERB_BER_APPLICATION_MASK 0x1f #define KERB_TGS_REQ_TAG 12 #define KERB_AS_REQ_TAG 10 #define KERB_TGS_REP_TAG 13 #define KERB_AS_REP_TAG 11 #define KERB_ERROR_TAG 30 // // Common types // typedef struct _KERB_MESSAGE_BUFFER { ULONG BufferSize; PUCHAR Buffer; } KERB_MESSAGE_BUFFER, *PKERB_MESSAGE_BUFFER; typedef enum _KERB_ACCOUNT_TYPE { UserAccount, MachineAccount, DomainTrustAccount, UnknownAccount } KERB_ACCOUNT_TYPE, *PKERB_ACCOUNT_TYPE; // // This is the maximum number of elements in a KERB_INTERNAL_NAME // #define MAX_NAME_ELEMENTS 20 typedef struct _KERB_INTERNAL_NAME { SHORT NameType; USHORT NameCount; UNICODE_STRING Names[ANYSIZE_ARRAY]; } KERB_INTERNAL_NAME, *PKERB_INTERNAL_NAME; // // Prototypes // #ifdef __cplusplus class CAuthenticatorList; KERBERR NTAPI KerbCheckTicket( IN PKERB_TICKET PackedTicket, IN PKERB_ENCRYPTED_DATA EncryptedAuthenticator, IN PKERB_ENCRYPTION_KEY pkKey, IN OUT CAuthenticatorList * AuthenticatorList, IN PTimeStamp SkewTime, IN ULONG ServiceNameCount, IN OPTIONAL PUNICODE_STRING ServiceName, IN OPTIONAL PUNICODE_STRING ServiceRealm, IN BOOLEAN CheckForReplay, IN BOOLEAN KdcRequest, OUT PKERB_ENCRYPTED_TICKET * EncryptTicket, OUT PKERB_AUTHENTICATOR * Authenticator, OUT PKERB_ENCRYPTION_KEY pkSessionKey, OUT OPTIONAL PKERB_ENCRYPTION_KEY pkTicketKey, OUT PBOOLEAN UseSubKey ); extern "C" { #endif // __cplusplus KERBERR KerbVerifyTicket( IN PKERB_TICKET PackedTicket, IN ULONG NameCount, IN OPTIONAL PUNICODE_STRING ServiceNames, IN OPTIONAL PUNICODE_STRING ServiceRealm, IN PKERB_ENCRYPTION_KEY ServiceKey, IN OPTIONAL PTimeStamp SkewTime, OUT PKERB_ENCRYPTED_TICKET * DecryptedTicket ); KERBERR NTAPI KerbPackTicket( IN PKERB_TICKET InternalTicket, IN PKERB_ENCRYPTION_KEY pkKey, IN ULONG EncryptionType, OUT PKERB_TICKET PackedTicket ); KERBERR NTAPI KerbUnpackTicket( IN PKERB_TICKET PackedTicket, IN PKERB_ENCRYPTION_KEY pkKey, OUT PKERB_ENCRYPTED_TICKET * InternalTicket ); // VOID NTAPI // KerbFreeTicket( // IN PKERB_ENCRYPTED_TICKET Ticket // ); #define KerbFreeTicket( Ticket ) \ KerbFreeData( \ KERB_ENCRYPTED_TICKET_PDU, \ (Ticket) \ ) KERBERR NTAPI KerbDuplicateTicket( OUT PKERB_TICKET DestinationTicket, IN PKERB_TICKET SourceTicket ); VOID KerbFreeDuplicatedTicket( IN PKERB_TICKET Ticket ); VOID CheckForOutsideStringToKey(); KERBERR NTAPI KerbHashPassword( IN PUNICODE_STRING Password, IN ULONG EncryptionType, OUT PKERB_ENCRYPTION_KEY Key ); KERBERR NTAPI KerbHashPasswordEx( IN PUNICODE_STRING Password, IN PUNICODE_STRING PrincipalName, IN ULONG EncryptionType, OUT PKERB_ENCRYPTION_KEY Key ); KERBERR NTAPI KerbMakeKey( IN ULONG EncryptionType, OUT PKERB_ENCRYPTION_KEY NewKey ); BOOLEAN KerbIsKeyExportable( IN PKERB_ENCRYPTION_KEY Key ); KERBERR KerbMakeExportableKey( IN ULONG KeyType, OUT PKERB_ENCRYPTION_KEY NewKey ); KERBERR NTAPI KerbCreateKeyFromBuffer( OUT PKERB_ENCRYPTION_KEY NewKey, IN PUCHAR Buffer, IN ULONG BufferSize, IN ULONG EncryptionType ); KERBERR NTAPI KerbDuplicateKey( OUT PKERB_ENCRYPTION_KEY NewKey, IN PKERB_ENCRYPTION_KEY Key ); VOID KerbFreeKey( IN PKERB_ENCRYPTION_KEY Key ); PKERB_ENCRYPTION_KEY KerbGetKeyFromList( IN PKERB_STORED_CREDENTIAL Passwords, IN ULONG EncryptionType ); KERBERR KerbFindCommonCryptSystem( IN PKERB_CRYPT_LIST CryptList, IN PKERB_STORED_CREDENTIAL Passwords, IN OPTIONAL PKERB_STORED_CREDENTIAL MorePasswords, OUT PULONG CommonCryptSystem, OUT PKERB_ENCRYPTION_KEY * Key ); KERBERR NTAPI KerbRandomFill( IN OUT PUCHAR pbBuffer, IN ULONG cbBuffer ); KERBERR NTAPI KerbCreateAuthenticator( IN PKERB_ENCRYPTION_KEY pkKey, IN ULONG EncryptionType, IN ULONG SequenceNumber, IN PUNICODE_STRING ClientName, IN PUNICODE_STRING ClientRealm, IN PTimeStamp ptsTime, IN PKERB_ENCRYPTION_KEY pkSubKey, IN OPTIONAL PKERB_CHECKSUM GssChecksum, IN BOOLEAN KdcRequest, OUT PKERB_ENCRYPTED_DATA Authenticator ); KERBERR NTAPI KerbUnpackAuthenticator( IN PKERB_ENCRYPTION_KEY Key, IN PKERB_ENCRYPTED_DATA EncryptedAuthenticator, IN BOOLEAN KdcRequest, OUT PKERB_AUTHENTICATOR * Authenticator ); // VOID NTAPI // KerbFreeAuthenticator( // IN PKERB_AUTHENTICATOR Authenticator // ); #define KerbFreeAuthenticator( Authenticator ) \ KerbFreeData( \ KERB_AUTHENTICATOR_PDU, \ (Authenticator) \ ) KERBERR NTAPI KerbPackKdcReplyBody( IN PKERB_ENCRYPTED_KDC_REPLY ReplyBody, IN PKERB_ENCRYPTION_KEY Key, IN ULONG EncryptionType, IN ULONG Pdu, OUT PKERB_ENCRYPTED_DATA EncryptedReply ); KERBERR NTAPI KerbUnpackKdcReplyBody( IN PKERB_ENCRYPTED_DATA EncryptedReplyBody, IN PKERB_ENCRYPTION_KEY Key, IN ULONG Pdu, OUT PKERB_ENCRYPTED_KDC_REPLY * ReplyBody ); KERBERR NTAPI KerbPackData( IN PVOID Data, IN ULONG PduValue, OUT PULONG DataSize, OUT PUCHAR * MarshalledData ); KERBERR NTAPI KerbUnpackData( IN PUCHAR Data, IN ULONG DataSize, IN ULONG PduValue, OUT PVOID * DecodedData ); VOID KerbFreeData( IN ULONG PduValue, IN PVOID Data ); // KERBERR NTAPI // KerbPackAsReply( // IN PKERB_KDC_REPLY ReplyMessage, // OUT PULONG ReplySize, // OUT PUCHAR * MarshalledReply // ); #define KerbPackAsReply( ReplyMessage, ReplySize, MarshalledReply ) \ KerbPackData( \ (PVOID) (ReplyMessage), \ KERB_AS_REPLY_PDU, \ (ReplySize), \ (MarshalledReply) \ ) // KERBERR NTAPI // KerbUnpackAsReply( // IN PUCHAR ReplyMessage, // IN ULONG ReplySize, // OUT PKERB_KDC_REPLY * Reply // ); #define KerbUnpackAsReply( ReplyMessage, ReplySize, Reply ) \ KerbUnpackData( \ (ReplyMessage), \ (ReplySize), \ KERB_AS_REPLY_PDU, \ (PVOID *) (Reply) \ ) // VOID // KerbFreeAsReply( // IN PKERB_KDC_REPLY Request // ); #define KerbFreeAsReply( Request) \ KerbFreeData( \ KERB_AS_REPLY_PDU, \ (PVOID) (Request) \ ) // KERBERR NTAPI // KerbPackTgsReply( // IN PKERB_KDC_REPLY ReplyMessage, // OUT PULONG ReplySize, // OUT PUCHAR * MarshalledReply // ); #define KerbPackTgsReply( ReplyMessage, ReplySize, MarshalledReply ) \ KerbPackData( \ (PVOID) (ReplyMessage), \ KERB_TGS_REPLY_PDU, \ (ReplySize), \ (MarshalledReply) \ ) // KERBERR NTAPI // KerbUnpackTgsReply( // IN PUCHAR ReplyMessage, // IN ULONG ReplySize, // OUT PKERB_KDC_REPLY * Reply // ); #define KerbUnpackTgsReply( ReplyMessage, ReplySize, Reply ) \ KerbUnpackData( \ (ReplyMessage), \ (ReplySize), \ KERB_TGS_REPLY_PDU, \ (PVOID *) (Reply) \ ) // VOID // KerbFreeTgsReply( // IN PKERB_KDC_REPLY Request // ); #define KerbFreeTgsReply( Request) \ KerbFreeData( \ KERB_TGS_REPLY_PDU, \ (PVOID) (Request) \ ) // VOID // KerbFreeKdcReplyBody( // IN PKERB_ENCRYPTED_KDC_REPLY Request // ); #define KerbFreeKdcReplyBody( Request) \ KerbFreeData( \ KERB_ENCRYPTED_TGS_REPLY_PDU, \ (PVOID) (Request) \ ) // KERBERR NTAPI // KerbPackAsRequest( // IN PKERB_KDC_REQUEST RequestMessage, // OUT PULONG RequestSize, // OUT PUCHAR * MarshalledRequest // ); #define KerbPackAsRequest( RequestMessage, RequestSize, MarshalledRequest )\ KerbPackData( \ (PVOID) (RequestMessage), \ KERB_AS_REQUEST_PDU, \ (RequestSize), \ (MarshalledRequest) \ ) // KERBERR NTAPI // KerbUnpackAsRequest( // IN PUCHAR RequestMessage, // IN ULONG RequestSize, // OUT PKERB_KDC_REQUEST * Request // ); #define KerbUnpackAsRequest( RequestMessage, RequestSize, Request ) \ KerbUnpackData( \ (RequestMessage), \ (RequestSize), \ KERB_AS_REQUEST_PDU, \ (PVOID *) (Request) \ ) // VOID // KerbFreeAsRequest( // IN PKERB_KDC_REQUEST Request // ); #define KerbFreeAsRequest( Request) \ KerbFreeData( \ KERB_TGS_REQUEST_PDU, \ (PVOID) (Request) \ ) // KERBERR NTAPI // KerbPackTgsRequest( // IN PKERB_KDC_REQUEST RequestMessage, // OUT PULONG RequestSize, // OUT PUCHAR * MarshalledRequest // ); #define KerbPackTgsRequest( RequestMessage, RequestSize, MarshalledRequest )\ KerbPackData( \ (PVOID) (RequestMessage), \ KERB_TGS_REQUEST_PDU, \ (RequestSize), \ (MarshalledRequest) \ ) // KERBERR NTAPI // KerbUnpackTgsRequest( // IN PUCHAR RequestMessage, // IN ULONG RequestSize, // OUT PKERB_KDC_REQUEST * Request // ); #define KerbUnpackTgsRequest( RequestMessage, RequestSize, Request ) \ KerbUnpackData( \ (RequestMessage), \ (RequestSize), \ KERB_TGS_REQUEST_PDU, \ (PVOID *) (Request) \ ) // VOID // KerbFreeTgsRequest( // IN PKERB_KDC_REQUEST Request // ); #define KerbFreeTgsRequest( Request) \ KerbFreeData( \ KERB_TGS_REQUEST_PDU, \ (PVOID) (Request) \ ) // KERBERR NTAPI // KerbPackEncryptedData( // IN PKERB_ENCRYPTED_DATA EncryptedData, // OUT PULONG DataSize, // OUT PUCHAR * MarshalledData // ); #define KerbPackEncryptedData( EncryptedData, DataSize, MarshalledData ) \ KerbPackData( \ (PVOID) (EncryptedData), \ KERB_ENCRYPTED_DATA_PDU, \ (DataSize), \ (PUCHAR *) (MarshalledData) \ ) // KERBERR NTAPI // KerbUnpackEncryptedData( // IN PUCHAR EncryptedData, // IN ULONG DataSize, // OUT PKERB_ENCRYPTED_DATA * Data // ); #define KerbUnpackEncryptedData( EncryptedData,DataSize,Data ) \ KerbUnpackData( \ (EncryptedData), \ (DataSize), \ KERB_ENCRYPTED_DATA_PDU, \ (PVOID *) (Data) \ ) // VOID // KerbFreeEncryptedData( // IN PKERB_ENCRYPTED_DATA EncryptedData // ); #define KerbFreeEncryptedData( EncryptedData) \ KerbFreeData( \ KERB_ENCRYPTED_DATA_PDU, \ (PVOID) (EncryptedData) \ ) #ifdef notdef // KERBERR NTAPI // KerbPackAuthData( // IN PKERB_AUTHORIZATION_DATA AuthData, // OUT PULONG AuthDataSize, // OUT PUCHAR * MarshalledAuthData // ); #define KerbPackAuthData( AuthData, AuthDataSize, MarshalledAuthData ) \ KerbPackData( \ (PVOID) (AuthData), \ KERB_AUTHORIZATION_DATA_PDU, \ (AuthDataSize), \ (MarshalledAuthData) \ ) // KERBERR NTAPI // KerbUnpackAuthData( // IN PUCHAR PackedAuthData, // IN ULONG AuthDataSize, // OUT PKERB_AUTHORIZATION_DATA * AuthData // ); #define KerbUnpackAuthData( PackedAuthData, AuthDataSize, AuthData ) \ KerbUnpackData( \ (PackedAuthData), \ (AuthDataSize), \ KERB_AUTHORIZATION_DATA_PDU, \ (PVOID *) (AuthData) \ ) // VOID // KerbFreeAuthData( // IN PKERB_AUTH_DATA AuthData // ); #define KerbFreeAuthData( AuthData) \ KerbFreeData( \ KERB_AUTHORIZATION_DATA_PDU, \ (PVOID) (AuthData) \ ) #endif // notdef VOID KerbFreeAuthData( IN PKERB_AUTHORIZATION_DATA AuthData ); // KERBERR NTAPI // KerbPackApRequest( // IN PKERB_AP_REQUEST ApRequestMessage, // OUT PULONG ApRequestSize, // OUT PUCHAR * MarshalledApRequest // ); #define KerbPackApRequest( ApRequestMessage, ApRequestSize, MarshalledApRequest ) \ KerbPackData( \ (PVOID) (ApRequestMessage), \ KERB_AP_REQUEST_PDU, \ (ApRequestSize), \ (MarshalledApRequest) \ ) // KERBERR NTAPI // KerbUnpackApRequest( // IN PUCHAR ApRequestMessage, // IN ULONG ApRequestSize, // OUT PKERB_AP_REQUEST * ApRequest // ); #define KerbUnpackApRequest( ApRequestMessage,ApRequestSize, ApRequest) \ KerbUnpackData( \ (ApRequestMessage), \ (ApRequestSize), \ KERB_AP_REQUEST_PDU, \ (PVOID *) (ApRequest) \ ) // VOID // KerbFreeApRequest( // IN PKERB_AP_REQUEST Request // ); #define KerbFreeApRequest( Request) \ KerbFreeData( \ KERB_AP_REQUEST_PDU, \ (PVOID) (Request) \ ) // KERBERR NTAPI // KerbPackApReply( // IN PKERB_AP_REPLY ApReplyMessage, // OUT PULONG ApReplySize, // OUT PUCHAR * MarshalledApReply // ); #define KerbPackApReply( ApReplyMessage, ApReplySize, MarshalledApReply ) \ KerbPackData( \ (PVOID) (ApReplyMessage), \ KERB_AP_REPLY_PDU, \ (ApReplySize), \ (MarshalledApReply) \ ) // KERBERR NTAPI // KerbUnpackApReply( // IN PUCHAR ApReplyMessage, // IN ULONG ApReplySize, // OUT PKERB_AP_REPLY * ApReply // ); #define KerbUnpackApReply( ApReplyMessage,ApReplySize, ApReply) \ KerbUnpackData( \ (ApReplyMessage), \ (ApReplySize), \ KERB_AP_REPLY_PDU, \ (PVOID *) (ApReply) \ ) // VOID // KerbFreeApReply( // IN PKERB_AP_REPLY Reply // ); #define KerbFreeApReply( Reply) \ KerbFreeData( \ KERB_AP_REPLY_PDU, \ (PVOID) (Reply) \ ) // KERBERR NTAPI // KerbPackApReplyBody( // IN PKERB_ENCRYPTED_AP_REPLY ApReplyBodyMessage, // OUT PULONG ApReplyBodySize, // OUT PUCHAR * MarshalledApReplyBody // ); #define KerbPackApReplyBody( ApReplyBodyMessage, ApReplyBodySize, MarshalledApReplyBody ) \ KerbPackData( \ (PVOID) (ApReplyBodyMessage), \ KERB_ENCRYPTED_AP_REPLY_PDU, \ (ApReplyBodySize), \ (MarshalledApReplyBody) \ ) // KERBERR NTAPI // KerbUnpackApReplyBody( // IN PUCHAR ApReplyBodyMessage, // IN ULONG ApReplyBodySize, // OUT PKERB_ENCRYPTED_AP_REPLY * ApReplyBody // ); #define KerbUnpackApReplyBody( ApReplyBodyMessage,ApReplyBodySize, ApReplyBody) \ KerbUnpackData( \ (ApReplyBodyMessage), \ (ApReplyBodySize), \ KERB_ENCRYPTED_AP_REPLY_PDU, \ (PVOID *) (ApReplyBody) \ ) // VOID // KerbFreeApReplyBody( // IN PKERB_ENCRYPTED_AP_REPLY ReplyBody // ); #define KerbFreeApReplyBody( ReplyBody) \ KerbFreeData( \ KERB_ENCRYPTED_AP_REPLY_PDU, \ (PVOID) (ReplyBody) \ ) // KERBERR NTAPI // KerbUnmarshallTicket( // IN PUCHAR TicketMessage, // IN ULONG TicketSize, // OUT PKERB_ENCRYPTED_TICKET * Ticket // ); #define KerbUnmarshallTicket( TicketMessage, TicketSize, Ticket ) \ KerbUnpackData( \ (TicketMessage), \ (TicketSize), \ KERB_ENCRYPTED_TICKET_PDU, \ (PVOID *) (Ticket) \ ) // KERBERR NTAPI // KerbPackEncryptedCred( // IN PKERB_ENCRYPTED_CRED EncryptedCred, // OUT PULONG CredSize, // OUT PUCHAR * MarshalledCred // ); #define KerbPackEncryptedCred( EncryptedCred, CredSize, MarshalledCred ) \ KerbPackData( \ (PVOID) (EncryptedCred), \ KERB_ENCRYPTED_CRED_PDU, \ (CredSize), \ (MarshalledCred) \ ) // KERBERR NTAPI // KerbUnpackEncryptedCred( // IN PUCHAR EncryptedCred, // IN ULONG CredSize, // OUT PKERB_ENCRYPTED_CRED * Cred // ); #define KerbUnpackEncryptedCred( EncryptedCred,CredSize,Cred ) \ KerbUnpackData( \ (EncryptedCred), \ (CredSize), \ KERB_ENCRYPTED_CRED_PDU, \ (PVOID *) (Cred) \ ) // VOID // KerbFreeEncryptedCred( // IN PKERB_ENCRYPTED_CRED EncryptedCred // ); #define KerbFreeEncryptedCred( EncryptedCred) \ KerbFreeData( \ KERB_ENCRYPTED_CRED_PDU, \ (PVOID) (EncryptedCred) \ ) // KERBERR NTAPI // KerbPackKerbCred( // IN PKERB_CRED KerbCred, // OUT PULONG KerbCredSize, // OUT PUCHAR * MarshalledKerbCred // ); #define KerbPackKerbCred( KerbCred, KerbCredSize, MarshalledKerbCred ) \ KerbPackData( \ (PVOID) (KerbCred), \ KERB_CRED_PDU, \ (KerbCredSize), \ (MarshalledKerbCred) \ ) // KERBERR NTAPI // KerbUnpackKerbCred( // IN PUCHAR MarshalledKerbCred, // IN ULONG KerbCredSize, // OUT PKERB_CRED * KerbCred // ); #define KerbUnpackKerbCred( MarshalledKerbCred,KerbCredSize,KerbCred ) \ KerbUnpackData( \ (MarshalledKerbCred), \ (KerbCredSize), \ KERB_CRED_PDU, \ (PVOID *) (KerbCred) \ ) // VOID // KerbFreeKerbCred( // IN PKERB_CRED KerbCred // ); #define KerbFreeKerbCred( KerbCred) \ KerbFreeData( \ KERB_CRED_PDU, \ (PVOID) (KerbCred) \ ) // KERBERR NTAPI // KerbPackKerbError( // IN PKERB_ERROR ErrorMessage, // OUT PULONG ErrorSize, // OUT PUCHAR * MarshalledError // ); #define KerbPackKerbError( ErrorMessage, ErrorSize, MarshalledError ) \ KerbPackData( \ (PVOID) (ErrorMessage), \ KERB_ERROR_PDU, \ (ErrorSize), \ (MarshalledError) \ ) // KERBERR NTAPI // KerbUnpackKerbError( // IN PUCHAR ErrorMessage, // IN ULONG ErrorSize, // OUT PKERB_ERROR * Error // ); #define KerbUnpackKerbError( ErrorMessage, ErrorSize, Error ) \ KerbUnpackData( \ (ErrorMessage), \ (ErrorSize), \ KERB_ERROR_PDU, \ (PVOID *) (Error) \ ) // VOID // KerbFreeKerbError( // IN PKERB_ERROR Request // ); #define KerbFreeKerbError( Error ) \ KerbFreeData( \ KERB_ERROR_PDU, \ (PVOID) (Error) \ ) // KERBERR NTAPI // KerbPackEncryptedTime( // IN PKERB_ENCRYPTED_TIMESTAMP EncryptedTimeMessage, // OUT PULONG EncryptedTimeSize, // OUT PUCHAR * MarshalledEncryptedTime // ); #define KerbPackEncryptedTime( EncryptedTimeMessage, EncryptedTimeSize, MarshalledEncryptedTime ) \ KerbPackData( \ (PVOID) (EncryptedTimeMessage), \ KERB_ENCRYPTED_TIMESTAMP_PDU, \ (EncryptedTimeSize), \ (MarshalledEncryptedTime) \ ) // KERBERR NTAPI // KerbUnpackEncryptedTime( // IN PUCHAR EncryptedTimeMessage, // IN ULONG EncryptedTimeSize, // OUT PKERB_ENCRYPTED_TIMESTAMP * EncryptedTime // ); #define KerbUnpackEncryptedTime( EncryptedTimeMessage, EncryptedTimeSize, EncryptedTime ) \ KerbUnpackData( \ (EncryptedTimeMessage), \ (EncryptedTimeSize), \ KERB_ENCRYPTED_TIMESTAMP_PDU, \ (PVOID *) (EncryptedTime) \ ) // VOID // KerbFreeEncryptedTime( // IN PKERB_ENCRYPTED_TIMESTAMP EncryptedTime // ); #define KerbFreeEncryptedTime( EncryptedTime ) \ KerbFreeData( \ KERB_ENCRYPTED_TIMESTAMP_PDU, \ (PVOID) (EncryptedTime) \ ) KERBERR KerbAllocateEncryptionBuffer( IN ULONG EncryptionType, IN ULONG BufferSize, OUT PUINT EncryptionBufferSize, OUT PBYTE * EncryptionBuffer ); KERBERR KerbAllocateEncryptionBufferWrapper( IN ULONG EncryptionType, IN ULONG BufferSize, OUT unsigned long * EncryptionBufferSize, OUT PBYTE * EncryptionBuffer ); KERBERR NTAPI KerbEncryptData( OUT PKERB_ENCRYPTED_DATA EncryptedData, IN ULONG DataSize, IN PUCHAR Data, IN ULONG Algorithm, IN PKERB_ENCRYPTION_KEY Key ); KERBERR NTAPI KerbDecryptData( IN PKERB_ENCRYPTED_DATA EncryptedData, IN PKERB_ENCRYPTION_KEY pkKey, OUT PULONG DataSize, OUT PUCHAR Data ); KERBERR NTAPI KerbEncryptDataEx( OUT PKERB_ENCRYPTED_DATA EncryptedData, IN ULONG DataSize, IN PUCHAR Data, IN ULONG Algorithm, IN ULONG UsageFlags, IN PKERB_ENCRYPTION_KEY Key ); KERBERR NTAPI KerbDecryptDataEx( IN PKERB_ENCRYPTED_DATA EncryptedData, IN PKERB_ENCRYPTION_KEY pkKey, IN ULONG UsageFlags, OUT PULONG DataSize, OUT PUCHAR Data ); #ifndef WIN32_CHICAGO KERBERR NTAPI KerbCheckSumVerify( IN PUCHAR pbBuffer, IN ULONG cbBuffer, OUT PKERB_CHECKSUM pcsCheck ); KERBERR NTAPI KerbCheckSum( PUCHAR pbData, ULONG cbData, PCHECKSUM_FUNCTION pcsfSum, PKERB_CHECKSUM pcsCheckSum ); #endif // WIN32_CHICAGO KERBERR KerbGetEncryptionOverhead( IN ULONG Algorithm, OUT PULONG Overhead, OUT OPTIONAL PULONG BlockSize ); NTSTATUS KerbDuplicateSid( OUT PSID * DestinationSid, IN PSID SourceSid ); NTSTATUS KerbConvertStringToSid( IN PUNICODE_STRING String, OUT PSID * Sid ); NTSTATUS KerbConvertSidToString( IN PSID Sid, OUT PUNICODE_STRING String, IN BOOLEAN AllocateDestination ); KERBERR KerbExtractSidFromKdcName( IN OUT PKERB_INTERNAL_NAME Name, OUT PSID * Sid ); KERBERR KerbBuildFullServiceKdcNameWithSid( IN PUNICODE_STRING DomainName, IN PUNICODE_STRING ServiceName, IN OPTIONAL PSID Sid, IN ULONG NameType, OUT PKERB_INTERNAL_NAME * FullServiceName ); NTSTATUS KerbDuplicateString( OUT PUNICODE_STRING DestinationString, IN OPTIONAL PUNICODE_STRING SourceString ); LPWSTR KerbBuildNullTerminatedString( IN PUNICODE_STRING String ); VOID KerbFreeString( IN OPTIONAL PUNICODE_STRING String ); VOID KerbFreeRealm( IN PKERB_REALM Realm ); VOID KerbFreePrincipalName( IN PKERB_PRINCIPAL_NAME Name ); #ifndef WIN32_CHICAGO KERBERR KerbCheckLogonRestrictions( IN PVOID UserHandle, IN PUNICODE_STRING Workstation, IN PUSER_ALL_INFORMATION UserAll, IN ULONG LogonRestrictionsFlags, OUT PTimeStamp LogoffTime, OUT PNTSTATUS RetStatus ); #include NTSTATUS PAC_EncodeTokenRestrictions( IN PKERB_TOKEN_RESTRICTIONS TokenRestrictions, OUT PBYTE * EncodedData, OUT PULONG DataSize ); NTSTATUS PAC_DecodeTokenRestrictions( IN PBYTE EncodedData, IN ULONG DataSize, OUT PKERB_TOKEN_RESTRICTIONS * TokenRestrictions ); #define KERB_TOKEN_RESTRICTION_DISABLE_GROUPS 1 #define KERB_TOKEN_RESTRICTION_RESTRICT_SIDS 2 #define KERB_TOKEN_RESTRICTION_DELETE_PRIVS 4 #endif // WIN32_CHICAGO KERBERR KerbConvertStringToPrincipalName( OUT PKERB_PRINCIPAL_NAME PrincipalName, IN PUNICODE_STRING String, IN ULONG NameType ); KERBERR KerbDuplicatePrincipalName( OUT PKERB_PRINCIPAL_NAME PrincipalName, IN PKERB_PRINCIPAL_NAME SourcePrincipalName ); KERBERR KerbConvertPrincipalNameToString( OUT PUNICODE_STRING String, OUT PULONG NameType, IN PKERB_PRINCIPAL_NAME PrincipalName ); KERBERR KerbConvertPrincipalNameToFullServiceString( OUT PUNICODE_STRING String, IN PKERB_PRINCIPAL_NAME PrincipalName, IN KERB_REALM RealmName ); BOOLEAN KerbComparePrincipalNames( IN PKERB_PRINCIPAL_NAME Name1, IN PKERB_PRINCIPAL_NAME Name2 ); KERBERR KerbConvertUnicodeStringToRealm( OUT PKERB_REALM Realm, IN PUNICODE_STRING String ); KERBERR KerbConvertRealmToUnicodeString( OUT PUNICODE_STRING String, IN PKERB_REALM Realm ); KERBERR KerbDuplicateRealm( OUT PKERB_REALM Realm, IN KERB_REALM SourceRealm ); BOOLEAN KerbCompareRealmNames( IN PKERB_REALM Realm1, IN PKERB_REALM Realm2 ); BOOLEAN KerbCompareUnicodeRealmNames( IN PUNICODE_STRING Domain1, IN PUNICODE_STRING Domain2 ); BOOLEAN KerbCompareStringToPrincipalName( IN PKERB_PRINCIPAL_NAME PrincipalName, IN PUNICODE_STRING String ); VOID KerbConvertLargeIntToGeneralizedTime( OUT PKERB_TIME ClientTime, OUT OPTIONAL int * ClientUsec, IN PTimeStamp TimeStamp ); VOID KerbConvertLargeIntToGeneralizedTimeWrapper( OUT PKERB_TIME ClientTime, OUT OPTIONAL long * ClientUsec, IN PTimeStamp TimeStamp ); VOID KerbConvertGeneralizedTimeToLargeInt( OUT PTimeStamp TimeStamp, IN PKERB_TIME ClientTime, IN int ClientUsec ); BOOLEAN KerbCheckTimeSkew( IN PTimeStamp CurrentTime, IN PTimeStamp ClientTime, IN PTimeStamp AllowedSkew ); KERBERR KerbConvertArrayToCryptList( OUT PKERB_CRYPT_LIST * CryptList, IN PULONG ETypeArray, IN ULONG ETypeCount ); KERBERR KerbConvertKeysToCryptList( OUT PKERB_CRYPT_LIST * CryptList, IN PKERB_STORED_CREDENTIAL Keys ); KERBERR KerbConvertCryptListToArray( OUT PULONG * ETypeArray, OUT PULONG ETypeCount, IN PKERB_CRYPT_LIST CryptList ); VOID KerbFreeCryptList( IN PKERB_CRYPT_LIST CryptList ); PKERB_AUTHORIZATION_DATA KerbFindAuthDataEntry( IN ULONG EntryId, IN PKERB_AUTHORIZATION_DATA AuthData ); PKERB_PA_DATA KerbFindPreAuthDataEntry( IN ULONG EntryId, IN PKERB_PA_DATA_LIST AuthData ); VOID KerbFreePreAuthData( IN OPTIONAL PKERB_PA_DATA_LIST PreAuthData ); KERBERR KerbCopyAndAppendAuthData( OUT PKERB_AUTHORIZATION_DATA * OutputAuthData, IN PKERB_AUTHORIZATION_DATA InputAuthData ); KERBERR KerbGetPacFromAuthData( IN PKERB_AUTHORIZATION_DATA AuthData, OUT PKERB_IF_RELEVANT_AUTH_DATA ** ReturnIfRelevantData, OUT PKERB_AUTHORIZATION_DATA * Pac ); KERBERR KerbCreateApRequest( IN PKERB_INTERNAL_NAME ClientName, IN PUNICODE_STRING ClientRealm, IN PKERB_ENCRYPTION_KEY SessionKey, IN PKERB_ENCRYPTION_KEY SubSessionKey, IN ULONG Nonce, IN PKERB_TICKET ServiceTicket, IN ULONG ApOptions, IN OPTIONAL PKERB_CHECKSUM GssChecksum, IN OPTIONAL PTimeStamp ServerSkewTime, IN BOOLEAN KdcRequest, OUT PULONG RequestSize, OUT PUCHAR * Request ); KERBERR KerbBuildFullServiceName( IN PUNICODE_STRING DomainName, IN PUNICODE_STRING ServiceName, OUT PUNICODE_STRING FullServiceName ); KERBERR KerbBuildUnicodeSpn( IN PUNICODE_STRING DomainName, IN PUNICODE_STRING ServiceName, OUT PUNICODE_STRING UnicodeSpn ); KERBERR KerbBuildEmailName( IN PUNICODE_STRING DomainName, IN PUNICODE_STRING ServiceName, OUT PUNICODE_STRING EmailName ); KERBERR KerbBuildFullServiceKdcName( IN PUNICODE_STRING DomainName, IN PUNICODE_STRING ServiceName, IN ULONG NameType, OUT PKERB_INTERNAL_NAME * FullServiceName ); KERBERR KerbBuildAltSecId( OUT PUNICODE_STRING AlternateName, IN PKERB_INTERNAL_NAME PrincipalName, IN OPTIONAL PKERB_REALM Realm, IN OPTIONAL PUNICODE_STRING UnicodeRealm ); KERBERR KerbBuildKeySalt( IN PUNICODE_STRING DomainName, IN PUNICODE_STRING ServiceName, IN KERB_ACCOUNT_TYPE AccountType, OUT PUNICODE_STRING KeySalt ); KERBERR KerbBuildKeySaltFromUpn( IN PUNICODE_STRING Upn, OUT PUNICODE_STRING Salt ); KERBERR KerbBuildErrorMessageEx( IN KERBERR ErrorCode, IN OPTIONAL PKERB_EXT_ERROR pExtendedError, IN PUNICODE_STRING ServerRealm, IN PKERB_INTERNAL_NAME ServerName, IN OPTIONAL PUNICODE_STRING ClientRealm, IN OPTIONAL PBYTE ErrorData, IN ULONG ErrorDataSize, OUT PULONG ErrorMessageSize, OUT PUCHAR * ErrorMessage ); KERBERR KerbBuildExtendedError( IN PKERB_EXT_ERROR pExtendedError, OUT PULONG ExtErrorSize, OUT PBYTE* ExtErrorData ); #ifdef __cplusplus } // extern "C" #endif // // Socket functions // NTSTATUS KerbInitializeSockets( IN ULONG VersionRequired, IN ULONG MinSockets, OUT BOOLEAN *TcpNotInstalled ); VOID KerbCleanupSockets( ); NTSTATUS KerbCallKdc( IN PUNICODE_STRING KdcAddress, IN ULONG AddressType, IN ULONG Timeout, IN BOOLEAN UseDatagram, IN USHORT PortNumber, IN PKERB_MESSAGE_BUFFER Input, OUT PKERB_MESSAGE_BUFFER Output ); NTSTATUS KerbMapKerbError( IN KERBERR KerbError ); VOID KerbFreeHostAddresses( IN PKERB_HOST_ADDRESSES Addresses ); KERBERR KerbDuplicateHostAddresses( OUT PKERB_HOST_ADDRESSES * DestAddresses, IN PKERB_HOST_ADDRESSES SourceAddresses ); KERBERR KerbUnicodeStringToKerbString( OUT PSTRING KerbString, IN PUNICODE_STRING String ); KERBERR KerbStringToUnicodeString( OUT PUNICODE_STRING String, IN PSTRING KerbString ); BOOLEAN KerbMbStringToUnicodeString( PUNICODE_STRING pDest, char * pszString ); VOID KerbFreeKdcName( IN PKERB_INTERNAL_NAME * KdcName ); KERBERR KerbConvertPrincipalNameToKdcName( OUT PKERB_INTERNAL_NAME * OutputName, IN PKERB_PRINCIPAL_NAME PrincipalName ); KERBERR KerbConvertKdcNameToPrincipalName( OUT PKERB_PRINCIPAL_NAME PrincipalName, IN PKERB_INTERNAL_NAME KdcName ); BOOLEAN KerbEqualKdcNames( IN PKERB_INTERNAL_NAME Name1, IN PKERB_INTERNAL_NAME Name2 ); KERBERR KerbCompareKdcNameToPrincipalName( IN PKERB_PRINCIPAL_NAME PrincipalName, IN PKERB_INTERNAL_NAME KdcName, OUT PBOOLEAN Result ); VOID KerbPrintKdcNameEx( IN ULONG DebugLevel, IN ULONG InfoLevel, IN PKERB_INTERNAL_NAME Name ); #define KERB_INTERNAL_NAME_SIZE(NameCount) (sizeof(KERB_INTERNAL_NAME) + ((NameCount) - ANYSIZE_ARRAY) * sizeof(UNICODE_STRING)) KERBERR KerbConvertStringToKdcName( OUT PKERB_INTERNAL_NAME * PrincipalName, IN PUNICODE_STRING String ); NTSTATUS KerbBuildKpasswdName( OUT PKERB_INTERNAL_NAME * KpasswdName ); KERBERR KerbConvertKdcNameToString( OUT PUNICODE_STRING String, IN PKERB_INTERNAL_NAME PrincipalName, IN PUNICODE_STRING Realm ); NTSTATUS KerbDuplicateKdcName( OUT PKERB_INTERNAL_NAME * Destination, IN PKERB_INTERNAL_NAME Source ); PSID KerbMakeDomainRelativeSid( IN PSID DomainId, IN ULONG RelativeId ); ULONG KerbConvertFlagsToUlong( IN PVOID Flags ); ULONG KerbConvertUlongToFlagUlong( IN ULONG Flag ); BOOLEAN KerbCompareObjectIds( IN PKERB_OBJECT_ID Object1, IN PKERB_OBJECT_ID Object2 ); KERBERR KerbGetClientNetbiosAddress( OUT PUNICODE_STRING ClientNetbiosAddress, IN PKERB_HOST_ADDRESSES Addresses ); #ifdef __WINCRYPT_H__ KERBERR KerbCreateCertificateList( OUT PKERB_CERTIFICATE_LIST * Certificates, IN PCCERT_CONTEXT CertContext ); VOID KerbFreeCertificateList( IN PKERB_CERTIFICATE_LIST Certificates ); NTSTATUS KerbGetPrincipalNameFromCertificate( IN PCCERT_CONTEXT ClientCert, OUT PUNICODE_STRING String ); NTSTATUS KerbDuplicateStringEx( OUT PUNICODE_STRING DestinationString, IN OPTIONAL PUNICODE_STRING SourceString, IN BOOLEAN NullTerminate ); #if DBG void DebugDisplayTime( IN ULONG DebugLevel, IN FILETIME *pFileTime ); #endif #endif // __WINCRYPT_H__ #endif // _KERBCOMM_H_