Home | History | Annotate | Download | only in include
      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
    743