VirtualBox

source: vbox/trunk/src/VBox/Devices/Graphics/shaderlib/wine/include/ntsecapi.h@ 104831

最後變更 在這個檔案從104831是 53206,由 vboxsync 提交於 10 年 前

Devices/vmsvga: header fixes

  • 屬性 svn:eol-style 設為 native
  • 屬性 svn:keywords 設為 Author Date Id Revision
檔案大小: 14.4 KB
 
1/*
2 * Copyright (C) 1999 Juergen Schmied
3 *
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.
8 *
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.
13 *
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
17 */
18
19/*
20 * Oracle LGPL Disclaimer: For the avoidance of doubt, except that if any license choice
21 * other than GPL or LGPL is available it will apply instead, Oracle elects to use only
22 * the Lesser General Public License version 2.1 (LGPLv2) at this time for any software where
23 * a choice of LGPL license versions is made available with the language indicating
24 * that LGPLv2 or any later version may be used, or where a choice of which version
25 * of the LGPL is applied is otherwise unspecified.
26 */
27
28#ifndef __WINE_NTSECAPI_H
29#define __WINE_NTSECAPI_H
30
31#ifndef GUID_DEFINED
32# include <guiddef.h>
33#endif
34
35#ifdef __cplusplus
36extern "C" {
37#endif /* defined(__cplusplus) */
38
39/* Policy access rights */
40#define POLICY_VIEW_LOCAL_INFORMATION __MSABI_LONG(0x00000001)
41#define POLICY_VIEW_AUDIT_INFORMATION __MSABI_LONG(0x00000002)
42#define POLICY_GET_PRIVATE_INFORMATION __MSABI_LONG(0x00000004)
43#define POLICY_TRUST_ADMIN __MSABI_LONG(0x00000008)
44#define POLICY_CREATE_ACCOUNT __MSABI_LONG(0x00000010)
45#define POLICY_CREATE_SECRET __MSABI_LONG(0x00000020)
46#define POLICY_CREATE_PRIVILEGE __MSABI_LONG(0x00000040)
47#define POLICY_SET_DEFAULT_QUOTA_LIMITS __MSABI_LONG(0x00000080)
48#define POLICY_SET_AUDIT_REQUIREMENTS __MSABI_LONG(0x00000100)
49#define POLICY_AUDIT_LOG_ADMIN __MSABI_LONG(0x00000200)
50#define POLICY_SERVER_ADMIN __MSABI_LONG(0x00000400)
51#define POLICY_LOOKUP_NAMES __MSABI_LONG(0x00000800)
52#define POLICY_NOTIFICATION __MSABI_LONG(0x00001000)
53
54#define POLICY_ALL_ACCESS ( \
55 STANDARD_RIGHTS_REQUIRED | \
56 POLICY_VIEW_LOCAL_INFORMATION | \
57 POLICY_VIEW_AUDIT_INFORMATION | \
58 POLICY_GET_PRIVATE_INFORMATION | \
59 POLICY_TRUST_ADMIN | \
60 POLICY_CREATE_ACCOUNT | \
61 POLICY_CREATE_SECRET | \
62 POLICY_CREATE_PRIVILEGE | \
63 POLICY_SET_DEFAULT_QUOTA_LIMITS | \
64 POLICY_SET_AUDIT_REQUIREMENTS | \
65 POLICY_AUDIT_LOG_ADMIN | \
66 POLICY_SERVER_ADMIN | \
67 POLICY_LOOKUP_NAMES)
68
69
70#define POLICY_READ ( \
71 STANDARD_RIGHTS_READ | \
72 POLICY_VIEW_AUDIT_INFORMATION | \
73 POLICY_GET_PRIVATE_INFORMATION)
74
75#define POLICY_WRITE ( \
76 STANDARD_RIGHTS_WRITE | \
77 POLICY_TRUST_ADMIN | \
78 POLICY_CREATE_ACCOUNT | \
79 POLICY_CREATE_SECRET | \
80 POLICY_CREATE_PRIVILEGE | \
81 POLICY_SET_DEFAULT_QUOTA_LIMITS | \
82 POLICY_SET_AUDIT_REQUIREMENTS | \
83 POLICY_AUDIT_LOG_ADMIN | \
84 POLICY_SERVER_ADMIN)
85
86#define POLICY_EXECUTE ( \
87 STANDARD_RIGHTS_EXECUTE | \
88 POLICY_VIEW_LOCAL_INFORMATION | \
89 POLICY_LOOKUP_NAMES)
90
91#define POLICY_AUDIT_EVENT_UNCHANGED __MSABI_LONG(0x00000000)
92#define POLICY_AUDIT_EVENT_SUCCESS __MSABI_LONG(0x00000001)
93#define POLICY_AUDIT_EVENT_FAILURE __MSABI_LONG(0x00000002)
94#define POLICY_AUDIT_EVENT_NONE __MSABI_LONG(0x00000004)
95
96#define POLICY_AUDIT_EVENT_MASK (POLICY_AUDIT_EVENT_SUCCESS | \
97 POLICY_AUDIT_EVENT_FAILURE | \
98 POLICY_AUDIT_EVENT_NONE)
99
100/* logon rights names */
101#define SE_BATCH_LOGON_NAME \
102 TEXT("SeBatchLogonRight")
103#define SE_INTERACTIVE_LOGON_NAME \
104 TEXT("SeInteractiveLogonRight")
105#define SE_NETWORK_LOGON_NAME \
106 TEXT("SeNetworkLogonRight")
107#define SE_REMOTE_INTERACTIVE_LOGON_NAME \
108 TEXT("SeRemoteInteractiveLogonRight")
109#define SE_SERVICE_LOGON_NAME \
110 TEXT("SeServiceLogonRight")
111#define SE_DENY_BATCH_LOGON_NAME \
112 TEXT("SeDenyBatchLogonRight")
113#define SE_DENY_INTERACTIVE_LOGON_NAME \
114 TEXT("SeDenyInteractiveLogonRight")
115#define SE_DENY_NETWORK_LOGON_NAME \
116 TEXT("SeDenyNetworkLogonRight")
117#define SE_DENY_REMOTE_INTERACTIVE_LOGON_NAME \
118 TEXT("SeDenyRemoteInteractiveLogonRight")
119#define SE_DENY_SERVICE_LOGON_NAME \
120 TEXT("SeDenyServiceLogonRight")
121
122#ifndef WINE_NTSTATUS_DECLARED
123#define WINE_NTSTATUS_DECLARED
124typedef LONG NTSTATUS;
125#endif
126#ifndef WINE_PNTSTATUS_DECLARED
127#define WINE_PNTSTATUS_DECLARED
128typedef NTSTATUS *PNTSTATUS;
129#endif
130
131typedef enum _SECURITY_LOGON_TYPE
132{
133 Interactive = 2,
134 Network,
135 Batch,
136 Service,
137 Proxy
138} SECURITY_LOGON_TYPE, *PSECURITY_LOGON_TYPE;
139
140typedef enum _POLICY_AUDIT_EVENT_TYPE
141{
142 AuditCategorySystem,
143 AuditCategoryLogon,
144 AuditCategoryObjectAccess,
145 AuditCategoryPrivilegeUse,
146 AuditCategoryDetailedTracking,
147 AuditCategoryPolicyChange,
148 AuditCategoryAccountManagement
149} POLICY_AUDIT_EVENT_TYPE, *PPOLICY_AUDIT_EVENT_TYPE;
150
151#ifndef __STRING_DEFINED__
152#define __STRING_DEFINED__
153typedef struct _STRING {
154 USHORT Length;
155 USHORT MaximumLength;
156 PCHAR Buffer;
157} STRING, *PSTRING;
158#endif
159
160#ifndef __UNICODE_STRING_DEFINED__
161#define __UNICODE_STRING_DEFINED__
162typedef struct _UNICODE_STRING {
163 USHORT Length; /* bytes */
164 USHORT MaximumLength; /* bytes */
165 PWSTR Buffer;
166} UNICODE_STRING, *PUNICODE_STRING;
167#endif
168
169#ifndef __OBJECT_ATTRIBUTES_DEFINED__
170#define __OBJECT_ATTRIBUTES_DEFINED__
171typedef struct _OBJECT_ATTRIBUTES {
172 ULONG Length;
173 HANDLE RootDirectory;
174 PUNICODE_STRING ObjectName;
175 ULONG Attributes;
176 PVOID SecurityDescriptor; /* type SECURITY_DESCRIPTOR */
177 PVOID SecurityQualityOfService; /* type SECURITY_QUALITY_OF_SERVICE */
178} OBJECT_ATTRIBUTES, *POBJECT_ATTRIBUTES;
179#endif
180
181typedef UNICODE_STRING LSA_UNICODE_STRING, *PLSA_UNICODE_STRING;
182typedef STRING LSA_STRING, *PLSA_STRING;
183typedef OBJECT_ATTRIBUTES LSA_OBJECT_ATTRIBUTES, *PLSA_OBJECT_ATTRIBUTES;
184
185typedef PVOID LSA_HANDLE, *PLSA_HANDLE;
186typedef ULONG LSA_ENUMERATION_HANDLE, *PLSA_ENUMERATION_HANDLE;
187typedef ULONG LSA_OPERATIONAL_MODE, *PLSA_OPERATIONAL_MODE;
188
189typedef enum
190{
191 PolicyAuditLogInformation = 1,
192 PolicyAuditEventsInformation,
193 PolicyPrimaryDomainInformation,
194 PolicyPdAccountInformation,
195 PolicyAccountDomainInformation,
196 PolicyLsaServerRoleInformation,
197 PolicyReplicaSourceInformation,
198 PolicyDefaultQuotaInformation,
199 PolicyModificationInformation,
200 PolicyAuditFullSetInformation,
201 PolicyAuditFullQueryInformation,
202 PolicyDnsDomainInformation
203} POLICY_INFORMATION_CLASS, *PPOLICY_INFORMATION_CLASS;
204
205typedef ULONG POLICY_AUDIT_EVENT_OPTIONS, *PPOLICY_AUDIT_EVENT_OPTIONS;
206
207typedef struct _POLICY_AUDIT_EVENTS_INFO
208{
209 BOOLEAN AuditingMode;
210 PPOLICY_AUDIT_EVENT_OPTIONS EventAuditingOptions;
211 ULONG MaximumAuditEventCount;
212} POLICY_AUDIT_EVENTS_INFO, *PPOLICY_AUDIT_EVENTS_INFO;
213
214typedef struct _POLICY_PRIMARY_DOMAIN_INFO
215{
216 LSA_UNICODE_STRING Name;
217 PSID Sid;
218} POLICY_PRIMARY_DOMAIN_INFO, *PPOLICY_PRIMARY_DOMAIN_INFO;
219
220typedef struct _POLICY_ACCOUNT_DOMAIN_INFO
221{
222 LSA_UNICODE_STRING DomainName;
223 PSID DomainSid;
224} POLICY_ACCOUNT_DOMAIN_INFO, *PPOLICY_ACCOUNT_DOMAIN_INFO;
225
226typedef struct _POLICY_DNS_DOMAIN_INFO
227{
228 LSA_UNICODE_STRING Name;
229 LSA_UNICODE_STRING DnsDomainName;
230 LSA_UNICODE_STRING DnsForestName;
231 GUID DomainGuid;
232 PSID Sid;
233} POLICY_DNS_DOMAIN_INFO, *PPOLICY_DNS_DOMAIN_INFO;
234
235typedef enum _POLICY_LSA_SERVER_ROLE
236{
237 PolicyServerRoleBackup = 2,
238 PolicyServerRolePrimary
239} POLICY_LSA_SERVER_ROLE, *PPOLICY_LSA_SERVER_ROLE;
240
241typedef struct _POLICY_LSA_SERVER_ROLE_INFO
242{
243 POLICY_LSA_SERVER_ROLE LsaServerRole;
244} POLICY_LSA_SERVER_ROLE_INFO, *PPOLICY_LSA_SERVER_ROLE_INFO;
245
246typedef struct _POLICY_MODIFICATION_INFO
247{
248 LARGE_INTEGER ModifiedId;
249 LARGE_INTEGER DatabaseCreationTime;
250} POLICY_MODIFICATION_INFO, *PPOLICY_MODIFICATION_INFO;
251
252typedef struct _SECURITY_LOGON_SESSION_DATA {
253 ULONG Size;
254 LUID LogonId;
255 LSA_UNICODE_STRING UserName;
256 LSA_UNICODE_STRING LogonDomain;
257 LSA_UNICODE_STRING AuthenticationPackage;
258 ULONG LogonType;
259 ULONG Session;
260 PSID Sid;
261 LARGE_INTEGER LogonTime;
262 LSA_UNICODE_STRING LogonServer;
263 LSA_UNICODE_STRING DnsDomainName;
264 LSA_UNICODE_STRING Upn;
265} SECURITY_LOGON_SESSION_DATA, *PSECURITY_LOGON_SESSION_DATA;
266
267typedef struct
268{
269 SID_NAME_USE Use;
270 LSA_UNICODE_STRING Name;
271 LONG DomainIndex;
272} LSA_TRANSLATED_NAME, *PLSA_TRANSLATED_NAME;
273
274typedef struct
275{
276 LSA_UNICODE_STRING Name;
277 PSID Sid;
278} LSA_TRUST_INFORMATION, *PLSA_TRUST_INFORMATION;
279
280typedef struct
281{
282 ULONG Entries;
283 PLSA_TRUST_INFORMATION Domains;
284} LSA_REFERENCED_DOMAIN_LIST, *PLSA_REFERENCED_DOMAIN_LIST;
285
286typedef struct _LSA_TRANSLATED_SID
287{
288 SID_NAME_USE Use;
289 ULONG RelativeId;
290 LONG DomainIndex;
291} LSA_TRANSLATED_SID, *PLSA_TRANSLATED_SID;
292
293typedef struct _TRUSTED_DOMAIN_INFORMATION_EX
294{
295 LSA_UNICODE_STRING Name;
296 LSA_UNICODE_STRING FlatName;
297 PSID Sid;
298 ULONG TrustDirection;
299 ULONG TrustType;
300 ULONG TrustAttributes;
301} TRUSTED_DOMAIN_INFORMATION_EX, *PTRUSTED_DOMAIN_INFORMATION_EX;
302
303typedef struct _LSA_AUTH_INFORMATION
304{
305 LARGE_INTEGER LastUpdateTime;
306 ULONG AuthType;
307 ULONG AuthInfoLength;
308 PUCHAR AuthInfo;
309} LSA_AUTH_INFORMATION, *PLSA_AUTH_INFORMATION;
310
311typedef struct _TRUSTED_DOMAIN_AUTH_INFORMATION
312{
313 ULONG IncomingAuthInfos;
314 PLSA_AUTH_INFORMATION IncomingAuthenticationInformation;
315 PLSA_AUTH_INFORMATION IncomingPreviousAuthenticationInformation;
316 ULONG OutgoingAuthInfos;
317 PLSA_AUTH_INFORMATION OutgoingAuthenticationInformation;
318 PLSA_AUTH_INFORMATION OutgoingPreviousAuthenticationInformation;
319} TRUSTED_DOMAIN_AUTH_INFORMATION, *PTRUSTED_DOMAIN_AUTH_INFORMATION;
320
321typedef struct _LSA_TRANSLATED_SID2
322{
323 SID_NAME_USE Use;
324 PSID Sid;
325 LONG DomainIndex;
326 ULONG Flags;
327} LSA_TRANSLATED_SID2, *PLSA_TRANSLATED_SID2;
328
329typedef enum _TRUSTED_INFORMATION_CLASS
330{
331 TrustedDomainNameInformation = 1,
332 TrustedControllersInformation,
333 TrustedPosixOffsetInformation,
334 TrustedPasswordInformation,
335 TrustedDomainInformationBasic,
336 TrustedDomainInformationEx,
337 TrustedDomainAuthInformation,
338 TrustedDomainFullInformation
339} TRUSTED_INFORMATION_CLASS, *PTRUSTED_INFORMATION_CLASS;
340
341typedef enum _POLICY_NOTIFICATION_INFORMATION_CLASS
342{
343 PolicyNotifyAuditEventsInformation = 1,
344 PolicyNotifyAccountDomainInformation,
345 PolicyNotifyServerRoleInformation,
346 PolicyNotifyDnsDomainInformation,
347 PolicyNotifyDomainEfsInformation,
348 PolicyNotifyDomainKerberosTicketInformation,
349 PolicyNotifyMachineAccountPasswordInformation
350} POLICY_NOTIFICATION_INFORMATION_CLASS, *PPOLICY_NOTIFICATION_INFORMATION_CLASS;
351
352#define RtlGenRandom SystemFunction036
353#define RtlEncryptMemory SystemFunction040
354#define RtlDecryptMemory SystemFunction041
355
356BOOLEAN WINAPI RtlGenRandom(PVOID,ULONG);
357NTSTATUS WINAPI RtlEncryptMemory(PVOID,ULONG,ULONG);
358NTSTATUS WINAPI RtlDecryptMemory(PVOID,ULONG,ULONG);
359
360NTSTATUS WINAPI LsaAddAccountRights(LSA_HANDLE,PSID,PLSA_UNICODE_STRING,ULONG);
361NTSTATUS WINAPI LsaCallAuthenticationPackage(HANDLE,ULONG,PVOID,ULONG,PVOID*,PULONG,PNTSTATUS);
362NTSTATUS WINAPI LsaClose(LSA_HANDLE);
363NTSTATUS WINAPI LsaConnectUntrusted(PHANDLE);
364NTSTATUS WINAPI LsaCreateTrustedDomainEx(LSA_HANDLE,PTRUSTED_DOMAIN_INFORMATION_EX,
365 PTRUSTED_DOMAIN_AUTH_INFORMATION,ACCESS_MASK,PLSA_HANDLE);
366NTSTATUS WINAPI LsaDeleteTrustedDomain(LSA_HANDLE,PSID);
367NTSTATUS WINAPI LsaDeregisterLogonProcess(HANDLE);
368NTSTATUS WINAPI LsaEnumerateAccountRights(LSA_HANDLE,PSID,PLSA_UNICODE_STRING*,PULONG);
369NTSTATUS WINAPI LsaEnumerateAccountsWithUserRight(LSA_HANDLE,PLSA_UNICODE_STRING,PVOID*,PULONG);
370NTSTATUS WINAPI LsaEnumerateLogonSessions(PULONG,PLUID*);
371NTSTATUS WINAPI LsaEnumerateTrustedDomains(LSA_HANDLE,PLSA_ENUMERATION_HANDLE,PVOID*,ULONG,PULONG);
372NTSTATUS WINAPI LsaEnumerateTrustedDomainsEx(LSA_HANDLE,PLSA_ENUMERATION_HANDLE,PVOID*,ULONG,PULONG);
373NTSTATUS WINAPI LsaFreeMemory(PVOID);
374NTSTATUS WINAPI LsaFreeReturnBuffer(PVOID);
375NTSTATUS WINAPI LsaGetLogonSessionData(PLUID,PSECURITY_LOGON_SESSION_DATA*);
376NTSTATUS WINAPI LsaLogonUser(HANDLE,PLSA_STRING,SECURITY_LOGON_TYPE,ULONG,PVOID,ULONG,PTOKEN_GROUPS,PTOKEN_SOURCE,PVOID*,PULONG,PLUID,PHANDLE,PQUOTA_LIMITS,PNTSTATUS);
377NTSTATUS WINAPI LsaLookupAuthenticationPackage(HANDLE,PLSA_STRING,PULONG);
378NTSTATUS WINAPI LsaLookupNames(LSA_HANDLE,ULONG,PLSA_UNICODE_STRING,PLSA_REFERENCED_DOMAIN_LIST*,
379 PLSA_TRANSLATED_SID*);
380NTSTATUS WINAPI LsaLookupNames2(LSA_HANDLE,ULONG,ULONG,PLSA_UNICODE_STRING,PLSA_REFERENCED_DOMAIN_LIST*,
381 PLSA_TRANSLATED_SID2*);
382NTSTATUS WINAPI LsaLookupSids(LSA_HANDLE,ULONG,PSID *,PLSA_REFERENCED_DOMAIN_LIST *,PLSA_TRANSLATED_NAME *);
383ULONG WINAPI LsaNtStatusToWinError(NTSTATUS);
384NTSTATUS WINAPI LsaOpenPolicy(PLSA_UNICODE_STRING,PLSA_OBJECT_ATTRIBUTES,ACCESS_MASK,PLSA_HANDLE);
385NTSTATUS WINAPI LsaOpenTrustedDomainByName(LSA_HANDLE,PLSA_UNICODE_STRING,ACCESS_MASK,PLSA_HANDLE);
386NTSTATUS WINAPI LsaQueryInformationPolicy(LSA_HANDLE,POLICY_INFORMATION_CLASS,PVOID*);
387NTSTATUS WINAPI LsaQueryTrustedDomainInfo(LSA_HANDLE,PSID,TRUSTED_INFORMATION_CLASS,PVOID*);
388NTSTATUS WINAPI LsaQueryTrustedDomainInfoByName(LSA_HANDLE,PLSA_UNICODE_STRING,TRUSTED_INFORMATION_CLASS,PVOID*);
389NTSTATUS WINAPI LsaRegisterLogonProcess(PLSA_STRING,PHANDLE,PLSA_OPERATIONAL_MODE);
390NTSTATUS WINAPI LsaRegisterPolicyChangeNotification(POLICY_NOTIFICATION_INFORMATION_CLASS,HANDLE);
391NTSTATUS WINAPI LsaRemoveAccountRights(LSA_HANDLE,PSID,BOOLEAN,PLSA_UNICODE_STRING,ULONG);
392NTSTATUS WINAPI LsaRetrievePrivateData(LSA_HANDLE,PLSA_UNICODE_STRING,PLSA_UNICODE_STRING*);
393NTSTATUS WINAPI LsaSetInformationPolicy(LSA_HANDLE,POLICY_INFORMATION_CLASS,PVOID);
394NTSTATUS WINAPI LsaSetTrustedDomainInfoByName(LSA_HANDLE,PLSA_UNICODE_STRING,TRUSTED_INFORMATION_CLASS,PVOID);
395NTSTATUS WINAPI LsaSetTrustedDomainInformation(LSA_HANDLE,PSID,TRUSTED_INFORMATION_CLASS,PVOID);
396NTSTATUS WINAPI LsaStorePrivateData(LSA_HANDLE,PLSA_UNICODE_STRING,PLSA_UNICODE_STRING);
397NTSTATUS WINAPI LsaUnregisterPolicyChangeNotification(POLICY_NOTIFICATION_INFORMATION_CLASS,HANDLE);
398
399#ifdef __cplusplus
400} /* extern "C" */
401#endif /* defined(__cplusplus) */
402
403#endif /* !defined(__WINE_NTSECAPI_H) */
注意: 瀏覽 TracBrowser 來幫助您使用儲存庫瀏覽器

© 2025 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette