subauth.h 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  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 _NTSUBAUTH_
  7. #define _NTSUBAUTH_
  8. #ifdef __cplusplus
  9. extern "C" {
  10. #endif
  11. #if (!defined(_NTDEF_)) && (!defined(_NTSECAPI_))
  12. #if !defined (_NTDEF_) && !defined (_NTSTATUS_PSDK)
  13. #define _NTSTATUS_PSDK
  14. typedef LONG NTSTATUS,*PNTSTATUS;
  15. #endif
  16. #ifndef __UNICODE_STRING_DEFINED
  17. #define __UNICODE_STRING_DEFINED
  18. typedef struct _UNICODE_STRING {
  19. USHORT Length;
  20. USHORT MaximumLength;
  21. PWSTR Buffer;
  22. } UNICODE_STRING,*PUNICODE_STRING;
  23. #endif
  24. #ifndef __STRING_DEFINED
  25. #define __STRING_DEFINED
  26. typedef struct _STRING {
  27. USHORT Length;
  28. USHORT MaximumLength;
  29. PCHAR Buffer;
  30. } STRING,*PSTRING;
  31. #endif
  32. #endif
  33. #ifndef _NTDEF_
  34. typedef struct _OLD_LARGE_INTEGER {
  35. ULONG LowPart;
  36. LONG HighPart;
  37. } OLD_LARGE_INTEGER,*POLD_LARGE_INTEGER;
  38. #define NT_SUCCESS(Status) ((NTSTATUS)(Status) >= 0)
  39. #endif
  40. #ifndef _NTSAM_SAM_HANDLE_
  41. typedef PVOID SAM_HANDLE,*PSAM_HANDLE;
  42. #define _NTSAM_SAM_HANDLE_
  43. #endif
  44. #ifndef _NTSAM_USER_ACCOUNT_FLAGS_
  45. #define USER_ACCOUNT_DISABLED (0x00000001)
  46. #define USER_HOME_DIRECTORY_REQUIRED (0x00000002)
  47. #define USER_PASSWORD_NOT_REQUIRED (0x00000004)
  48. #define USER_TEMP_DUPLICATE_ACCOUNT (0x00000008)
  49. #define USER_NORMAL_ACCOUNT (0x00000010)
  50. #define USER_MNS_LOGON_ACCOUNT (0x00000020)
  51. #define USER_INTERDOMAIN_TRUST_ACCOUNT (0x00000040)
  52. #define USER_WORKSTATION_TRUST_ACCOUNT (0x00000080)
  53. #define USER_SERVER_TRUST_ACCOUNT (0x00000100)
  54. #define USER_DONT_EXPIRE_PASSWORD (0x00000200)
  55. #define USER_ACCOUNT_AUTO_LOCKED (0x00000400)
  56. #define USER_ENCRYPTED_TEXT_PASSWORD_ALLOWED (0x00000800)
  57. #define USER_SMARTCARD_REQUIRED (0x00001000)
  58. #define USER_TRUSTED_FOR_DELEGATION (0x00002000)
  59. #define USER_NOT_DELEGATED (0x00004000)
  60. #define USER_USE_DES_KEY_ONLY (0x00008000)
  61. #define USER_DONT_REQUIRE_PREAUTH (0x00010000)
  62. #define USER_PASSWORD_EXPIRED (0x00020000)
  63. #define USER_TRUSTED_TO_AUTHENTICATE_FOR_DELEGATION (0x00040000)
  64. #define USER_NO_AUTH_DATA_REQUIRED (0x00080000)
  65. #define NEXT_FREE_ACCOUNT_CONTROL_BIT (USER_NO_AUTH_DATA_REQUIRED << 1)
  66. #define USER_MACHINE_ACCOUNT_MASK (USER_INTERDOMAIN_TRUST_ACCOUNT | USER_WORKSTATION_TRUST_ACCOUNT | USER_SERVER_TRUST_ACCOUNT)
  67. #define USER_ACCOUNT_TYPE_MASK (USER_TEMP_DUPLICATE_ACCOUNT | USER_NORMAL_ACCOUNT | USER_MACHINE_ACCOUNT_MASK)
  68. #define USER_COMPUTED_ACCOUNT_CONTROL_BITS (USER_ACCOUNT_AUTO_LOCKED | USER_PASSWORD_EXPIRED)
  69. #define SAM_DAYS_PER_WEEK (7)
  70. #define SAM_HOURS_PER_WEEK (24*SAM_DAYS_PER_WEEK)
  71. #define SAM_MINUTES_PER_WEEK (60*SAM_HOURS_PER_WEEK)
  72. typedef struct _LOGON_HOURS {
  73. USHORT UnitsPerWeek;
  74. PUCHAR LogonHours;
  75. } LOGON_HOURS,*PLOGON_HOURS;
  76. typedef struct _SR_SECURITY_DESCRIPTOR {
  77. ULONG Length;
  78. PUCHAR SecurityDescriptor;
  79. } SR_SECURITY_DESCRIPTOR,*PSR_SECURITY_DESCRIPTOR;
  80. #define _NTSAM_USER_ACCOUNT_FLAG_
  81. #endif
  82. #ifndef _NTSAM_USER_ALL_INFO_
  83. #include "pshpack4.h"
  84. typedef struct _USER_ALL_INFORMATION {
  85. LARGE_INTEGER LastLogon;
  86. LARGE_INTEGER LastLogoff;
  87. LARGE_INTEGER PasswordLastSet;
  88. LARGE_INTEGER AccountExpires;
  89. LARGE_INTEGER PasswordCanChange;
  90. LARGE_INTEGER PasswordMustChange;
  91. UNICODE_STRING UserName;
  92. UNICODE_STRING FullName;
  93. UNICODE_STRING HomeDirectory;
  94. UNICODE_STRING HomeDirectoryDrive;
  95. UNICODE_STRING ScriptPath;
  96. UNICODE_STRING ProfilePath;
  97. UNICODE_STRING AdminComment;
  98. UNICODE_STRING WorkStations;
  99. UNICODE_STRING UserComment;
  100. UNICODE_STRING Parameters;
  101. UNICODE_STRING LmPassword;
  102. UNICODE_STRING NtPassword;
  103. UNICODE_STRING PrivateData;
  104. SR_SECURITY_DESCRIPTOR SecurityDescriptor;
  105. ULONG UserId;
  106. ULONG PrimaryGroupId;
  107. ULONG UserAccountControl;
  108. ULONG WhichFields;
  109. LOGON_HOURS LogonHours;
  110. USHORT BadPasswordCount;
  111. USHORT LogonCount;
  112. USHORT CountryCode;
  113. USHORT CodePage;
  114. BOOLEAN LmPasswordPresent;
  115. BOOLEAN NtPasswordPresent;
  116. BOOLEAN PasswordExpired;
  117. BOOLEAN PrivateDataSensitive;
  118. } USER_ALL_INFORMATION,*PUSER_ALL_INFORMATION;
  119. #include "poppack.h"
  120. #define _NTSAM_USER_ALL_INFO_
  121. #endif
  122. #ifndef _NTSAM_SAM_USER_PARMS_
  123. #define USER_ALL_PARAMETERS 0x00200000
  124. #define _NTSAM_SAM_USER_PARMS_
  125. #endif
  126. #define CLEAR_BLOCK_LENGTH 8
  127. typedef struct _CLEAR_BLOCK {
  128. CHAR data[CLEAR_BLOCK_LENGTH];
  129. } CLEAR_BLOCK;
  130. typedef CLEAR_BLOCK *PCLEAR_BLOCK;
  131. #define CYPHER_BLOCK_LENGTH 8
  132. typedef struct _CYPHER_BLOCK {
  133. CHAR data[CYPHER_BLOCK_LENGTH];
  134. } CYPHER_BLOCK;
  135. typedef CYPHER_BLOCK *PCYPHER_BLOCK;
  136. typedef struct _LM_OWF_PASSWORD {
  137. CYPHER_BLOCK data[2];
  138. } LM_OWF_PASSWORD;
  139. typedef LM_OWF_PASSWORD *PLM_OWF_PASSWORD;
  140. typedef CLEAR_BLOCK LM_CHALLENGE;
  141. typedef LM_CHALLENGE *PLM_CHALLENGE;
  142. typedef LM_OWF_PASSWORD NT_OWF_PASSWORD;
  143. typedef NT_OWF_PASSWORD *PNT_OWF_PASSWORD;
  144. typedef LM_CHALLENGE NT_CHALLENGE;
  145. typedef NT_CHALLENGE *PNT_CHALLENGE;
  146. #define USER_SESSION_KEY_LENGTH (CYPHER_BLOCK_LENGTH *2)
  147. typedef struct _USER_SESSION_KEY {
  148. CYPHER_BLOCK data[2];
  149. } USER_SESSION_KEY;
  150. typedef USER_SESSION_KEY *PUSER_SESSION_KEY;
  151. typedef enum _NETLOGON_LOGON_INFO_CLASS {
  152. NetlogonInteractiveInformation = 1,NetlogonNetworkInformation,NetlogonServiceInformation,NetlogonGenericInformation,
  153. NetlogonInteractiveTransitiveInformation,NetlogonNetworkTransitiveInformation,NetlogonServiceTransitiveInformation
  154. } NETLOGON_LOGON_INFO_CLASS;
  155. typedef struct _NETLOGON_LOGON_IDENTITY_INFO {
  156. UNICODE_STRING LogonDomainName;
  157. ULONG ParameterControl;
  158. OLD_LARGE_INTEGER LogonId;
  159. UNICODE_STRING UserName;
  160. UNICODE_STRING Workstation;
  161. } NETLOGON_LOGON_IDENTITY_INFO,*PNETLOGON_LOGON_IDENTITY_INFO;
  162. typedef struct _NETLOGON_INTERACTIVE_INFO {
  163. NETLOGON_LOGON_IDENTITY_INFO Identity;
  164. LM_OWF_PASSWORD LmOwfPassword;
  165. NT_OWF_PASSWORD NtOwfPassword;
  166. } NETLOGON_INTERACTIVE_INFO,*PNETLOGON_INTERACTIVE_INFO;
  167. typedef struct _NETLOGON_SERVICE_INFO {
  168. NETLOGON_LOGON_IDENTITY_INFO Identity;
  169. LM_OWF_PASSWORD LmOwfPassword;
  170. NT_OWF_PASSWORD NtOwfPassword;
  171. } NETLOGON_SERVICE_INFO,*PNETLOGON_SERVICE_INFO;
  172. typedef struct _NETLOGON_NETWORK_INFO {
  173. NETLOGON_LOGON_IDENTITY_INFO Identity;
  174. LM_CHALLENGE LmChallenge;
  175. STRING NtChallengeResponse;
  176. STRING LmChallengeResponse;
  177. } NETLOGON_NETWORK_INFO,*PNETLOGON_NETWORK_INFO;
  178. typedef struct _NETLOGON_GENERIC_INFO {
  179. NETLOGON_LOGON_IDENTITY_INFO Identity;
  180. UNICODE_STRING PackageName;
  181. ULONG DataLength;
  182. PUCHAR LogonData;
  183. } NETLOGON_GENERIC_INFO,*PNETLOGON_GENERIC_INFO;
  184. #define MSV1_0_PASSTHRU 0x01
  185. #define MSV1_0_GUEST_LOGON 0x02
  186. NTSTATUS NTAPI Msv1_0SubAuthenticationRoutine(NETLOGON_LOGON_INFO_CLASS LogonLevel,PVOID LogonInformation,ULONG Flags,PUSER_ALL_INFORMATION UserAll,PULONG WhichFields,PULONG UserFlags,PBOOLEAN Authoritative,PLARGE_INTEGER LogoffTime,PLARGE_INTEGER KickoffTime);
  187. typedef struct _MSV1_0_VALIDATION_INFO {
  188. LARGE_INTEGER LogoffTime;
  189. LARGE_INTEGER KickoffTime;
  190. UNICODE_STRING LogonServer;
  191. UNICODE_STRING LogonDomainName;
  192. USER_SESSION_KEY SessionKey;
  193. BOOLEAN Authoritative;
  194. ULONG UserFlags;
  195. ULONG WhichFields;
  196. ULONG UserId;
  197. } MSV1_0_VALIDATION_INFO,*PMSV1_0_VALIDATION_INFO;
  198. #define MSV1_0_VALIDATION_LOGOFF_TIME 0x00000001
  199. #define MSV1_0_VALIDATION_KICKOFF_TIME 0x00000002
  200. #define MSV1_0_VALIDATION_LOGON_SERVER 0x00000004
  201. #define MSV1_0_VALIDATION_LOGON_DOMAIN 0x00000008
  202. #define MSV1_0_VALIDATION_SESSION_KEY 0x00000010
  203. #define MSV1_0_VALIDATION_USER_FLAGS 0x00000020
  204. #define MSV1_0_VALIDATION_USER_ID 0x00000040
  205. #define MSV1_0_SUBAUTH_ACCOUNT_DISABLED 0x00000001
  206. #define MSV1_0_SUBAUTH_PASSWORD 0x00000002
  207. #define MSV1_0_SUBAUTH_WORKSTATIONS 0x00000004
  208. #define MSV1_0_SUBAUTH_LOGON_HOURS 0x00000008
  209. #define MSV1_0_SUBAUTH_ACCOUNT_EXPIRY 0x00000010
  210. #define MSV1_0_SUBAUTH_PASSWORD_EXPIRY 0x00000020
  211. #define MSV1_0_SUBAUTH_ACCOUNT_TYPE 0x00000040
  212. #define MSV1_0_SUBAUTH_LOCKOUT 0x00000080
  213. NTSTATUS NTAPI Msv1_0SubAuthenticationRoutineEx(NETLOGON_LOGON_INFO_CLASS LogonLevel,PVOID LogonInformation,ULONG Flags,PUSER_ALL_INFORMATION UserAll,SAM_HANDLE UserHandle,PMSV1_0_VALIDATION_INFO ValidationInfo,PULONG ActionsPerformed);
  214. NTSTATUS NTAPI Msv1_0SubAuthenticationRoutineGeneric(PVOID SubmitBuffer,ULONG SubmitBufferLength,PULONG ReturnBufferLength,PVOID *ReturnBuffer);
  215. NTSTATUS NTAPI Msv1_0SubAuthenticationFilter(NETLOGON_LOGON_INFO_CLASS LogonLevel,PVOID LogonInformation,ULONG Flags,PUSER_ALL_INFORMATION UserAll,PULONG WhichFields,PULONG UserFlags,PBOOLEAN Authoritative,PLARGE_INTEGER LogoffTime,PLARGE_INTEGER KickoffTime);
  216. #define STATUS_SUCCESS ((NTSTATUS)0x00000000)
  217. #define STATUS_INVALID_INFO_CLASS ((NTSTATUS)0xC0000003)
  218. #define STATUS_NO_SUCH_USER ((NTSTATUS)0xC0000064)
  219. #define STATUS_WRONG_PASSWORD ((NTSTATUS)0xC000006A)
  220. #define STATUS_PASSWORD_RESTRICTION ((NTSTATUS)0xC000006C)
  221. #define STATUS_LOGON_FAILURE ((NTSTATUS)0xC000006D)
  222. #define STATUS_ACCOUNT_RESTRICTION ((NTSTATUS)0xC000006E)
  223. #define STATUS_INVALID_LOGON_HOURS ((NTSTATUS)0xC000006F)
  224. #define STATUS_INVALID_WORKSTATION ((NTSTATUS)0xC0000070)
  225. #define STATUS_PASSWORD_EXPIRED ((NTSTATUS)0xC0000071)
  226. #define STATUS_ACCOUNT_DISABLED ((NTSTATUS)0xC0000072)
  227. #define STATUS_INSUFFICIENT_RESOURCES ((NTSTATUS)0xC000009A)
  228. #define STATUS_ACCOUNT_EXPIRED ((NTSTATUS)0xC0000193)
  229. #define STATUS_PASSWORD_MUST_CHANGE ((NTSTATUS)0xC0000224)
  230. #define STATUS_ACCOUNT_LOCKED_OUT ((NTSTATUS)0xC0000234)
  231. #ifdef __cplusplus
  232. }
  233. #endif
  234. #endif