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
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 | \
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 | \
73 #define POLICY_EXECUTE ( \
74 STANDARD_RIGHTS_EXECUTE | \
75 POLICY_VIEW_LOCAL_INFORMATION | \
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
;
113 #ifndef WINE_PNTSTATUS_DECLARED
114 #define WINE_PNTSTATUS_DECLARED
115 typedef NTSTATUS
*PNTSTATUS
;
118 typedef enum _SECURITY_LOGON_TYPE
125 } SECURITY_LOGON_TYPE
, *PSECURITY_LOGON_TYPE
;
127 typedef enum _POLICY_AUDIT_EVENT_TYPE
131 AuditCategoryObjectAccess
,
132 AuditCategoryPrivilegeUse
,
133 AuditCategoryDetailedTracking
,
134 AuditCategoryPolicyChange
,
135 AuditCategoryAccountManagement
136 } POLICY_AUDIT_EVENT_TYPE
, *PPOLICY_AUDIT_EVENT_TYPE
;
138 typedef UNICODE_STRING LSA_UNICODE_STRING
, *PLSA_UNICODE_STRING
;
139 typedef STRING LSA_STRING
, *PLSA_STRING
;
140 typedef OBJECT_ATTRIBUTES LSA_OBJECT_ATTRIBUTES
, *PLSA_OBJECT_ATTRIBUTES
;
142 typedef PVOID LSA_HANDLE
, *PLSA_HANDLE
;
143 typedef ULONG LSA_ENUMERATION_HANDLE
, *PLSA_ENUMERATION_HANDLE
;
147 PolicyAuditLogInformation
= 1,
148 PolicyAuditEventsInformation
,
149 PolicyPrimaryDomainInformation
,
150 PolicyPdAccountInformation
,
151 PolicyAccountDomainInformation
,
152 PolicyLsaServerRoleInformation
,
153 PolicyReplicaSourceInformation
,
154 PolicyDefaultQuotaInformation
,
155 PolicyModificationInformation
,
156 PolicyAuditFullSetInformation
,
157 PolicyAuditFullQueryInformation
,
158 PolicyDnsDomainInformation
159 } POLICY_INFORMATION_CLASS
, *PPOLICY_INFORMATION_CLASS
;
161 typedef ULONG POLICY_AUDIT_EVENT_OPTIONS
, *PPOLICY_AUDIT_EVENT_OPTIONS
;
163 typedef struct _POLICY_AUDIT_EVENTS_INFO
165 BOOLEAN AuditingMode
;
166 PPOLICY_AUDIT_EVENT_OPTIONS EventAuditingOptions
;
167 ULONG MaximumAuditEventCount
;
168 } POLICY_AUDIT_EVENTS_INFO
, *PPOLICY_AUDIT_EVENTS_INFO
;
170 typedef struct _POLICY_PRIMARY_DOMAIN_INFO
172 LSA_UNICODE_STRING Name
;
174 } POLICY_PRIMARY_DOMAIN_INFO
, *PPOLICY_PRIMARY_DOMAIN_INFO
;
176 typedef struct _POLICY_ACCOUNT_DOMAIN_INFO
178 LSA_UNICODE_STRING DomainName
;
180 } POLICY_ACCOUNT_DOMAIN_INFO
, *PPOLICY_ACCOUNT_DOMAIN_INFO
;
182 typedef struct _POLICY_DNS_DOMAIN_INFO
184 LSA_UNICODE_STRING Name
;
185 LSA_UNICODE_STRING DnsDomainName
;
186 LSA_UNICODE_STRING DnsForestName
;
189 } POLICY_DNS_DOMAIN_INFO
, *PPOLICY_DNS_DOMAIN_INFO
;
191 typedef enum _POLICY_LSA_SERVER_ROLE
193 PolicyServerRoleBackup
= 2,
194 PolicyServerRolePrimary
195 } POLICY_LSA_SERVER_ROLE
, *PPOLICY_LSA_SERVER_ROLE
;
197 typedef struct _POLICY_LSA_SERVER_ROLE_INFO
199 POLICY_LSA_SERVER_ROLE LsaServerRole
;
200 } POLICY_LSA_SERVER_ROLE_INFO
, *PPOLICY_LSA_SERVER_ROLE_INFO
;
202 typedef struct _POLICY_MODIFICATION_INFO
204 LARGE_INTEGER ModifiedId
;
205 LARGE_INTEGER DatabaseCreationTime
;
206 } POLICY_MODIFICATION_INFO
, *PPOLICY_MODIFICATION_INFO
;
211 LSA_UNICODE_STRING Name
;
213 } LSA_TRANSLATED_NAME
, *PLSA_TRANSLATED_NAME
;
217 LSA_UNICODE_STRING Name
;
219 } LSA_TRUST_INFORMATION
, *PLSA_TRUST_INFORMATION
;
224 PLSA_TRUST_INFORMATION Domains
;
225 } LSA_REFERENCED_DOMAIN_LIST
, *PLSA_REFERENCED_DOMAIN_LIST
;
227 typedef struct _LSA_TRANSLATED_SID
232 } LSA_TRANSLATED_SID
, *PLSA_TRANSLATED_SID
;
234 typedef struct _TRUSTED_DOMAIN_INFORMATION_EX
236 LSA_UNICODE_STRING Name
;
237 LSA_UNICODE_STRING FlatName
;
239 ULONG TrustDirection
;
241 ULONG TrustAttributes
;
242 } TRUSTED_DOMAIN_INFORMATION_EX
, *PTRUSTED_DOMAIN_INFORMATION_EX
;
244 typedef struct _LSA_AUTH_INFORMATION
246 LARGE_INTEGER LastUpdateTime
;
248 ULONG AuthInfoLength
;
250 } LSA_AUTH_INFORMATION
, *PLSA_AUTH_INFORMATION
;
252 typedef struct _TRUSTED_DOMAIN_AUTH_INFORMATION
254 ULONG IncomingAuthInfos
;
255 PLSA_AUTH_INFORMATION IncomingAuthenticationInformation
;
256 PLSA_AUTH_INFORMATION IncomingPreviousAuthenticationInformation
;
257 ULONG OutgoingAuthInfos
;
258 PLSA_AUTH_INFORMATION OutgoingAuthenticationInformation
;
259 PLSA_AUTH_INFORMATION OutgoingPreviousAuthenticationInformation
;
260 } TRUSTED_DOMAIN_AUTH_INFORMATION
, *PTRUSTED_DOMAIN_AUTH_INFORMATION
;
262 typedef struct _LSA_TRANSLATED_SID2
268 } LSA_TRANSLATED_SID2
, *PLSA_TRANSLATED_SID2
;
270 typedef enum _TRUSTED_INFORMATION_CLASS
272 TrustedDomainNameInformation
= 1,
273 TrustedControllersInformation
,
274 TrustedPosixOffsetInformation
,
275 TrustedPasswordInformation
,
276 TrustedDomainInformationBasic
,
277 TrustedDomainInformationEx
,
278 TrustedDomainAuthInformation
,
279 TrustedDomainFullInformation
280 } TRUSTED_INFORMATION_CLASS
, *PTRUSTED_INFORMATION_CLASS
;
282 typedef enum _POLICY_NOTIFICATION_INFORMATION_CLASS
284 PolicyNotifyAuditEventsInformation
= 1,
285 PolicyNotifyAccountDomainInformation
,
286 PolicyNotifyServerRoleInformation
,
287 PolicyNotifyDnsDomainInformation
,
288 PolicyNotifyDomainEfsInformation
,
289 PolicyNotifyDomainKerberosTicketInformation
,
290 PolicyNotifyMachineAccountPasswordInformation
291 } POLICY_NOTIFICATION_INFORMATION_CLASS
, *PPOLICY_NOTIFICATION_INFORMATION_CLASS
;
293 #define RtlGenRandom SystemFunction036
295 BOOLEAN WINAPI
RtlGenRandom(PVOID
,ULONG
);
297 NTSTATUS WINAPI
LsaAddAccountRights(LSA_HANDLE
,PSID
,PLSA_UNICODE_STRING
,ULONG
);
298 NTSTATUS WINAPI
LsaCallAuthenticationPackage(HANDLE
,ULONG
,PVOID
,ULONG
,PVOID
*,PULONG
,PNTSTATUS
);
299 NTSTATUS WINAPI
LsaClose(LSA_HANDLE
);
300 NTSTATUS WINAPI
LsaConnectUntrusted(PHANDLE
);
301 NTSTATUS WINAPI
LsaCreateTrustedDomainEx(LSA_HANDLE
,PTRUSTED_DOMAIN_INFORMATION_EX
,
302 PTRUSTED_DOMAIN_AUTH_INFORMATION
,ACCESS_MASK
,PLSA_HANDLE
);
303 NTSTATUS WINAPI
LsaDeleteTrustedDomain(LSA_HANDLE
,PSID
);
304 NTSTATUS WINAPI
LsaDeregisterLogonProcess(HANDLE
);
305 NTSTATUS WINAPI
LsaEnumerateAccountRights(LSA_HANDLE
,PSID
,PLSA_UNICODE_STRING
*,PULONG
);
306 NTSTATUS WINAPI
LsaEnumerateAccountsWithUserRight(LSA_HANDLE
,PLSA_UNICODE_STRING
,PVOID
*,PULONG
);
307 NTSTATUS WINAPI
LsaEnumerateTrustedDomains(LSA_HANDLE
,PLSA_ENUMERATION_HANDLE
,PVOID
*,ULONG
,PULONG
);
308 NTSTATUS WINAPI
LsaEnumerateTrustedDomainsEx(LSA_HANDLE
,PLSA_ENUMERATION_HANDLE
,PVOID
*,ULONG
,PULONG
);
309 NTSTATUS WINAPI
LsaFreeMemory(PVOID
);
310 NTSTATUS WINAPI
LsaLookupNames(LSA_HANDLE
,ULONG
,PLSA_UNICODE_STRING
,PLSA_REFERENCED_DOMAIN_LIST
*,
311 PLSA_TRANSLATED_SID
*);
312 NTSTATUS WINAPI
LsaLookupNames2(LSA_HANDLE
,ULONG
,ULONG
,PLSA_UNICODE_STRING
,PLSA_REFERENCED_DOMAIN_LIST
*,
313 PLSA_TRANSLATED_SID2
*);
314 NTSTATUS WINAPI
LsaLookupSids(LSA_HANDLE
,ULONG
,PSID
*,PLSA_REFERENCED_DOMAIN_LIST
*,PLSA_TRANSLATED_NAME
*);
315 ULONG WINAPI
LsaNtStatusToWinError(NTSTATUS
);
316 NTSTATUS WINAPI
LsaOpenPolicy(PLSA_UNICODE_STRING
,PLSA_OBJECT_ATTRIBUTES
,ACCESS_MASK
,PLSA_HANDLE
);
317 NTSTATUS WINAPI
LsaOpenTrustedDomainByName(LSA_HANDLE
,PLSA_UNICODE_STRING
,ACCESS_MASK
,PLSA_HANDLE
);
318 NTSTATUS WINAPI
LsaQueryInformationPolicy(LSA_HANDLE
,POLICY_INFORMATION_CLASS
,PVOID
*);
319 NTSTATUS WINAPI
LsaQueryTrustedDomainInfo(LSA_HANDLE
,PSID
,TRUSTED_INFORMATION_CLASS
,PVOID
*);
320 NTSTATUS WINAPI
LsaQueryTrustedDomainInfoByName(LSA_HANDLE
,PLSA_UNICODE_STRING
,TRUSTED_INFORMATION_CLASS
,PVOID
*);
321 NTSTATUS WINAPI
LsaRegisterPolicyChangeNotification(POLICY_NOTIFICATION_INFORMATION_CLASS
,HANDLE
);
322 NTSTATUS WINAPI
LsaRemoveAccountRights(LSA_HANDLE
,PSID
,BOOLEAN
,PLSA_UNICODE_STRING
,ULONG
);
323 NTSTATUS WINAPI
LsaRetrievePrivateData(LSA_HANDLE
,PLSA_UNICODE_STRING
,PLSA_UNICODE_STRING
*);
324 NTSTATUS WINAPI
LsaSetInformationPolicy(LSA_HANDLE
,POLICY_INFORMATION_CLASS
,PVOID
);
325 NTSTATUS WINAPI
LsaSetTrustedDomainInfoByName(LSA_HANDLE
,PLSA_UNICODE_STRING
,TRUSTED_INFORMATION_CLASS
,PVOID
);
326 NTSTATUS WINAPI
LsaSetTrustedDomainInformation(LSA_HANDLE
,PSID
,TRUSTED_INFORMATION_CLASS
,PVOID
);
327 NTSTATUS WINAPI
LsaStorePrivateData(LSA_HANDLE
,PLSA_UNICODE_STRING
,PLSA_UNICODE_STRING
);
328 NTSTATUS WINAPI
LsaUnregisterPolicyChangeNotification(POLICY_NOTIFICATION_INFORMATION_CLASS
,HANDLE
);
332 #endif /* defined(__cplusplus) */
334 #endif /* !defined(__WINE_NTSECAPI_H) */