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