Release 0.9.39.
[wine/gsoc-2012-control.git] / include / ntsecapi.h
blob8ef61674e3fe44eda90087c45072ee8960115e83
1 /*
2 * Copyright (C) 1999 Juergen Schmied
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 #ifndef __WINE_NTSECAPI_H
20 #define __WINE_NTSECAPI_H
22 #ifdef __cplusplus
23 extern "C" {
24 #endif /* defined(__cplusplus) */
26 /* Policy access rights */
27 #define POLICY_VIEW_LOCAL_INFORMATION 0x00000001L
28 #define POLICY_VIEW_AUDIT_INFORMATION 0x00000002L
29 #define POLICY_GET_PRIVATE_INFORMATION 0x00000004L
30 #define POLICY_TRUST_ADMIN 0x00000008L
31 #define POLICY_CREATE_ACCOUNT 0x00000010L
32 #define POLICY_CREATE_SECRET 0x00000020L
33 #define POLICY_CREATE_PRIVILEGE 0x00000040L
34 #define POLICY_SET_DEFAULT_QUOTA_LIMITS 0x00000080L
35 #define POLICY_SET_AUDIT_REQUIREMENTS 0x00000100L
36 #define POLICY_AUDIT_LOG_ADMIN 0x00000200L
37 #define POLICY_SERVER_ADMIN 0x00000400L
38 #define POLICY_LOOKUP_NAMES 0x00000800L
39 #define POLICY_NOTIFICATION 0x00001000L
41 #define POLICY_ALL_ACCESS ( \
42 STANDARD_RIGHTS_REQUIRED | \
43 POLICY_VIEW_LOCAL_INFORMATION | \
44 POLICY_VIEW_AUDIT_INFORMATION | \
45 POLICY_GET_PRIVATE_INFORMATION | \
46 POLICY_TRUST_ADMIN | \
47 POLICY_CREATE_ACCOUNT | \
48 POLICY_CREATE_SECRET | \
49 POLICY_CREATE_PRIVILEGE | \
50 POLICY_SET_DEFAULT_QUOTA_LIMITS | \
51 POLICY_SET_AUDIT_REQUIREMENTS | \
52 POLICY_AUDIT_LOG_ADMIN | \
53 POLICY_SERVER_ADMIN | \
54 POLICY_LOOKUP_NAMES)
57 #define POLICY_READ ( \
58 STANDARD_RIGHTS_READ | \
59 POLICY_VIEW_AUDIT_INFORMATION | \
60 POLICY_GET_PRIVATE_INFORMATION)
62 #define POLICY_WRITE ( \
63 STANDARD_RIGHTS_WRITE | \
64 POLICY_TRUST_ADMIN | \
65 POLICY_CREATE_ACCOUNT | \
66 POLICY_CREATE_SECRET | \
67 POLICY_CREATE_PRIVILEGE | \
68 POLICY_SET_DEFAULT_QUOTA_LIMITS | \
69 POLICY_SET_AUDIT_REQUIREMENTS | \
70 POLICY_AUDIT_LOG_ADMIN | \
71 POLICY_SERVER_ADMIN)
73 #define POLICY_EXECUTE ( \
74 STANDARD_RIGHTS_EXECUTE | \
75 POLICY_VIEW_LOCAL_INFORMATION | \
76 POLICY_LOOKUP_NAMES)
78 #define POLICY_AUDIT_EVENT_UNCHANGED 0x00000000L
79 #define POLICY_AUDIT_EVENT_SUCCESS 0x00000001L
80 #define POLICY_AUDIT_EVENT_FAILURE 0x00000002L
81 #define POLICY_AUDIT_EVENT_NONE 0x00000004L
83 #define POLICY_AUDIT_EVENT_MASK (POLICY_AUDIT_EVENT_SUCCESS | \
84 POLICY_AUDIT_EVENT_FAILURE | \
85 POLICY_AUDIT_EVENT_NONE)
87 /* logon rights names */
88 #define SE_BATCH_LOGON_NAME \
89 TEXT("SeBatchLogonRight")
90 #define SE_INTERACTIVE_LOGON_NAME \
91 TEXT("SeInteractiveLogonRight")
92 #define SE_NETWORK_LOGON_NAME \
93 TEXT("SeNetworkLogonRight")
94 #define SE_REMOTE_INTERACTIVE_LOGON_NAME \
95 TEXT("SeRemoteInteractiveLogonRight")
96 #define SE_SERVICE_LOGON_NAME \
97 TEXT("SeServiceLogonRight")
98 #define SE_DENY_BATCH_LOGON_NAME \
99 TEXT("SeDenyBatchLogonRight")
100 #define SE_DENY_INTERACTIVE_LOGON_NAME \
101 TEXT("SeDenyInteractiveLogonRight")
102 #define SE_DENY_NETWORK_LOGON_NAME \
103 TEXT("SeDenyNetworkLogonRight")
104 #define SE_DENY_REMOTE_INTERACTIVE_LOGON_NAME \
105 TEXT("SeDenyRemoteInteractiveLogonRight")
106 #define SE_DENY_SERVICE_LOGON_NAME \
107 TEXT("SeDenyServiceLogonRight")
109 #ifndef WINE_NTSTATUS_DECLARED
110 #define WINE_NTSTATUS_DECLARED
111 typedef LONG NTSTATUS;
112 #endif
113 #ifndef WINE_PNTSTATUS_DECLARED
114 #define WINE_PNTSTATUS_DECLARED
115 typedef NTSTATUS *PNTSTATUS;
116 #endif
118 typedef enum _SECURITY_LOGON_TYPE
120 Interactive = 2,
121 Network,
122 Batch,
123 Service,
124 Proxy
125 } SECURITY_LOGON_TYPE, *PSECURITY_LOGON_TYPE;
127 typedef enum _POLICY_AUDIT_EVENT_TYPE
129 AuditCategorySystem,
130 AuditCategoryLogon,
131 AuditCategoryObjectAccess,
132 AuditCategoryPrivilegeUse,
133 AuditCategoryDetailedTracking,
134 AuditCategoryPolicyChange,
135 AuditCategoryAccountManagement
136 } POLICY_AUDIT_EVENT_TYPE, *PPOLICY_AUDIT_EVENT_TYPE;
138 #ifndef __STRING_DEFINED__
139 #define __STRING_DEFINED__
140 typedef struct _STRING {
141 USHORT Length;
142 USHORT MaximumLength;
143 PCHAR Buffer;
144 } STRING, *PSTRING;
145 #endif
147 #ifndef __UNICODE_STRING_DEFINED__
148 #define __UNICODE_STRING_DEFINED__
149 typedef struct _UNICODE_STRING {
150 USHORT Length; /* bytes */
151 USHORT MaximumLength; /* bytes */
152 PWSTR Buffer;
153 } UNICODE_STRING, *PUNICODE_STRING;
154 #endif
156 #ifndef __OBJECT_ATTRIBUTES_DEFINED__
157 #define __OBJECT_ATTRIBUTES_DEFINED__
158 typedef struct _OBJECT_ATTRIBUTES {
159 ULONG Length;
160 HANDLE RootDirectory;
161 PUNICODE_STRING ObjectName;
162 ULONG Attributes;
163 PVOID SecurityDescriptor; /* type SECURITY_DESCRIPTOR */
164 PVOID SecurityQualityOfService; /* type SECURITY_QUALITY_OF_SERVICE */
165 } OBJECT_ATTRIBUTES, *POBJECT_ATTRIBUTES;
166 #endif
168 typedef UNICODE_STRING LSA_UNICODE_STRING, *PLSA_UNICODE_STRING;
169 typedef STRING LSA_STRING, *PLSA_STRING;
170 typedef OBJECT_ATTRIBUTES LSA_OBJECT_ATTRIBUTES, *PLSA_OBJECT_ATTRIBUTES;
172 typedef PVOID LSA_HANDLE, *PLSA_HANDLE;
173 typedef ULONG LSA_ENUMERATION_HANDLE, *PLSA_ENUMERATION_HANDLE;
175 typedef enum
177 PolicyAuditLogInformation = 1,
178 PolicyAuditEventsInformation,
179 PolicyPrimaryDomainInformation,
180 PolicyPdAccountInformation,
181 PolicyAccountDomainInformation,
182 PolicyLsaServerRoleInformation,
183 PolicyReplicaSourceInformation,
184 PolicyDefaultQuotaInformation,
185 PolicyModificationInformation,
186 PolicyAuditFullSetInformation,
187 PolicyAuditFullQueryInformation,
188 PolicyDnsDomainInformation
189 } POLICY_INFORMATION_CLASS, *PPOLICY_INFORMATION_CLASS;
191 typedef ULONG POLICY_AUDIT_EVENT_OPTIONS, *PPOLICY_AUDIT_EVENT_OPTIONS;
193 typedef struct _POLICY_AUDIT_EVENTS_INFO
195 BOOLEAN AuditingMode;
196 PPOLICY_AUDIT_EVENT_OPTIONS EventAuditingOptions;
197 ULONG MaximumAuditEventCount;
198 } POLICY_AUDIT_EVENTS_INFO, *PPOLICY_AUDIT_EVENTS_INFO;
200 typedef struct _POLICY_PRIMARY_DOMAIN_INFO
202 LSA_UNICODE_STRING Name;
203 PSID Sid;
204 } POLICY_PRIMARY_DOMAIN_INFO, *PPOLICY_PRIMARY_DOMAIN_INFO;
206 typedef struct _POLICY_ACCOUNT_DOMAIN_INFO
208 LSA_UNICODE_STRING DomainName;
209 PSID DomainSid;
210 } POLICY_ACCOUNT_DOMAIN_INFO, *PPOLICY_ACCOUNT_DOMAIN_INFO;
212 typedef struct _POLICY_DNS_DOMAIN_INFO
214 LSA_UNICODE_STRING Name;
215 LSA_UNICODE_STRING DnsDomainName;
216 LSA_UNICODE_STRING DnsForestName;
217 GUID DomainGuid;
218 PSID Sid;
219 } POLICY_DNS_DOMAIN_INFO, *PPOLICY_DNS_DOMAIN_INFO;
221 typedef enum _POLICY_LSA_SERVER_ROLE
223 PolicyServerRoleBackup = 2,
224 PolicyServerRolePrimary
225 } POLICY_LSA_SERVER_ROLE, *PPOLICY_LSA_SERVER_ROLE;
227 typedef struct _POLICY_LSA_SERVER_ROLE_INFO
229 POLICY_LSA_SERVER_ROLE LsaServerRole;
230 } POLICY_LSA_SERVER_ROLE_INFO, *PPOLICY_LSA_SERVER_ROLE_INFO;
232 typedef struct _POLICY_MODIFICATION_INFO
234 LARGE_INTEGER ModifiedId;
235 LARGE_INTEGER DatabaseCreationTime;
236 } POLICY_MODIFICATION_INFO, *PPOLICY_MODIFICATION_INFO;
238 typedef struct
240 SID_NAME_USE Use;
241 LSA_UNICODE_STRING Name;
242 LONG DomainIndex;
243 } LSA_TRANSLATED_NAME, *PLSA_TRANSLATED_NAME;
245 typedef struct
247 LSA_UNICODE_STRING Name;
248 PSID Sid;
249 } LSA_TRUST_INFORMATION, *PLSA_TRUST_INFORMATION;
251 typedef struct
253 ULONG Entries;
254 PLSA_TRUST_INFORMATION Domains;
255 } LSA_REFERENCED_DOMAIN_LIST, *PLSA_REFERENCED_DOMAIN_LIST;
257 typedef struct _LSA_TRANSLATED_SID
259 SID_NAME_USE Use;
260 ULONG RelativeId;
261 LONG DomainIndex;
262 } LSA_TRANSLATED_SID, *PLSA_TRANSLATED_SID;
264 typedef struct _TRUSTED_DOMAIN_INFORMATION_EX
266 LSA_UNICODE_STRING Name;
267 LSA_UNICODE_STRING FlatName;
268 PSID Sid;
269 ULONG TrustDirection;
270 ULONG TrustType;
271 ULONG TrustAttributes;
272 } TRUSTED_DOMAIN_INFORMATION_EX, *PTRUSTED_DOMAIN_INFORMATION_EX;
274 typedef struct _LSA_AUTH_INFORMATION
276 LARGE_INTEGER LastUpdateTime;
277 ULONG AuthType;
278 ULONG AuthInfoLength;
279 PUCHAR AuthInfo;
280 } LSA_AUTH_INFORMATION, *PLSA_AUTH_INFORMATION;
282 typedef struct _TRUSTED_DOMAIN_AUTH_INFORMATION
284 ULONG IncomingAuthInfos;
285 PLSA_AUTH_INFORMATION IncomingAuthenticationInformation;
286 PLSA_AUTH_INFORMATION IncomingPreviousAuthenticationInformation;
287 ULONG OutgoingAuthInfos;
288 PLSA_AUTH_INFORMATION OutgoingAuthenticationInformation;
289 PLSA_AUTH_INFORMATION OutgoingPreviousAuthenticationInformation;
290 } TRUSTED_DOMAIN_AUTH_INFORMATION, *PTRUSTED_DOMAIN_AUTH_INFORMATION;
292 typedef struct _LSA_TRANSLATED_SID2
294 SID_NAME_USE Use;
295 PSID Sid;
296 LONG DomainIndex;
297 ULONG Flags;
298 } LSA_TRANSLATED_SID2, *PLSA_TRANSLATED_SID2;
300 typedef enum _TRUSTED_INFORMATION_CLASS
302 TrustedDomainNameInformation = 1,
303 TrustedControllersInformation,
304 TrustedPosixOffsetInformation,
305 TrustedPasswordInformation,
306 TrustedDomainInformationBasic,
307 TrustedDomainInformationEx,
308 TrustedDomainAuthInformation,
309 TrustedDomainFullInformation
310 } TRUSTED_INFORMATION_CLASS, *PTRUSTED_INFORMATION_CLASS;
312 typedef enum _POLICY_NOTIFICATION_INFORMATION_CLASS
314 PolicyNotifyAuditEventsInformation = 1,
315 PolicyNotifyAccountDomainInformation,
316 PolicyNotifyServerRoleInformation,
317 PolicyNotifyDnsDomainInformation,
318 PolicyNotifyDomainEfsInformation,
319 PolicyNotifyDomainKerberosTicketInformation,
320 PolicyNotifyMachineAccountPasswordInformation
321 } POLICY_NOTIFICATION_INFORMATION_CLASS, *PPOLICY_NOTIFICATION_INFORMATION_CLASS;
323 #define RtlGenRandom SystemFunction036
325 BOOLEAN WINAPI RtlGenRandom(PVOID,ULONG);
327 NTSTATUS WINAPI LsaAddAccountRights(LSA_HANDLE,PSID,PLSA_UNICODE_STRING,ULONG);
328 NTSTATUS WINAPI LsaCallAuthenticationPackage(HANDLE,ULONG,PVOID,ULONG,PVOID*,PULONG,PNTSTATUS);
329 NTSTATUS WINAPI LsaClose(LSA_HANDLE);
330 NTSTATUS WINAPI LsaConnectUntrusted(PHANDLE);
331 NTSTATUS WINAPI LsaCreateTrustedDomainEx(LSA_HANDLE,PTRUSTED_DOMAIN_INFORMATION_EX,
332 PTRUSTED_DOMAIN_AUTH_INFORMATION,ACCESS_MASK,PLSA_HANDLE);
333 NTSTATUS WINAPI LsaDeleteTrustedDomain(LSA_HANDLE,PSID);
334 NTSTATUS WINAPI LsaDeregisterLogonProcess(HANDLE);
335 NTSTATUS WINAPI LsaEnumerateAccountRights(LSA_HANDLE,PSID,PLSA_UNICODE_STRING*,PULONG);
336 NTSTATUS WINAPI LsaEnumerateAccountsWithUserRight(LSA_HANDLE,PLSA_UNICODE_STRING,PVOID*,PULONG);
337 NTSTATUS WINAPI LsaEnumerateTrustedDomains(LSA_HANDLE,PLSA_ENUMERATION_HANDLE,PVOID*,ULONG,PULONG);
338 NTSTATUS WINAPI LsaEnumerateTrustedDomainsEx(LSA_HANDLE,PLSA_ENUMERATION_HANDLE,PVOID*,ULONG,PULONG);
339 NTSTATUS WINAPI LsaFreeMemory(PVOID);
340 NTSTATUS WINAPI LsaLookupNames(LSA_HANDLE,ULONG,PLSA_UNICODE_STRING,PLSA_REFERENCED_DOMAIN_LIST*,
341 PLSA_TRANSLATED_SID*);
342 NTSTATUS WINAPI LsaLookupNames2(LSA_HANDLE,ULONG,ULONG,PLSA_UNICODE_STRING,PLSA_REFERENCED_DOMAIN_LIST*,
343 PLSA_TRANSLATED_SID2*);
344 NTSTATUS WINAPI LsaLookupSids(LSA_HANDLE,ULONG,PSID *,PLSA_REFERENCED_DOMAIN_LIST *,PLSA_TRANSLATED_NAME *);
345 ULONG WINAPI LsaNtStatusToWinError(NTSTATUS);
346 NTSTATUS WINAPI LsaOpenPolicy(PLSA_UNICODE_STRING,PLSA_OBJECT_ATTRIBUTES,ACCESS_MASK,PLSA_HANDLE);
347 NTSTATUS WINAPI LsaOpenTrustedDomainByName(LSA_HANDLE,PLSA_UNICODE_STRING,ACCESS_MASK,PLSA_HANDLE);
348 NTSTATUS WINAPI LsaQueryInformationPolicy(LSA_HANDLE,POLICY_INFORMATION_CLASS,PVOID*);
349 NTSTATUS WINAPI LsaQueryTrustedDomainInfo(LSA_HANDLE,PSID,TRUSTED_INFORMATION_CLASS,PVOID*);
350 NTSTATUS WINAPI LsaQueryTrustedDomainInfoByName(LSA_HANDLE,PLSA_UNICODE_STRING,TRUSTED_INFORMATION_CLASS,PVOID*);
351 NTSTATUS WINAPI LsaRegisterPolicyChangeNotification(POLICY_NOTIFICATION_INFORMATION_CLASS,HANDLE);
352 NTSTATUS WINAPI LsaRemoveAccountRights(LSA_HANDLE,PSID,BOOLEAN,PLSA_UNICODE_STRING,ULONG);
353 NTSTATUS WINAPI LsaRetrievePrivateData(LSA_HANDLE,PLSA_UNICODE_STRING,PLSA_UNICODE_STRING*);
354 NTSTATUS WINAPI LsaSetInformationPolicy(LSA_HANDLE,POLICY_INFORMATION_CLASS,PVOID);
355 NTSTATUS WINAPI LsaSetTrustedDomainInfoByName(LSA_HANDLE,PLSA_UNICODE_STRING,TRUSTED_INFORMATION_CLASS,PVOID);
356 NTSTATUS WINAPI LsaSetTrustedDomainInformation(LSA_HANDLE,PSID,TRUSTED_INFORMATION_CLASS,PVOID);
357 NTSTATUS WINAPI LsaStorePrivateData(LSA_HANDLE,PLSA_UNICODE_STRING,PLSA_UNICODE_STRING);
358 NTSTATUS WINAPI LsaUnregisterPolicyChangeNotification(POLICY_NOTIFICATION_INFORMATION_CLASS,HANDLE);
360 #ifdef __cplusplus
361 } /* extern "C" */
362 #endif /* defined(__cplusplus) */
364 #endif /* !defined(__WINE_NTSECAPI_H) */