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