| 1 | /** | 
 
 
 
 
 | 2 | * This file has no copyright assigned and is placed in the Public Domain. | 
 
 
 
 
 | 3 | * This file is part of the mingw-w64 runtime package. | 
 
 
 
 
 | 4 | * No warranty is given; refer to the file DISCLAIMER.PD within this package. | 
 
 
 
 
 | 5 | */ | 
 
 
 
 
 | 6 | #ifndef _NTSECPKG_ | 
 
 
 
 
 | 7 | #define _NTSECPKG_ | 
 
 
 
 
 | 8 |  | 
 
 
 
 
 | 9 | #ifdef __cplusplus | 
 
 
 
 
 | 10 | extern "C" { | 
 
 
 
 
 | 11 | #endif | 
 
 
 
 
 | 12 |  | 
 
 
 
 
 | 13 | typedef PVOID *PLSA_CLIENT_REQUEST; | 
 
 
 
 
 | 14 |  | 
 
 
 
 
 | 15 | typedef enum _LSA_TOKEN_INFORMATION_TYPE { | 
 
 
 
 
 | 16 | LsaTokenInformationNull, | 
 
 
 
 
 | 17 | LsaTokenInformationV1, | 
 
 
 
 
 | 18 | LsaTokenInformationV2 | 
 
 
 
 
 | 19 | } LSA_TOKEN_INFORMATION_TYPE,*PLSA_TOKEN_INFORMATION_TYPE; | 
 
 
 
 
 | 20 |  | 
 
 
 
 
 | 21 | typedef struct _LSA_TOKEN_INFORMATION_NULL { | 
 
 
 
 
 | 22 | LARGE_INTEGER ExpirationTime; | 
 
 
 
 
 | 23 | PTOKEN_GROUPS Groups; | 
 
 
 
 
 | 24 | } LSA_TOKEN_INFORMATION_NULL,*PLSA_TOKEN_INFORMATION_NULL; | 
 
 
 
 
 | 25 |  | 
 
 
 
 
 | 26 | typedef struct _LSA_TOKEN_INFORMATION_V1 { | 
 
 
 
 
 | 27 | LARGE_INTEGER ExpirationTime; | 
 
 
 
 
 | 28 | TOKEN_USER User; | 
 
 
 
 
 | 29 | PTOKEN_GROUPS Groups; | 
 
 
 
 
 | 30 | TOKEN_PRIMARY_GROUP PrimaryGroup; | 
 
 
 
 
 | 31 | PTOKEN_PRIVILEGES Privileges; | 
 
 
 
 
 | 32 | TOKEN_OWNER Owner; | 
 
 
 
 
 | 33 | TOKEN_DEFAULT_DACL DefaultDacl; | 
 
 
 
 
 | 34 | } LSA_TOKEN_INFORMATION_V1,*PLSA_TOKEN_INFORMATION_V1; | 
 
 
 
 
 | 35 |  | 
 
 
 
 
 | 36 | typedef LSA_TOKEN_INFORMATION_V1 LSA_TOKEN_INFORMATION_V2,*PLSA_TOKEN_INFORMATION_V2; | 
 
 
 
 
 | 37 | typedef NTSTATUS (NTAPI LSA_CREATE_LOGON_SESSION)(PLUID LogonId); | 
 
 
 
 
 | 38 | typedef NTSTATUS (NTAPI LSA_DELETE_LOGON_SESSION)(PLUID LogonId); | 
 
 
 
 
 | 39 | typedef NTSTATUS (NTAPI LSA_ADD_CREDENTIAL)(PLUID LogonId,ULONG AuthenticationPackage,PLSA_STRING PrimaryKeyValue,PLSA_STRING Credentials); | 
 
 
 
 
 | 40 | typedef NTSTATUS (NTAPI LSA_GET_CREDENTIALS)(PLUID LogonId,ULONG AuthenticationPackage,PULONG QueryContext,BOOLEAN RetrieveAllCredentials,PLSA_STRING PrimaryKeyValue,PULONG PrimaryKeyLength,PLSA_STRING Credentials); | 
 
 
 
 
 | 41 | typedef NTSTATUS (NTAPI LSA_DELETE_CREDENTIAL)(PLUID LogonId,ULONG AuthenticationPackage,PLSA_STRING PrimaryKeyValue); | 
 
 
 
 
 | 42 | typedef PVOID (NTAPI LSA_ALLOCATE_LSA_HEAP)(ULONG Length); | 
 
 
 
 
 | 43 | typedef VOID (NTAPI LSA_FREE_LSA_HEAP)(PVOID Base); | 
 
 
 
 
 | 44 | typedef PVOID (NTAPI LSA_ALLOCATE_PRIVATE_HEAP)(SIZE_T Length); | 
 
 
 
 
 | 45 | typedef VOID (NTAPI LSA_FREE_PRIVATE_HEAP)(PVOID Base); | 
 
 
 
 
 | 46 | typedef NTSTATUS (NTAPI LSA_ALLOCATE_CLIENT_BUFFER)(PLSA_CLIENT_REQUEST ClientRequest,ULONG LengthRequired,PVOID *ClientBaseAddress); | 
 
 
 
 
 | 47 | typedef NTSTATUS (NTAPI LSA_FREE_CLIENT_BUFFER)(PLSA_CLIENT_REQUEST ClientRequest,PVOID ClientBaseAddress); | 
 
 
 
 
 | 48 | typedef NTSTATUS (NTAPI LSA_COPY_TO_CLIENT_BUFFER)(PLSA_CLIENT_REQUEST ClientRequest,ULONG Length,PVOID ClientBaseAddress,PVOID BufferToCopy); | 
 
 
 
 
 | 49 | typedef NTSTATUS (NTAPI LSA_COPY_FROM_CLIENT_BUFFER)(PLSA_CLIENT_REQUEST ClientRequest,ULONG Length,PVOID BufferToCopy,PVOID ClientBaseAddress); | 
 
 
 
 
 | 50 |  | 
 
 
 
 
 | 51 | typedef LSA_CREATE_LOGON_SESSION *PLSA_CREATE_LOGON_SESSION; | 
 
 
 
 
 | 52 | typedef LSA_DELETE_LOGON_SESSION *PLSA_DELETE_LOGON_SESSION; | 
 
 
 
 
 | 53 | typedef LSA_ADD_CREDENTIAL *PLSA_ADD_CREDENTIAL; | 
 
 
 
 
 | 54 | typedef LSA_GET_CREDENTIALS *PLSA_GET_CREDENTIALS; | 
 
 
 
 
 | 55 | typedef LSA_DELETE_CREDENTIAL *PLSA_DELETE_CREDENTIAL; | 
 
 
 
 
 | 56 | typedef LSA_ALLOCATE_LSA_HEAP *PLSA_ALLOCATE_LSA_HEAP; | 
 
 
 
 
 | 57 | typedef LSA_FREE_LSA_HEAP *PLSA_FREE_LSA_HEAP; | 
 
 
 
 
 | 58 | typedef LSA_ALLOCATE_PRIVATE_HEAP *PLSA_ALLOCATE_PRIVATE_HEAP; | 
 
 
 
 
 | 59 | typedef LSA_FREE_PRIVATE_HEAP *PLSA_FREE_PRIVATE_HEAP; | 
 
 
 
 
 | 60 | typedef LSA_ALLOCATE_CLIENT_BUFFER *PLSA_ALLOCATE_CLIENT_BUFFER; | 
 
 
 
 
 | 61 | typedef LSA_FREE_CLIENT_BUFFER *PLSA_FREE_CLIENT_BUFFER; | 
 
 
 
 
 | 62 | typedef LSA_COPY_TO_CLIENT_BUFFER *PLSA_COPY_TO_CLIENT_BUFFER; | 
 
 
 
 
 | 63 | typedef LSA_COPY_FROM_CLIENT_BUFFER *PLSA_COPY_FROM_CLIENT_BUFFER; | 
 
 
 
 
 | 64 |  | 
 
 
 
 
 | 65 | typedef struct _LSA_DISPATCH_TABLE { | 
 
 
 
 
 | 66 | PLSA_CREATE_LOGON_SESSION CreateLogonSession; | 
 
 
 
 
 | 67 | PLSA_DELETE_LOGON_SESSION DeleteLogonSession; | 
 
 
 
 
 | 68 | PLSA_ADD_CREDENTIAL AddCredential; | 
 
 
 
 
 | 69 | PLSA_GET_CREDENTIALS GetCredentials; | 
 
 
 
 
 | 70 | PLSA_DELETE_CREDENTIAL DeleteCredential; | 
 
 
 
 
 | 71 | PLSA_ALLOCATE_LSA_HEAP AllocateLsaHeap; | 
 
 
 
 
 | 72 | PLSA_FREE_LSA_HEAP FreeLsaHeap; | 
 
 
 
 
 | 73 | PLSA_ALLOCATE_CLIENT_BUFFER AllocateClientBuffer; | 
 
 
 
 
 | 74 | PLSA_FREE_CLIENT_BUFFER FreeClientBuffer; | 
 
 
 
 
 | 75 | PLSA_COPY_TO_CLIENT_BUFFER CopyToClientBuffer; | 
 
 
 
 
 | 76 | PLSA_COPY_FROM_CLIENT_BUFFER CopyFromClientBuffer; | 
 
 
 
 
 | 77 | } LSA_DISPATCH_TABLE,*PLSA_DISPATCH_TABLE; | 
 
 
 
 
 | 78 |  | 
 
 
 
 
 | 79 | #define LSA_AP_NAME_INITIALIZE_PACKAGE "LsaApInitializePackage\0" | 
 
 
 
 
 | 80 | #define LSA_AP_NAME_LOGON_USER "LsaApLogonUser\0" | 
 
 
 
 
 | 81 | #define LSA_AP_NAME_LOGON_USER_EX "LsaApLogonUserEx\0" | 
 
 
 
 
 | 82 | #define LSA_AP_NAME_CALL_PACKAGE "LsaApCallPackage\0" | 
 
 
 
 
 | 83 | #define LSA_AP_NAME_LOGON_TERMINATED "LsaApLogonTerminated\0" | 
 
 
 
 
 | 84 | #define LSA_AP_NAME_CALL_PACKAGE_UNTRUSTED "LsaApCallPackageUntrusted\0" | 
 
 
 
 
 | 85 | #define LSA_AP_NAME_CALL_PACKAGE_PASSTHROUGH "LsaApCallPackagePassthrough\0" | 
 
 
 
 
 | 86 |  | 
 
 
 
 
 | 87 | typedef NTSTATUS (NTAPI LSA_AP_INITIALIZE_PACKAGE)(ULONG AuthenticationPackageId,PLSA_DISPATCH_TABLE LsaDispatchTable,PLSA_STRING Database,PLSA_STRING Confidentiality,PLSA_STRING *AuthenticationPackageName); | 
 
 
 
 
 | 88 | typedef NTSTATUS (NTAPI LSA_AP_LOGON_USER)(PLSA_CLIENT_REQUEST ClientRequest,SECURITY_LOGON_TYPE LogonType,PVOID AuthenticationInformation,PVOID ClientAuthenticationBase,ULONG AuthenticationInformationLength,PVOID *ProfileBuffer,PULONG ProfileBufferLength,PLUID LogonId,PNTSTATUS SubStatus,PLSA_TOKEN_INFORMATION_TYPE TokenInformationType,PVOID *TokenInformation,PLSA_UNICODE_STRING *AccountName,PLSA_UNICODE_STRING *AuthenticatingAuthority); | 
 
 
 
 
 | 89 | typedef NTSTATUS (NTAPI LSA_AP_LOGON_USER_EX)(PLSA_CLIENT_REQUEST ClientRequest,SECURITY_LOGON_TYPE LogonType,PVOID AuthenticationInformation,PVOID ClientAuthenticationBase,ULONG AuthenticationInformationLength,PVOID *ProfileBuffer,PULONG ProfileBufferLength,PLUID LogonId,PNTSTATUS SubStatus,PLSA_TOKEN_INFORMATION_TYPE TokenInformationType,PVOID *TokenInformation,PUNICODE_STRING *AccountName,PUNICODE_STRING *AuthenticatingAuthority,PUNICODE_STRING *MachineName); | 
 
 
 
 
 | 90 | typedef NTSTATUS (NTAPI LSA_AP_CALL_PACKAGE)(PLSA_CLIENT_REQUEST ClientRequest,PVOID ProtocolSubmitBuffer,PVOID ClientBufferBase,ULONG SubmitBufferLength,PVOID *ProtocolReturnBuffer,PULONG ReturnBufferLength,PNTSTATUS ProtocolStatus); | 
 
 
 
 
 | 91 | typedef NTSTATUS (NTAPI LSA_AP_CALL_PACKAGE_PASSTHROUGH)(PLSA_CLIENT_REQUEST ClientRequest,PVOID ProtocolSubmitBuffer,PVOID ClientBufferBase,ULONG SubmitBufferLength,PVOID *ProtocolReturnBuffer,PULONG ReturnBufferLength,PNTSTATUS ProtocolStatus); | 
 
 
 
 
 | 92 | typedef VOID (NTAPI LSA_AP_LOGON_TERMINATED)(PLUID LogonId); | 
 
 
 
 
 | 93 |  | 
 
 
 
 
 | 94 | typedef LSA_AP_CALL_PACKAGE LSA_AP_CALL_PACKAGE_UNTRUSTED; | 
 
 
 
 
 | 95 | typedef LSA_AP_INITIALIZE_PACKAGE *PLSA_AP_INITIALIZE_PACKAGE; | 
 
 
 
 
 | 96 | typedef LSA_AP_LOGON_USER *PLSA_AP_LOGON_USER; | 
 
 
 
 
 | 97 | typedef LSA_AP_LOGON_USER_EX *PLSA_AP_LOGON_USER_EX; | 
 
 
 
 
 | 98 | typedef LSA_AP_CALL_PACKAGE *PLSA_AP_CALL_PACKAGE; | 
 
 
 
 
 | 99 | typedef LSA_AP_CALL_PACKAGE_PASSTHROUGH *PLSA_AP_CALL_PACKAGE_PASSTHROUGH; | 
 
 
 
 
 | 100 | typedef LSA_AP_LOGON_TERMINATED *PLSA_AP_LOGON_TERMINATED; | 
 
 
 
 
 | 101 | typedef LSA_AP_CALL_PACKAGE_UNTRUSTED *PLSA_AP_CALL_PACKAGE_UNTRUSTED; | 
 
 
 
 
 | 102 |  | 
 
 
 
 
 | 103 | #ifndef _SAM_CREDENTIAL_UPDATE_DEFINED | 
 
 
 
 
 | 104 | #define _SAM_CREDENTIAL_UPDATE_DEFINED | 
 
 
 
 
 | 105 |  | 
 
 
 
 
 | 106 | typedef NTSTATUS (*PSAM_CREDENTIAL_UPDATE_NOTIFY_ROUTINE)(PUNICODE_STRING ClearPassword,PVOID OldCredentials,ULONG OldCredentialSize,ULONG UserAccountControl,PUNICODE_STRING UPN,PUNICODE_STRING UserName,PUNICODE_STRING NetbiosDomainName,PUNICODE_STRING DnsDomainName,PVOID *NewCredentials,ULONG *NewCredentialSize); | 
 
 
 
 
 | 107 |  | 
 
 
 
 
 | 108 | #define SAM_CREDENTIAL_UPDATE_NOTIFY_ROUTINE "CredentialUpdateNotify" | 
 
 
 
 
 | 109 |  | 
 
 
 
 
 | 110 | typedef BOOLEAN (*PSAM_CREDENTIAL_UPDATE_REGISTER_ROUTINE)(PUNICODE_STRING CredentialName); | 
 
 
 
 
 | 111 |  | 
 
 
 
 
 | 112 | #define SAM_CREDENTIAL_UPDATE_REGISTER_ROUTINE "CredentialUpdateRegister" | 
 
 
 
 
 | 113 |  | 
 
 
 
 
 | 114 | typedef VOID (*PSAM_CREDENTIAL_UPDATE_FREE_ROUTINE)(PVOID p); | 
 
 
 
 
 | 115 |  | 
 
 
 
 
 | 116 | #define SAM_CREDENTIAL_UPDATE_FREE_ROUTINE "CredentialUpdateFree" | 
 
 
 
 
 | 117 | #endif | 
 
 
 
 
 | 118 |  | 
 
 
 
 
 | 119 | #ifdef SECURITY_KERNEL | 
 
 
 
 
 | 120 |  | 
 
 
 
 
 | 121 | typedef PVOID SEC_THREAD_START; | 
 
 
 
 
 | 122 | typedef PVOID SEC_ATTRS; | 
 
 
 
 
 | 123 | #else | 
 
 
 
 
 | 124 | typedef LPTHREAD_START_ROUTINE SEC_THREAD_START; | 
 
 
 
 
 | 125 | typedef LPSECURITY_ATTRIBUTES SEC_ATTRS; | 
 
 
 
 
 | 126 | #endif | 
 
 
 
 
 | 127 |  | 
 
 
 
 
 | 128 | #define SecEqualLuid(L1,L2) ((((PLUID)L1)->LowPart==((PLUID)L2)->LowPart) && (((PLUID)L1)->HighPart==((PLUID)L2)->HighPart)) | 
 
 
 
 
 | 129 | #define SecIsZeroLuid(L1) ((L1->LowPart | L1->HighPart)==0) | 
 
 
 
 
 | 130 |  | 
 
 
 
 
 | 131 | typedef struct _SECPKG_CLIENT_INFO { | 
 
 
 
 
 | 132 | LUID LogonId; | 
 
 
 
 
 | 133 | ULONG ProcessID; | 
 
 
 
 
 | 134 | ULONG ThreadID; | 
 
 
 
 
 | 135 | BOOLEAN HasTcbPrivilege; | 
 
 
 
 
 | 136 | BOOLEAN Impersonating; | 
 
 
 
 
 | 137 | BOOLEAN Restricted; | 
 
 
 
 
 | 138 |  | 
 
 
 
 
 | 139 | UCHAR ClientFlags; | 
 
 
 
 
 | 140 | SECURITY_IMPERSONATION_LEVEL ImpersonationLevel; | 
 
 
 
 
 | 141 |  | 
 
 
 
 
 | 142 | } SECPKG_CLIENT_INFO,*PSECPKG_CLIENT_INFO; | 
 
 
 
 
 | 143 |  | 
 
 
 
 
 | 144 | #define SECPKG_CLIENT_PROCESS_TERMINATED 0x01 | 
 
 
 
 
 | 145 | #define SECPKG_CLIENT_THREAD_TERMINATED 0x02 | 
 
 
 
 
 | 146 |  | 
 
 
 
 
 | 147 | typedef struct _SECPKG_CALL_INFO { | 
 
 
 
 
 | 148 | ULONG ProcessId; | 
 
 
 
 
 | 149 | ULONG ThreadId; | 
 
 
 
 
 | 150 | ULONG Attributes; | 
 
 
 
 
 | 151 | ULONG CallCount; | 
 
 
 
 
 | 152 | } SECPKG_CALL_INFO,*PSECPKG_CALL_INFO; | 
 
 
 
 
 | 153 |  | 
 
 
 
 
 | 154 | #define SECPKG_CALL_KERNEL_MODE 0x00000001 | 
 
 
 
 
 | 155 | #define SECPKG_CALL_ANSI 0x00000002 | 
 
 
 
 
 | 156 | #define SECPKG_CALL_URGENT 0x00000004 | 
 
 
 
 
 | 157 | #define SECPKG_CALL_RECURSIVE 0x00000008 | 
 
 
 
 
 | 158 | #define SECPKG_CALL_IN_PROC 0x00000010 | 
 
 
 
 
 | 159 | #define SECPKG_CALL_CLEANUP 0x00000020 | 
 
 
 
 
 | 160 | #define SECPKG_CALL_WOWCLIENT 0x00000040 | 
 
 
 
 
 | 161 | #define SECPKG_CALL_THREAD_TERM 0x00000080 | 
 
 
 
 
 | 162 | #define SECPKG_CALL_PROCESS_TERM 0x00000100 | 
 
 
 
 
 | 163 | #define SECPKG_CALL_IS_TCB 0x00000200 | 
 
 
 
 
 | 164 |  | 
 
 
 
 
 | 165 | typedef struct _SECPKG_SUPPLEMENTAL_CRED { | 
 
 
 
 
 | 166 | UNICODE_STRING PackageName; | 
 
 
 
 
 | 167 | ULONG CredentialSize; | 
 
 
 
 
 | 168 | PUCHAR Credentials; | 
 
 
 
 
 | 169 | } SECPKG_SUPPLEMENTAL_CRED,*PSECPKG_SUPPLEMENTAL_CRED; | 
 
 
 
 
 | 170 |  | 
 
 
 
 
 | 171 | typedef ULONG_PTR LSA_SEC_HANDLE; | 
 
 
 
 
 | 172 | typedef LSA_SEC_HANDLE *PLSA_SEC_HANDLE; | 
 
 
 
 
 | 173 | typedef struct _SECPKG_SUPPLEMENTAL_CRED_ARRAY { | 
 
 
 
 
 | 174 | ULONG CredentialCount; | 
 
 
 
 
 | 175 | SECPKG_SUPPLEMENTAL_CRED Credentials[1]; | 
 
 
 
 
 | 176 | } SECPKG_SUPPLEMENTAL_CRED_ARRAY,*PSECPKG_SUPPLEMENTAL_CRED_ARRAY; | 
 
 
 
 
 | 177 |  | 
 
 
 
 
 | 178 | #define SECBUFFER_UNMAPPED 0x40000000 | 
 
 
 
 
 | 179 |  | 
 
 
 
 
 | 180 | #define SECBUFFER_KERNEL_MAP 0x20000000 | 
 
 
 
 
 | 181 |  | 
 
 
 
 
 | 182 | typedef NTSTATUS (NTAPI LSA_CALLBACK_FUNCTION)(ULONG_PTR Argument1,ULONG_PTR Argument2,PSecBuffer InputBuffer,PSecBuffer OutputBuffer); | 
 
 
 
 
 | 183 |  | 
 
 
 
 
 | 184 | typedef LSA_CALLBACK_FUNCTION *PLSA_CALLBACK_FUNCTION; | 
 
 
 
 
 | 185 |  | 
 
 
 
 
 | 186 | #define PRIMARY_CRED_CLEAR_PASSWORD 0x1 | 
 
 
 
 
 | 187 | #define PRIMARY_CRED_OWF_PASSWORD 0x2 | 
 
 
 
 
 | 188 | #define PRIMARY_CRED_UPDATE 0x4 | 
 
 
 
 
 | 189 | #define PRIMARY_CRED_CACHED_LOGON 0x8 | 
 
 
 
 
 | 190 | #define PRIMARY_CRED_LOGON_NO_TCB 0x10 | 
 
 
 
 
 | 191 |  | 
 
 
 
 
 | 192 | #define PRIMARY_CRED_LOGON_PACKAGE_SHIFT 24 | 
 
 
 
 
 | 193 | #define PRIMARY_CRED_PACKAGE_MASK 0xff000000 | 
 
 
 
 
 | 194 |  | 
 
 
 
 
 | 195 | typedef struct _SECPKG_PRIMARY_CRED { | 
 
 
 
 
 | 196 | LUID LogonId; | 
 
 
 
 
 | 197 | UNICODE_STRING DownlevelName; | 
 
 
 
 
 | 198 | UNICODE_STRING DomainName; | 
 
 
 
 
 | 199 | UNICODE_STRING Password; | 
 
 
 
 
 | 200 | UNICODE_STRING OldPassword; | 
 
 
 
 
 | 201 | PSID UserSid; | 
 
 
 
 
 | 202 | ULONG Flags; | 
 
 
 
 
 | 203 | UNICODE_STRING DnsDomainName; | 
 
 
 
 
 | 204 | UNICODE_STRING Upn; | 
 
 
 
 
 | 205 | UNICODE_STRING LogonServer; | 
 
 
 
 
 | 206 | UNICODE_STRING Spare1; | 
 
 
 
 
 | 207 | UNICODE_STRING Spare2; | 
 
 
 
 
 | 208 | UNICODE_STRING Spare3; | 
 
 
 
 
 | 209 | UNICODE_STRING Spare4; | 
 
 
 
 
 | 210 | } SECPKG_PRIMARY_CRED,*PSECPKG_PRIMARY_CRED; | 
 
 
 
 
 | 211 |  | 
 
 
 
 
 | 212 | #define MAX_CRED_SIZE 1024 | 
 
 
 
 
 | 213 |  | 
 
 
 
 
 | 214 | #define SECPKG_STATE_ENCRYPTION_PERMITTED 0x01 | 
 
 
 
 
 | 215 | #define SECPKG_STATE_STRONG_ENCRYPTION_PERMITTED 0x02 | 
 
 
 
 
 | 216 | #define SECPKG_STATE_DOMAIN_CONTROLLER 0x04 | 
 
 
 
 
 | 217 | #define SECPKG_STATE_WORKSTATION 0x08 | 
 
 
 
 
 | 218 | #define SECPKG_STATE_STANDALONE 0x10 | 
 
 
 
 
 | 219 |  | 
 
 
 
 
 | 220 | typedef struct _SECPKG_PARAMETERS { | 
 
 
 
 
 | 221 | ULONG Version; | 
 
 
 
 
 | 222 | ULONG MachineState; | 
 
 
 
 
 | 223 | ULONG SetupMode; | 
 
 
 
 
 | 224 | PSID DomainSid; | 
 
 
 
 
 | 225 | UNICODE_STRING DomainName; | 
 
 
 
 
 | 226 | UNICODE_STRING DnsDomainName; | 
 
 
 
 
 | 227 | GUID DomainGuid; | 
 
 
 
 
 | 228 | } SECPKG_PARAMETERS,*PSECPKG_PARAMETERS; | 
 
 
 
 
 | 229 |  | 
 
 
 
 
 | 230 | typedef enum _SECPKG_EXTENDED_INFORMATION_CLASS { | 
 
 
 
 
 | 231 | SecpkgGssInfo = 1, | 
 
 
 
 
 | 232 | SecpkgContextThunks, | 
 
 
 
 
 | 233 | SecpkgMutualAuthLevel, | 
 
 
 
 
 | 234 | SecpkgWowClientDll, | 
 
 
 
 
 | 235 | SecpkgExtraOids, | 
 
 
 
 
 | 236 | SecpkgMaxInfo | 
 
 
 
 
 | 237 | } SECPKG_EXTENDED_INFORMATION_CLASS; | 
 
 
 
 
 | 238 |  | 
 
 
 
 
 | 239 | typedef struct _SECPKG_GSS_INFO { | 
 
 
 
 
 | 240 | ULONG EncodedIdLength; | 
 
 
 
 
 | 241 | UCHAR EncodedId[4]; | 
 
 
 
 
 | 242 | } SECPKG_GSS_INFO,*PSECPKG_GSS_INFO; | 
 
 
 
 
 | 243 |  | 
 
 
 
 
 | 244 | typedef struct _SECPKG_CONTEXT_THUNKS { | 
 
 
 
 
 | 245 | ULONG InfoLevelCount; | 
 
 
 
 
 | 246 | ULONG Levels[1]; | 
 
 
 
 
 | 247 | } SECPKG_CONTEXT_THUNKS,*PSECPKG_CONTEXT_THUNKS; | 
 
 
 
 
 | 248 |  | 
 
 
 
 
 | 249 | typedef struct _SECPKG_MUTUAL_AUTH_LEVEL { | 
 
 
 
 
 | 250 | ULONG MutualAuthLevel; | 
 
 
 
 
 | 251 | } SECPKG_MUTUAL_AUTH_LEVEL,*PSECPKG_MUTUAL_AUTH_LEVEL; | 
 
 
 
 
 | 252 |  | 
 
 
 
 
 | 253 | typedef struct _SECPKG_WOW_CLIENT_DLL { | 
 
 
 
 
 | 254 | SECURITY_STRING WowClientDllPath; | 
 
 
 
 
 | 255 | } SECPKG_WOW_CLIENT_DLL,*PSECPKG_WOW_CLIENT_DLL; | 
 
 
 
 
 | 256 |  | 
 
 
 
 
 | 257 | #define SECPKG_MAX_OID_LENGTH 32 | 
 
 
 
 
 | 258 |  | 
 
 
 
 
 | 259 | typedef struct _SECPKG_SERIALIZED_OID { | 
 
 
 
 
 | 260 | ULONG OidLength; | 
 
 
 
 
 | 261 | ULONG OidAttributes; | 
 
 
 
 
 | 262 | UCHAR OidValue[SECPKG_MAX_OID_LENGTH ]; | 
 
 
 
 
 | 263 | } SECPKG_SERIALIZED_OID,*PSECPKG_SERIALIZED_OID; | 
 
 
 
 
 | 264 |  | 
 
 
 
 
 | 265 | typedef struct _SECPKG_EXTRA_OIDS { | 
 
 
 
 
 | 266 | ULONG OidCount; | 
 
 
 
 
 | 267 | SECPKG_SERIALIZED_OID Oids[1 ]; | 
 
 
 
 
 | 268 | } SECPKG_EXTRA_OIDS,*PSECPKG_EXTRA_OIDS; | 
 
 
 
 
 | 269 |  | 
 
 
 
 
 | 270 | typedef struct _SECPKG_EXTENDED_INFORMATION { | 
 
 
 
 
 | 271 | SECPKG_EXTENDED_INFORMATION_CLASS Class; | 
 
 
 
 
 | 272 | union { | 
 
 
 
 
 | 273 | SECPKG_GSS_INFO GssInfo; | 
 
 
 
 
 | 274 | SECPKG_CONTEXT_THUNKS ContextThunks; | 
 
 
 
 
 | 275 | SECPKG_MUTUAL_AUTH_LEVEL MutualAuthLevel; | 
 
 
 
 
 | 276 | SECPKG_WOW_CLIENT_DLL WowClientDll; | 
 
 
 
 
 | 277 | SECPKG_EXTRA_OIDS ExtraOids; | 
 
 
 
 
 | 278 | } Info; | 
 
 
 
 
 | 279 | } SECPKG_EXTENDED_INFORMATION,*PSECPKG_EXTENDED_INFORMATION; | 
 
 
 
 
 | 280 |  | 
 
 
 
 
 | 281 | #define SECPKG_ATTR_SASL_CONTEXT 0x00010000 | 
 
 
 
 
 | 282 |  | 
 
 
 
 
 | 283 | typedef struct _SecPkgContext_SaslContext { | 
 
 
 
 
 | 284 | PVOID SaslContext; | 
 
 
 
 
 | 285 | } SecPkgContext_SaslContext,*PSecPkgContext_SaslContext; | 
 
 
 
 
 | 286 |  | 
 
 
 
 
 | 287 | #define SECPKG_ATTR_THUNK_ALL 0x00010000 | 
 
 
 
 
 | 288 |  | 
 
 
 
 
 | 289 | #ifndef SECURITY_USER_DATA_DEFINED | 
 
 
 
 
 | 290 | #define SECURITY_USER_DATA_DEFINED | 
 
 
 
 
 | 291 |  | 
 
 
 
 
 | 292 | typedef struct _SECURITY_USER_DATA { | 
 
 
 
 
 | 293 | SECURITY_STRING UserName; | 
 
 
 
 
 | 294 | SECURITY_STRING LogonDomainName; | 
 
 
 
 
 | 295 | SECURITY_STRING LogonServer; | 
 
 
 
 
 | 296 | PSID pSid; | 
 
 
 
 
 | 297 | } SECURITY_USER_DATA,*PSECURITY_USER_DATA; | 
 
 
 
 
 | 298 |  | 
 
 
 
 
 | 299 | typedef SECURITY_USER_DATA SecurityUserData,*PSecurityUserData; | 
 
 
 
 
 | 300 |  | 
 
 
 
 
 | 301 | #define UNDERSTANDS_LONG_NAMES 1 | 
 
 
 
 
 | 302 | #define NO_LONG_NAMES 2 | 
 
 
 
 
 | 303 | #endif | 
 
 
 
 
 | 304 |  | 
 
 
 
 
 | 305 | typedef NTSTATUS (NTAPI LSA_IMPERSONATE_CLIENT)(VOID); | 
 
 
 
 
 | 306 | typedef NTSTATUS (NTAPI LSA_UNLOAD_PACKAGE)(VOID); | 
 
 
 
 
 | 307 | typedef NTSTATUS (NTAPI LSA_DUPLICATE_HANDLE)(HANDLE SourceHandle,PHANDLE DestionationHandle); | 
 
 
 
 
 | 308 | typedef NTSTATUS (NTAPI LSA_SAVE_SUPPLEMENTAL_CREDENTIALS)(PLUID LogonId,ULONG SupplementalCredSize,PVOID SupplementalCreds,BOOLEAN Synchronous); | 
 
 
 
 
 | 309 | typedef HANDLE (NTAPI LSA_CREATE_THREAD)(SEC_ATTRS SecurityAttributes,ULONG StackSize,SEC_THREAD_START StartFunction,PVOID ThreadParameter,ULONG CreationFlags,PULONG ThreadId); | 
 
 
 
 
 | 310 | typedef NTSTATUS (NTAPI LSA_GET_CLIENT_INFO)(PSECPKG_CLIENT_INFO ClientInfo); | 
 
 
 
 
 | 311 | typedef HANDLE (NTAPI LSA_REGISTER_NOTIFICATION)(SEC_THREAD_START StartFunction,PVOID Parameter,ULONG NotificationType,ULONG NotificationClass,ULONG NotificationFlags,ULONG IntervalMinutes,HANDLE WaitEvent); | 
 
 
 
 
 | 312 | typedef NTSTATUS (NTAPI LSA_CANCEL_NOTIFICATION)(HANDLE NotifyHandle); | 
 
 
 
 
 | 313 | typedef NTSTATUS (NTAPI LSA_MAP_BUFFER)(PSecBuffer InputBuffer,PSecBuffer OutputBuffer); | 
 
 
 
 
 | 314 | typedef NTSTATUS (NTAPI LSA_CREATE_TOKEN)(PLUID LogonId,PTOKEN_SOURCE TokenSource,SECURITY_LOGON_TYPE LogonType,SECURITY_IMPERSONATION_LEVEL ImpersonationLevel,LSA_TOKEN_INFORMATION_TYPE TokenInformationType,PVOID TokenInformation,PTOKEN_GROUPS TokenGroups,PUNICODE_STRING AccountName,PUNICODE_STRING AuthorityName,PUNICODE_STRING Workstation,PUNICODE_STRING ProfilePath,PHANDLE Token,PNTSTATUS SubStatus); | 
 
 
 
 
 | 315 |  | 
 
 
 
 
 | 316 | typedef enum _SECPKG_SESSIONINFO_TYPE { | 
 
 
 
 
 | 317 | SecSessionPrimaryCred | 
 
 
 
 
 | 318 | } SECPKG_SESSIONINFO_TYPE; | 
 
 
 
 
 | 319 |  | 
 
 
 
 
 | 320 | typedef NTSTATUS (NTAPI LSA_CREATE_TOKEN_EX)(PLUID LogonId,PTOKEN_SOURCE TokenSource,SECURITY_LOGON_TYPE LogonType,SECURITY_IMPERSONATION_LEVEL ImpersonationLevel,LSA_TOKEN_INFORMATION_TYPE TokenInformationType,PVOID TokenInformation,PTOKEN_GROUPS TokenGroups,PUNICODE_STRING Workstation,PUNICODE_STRING ProfilePath,PVOID SessionInformation,SECPKG_SESSIONINFO_TYPE SessionInformationType,PHANDLE Token,PNTSTATUS SubStatus); | 
 
 
 
 
 | 321 | typedef VOID (NTAPI LSA_AUDIT_LOGON)(NTSTATUS Status,NTSTATUS SubStatus,PUNICODE_STRING AccountName,PUNICODE_STRING AuthenticatingAuthority,PUNICODE_STRING WorkstationName,PSID UserSid,SECURITY_LOGON_TYPE LogonType,PTOKEN_SOURCE TokenSource,PLUID LogonId); | 
 
 
 
 
 | 322 | typedef NTSTATUS (NTAPI LSA_CALL_PACKAGE)(PUNICODE_STRING AuthenticationPackage,PVOID ProtocolSubmitBuffer,ULONG SubmitBufferLength,PVOID *ProtocolReturnBuffer,PULONG ReturnBufferLength,PNTSTATUS ProtocolStatus); | 
 
 
 
 
 | 323 | typedef NTSTATUS (NTAPI LSA_CALL_PACKAGEEX)(PUNICODE_STRING AuthenticationPackage,PVOID ClientBufferBase,PVOID ProtocolSubmitBuffer,ULONG SubmitBufferLength,PVOID *ProtocolReturnBuffer,PULONG ReturnBufferLength,PNTSTATUS ProtocolStatus); | 
 
 
 
 
 | 324 | typedef NTSTATUS (NTAPI LSA_CALL_PACKAGE_PASSTHROUGH)(PUNICODE_STRING AuthenticationPackage,PVOID ClientBufferBase,PVOID ProtocolSubmitBuffer,ULONG SubmitBufferLength,PVOID *ProtocolReturnBuffer,PULONG ReturnBufferLength,PNTSTATUS ProtocolStatus); | 
 
 
 
 
 | 325 | typedef BOOLEAN (NTAPI LSA_GET_CALL_INFO)(PSECPKG_CALL_INFO Info); | 
 
 
 
 
 | 326 | typedef PVOID (NTAPI LSA_CREATE_SHARED_MEMORY)(ULONG MaxSize,ULONG InitialSize); | 
 
 
 
 
 | 327 | typedef PVOID (NTAPI LSA_ALLOCATE_SHARED_MEMORY)(PVOID SharedMem,ULONG Size); | 
 
 
 
 
 | 328 | typedef VOID (NTAPI LSA_FREE_SHARED_MEMORY)(PVOID SharedMem,PVOID Memory); | 
 
 
 
 
 | 329 | typedef BOOLEAN (NTAPI LSA_DELETE_SHARED_MEMORY)(PVOID SharedMem); | 
 
 
 
 
 | 330 |  | 
 
 
 
 
 | 331 | typedef enum _SECPKG_NAME_TYPE { | 
 
 
 
 
 | 332 | SecNameSamCompatible, | 
 
 
 
 
 | 333 | SecNameAlternateId, | 
 
 
 
 
 | 334 | SecNameFlat, | 
 
 
 
 
 | 335 | SecNameDN, | 
 
 
 
 
 | 336 | SecNameSPN | 
 
 
 
 
 | 337 | } SECPKG_NAME_TYPE; | 
 
 
 
 
 | 338 |  | 
 
 
 
 
 | 339 | typedef NTSTATUS (NTAPI LSA_OPEN_SAM_USER)(PSECURITY_STRING Name,SECPKG_NAME_TYPE NameType,PSECURITY_STRING Prefix,BOOLEAN AllowGuest,ULONG Reserved,PVOID *UserHandle); | 
 
 
 
 
 | 340 | typedef NTSTATUS (NTAPI LSA_GET_USER_CREDENTIALS)(PVOID UserHandle,PVOID *PrimaryCreds,PULONG PrimaryCredsSize,PVOID *SupplementalCreds,PULONG SupplementalCredsSize); | 
 
 
 
 
 | 341 | typedef NTSTATUS (NTAPI LSA_GET_USER_AUTH_DATA)(PVOID UserHandle,PUCHAR *UserAuthData,PULONG UserAuthDataSize); | 
 
 
 
 
 | 342 | typedef NTSTATUS (NTAPI LSA_CLOSE_SAM_USER)(PVOID UserHandle); | 
 
 
 
 
 | 343 | typedef NTSTATUS (NTAPI LSA_GET_AUTH_DATA_FOR_USER)(PSECURITY_STRING Name,SECPKG_NAME_TYPE NameType,PSECURITY_STRING Prefix,PUCHAR *UserAuthData,PULONG UserAuthDataSize,PUNICODE_STRING UserFlatName); | 
 
 
 
 
 | 344 | typedef NTSTATUS (NTAPI LSA_CONVERT_AUTH_DATA_TO_TOKEN)(PVOID UserAuthData,ULONG UserAuthDataSize,SECURITY_IMPERSONATION_LEVEL ImpersonationLevel,PTOKEN_SOURCE TokenSource,SECURITY_LOGON_TYPE LogonType,PUNICODE_STRING AuthorityName,PHANDLE Token,PLUID LogonId,PUNICODE_STRING AccountName,PNTSTATUS SubStatus); | 
 
 
 
 
 | 345 | typedef NTSTATUS (NTAPI LSA_CRACK_SINGLE_NAME)(ULONG FormatOffered,BOOLEAN PerformAtGC,PUNICODE_STRING NameInput,PUNICODE_STRING Prefix,ULONG RequestedFormat,PUNICODE_STRING CrackedName,PUNICODE_STRING DnsDomainName,PULONG SubStatus); | 
 
 
 
 
 | 346 | typedef NTSTATUS (NTAPI LSA_AUDIT_ACCOUNT_LOGON)(ULONG AuditId,BOOLEAN Success,PUNICODE_STRING Source,PUNICODE_STRING ClientName,PUNICODE_STRING MappedName,NTSTATUS Status); | 
 
 
 
 
 | 347 | typedef NTSTATUS (NTAPI LSA_CLIENT_CALLBACK)(PCHAR Callback,ULONG_PTR Argument1,ULONG_PTR Argument2,PSecBuffer Input,PSecBuffer Output); | 
 
 
 
 
 | 348 | typedef NTSTATUS (NTAPI LSA_REGISTER_CALLBACK)(ULONG CallbackId,PLSA_CALLBACK_FUNCTION Callback); | 
 
 
 
 
 | 349 |  | 
 
 
 
 
 | 350 | #define NOTIFIER_FLAG_NEW_THREAD 0x00000001 | 
 
 
 
 
 | 351 | #define NOTIFIER_FLAG_ONE_SHOT 0x00000002 | 
 
 
 
 
 | 352 | #define NOTIFIER_FLAG_SECONDS 0x80000000 | 
 
 
 
 
 | 353 |  | 
 
 
 
 
 | 354 | #define NOTIFIER_TYPE_INTERVAL 1 | 
 
 
 
 
 | 355 | #define NOTIFIER_TYPE_HANDLE_WAIT 2 | 
 
 
 
 
 | 356 | #define NOTIFIER_TYPE_STATE_CHANGE 3 | 
 
 
 
 
 | 357 | #define NOTIFIER_TYPE_NOTIFY_EVENT 4 | 
 
 
 
 
 | 358 | #define NOTIFIER_TYPE_IMMEDIATE 16 | 
 
 
 
 
 | 359 |  | 
 
 
 
 
 | 360 | #define NOTIFY_CLASS_PACKAGE_CHANGE 1 | 
 
 
 
 
 | 361 | #define NOTIFY_CLASS_ROLE_CHANGE 2 | 
 
 
 
 
 | 362 | #define NOTIFY_CLASS_DOMAIN_CHANGE 3 | 
 
 
 
 
 | 363 | #define NOTIFY_CLASS_REGISTRY_CHANGE 4 | 
 
 
 
 
 | 364 |  | 
 
 
 
 
 | 365 | typedef struct _SECPKG_EVENT_PACKAGE_CHANGE { | 
 
 
 
 
 | 366 | ULONG ChangeType; | 
 
 
 
 
 | 367 | LSA_SEC_HANDLE PackageId; | 
 
 
 
 
 | 368 | SECURITY_STRING PackageName; | 
 
 
 
 
 | 369 | } SECPKG_EVENT_PACKAGE_CHANGE,*PSECPKG_EVENT_PACKAGE_CHANGE; | 
 
 
 
 
 | 370 |  | 
 
 
 
 
 | 371 | #define SECPKG_PACKAGE_CHANGE_LOAD 0 | 
 
 
 
 
 | 372 | #define SECPKG_PACKAGE_CHANGE_UNLOAD 1 | 
 
 
 
 
 | 373 | #define SECPKG_PACKAGE_CHANGE_SELECT 2 | 
 
 
 
 
 | 374 |  | 
 
 
 
 
 | 375 | typedef struct _SECPKG_EVENT_ROLE_CHANGE { | 
 
 
 
 
 | 376 | ULONG PreviousRole; | 
 
 
 
 
 | 377 | ULONG NewRole; | 
 
 
 
 
 | 378 | } SECPKG_EVENT_ROLE_CHANGE,*PSECPKG_EVENT_ROLE_CHANGE; | 
 
 
 
 
 | 379 |  | 
 
 
 
 
 | 380 | typedef struct _SECPKG_PARAMETERS SECPKG_EVENT_DOMAIN_CHANGE; | 
 
 
 
 
 | 381 | typedef struct _SECPKG_PARAMETERS *PSECPKG_EVENT_DOMAIN_CHANGE; | 
 
 
 
 
 | 382 |  | 
 
 
 
 
 | 383 | typedef struct _SECPKG_EVENT_NOTIFY { | 
 
 
 
 
 | 384 | ULONG EventClass; | 
 
 
 
 
 | 385 | ULONG Reserved; | 
 
 
 
 
 | 386 | ULONG EventDataSize; | 
 
 
 
 
 | 387 | PVOID EventData; | 
 
 
 
 
 | 388 | PVOID PackageParameter; | 
 
 
 
 
 | 389 | } SECPKG_EVENT_NOTIFY,*PSECPKG_EVENT_NOTIFY; | 
 
 
 
 
 | 390 |  | 
 
 
 
 
 | 391 | typedef NTSTATUS (NTAPI LSA_UPDATE_PRIMARY_CREDENTIALS)(PSECPKG_PRIMARY_CRED PrimaryCredentials,PSECPKG_SUPPLEMENTAL_CRED_ARRAY Credentials); | 
 
 
 
 
 | 392 | typedef VOID (NTAPI LSA_PROTECT_MEMORY)(PVOID Buffer,ULONG BufferSize); | 
 
 
 
 
 | 393 | typedef NTSTATUS (NTAPI LSA_OPEN_TOKEN_BY_LOGON_ID)(PLUID LogonId,HANDLE *RetTokenHandle); | 
 
 
 
 
 | 394 | typedef NTSTATUS (NTAPI LSA_EXPAND_AUTH_DATA_FOR_DOMAIN)(PUCHAR UserAuthData,ULONG UserAuthDataSize,PVOID Reserved,PUCHAR *ExpandedAuthData,PULONG ExpandedAuthDataSize); | 
 
 
 
 
 | 395 |  | 
 
 
 
 
 | 396 | typedef LSA_IMPERSONATE_CLIENT *PLSA_IMPERSONATE_CLIENT; | 
 
 
 
 
 | 397 | typedef LSA_UNLOAD_PACKAGE *PLSA_UNLOAD_PACKAGE; | 
 
 
 
 
 | 398 | typedef LSA_DUPLICATE_HANDLE *PLSA_DUPLICATE_HANDLE; | 
 
 
 
 
 | 399 | typedef LSA_SAVE_SUPPLEMENTAL_CREDENTIALS *PLSA_SAVE_SUPPLEMENTAL_CREDENTIALS; | 
 
 
 
 
 | 400 | typedef LSA_CREATE_THREAD *PLSA_CREATE_THREAD; | 
 
 
 
 
 | 401 | typedef LSA_GET_CLIENT_INFO *PLSA_GET_CLIENT_INFO; | 
 
 
 
 
 | 402 | typedef LSA_REGISTER_NOTIFICATION *PLSA_REGISTER_NOTIFICATION; | 
 
 
 
 
 | 403 | typedef LSA_CANCEL_NOTIFICATION *PLSA_CANCEL_NOTIFICATION; | 
 
 
 
 
 | 404 | typedef LSA_MAP_BUFFER *PLSA_MAP_BUFFER; | 
 
 
 
 
 | 405 | typedef LSA_CREATE_TOKEN *PLSA_CREATE_TOKEN; | 
 
 
 
 
 | 406 | typedef LSA_AUDIT_LOGON *PLSA_AUDIT_LOGON; | 
 
 
 
 
 | 407 | typedef LSA_CALL_PACKAGE *PLSA_CALL_PACKAGE; | 
 
 
 
 
 | 408 | typedef LSA_CALL_PACKAGEEX *PLSA_CALL_PACKAGEEX; | 
 
 
 
 
 | 409 | typedef LSA_GET_CALL_INFO *PLSA_GET_CALL_INFO; | 
 
 
 
 
 | 410 | typedef LSA_CREATE_SHARED_MEMORY *PLSA_CREATE_SHARED_MEMORY; | 
 
 
 
 
 | 411 | typedef LSA_ALLOCATE_SHARED_MEMORY *PLSA_ALLOCATE_SHARED_MEMORY; | 
 
 
 
 
 | 412 | typedef LSA_FREE_SHARED_MEMORY *PLSA_FREE_SHARED_MEMORY; | 
 
 
 
 
 | 413 | typedef LSA_DELETE_SHARED_MEMORY *PLSA_DELETE_SHARED_MEMORY; | 
 
 
 
 
 | 414 | typedef LSA_OPEN_SAM_USER *PLSA_OPEN_SAM_USER; | 
 
 
 
 
 | 415 | typedef LSA_GET_USER_CREDENTIALS *PLSA_GET_USER_CREDENTIALS; | 
 
 
 
 
 | 416 | typedef LSA_GET_USER_AUTH_DATA *PLSA_GET_USER_AUTH_DATA; | 
 
 
 
 
 | 417 | typedef LSA_CLOSE_SAM_USER *PLSA_CLOSE_SAM_USER; | 
 
 
 
 
 | 418 | typedef LSA_CONVERT_AUTH_DATA_TO_TOKEN *PLSA_CONVERT_AUTH_DATA_TO_TOKEN; | 
 
 
 
 
 | 419 | typedef LSA_CLIENT_CALLBACK *PLSA_CLIENT_CALLBACK; | 
 
 
 
 
 | 420 | typedef LSA_REGISTER_CALLBACK *PLSA_REGISTER_CALLBACK; | 
 
 
 
 
 | 421 | typedef LSA_UPDATE_PRIMARY_CREDENTIALS *PLSA_UPDATE_PRIMARY_CREDENTIALS; | 
 
 
 
 
 | 422 | typedef LSA_GET_AUTH_DATA_FOR_USER *PLSA_GET_AUTH_DATA_FOR_USER; | 
 
 
 
 
 | 423 | typedef LSA_CRACK_SINGLE_NAME *PLSA_CRACK_SINGLE_NAME; | 
 
 
 
 
 | 424 | typedef LSA_AUDIT_ACCOUNT_LOGON *PLSA_AUDIT_ACCOUNT_LOGON; | 
 
 
 
 
 | 425 | typedef LSA_CALL_PACKAGE_PASSTHROUGH *PLSA_CALL_PACKAGE_PASSTHROUGH; | 
 
 
 
 
 | 426 | typedef LSA_PROTECT_MEMORY *PLSA_PROTECT_MEMORY; | 
 
 
 
 
 | 427 | typedef LSA_OPEN_TOKEN_BY_LOGON_ID *PLSA_OPEN_TOKEN_BY_LOGON_ID; | 
 
 
 
 
 | 428 | typedef LSA_EXPAND_AUTH_DATA_FOR_DOMAIN *PLSA_EXPAND_AUTH_DATA_FOR_DOMAIN; | 
 
 
 
 
 | 429 | typedef LSA_CREATE_TOKEN_EX *PLSA_CREATE_TOKEN_EX; | 
 
 
 
 
 | 430 |  | 
 
 
 
 
 | 431 | #ifdef _WINCRED_H_ | 
 
 
 
 
 | 432 |  | 
 
 
 
 
 | 433 | #ifndef _ENCRYPTED_CREDENTIAL_DEFINED | 
 
 
 
 
 | 434 | #define _ENCRYPTED_CREDENTIAL_DEFINED | 
 
 
 
 
 | 435 |  | 
 
 
 
 
 | 436 | typedef struct _ENCRYPTED_CREDENTIALW { | 
 
 
 
 
 | 437 | CREDENTIALW Cred; | 
 
 
 
 
 | 438 | ULONG ClearCredentialBlobSize; | 
 
 
 
 
 | 439 | } ENCRYPTED_CREDENTIALW,*PENCRYPTED_CREDENTIALW; | 
 
 
 
 
 | 440 | #endif | 
 
 
 
 
 | 441 |  | 
 
 
 
 
 | 442 | #define CREDP_FLAGS_IN_PROCESS 0x01 | 
 
 
 
 
 | 443 | #define CREDP_FLAGS_USE_MIDL_HEAP 0x02 | 
 
 
 
 
 | 444 | #define CREDP_FLAGS_DONT_CACHE_TI 0x04 | 
 
 
 
 
 | 445 | #define CREDP_FLAGS_CLEAR_PASSWORD 0x08 | 
 
 
 
 
 | 446 | #define CREDP_FLAGS_USER_ENCRYPTED_PASSWORD 0x10 | 
 
 
 
 
 | 447 |  | 
 
 
 
 
 | 448 | typedef NTSTATUS (NTAPI CredReadFn)(PLUID LogonId,ULONG CredFlags,LPWSTR TargetName,ULONG Type,ULONG Flags,PENCRYPTED_CREDENTIALW *Credential); | 
 
 
 
 
 | 449 | typedef NTSTATUS (NTAPI CredReadDomainCredentialsFn)(PLUID LogonId,ULONG CredFlags,PCREDENTIAL_TARGET_INFORMATIONW TargetInfo,ULONG Flags,PULONG Count,PENCRYPTED_CREDENTIALW **Credential); | 
 
 
 
 
 | 450 | typedef VOID (NTAPI CredFreeCredentialsFn)(ULONG Count,PENCRYPTED_CREDENTIALW *Credentials); | 
 
 
 
 
 | 451 | typedef NTSTATUS (NTAPI CredWriteFn)(PLUID LogonId,ULONG CredFlags,PENCRYPTED_CREDENTIALW Credential,ULONG Flags); | 
 
 
 
 
 | 452 |  | 
 
 
 
 
 | 453 | NTSTATUS CredMarshalTargetInfo (PCREDENTIAL_TARGET_INFORMATIONW InTargetInfo,PUSHORT *Buffer,PULONG BufferSize); | 
 
 
 
 
 | 454 | NTSTATUS CredUnmarshalTargetInfo (PUSHORT Buffer,ULONG BufferSize,PCREDENTIAL_TARGET_INFORMATIONW *RetTargetInfo,PULONG RetActualSize); | 
 
 
 
 
 | 455 |  | 
 
 
 
 
 | 456 | #define CRED_MARSHALED_TI_SIZE_SIZE 12 | 
 
 
 
 
 | 457 | #endif | 
 
 
 
 
 | 458 |  | 
 
 
 
 
 | 459 | typedef struct _SEC_WINNT_AUTH_IDENTITY32 { | 
 
 
 
 
 | 460 | ULONG User; | 
 
 
 
 
 | 461 | ULONG UserLength; | 
 
 
 
 
 | 462 | ULONG Domain; | 
 
 
 
 
 | 463 | ULONG DomainLength; | 
 
 
 
 
 | 464 | ULONG Password; | 
 
 
 
 
 | 465 | ULONG PasswordLength; | 
 
 
 
 
 | 466 | ULONG Flags; | 
 
 
 
 
 | 467 | } SEC_WINNT_AUTH_IDENTITY32,*PSEC_WINNT_AUTH_IDENTITY32; | 
 
 
 
 
 | 468 |  | 
 
 
 
 
 | 469 | typedef struct _SEC_WINNT_AUTH_IDENTITY_EX32 { | 
 
 
 
 
 | 470 | ULONG Version; | 
 
 
 
 
 | 471 | ULONG Length; | 
 
 
 
 
 | 472 | ULONG User; | 
 
 
 
 
 | 473 | ULONG UserLength; | 
 
 
 
 
 | 474 | ULONG Domain; | 
 
 
 
 
 | 475 | ULONG DomainLength; | 
 
 
 
 
 | 476 | ULONG Password; | 
 
 
 
 
 | 477 | ULONG PasswordLength; | 
 
 
 
 
 | 478 | ULONG Flags; | 
 
 
 
 
 | 479 | ULONG PackageList; | 
 
 
 
 
 | 480 | ULONG PackageListLength; | 
 
 
 
 
 | 481 | } SEC_WINNT_AUTH_IDENTITY_EX32,*PSEC_WINNT_AUTH_IDENTITY_EX32; | 
 
 
 
 
 | 482 |  | 
 
 
 
 
 | 483 | typedef struct _LSA_SECPKG_FUNCTION_TABLE { | 
 
 
 
 
 | 484 | PLSA_CREATE_LOGON_SESSION CreateLogonSession; | 
 
 
 
 
 | 485 | PLSA_DELETE_LOGON_SESSION DeleteLogonSession; | 
 
 
 
 
 | 486 | PLSA_ADD_CREDENTIAL AddCredential; | 
 
 
 
 
 | 487 | PLSA_GET_CREDENTIALS GetCredentials; | 
 
 
 
 
 | 488 | PLSA_DELETE_CREDENTIAL DeleteCredential; | 
 
 
 
 
 | 489 | PLSA_ALLOCATE_LSA_HEAP AllocateLsaHeap; | 
 
 
 
 
 | 490 | PLSA_FREE_LSA_HEAP FreeLsaHeap; | 
 
 
 
 
 | 491 | PLSA_ALLOCATE_CLIENT_BUFFER AllocateClientBuffer; | 
 
 
 
 
 | 492 | PLSA_FREE_CLIENT_BUFFER FreeClientBuffer; | 
 
 
 
 
 | 493 | PLSA_COPY_TO_CLIENT_BUFFER CopyToClientBuffer; | 
 
 
 
 
 | 494 | PLSA_COPY_FROM_CLIENT_BUFFER CopyFromClientBuffer; | 
 
 
 
 
 | 495 | PLSA_IMPERSONATE_CLIENT ImpersonateClient; | 
 
 
 
 
 | 496 | PLSA_UNLOAD_PACKAGE UnloadPackage; | 
 
 
 
 
 | 497 | PLSA_DUPLICATE_HANDLE DuplicateHandle; | 
 
 
 
 
 | 498 | PLSA_SAVE_SUPPLEMENTAL_CREDENTIALS SaveSupplementalCredentials; | 
 
 
 
 
 | 499 | PLSA_CREATE_THREAD CreateThread; | 
 
 
 
 
 | 500 | PLSA_GET_CLIENT_INFO GetClientInfo; | 
 
 
 
 
 | 501 | PLSA_REGISTER_NOTIFICATION RegisterNotification; | 
 
 
 
 
 | 502 | PLSA_CANCEL_NOTIFICATION CancelNotification; | 
 
 
 
 
 | 503 | PLSA_MAP_BUFFER MapBuffer; | 
 
 
 
 
 | 504 | PLSA_CREATE_TOKEN CreateToken; | 
 
 
 
 
 | 505 | PLSA_AUDIT_LOGON AuditLogon; | 
 
 
 
 
 | 506 | PLSA_CALL_PACKAGE CallPackage; | 
 
 
 
 
 | 507 | PLSA_FREE_LSA_HEAP FreeReturnBuffer; | 
 
 
 
 
 | 508 | PLSA_GET_CALL_INFO GetCallInfo; | 
 
 
 
 
 | 509 | PLSA_CALL_PACKAGEEX CallPackageEx; | 
 
 
 
 
 | 510 | PLSA_CREATE_SHARED_MEMORY CreateSharedMemory; | 
 
 
 
 
 | 511 | PLSA_ALLOCATE_SHARED_MEMORY AllocateSharedMemory; | 
 
 
 
 
 | 512 | PLSA_FREE_SHARED_MEMORY FreeSharedMemory; | 
 
 
 
 
 | 513 | PLSA_DELETE_SHARED_MEMORY DeleteSharedMemory; | 
 
 
 
 
 | 514 | PLSA_OPEN_SAM_USER OpenSamUser; | 
 
 
 
 
 | 515 | PLSA_GET_USER_CREDENTIALS GetUserCredentials; | 
 
 
 
 
 | 516 | PLSA_GET_USER_AUTH_DATA GetUserAuthData; | 
 
 
 
 
 | 517 | PLSA_CLOSE_SAM_USER CloseSamUser; | 
 
 
 
 
 | 518 | PLSA_CONVERT_AUTH_DATA_TO_TOKEN ConvertAuthDataToToken; | 
 
 
 
 
 | 519 | PLSA_CLIENT_CALLBACK ClientCallback; | 
 
 
 
 
 | 520 | PLSA_UPDATE_PRIMARY_CREDENTIALS UpdateCredentials; | 
 
 
 
 
 | 521 | PLSA_GET_AUTH_DATA_FOR_USER GetAuthDataForUser; | 
 
 
 
 
 | 522 | PLSA_CRACK_SINGLE_NAME CrackSingleName; | 
 
 
 
 
 | 523 | PLSA_AUDIT_ACCOUNT_LOGON AuditAccountLogon; | 
 
 
 
 
 | 524 | PLSA_CALL_PACKAGE_PASSTHROUGH CallPackagePassthrough; | 
 
 
 
 
 | 525 | #ifdef _WINCRED_H_ | 
 
 
 
 
 | 526 | CredReadFn *CrediRead; | 
 
 
 
 
 | 527 | CredReadDomainCredentialsFn *CrediReadDomainCredentials; | 
 
 
 
 
 | 528 | CredFreeCredentialsFn *CrediFreeCredentials; | 
 
 
 
 
 | 529 | #else | 
 
 
 
 
 | 530 | PLSA_PROTECT_MEMORY DummyFunction1; | 
 
 
 
 
 | 531 | PLSA_PROTECT_MEMORY DummyFunction2; | 
 
 
 
 
 | 532 | PLSA_PROTECT_MEMORY DummyFunction3; | 
 
 
 
 
 | 533 | #endif | 
 
 
 
 
 | 534 | PLSA_PROTECT_MEMORY LsaProtectMemory; | 
 
 
 
 
 | 535 | PLSA_PROTECT_MEMORY LsaUnprotectMemory; | 
 
 
 
 
 | 536 | PLSA_OPEN_TOKEN_BY_LOGON_ID OpenTokenByLogonId; | 
 
 
 
 
 | 537 | PLSA_EXPAND_AUTH_DATA_FOR_DOMAIN ExpandAuthDataForDomain; | 
 
 
 
 
 | 538 | PLSA_ALLOCATE_PRIVATE_HEAP AllocatePrivateHeap; | 
 
 
 
 
 | 539 | PLSA_FREE_PRIVATE_HEAP FreePrivateHeap; | 
 
 
 
 
 | 540 | PLSA_CREATE_TOKEN_EX CreateTokenEx; | 
 
 
 
 
 | 541 | #ifdef _WINCRED_H_ | 
 
 
 
 
 | 542 | CredWriteFn *CrediWrite; | 
 
 
 
 
 | 543 | #else | 
 
 
 
 
 | 544 | PLSA_PROTECT_MEMORY DummyFunction4; | 
 
 
 
 
 | 545 | #endif | 
 
 
 
 
 | 546 | } LSA_SECPKG_FUNCTION_TABLE,*PLSA_SECPKG_FUNCTION_TABLE; | 
 
 
 
 
 | 547 |  | 
 
 
 
 
 | 548 | typedef struct _SECPKG_DLL_FUNCTIONS { | 
 
 
 
 
 | 549 | PLSA_ALLOCATE_LSA_HEAP AllocateHeap; | 
 
 
 
 
 | 550 | PLSA_FREE_LSA_HEAP FreeHeap; | 
 
 
 
 
 | 551 | PLSA_REGISTER_CALLBACK RegisterCallback; | 
 
 
 
 
 | 552 | } SECPKG_DLL_FUNCTIONS,*PSECPKG_DLL_FUNCTIONS; | 
 
 
 
 
 | 553 |  | 
 
 
 
 
 | 554 | typedef NTSTATUS (NTAPI SpInitializeFn)(ULONG_PTR PackageId,PSECPKG_PARAMETERS Parameters,PLSA_SECPKG_FUNCTION_TABLE FunctionTable); | 
 
 
 
 
 | 555 | typedef NTSTATUS (NTAPI SpShutdownFn)(VOID); | 
 
 
 
 
 | 556 | typedef NTSTATUS (NTAPI SpGetInfoFn)(PSecPkgInfo PackageInfo); | 
 
 
 
 
 | 557 | typedef NTSTATUS (NTAPI SpGetExtendedInformationFn)(SECPKG_EXTENDED_INFORMATION_CLASS Class,PSECPKG_EXTENDED_INFORMATION *ppInformation); | 
 
 
 
 
 | 558 | typedef NTSTATUS (NTAPI SpSetExtendedInformationFn)(SECPKG_EXTENDED_INFORMATION_CLASS Class,PSECPKG_EXTENDED_INFORMATION Info); | 
 
 
 
 
 | 559 | typedef NTSTATUS (LSA_AP_LOGON_USER_EX2)(PLSA_CLIENT_REQUEST ClientRequest,SECURITY_LOGON_TYPE LogonType,PVOID AuthenticationInformation,PVOID ClientAuthenticationBase,ULONG AuthenticationInformationLength,PVOID *ProfileBuffer,PULONG ProfileBufferLength,PLUID LogonId,PNTSTATUS SubStatus,PLSA_TOKEN_INFORMATION_TYPE TokenInformationType,PVOID *TokenInformation,PUNICODE_STRING *AccountName,PUNICODE_STRING *AuthenticatingAuthority,PUNICODE_STRING *MachineName,PSECPKG_PRIMARY_CRED PrimaryCredentials,PSECPKG_SUPPLEMENTAL_CRED_ARRAY *CachedCredentials); | 
 
 
 
 
 | 560 |  | 
 
 
 
 
 | 561 | typedef LSA_AP_LOGON_USER_EX2 *PLSA_AP_LOGON_USER_EX2; | 
 
 
 
 
 | 562 |  | 
 
 
 
 
 | 563 | #define LSA_AP_NAME_LOGON_USER_EX2 "LsaApLogonUserEx2\0" | 
 
 
 
 
 | 564 |  | 
 
 
 
 
 | 565 | typedef NTSTATUS (NTAPI SpAcceptCredentialsFn)(SECURITY_LOGON_TYPE LogonType,PUNICODE_STRING AccountName,PSECPKG_PRIMARY_CRED PrimaryCredentials,PSECPKG_SUPPLEMENTAL_CRED SupplementalCredentials); | 
 
 
 
 
 | 566 |  | 
 
 
 
 
 | 567 | #define SP_ACCEPT_CREDENTIALS_NAME "SpAcceptCredentials\0" | 
 
 
 
 
 | 568 |  | 
 
 
 
 
 | 569 | typedef NTSTATUS (NTAPI SpAcquireCredentialsHandleFn)(PUNICODE_STRING PrincipalName,ULONG CredentialUseFlags,PLUID LogonId,PVOID AuthorizationData,PVOID GetKeyFunciton,PVOID GetKeyArgument,PLSA_SEC_HANDLE CredentialHandle,PTimeStamp ExpirationTime); | 
 
 
 
 
 | 570 | typedef NTSTATUS (NTAPI SpFreeCredentialsHandleFn)(LSA_SEC_HANDLE CredentialHandle); | 
 
 
 
 
 | 571 | typedef NTSTATUS (NTAPI SpQueryCredentialsAttributesFn)(LSA_SEC_HANDLE CredentialHandle,ULONG CredentialAttribute,PVOID Buffer); | 
 
 
 
 
 | 572 | typedef NTSTATUS (NTAPI SpSetCredentialsAttributesFn)(LSA_SEC_HANDLE CredentialHandle,ULONG CredentialAttribute,PVOID Buffer,ULONG BufferSize); | 
 
 
 
 
 | 573 | typedef NTSTATUS (NTAPI SpAddCredentialsFn)(LSA_SEC_HANDLE CredentialHandle,PUNICODE_STRING PrincipalName,PUNICODE_STRING Package,ULONG CredentialUseFlags,PVOID AuthorizationData,PVOID GetKeyFunciton,PVOID GetKeyArgument,PTimeStamp ExpirationTime); | 
 
 
 
 
 | 574 | typedef NTSTATUS (NTAPI SpSaveCredentialsFn)(LSA_SEC_HANDLE CredentialHandle,PSecBuffer Credentials); | 
 
 
 
 
 | 575 | typedef NTSTATUS (NTAPI SpGetCredentialsFn)(LSA_SEC_HANDLE CredentialHandle,PSecBuffer Credentials); | 
 
 
 
 
 | 576 | typedef NTSTATUS (NTAPI SpDeleteCredentialsFn)(LSA_SEC_HANDLE CredentialHandle,PSecBuffer Key); | 
 
 
 
 
 | 577 | typedef NTSTATUS (NTAPI SpInitLsaModeContextFn)(LSA_SEC_HANDLE CredentialHandle,LSA_SEC_HANDLE ContextHandle,PUNICODE_STRING TargetName,ULONG ContextRequirements,ULONG TargetDataRep,PSecBufferDesc InputBuffers,PLSA_SEC_HANDLE NewContextHandle,PSecBufferDesc OutputBuffers,PULONG ContextAttributes,PTimeStamp ExpirationTime,PBOOLEAN MappedContext,PSecBuffer ContextData); | 
 
 
 
 
 | 578 | typedef NTSTATUS (NTAPI SpDeleteContextFn)(LSA_SEC_HANDLE ContextHandle); | 
 
 
 
 
 | 579 | typedef NTSTATUS (NTAPI SpApplyControlTokenFn)(LSA_SEC_HANDLE ContextHandle,PSecBufferDesc ControlToken); | 
 
 
 
 
 | 580 | typedef NTSTATUS (NTAPI SpAcceptLsaModeContextFn)(LSA_SEC_HANDLE CredentialHandle,LSA_SEC_HANDLE ContextHandle,PSecBufferDesc InputBuffer,ULONG ContextRequirements,ULONG TargetDataRep,PLSA_SEC_HANDLE NewContextHandle,PSecBufferDesc OutputBuffer,PULONG ContextAttributes,PTimeStamp ExpirationTime,PBOOLEAN MappedContext,PSecBuffer ContextData); | 
 
 
 
 
 | 581 | typedef NTSTATUS (NTAPI SpGetUserInfoFn)(PLUID LogonId,ULONG Flags,PSecurityUserData *UserData); | 
 
 
 
 
 | 582 | typedef NTSTATUS (NTAPI SpQueryContextAttributesFn)(LSA_SEC_HANDLE ContextHandle,ULONG ContextAttribute,PVOID Buffer); | 
 
 
 
 
 | 583 | typedef NTSTATUS (NTAPI SpSetContextAttributesFn)(LSA_SEC_HANDLE ContextHandle,ULONG ContextAttribute,PVOID Buffer,ULONG BufferSize); | 
 
 
 
 
 | 584 |  | 
 
 
 
 
 | 585 | typedef struct _SECPKG_FUNCTION_TABLE { | 
 
 
 
 
 | 586 | PLSA_AP_INITIALIZE_PACKAGE InitializePackage; | 
 
 
 
 
 | 587 | PLSA_AP_LOGON_USER LogonUser; | 
 
 
 
 
 | 588 | PLSA_AP_CALL_PACKAGE CallPackage; | 
 
 
 
 
 | 589 | PLSA_AP_LOGON_TERMINATED LogonTerminated; | 
 
 
 
 
 | 590 | PLSA_AP_CALL_PACKAGE_UNTRUSTED CallPackageUntrusted; | 
 
 
 
 
 | 591 | PLSA_AP_CALL_PACKAGE_PASSTHROUGH CallPackagePassthrough; | 
 
 
 
 
 | 592 | PLSA_AP_LOGON_USER_EX LogonUserEx; | 
 
 
 
 
 | 593 | PLSA_AP_LOGON_USER_EX2 LogonUserEx2; | 
 
 
 
 
 | 594 | SpInitializeFn *Initialize; | 
 
 
 
 
 | 595 | SpShutdownFn *Shutdown; | 
 
 
 
 
 | 596 | SpGetInfoFn *GetInfo; | 
 
 
 
 
 | 597 | SpAcceptCredentialsFn *AcceptCredentials; | 
 
 
 
 
 | 598 | SpAcquireCredentialsHandleFn *AcquireCredentialsHandle; | 
 
 
 
 
 | 599 | SpQueryCredentialsAttributesFn *QueryCredentialsAttributes; | 
 
 
 
 
 | 600 | SpFreeCredentialsHandleFn *FreeCredentialsHandle; | 
 
 
 
 
 | 601 | SpSaveCredentialsFn *SaveCredentials; | 
 
 
 
 
 | 602 | SpGetCredentialsFn *GetCredentials; | 
 
 
 
 
 | 603 | SpDeleteCredentialsFn *DeleteCredentials; | 
 
 
 
 
 | 604 | SpInitLsaModeContextFn *InitLsaModeContext; | 
 
 
 
 
 | 605 | SpAcceptLsaModeContextFn *AcceptLsaModeContext; | 
 
 
 
 
 | 606 | SpDeleteContextFn *DeleteContext; | 
 
 
 
 
 | 607 | SpApplyControlTokenFn *ApplyControlToken; | 
 
 
 
 
 | 608 | SpGetUserInfoFn *GetUserInfo; | 
 
 
 
 
 | 609 | SpGetExtendedInformationFn *GetExtendedInformation; | 
 
 
 
 
 | 610 | SpQueryContextAttributesFn *QueryContextAttributes; | 
 
 
 
 
 | 611 | SpAddCredentialsFn *AddCredentials; | 
 
 
 
 
 | 612 | SpSetExtendedInformationFn *SetExtendedInformation; | 
 
 
 
 
 | 613 | SpSetContextAttributesFn *SetContextAttributes; | 
 
 
 
 
 | 614 | SpSetCredentialsAttributesFn *SetCredentialsAttributes; | 
 
 
 
 
 | 615 | } SECPKG_FUNCTION_TABLE,*PSECPKG_FUNCTION_TABLE; | 
 
 
 
 
 | 616 |  | 
 
 
 
 
 | 617 | typedef NTSTATUS (NTAPI SpInstanceInitFn)(ULONG Version,PSECPKG_DLL_FUNCTIONS FunctionTable,PVOID *UserFunctions); | 
 
 
 
 
 | 618 | typedef NTSTATUS (NTAPI SpInitUserModeContextFn)(LSA_SEC_HANDLE ContextHandle,PSecBuffer PackedContext); | 
 
 
 
 
 | 619 | typedef NTSTATUS (NTAPI SpMakeSignatureFn)(LSA_SEC_HANDLE ContextHandle,ULONG QualityOfProtection,PSecBufferDesc MessageBuffers,ULONG MessageSequenceNumber); | 
 
 
 
 
 | 620 | typedef NTSTATUS (NTAPI SpVerifySignatureFn)(LSA_SEC_HANDLE ContextHandle,PSecBufferDesc MessageBuffers,ULONG MessageSequenceNumber,PULONG QualityOfProtection); | 
 
 
 
 
 | 621 | typedef NTSTATUS (NTAPI SpSealMessageFn)(LSA_SEC_HANDLE ContextHandle,ULONG QualityOfProtection,PSecBufferDesc MessageBuffers,ULONG MessageSequenceNumber); | 
 
 
 
 
 | 622 | typedef NTSTATUS (NTAPI SpUnsealMessageFn)(LSA_SEC_HANDLE ContextHandle,PSecBufferDesc MessageBuffers,ULONG MessageSequenceNumber,PULONG QualityOfProtection); | 
 
 
 
 
 | 623 | typedef NTSTATUS (NTAPI SpGetContextTokenFn)(LSA_SEC_HANDLE ContextHandle,PHANDLE ImpersonationToken); | 
 
 
 
 
 | 624 | typedef NTSTATUS (NTAPI SpExportSecurityContextFn)(LSA_SEC_HANDLE phContext,ULONG fFlags,PSecBuffer pPackedContext,PHANDLE pToken); | 
 
 
 
 
 | 625 | typedef NTSTATUS (NTAPI SpImportSecurityContextFn)(PSecBuffer pPackedContext,HANDLE Token,PLSA_SEC_HANDLE phContext); | 
 
 
 
 
 | 626 | typedef NTSTATUS (NTAPI SpCompleteAuthTokenFn)(LSA_SEC_HANDLE ContextHandle,PSecBufferDesc InputBuffer); | 
 
 
 
 
 | 627 | typedef NTSTATUS (NTAPI SpFormatCredentialsFn)(PSecBuffer Credentials,PSecBuffer FormattedCredentials); | 
 
 
 
 
 | 628 | typedef NTSTATUS (NTAPI SpMarshallSupplementalCredsFn)(ULONG CredentialSize,PUCHAR Credentials,PULONG MarshalledCredSize,PVOID *MarshalledCreds); | 
 
 
 
 
 | 629 |  | 
 
 
 
 
 | 630 | typedef struct _SECPKG_USER_FUNCTION_TABLE { | 
 
 
 
 
 | 631 | SpInstanceInitFn *InstanceInit; | 
 
 
 
 
 | 632 | SpInitUserModeContextFn *InitUserModeContext; | 
 
 
 
 
 | 633 | SpMakeSignatureFn *MakeSignature; | 
 
 
 
 
 | 634 | SpVerifySignatureFn *VerifySignature; | 
 
 
 
 
 | 635 | SpSealMessageFn *SealMessage; | 
 
 
 
 
 | 636 | SpUnsealMessageFn *UnsealMessage; | 
 
 
 
 
 | 637 | SpGetContextTokenFn *GetContextToken; | 
 
 
 
 
 | 638 | SpQueryContextAttributesFn *QueryContextAttributes; | 
 
 
 
 
 | 639 | SpCompleteAuthTokenFn *CompleteAuthToken; | 
 
 
 
 
 | 640 | SpDeleteContextFn *DeleteUserModeContext; | 
 
 
 
 
 | 641 | SpFormatCredentialsFn *FormatCredentials; | 
 
 
 
 
 | 642 | SpMarshallSupplementalCredsFn *MarshallSupplementalCreds; | 
 
 
 
 
 | 643 | SpExportSecurityContextFn *ExportContext; | 
 
 
 
 
 | 644 | SpImportSecurityContextFn *ImportContext; | 
 
 
 
 
 | 645 | } SECPKG_USER_FUNCTION_TABLE,*PSECPKG_USER_FUNCTION_TABLE; | 
 
 
 
 
 | 646 |  | 
 
 
 
 
 | 647 | typedef NTSTATUS (SEC_ENTRY *SpLsaModeInitializeFn)(ULONG LsaVersion,PULONG PackageVersion,PSECPKG_FUNCTION_TABLE *ppTables,PULONG pcTables); | 
 
 
 
 
 | 648 | typedef NTSTATUS (SEC_ENTRY *SpUserModeInitializeFn)(ULONG LsaVersion,PULONG PackageVersion,PSECPKG_USER_FUNCTION_TABLE *ppTables,PULONG pcTables); | 
 
 
 
 
 | 649 |  | 
 
 
 
 
 | 650 | #define SECPKG_LSAMODEINIT_NAME "SpLsaModeInitialize" | 
 
 
 
 
 | 651 | #define SECPKG_USERMODEINIT_NAME "SpUserModeInitialize" | 
 
 
 
 
 | 652 |  | 
 
 
 
 
 | 653 | #define SECPKG_INTERFACE_VERSION 0x00010000 | 
 
 
 
 
 | 654 | #define SECPKG_INTERFACE_VERSION_2 0x00020000 | 
 
 
 
 
 | 655 | #define SECPKG_INTERFACE_VERSION_3 0x00040000 | 
 
 
 
 
 | 656 |  | 
 
 
 
 
 | 657 | typedef enum _KSEC_CONTEXT_TYPE { | 
 
 
 
 
 | 658 | KSecPaged,KSecNonPaged | 
 
 
 
 
 | 659 | } KSEC_CONTEXT_TYPE; | 
 
 
 
 
 | 660 |  | 
 
 
 
 
 | 661 | typedef struct _KSEC_LIST_ENTRY { | 
 
 
 
 
 | 662 | LIST_ENTRY List; | 
 
 
 
 
 | 663 | LONG RefCount; | 
 
 
 
 
 | 664 | ULONG Signature; | 
 
 
 
 
 | 665 | PVOID OwningList; | 
 
 
 
 
 | 666 | PVOID Reserved; | 
 
 
 
 
 | 667 | } KSEC_LIST_ENTRY,*PKSEC_LIST_ENTRY; | 
 
 
 
 
 | 668 |  | 
 
 
 
 
 | 669 | #define KsecInitializeListEntry(Entry,SigValue) ((PKSEC_LIST_ENTRY) Entry)->List.Flink = ((PKSEC_LIST_ENTRY) Entry)->List.Blink = NULL; ((PKSEC_LIST_ENTRY) Entry)->RefCount = 1; ((PKSEC_LIST_ENTRY) Entry)->Signature = SigValue; ((PKSEC_LIST_ENTRY) Entry)->OwningList = NULL; ((PKSEC_LIST_ENTRY) Entry)->Reserved = NULL; | 
 
 
 
 
 | 670 |  | 
 
 
 
 
 | 671 | typedef PVOID (SEC_ENTRY KSEC_CREATE_CONTEXT_LIST)(KSEC_CONTEXT_TYPE Type); | 
 
 
 
 
 | 672 | typedef VOID (SEC_ENTRY KSEC_INSERT_LIST_ENTRY)(PVOID List,PKSEC_LIST_ENTRY Entry); | 
 
 
 
 
 | 673 | typedef NTSTATUS (SEC_ENTRY KSEC_REFERENCE_LIST_ENTRY)(PKSEC_LIST_ENTRY Entry,ULONG Signature,BOOLEAN RemoveNoRef); | 
 
 
 
 
 | 674 | typedef VOID (SEC_ENTRY KSEC_DEREFERENCE_LIST_ENTRY)(PKSEC_LIST_ENTRY Entry,BOOLEAN *Delete); | 
 
 
 
 
 | 675 | typedef NTSTATUS (SEC_ENTRY KSEC_SERIALIZE_WINNT_AUTH_DATA)(PVOID pvAuthData,PULONG Size,PVOID *SerializedData); | 
 
 
 
 
 | 676 | typedef NTSTATUS (SEC_ENTRY KSEC_SERIALIZE_SCHANNEL_AUTH_DATA)(PVOID pvAuthData,PULONG Size,PVOID *SerializedData); | 
 
 
 
 
 | 677 |  | 
 
 
 
 
 | 678 | KSEC_CREATE_CONTEXT_LIST KSecCreateContextList; | 
 
 
 
 
 | 679 | KSEC_INSERT_LIST_ENTRY KSecInsertListEntry; | 
 
 
 
 
 | 680 | KSEC_REFERENCE_LIST_ENTRY KSecReferenceListEntry; | 
 
 
 
 
 | 681 | KSEC_DEREFERENCE_LIST_ENTRY KSecDereferenceListEntry; | 
 
 
 
 
 | 682 | KSEC_SERIALIZE_WINNT_AUTH_DATA KSecSerializeWinntAuthData; | 
 
 
 
 
 | 683 | KSEC_SERIALIZE_SCHANNEL_AUTH_DATA KSecSerializeSchannelAuthData; | 
 
 
 
 
 | 684 |  | 
 
 
 
 
 | 685 | typedef KSEC_CREATE_CONTEXT_LIST *PKSEC_CREATE_CONTEXT_LIST; | 
 
 
 
 
 | 686 | typedef KSEC_INSERT_LIST_ENTRY *PKSEC_INSERT_LIST_ENTRY; | 
 
 
 
 
 | 687 | typedef KSEC_REFERENCE_LIST_ENTRY *PKSEC_REFERENCE_LIST_ENTRY; | 
 
 
 
 
 | 688 | typedef KSEC_DEREFERENCE_LIST_ENTRY *PKSEC_DEREFERENCE_LIST_ENTRY; | 
 
 
 
 
 | 689 | typedef KSEC_SERIALIZE_WINNT_AUTH_DATA *PKSEC_SERIALIZE_WINNT_AUTH_DATA; | 
 
 
 
 
 | 690 | typedef KSEC_SERIALIZE_SCHANNEL_AUTH_DATA *PKSEC_SERIALIZE_SCHANNEL_AUTH_DATA; | 
 
 
 
 
 | 691 |  | 
 
 
 
 
 | 692 | typedef struct _SECPKG_KERNEL_FUNCTIONS { | 
 
 
 
 
 | 693 | PLSA_ALLOCATE_LSA_HEAP AllocateHeap; | 
 
 
 
 
 | 694 | PLSA_FREE_LSA_HEAP FreeHeap; | 
 
 
 
 
 | 695 | PKSEC_CREATE_CONTEXT_LIST CreateContextList; | 
 
 
 
 
 | 696 | PKSEC_INSERT_LIST_ENTRY InsertListEntry; | 
 
 
 
 
 | 697 | PKSEC_REFERENCE_LIST_ENTRY ReferenceListEntry; | 
 
 
 
 
 | 698 | PKSEC_DEREFERENCE_LIST_ENTRY DereferenceListEntry; | 
 
 
 
 
 | 699 | PKSEC_SERIALIZE_WINNT_AUTH_DATA SerializeWinntAuthData; | 
 
 
 
 
 | 700 | PKSEC_SERIALIZE_SCHANNEL_AUTH_DATA SerializeSchannelAuthData; | 
 
 
 
 
 | 701 | } SECPKG_KERNEL_FUNCTIONS,*PSECPKG_KERNEL_FUNCTIONS; | 
 
 
 
 
 | 702 |  | 
 
 
 
 
 | 703 | typedef NTSTATUS (NTAPI KspInitPackageFn)(PSECPKG_KERNEL_FUNCTIONS FunctionTable); | 
 
 
 
 
 | 704 | typedef NTSTATUS (NTAPI KspDeleteContextFn)(LSA_SEC_HANDLE ContextId,PLSA_SEC_HANDLE LsaContextId); | 
 
 
 
 
 | 705 | typedef NTSTATUS (NTAPI KspInitContextFn)(LSA_SEC_HANDLE ContextId,PSecBuffer ContextData,PLSA_SEC_HANDLE NewContextId); | 
 
 
 
 
 | 706 | typedef NTSTATUS (NTAPI KspMakeSignatureFn)(LSA_SEC_HANDLE ContextId,ULONG fQOP,PSecBufferDesc Message,ULONG MessageSeqNo); | 
 
 
 
 
 | 707 | typedef NTSTATUS (NTAPI KspVerifySignatureFn)(LSA_SEC_HANDLE ContextId,PSecBufferDesc Message,ULONG MessageSeqNo,PULONG pfQOP); | 
 
 
 
 
 | 708 | typedef NTSTATUS (NTAPI KspSealMessageFn)(LSA_SEC_HANDLE ContextId,ULONG fQOP,PSecBufferDesc Message,ULONG MessageSeqNo); | 
 
 
 
 
 | 709 | typedef NTSTATUS (NTAPI KspUnsealMessageFn)(LSA_SEC_HANDLE ContextId,PSecBufferDesc Message,ULONG MessageSeqNo,PULONG pfQOP); | 
 
 
 
 
 | 710 | typedef NTSTATUS (NTAPI KspGetTokenFn)(LSA_SEC_HANDLE ContextId,PHANDLE ImpersonationToken,PACCESS_TOKEN *RawToken); | 
 
 
 
 
 | 711 | typedef NTSTATUS (NTAPI KspQueryAttributesFn)(LSA_SEC_HANDLE ContextId,ULONG Attribute,PVOID Buffer); | 
 
 
 
 
 | 712 | typedef NTSTATUS (NTAPI KspCompleteTokenFn)(LSA_SEC_HANDLE ContextId,PSecBufferDesc Token); | 
 
 
 
 
 | 713 | typedef NTSTATUS (NTAPI KspMapHandleFn)(LSA_SEC_HANDLE ContextId,PLSA_SEC_HANDLE LsaContextId); | 
 
 
 
 
 | 714 | typedef NTSTATUS (NTAPI KspSetPagingModeFn)(BOOLEAN PagingMode); | 
 
 
 
 
 | 715 | typedef NTSTATUS (NTAPI KspSerializeAuthDataFn)(PVOID pvAuthData,PULONG Size,PVOID *SerializedData); | 
 
 
 
 
 | 716 |  | 
 
 
 
 
 | 717 | typedef struct _SECPKG_KERNEL_FUNCTION_TABLE { | 
 
 
 
 
 | 718 | KspInitPackageFn *Initialize; | 
 
 
 
 
 | 719 | KspDeleteContextFn *DeleteContext; | 
 
 
 
 
 | 720 | KspInitContextFn *InitContext; | 
 
 
 
 
 | 721 | KspMapHandleFn *MapHandle; | 
 
 
 
 
 | 722 | KspMakeSignatureFn *Sign; | 
 
 
 
 
 | 723 | KspVerifySignatureFn *Verify; | 
 
 
 
 
 | 724 | KspSealMessageFn *Seal; | 
 
 
 
 
 | 725 | KspUnsealMessageFn *Unseal; | 
 
 
 
 
 | 726 | KspGetTokenFn *GetToken; | 
 
 
 
 
 | 727 | KspQueryAttributesFn *QueryAttributes; | 
 
 
 
 
 | 728 | KspCompleteTokenFn *CompleteToken; | 
 
 
 
 
 | 729 | SpExportSecurityContextFn *ExportContext; | 
 
 
 
 
 | 730 | SpImportSecurityContextFn *ImportContext; | 
 
 
 
 
 | 731 | KspSetPagingModeFn *SetPackagePagingMode; | 
 
 
 
 
 | 732 | KspSerializeAuthDataFn *SerializeAuthData; | 
 
 
 
 
 | 733 | } SECPKG_KERNEL_FUNCTION_TABLE,*PSECPKG_KERNEL_FUNCTION_TABLE; | 
 
 
 
 
 | 734 |  | 
 
 
 
 
 | 735 | SECURITY_STATUS SEC_ENTRY KSecRegisterSecurityProvider(PSECURITY_STRING ProviderName,PSECPKG_KERNEL_FUNCTION_TABLE Table); | 
 
 
 
 
 | 736 |  | 
 
 
 
 
 | 737 | extern SECPKG_KERNEL_FUNCTIONS KspKernelFunctions; | 
 
 
 
 
 | 738 |  | 
 
 
 
 
 | 739 | #ifdef __cplusplus | 
 
 
 
 
 | 740 | } | 
 
 
 
 
 | 741 | #endif | 
 
 
 
 
 | 742 | #endif |