- Merge the remaining portion of the wlan-bringup branch
[reactos.git] / reactos / dll / win32 / lsasrv / lsasrv.h
1 /*
2 * COPYRIGHT: See COPYING in the top level directory
3 * PROJECT: Local Security Authority (LSA) Server
4 * FILE: reactos/dll/win32/lsasrv/lsasrv.h
5 * PURPOSE: Common header file
6 *
7 * PROGRAMMERS: Eric Kohl
8 */
9
10 #define WIN32_NO_STATUS
11 #include <windows.h>
12 #define NTOS_MODE_USER
13 #include <ndk/cmfuncs.h>
14 #include <ndk/lpctypes.h>
15 #include <ndk/lpcfuncs.h>
16 #include <ndk/obfuncs.h>
17 #include <ndk/rtlfuncs.h>
18 #include <ndk/setypes.h>
19
20
21 #include <ntsecapi.h>
22
23 #include <string.h>
24
25 #include "lsass.h"
26 #include "lsa_s.h"
27
28 #include <wine/debug.h>
29
30
31 typedef enum _LSA_DB_OBJECT_TYPE
32 {
33 LsaDbIgnoreObject,
34 LsaDbContainerObject,
35 LsaDbPolicyObject,
36 LsaDbAccountObject,
37 LsaDbDomainObject,
38 LsaDbSecretObject
39 } LSA_DB_OBJECT_TYPE, *PLSA_DB_OBJECT_TYPE;
40
41 typedef struct _LSA_DB_OBJECT
42 {
43 ULONG Signature;
44 LSA_DB_OBJECT_TYPE ObjectType;
45 ULONG RefCount;
46 ACCESS_MASK Access;
47 HANDLE KeyHandle;
48 struct _LSA_DB_OBJECT *ParentObject;
49 } LSA_DB_OBJECT, *PLSA_DB_OBJECT;
50
51 #define LSAP_DB_SIGNATURE 0x12345678
52
53
54 /* authport.c */
55 NTSTATUS
56 StartAuthenticationPort(VOID);
57
58 /* database.c */
59 NTSTATUS
60 LsapInitDatabase(VOID);
61
62 LSAPR_HANDLE
63 LsapCreateDbObject(LSAPR_HANDLE ParentHandle,
64 LPWSTR ObjectName,
65 BOOLEAN Open,
66 LSA_DB_OBJECT_TYPE HandleType,
67 ACCESS_MASK DesiredAccess);
68
69 NTSTATUS
70 LsapValidateDbObject(LSAPR_HANDLE Handle,
71 LSA_DB_OBJECT_TYPE HandleType,
72 ACCESS_MASK GrantedAccess);
73
74 NTSTATUS
75 LsapCloseDbObject(LSAPR_HANDLE Handle);
76
77 NTSTATUS
78 LsapGetObjectAttribute(PLSA_DB_OBJECT DbObject,
79 LPWSTR AttributeName,
80 LPVOID AttributeData,
81 PULONG AttributeSize);
82
83 NTSTATUS
84 LsapSetObjectAttribute(PLSA_DB_OBJECT DbObject,
85 LPWSTR AttributeName,
86 LPVOID AttributeData,
87 ULONG AttributeSize);
88
89 /* lsarpc.c */
90 VOID
91 LsarStartRpcServer(VOID);
92
93 /* policy.c */
94 NTSTATUS
95 LsarQueryAuditEvents(LSAPR_HANDLE PolicyHandle,
96 PLSAPR_POLICY_INFORMATION *PolicyInformation);
97
98 NTSTATUS
99 LsarQueryPrimaryDomain(LSAPR_HANDLE PolicyHandle,
100 PLSAPR_POLICY_INFORMATION *PolicyInformation);
101
102 NTSTATUS
103 LsarQueryAccountDomain(LSAPR_HANDLE PolicyHandle,
104 PLSAPR_POLICY_INFORMATION *PolicyInformation);
105
106 NTSTATUS
107 LsarQueryDnsDomain(LSAPR_HANDLE PolicyHandle,
108 PLSAPR_POLICY_INFORMATION *PolicyInformation);
109
110 NTSTATUS
111 LsarSetPrimaryDomain(LSAPR_HANDLE PolicyObject,
112 PLSAPR_POLICY_PRIMARY_DOM_INFO Info);
113
114 NTSTATUS
115 LsarSetAccountDomain(LSAPR_HANDLE PolicyObject,
116 PLSAPR_POLICY_ACCOUNT_DOM_INFO Info);
117
118 NTSTATUS
119 LsarSetDnsDomain(LSAPR_HANDLE PolicyObject,
120 PLSAPR_POLICY_DNS_DOMAIN_INFO Info);
121
122 /* privileges.c */
123 NTSTATUS
124 LsarpLookupPrivilegeName(PLUID Value,
125 PUNICODE_STRING *Name);
126
127 NTSTATUS
128 LsarpLookupPrivilegeValue(PUNICODE_STRING Name,
129 PLUID Value);
130
131 /* sids.h */
132 NTSTATUS
133 LsapInitSids(VOID);
134
135 NTSTATUS
136 LsapLookupSids(PLSAPR_SID_ENUM_BUFFER SidEnumBuffer,
137 PLSAPR_TRANSLATED_NAME OutputNames);
138