summaryrefslogtreecommitdiffstats
path: root/winsup/w32api
diff options
context:
space:
mode:
authorLuke Dunstan <infidel@users.sourceforge.net>2004-04-23 16:03:43 +0000
committerLuke Dunstan <infidel@users.sourceforge.net>2004-04-23 16:03:43 +0000
commit3704b2de4d4287447e47fd989faadd6dc315d53e (patch)
treeea1af2f1ec923300300dd2787c630339a341678f /winsup/w32api
parent04e8fca1535cebbf0cbc270a637a3d70b792b745 (diff)
downloadcygnal-3704b2de4d4287447e47fd989faadd6dc315d53e.tar.gz
cygnal-3704b2de4d4287447e47fd989faadd6dc315d53e.tar.bz2
cygnal-3704b2de4d4287447e47fd989faadd6dc315d53e.zip
2004-04-23 Robert Wruck <wruck@tweerlei.de>
* include/aclui.h: New file. * lib/aclui.def: New file. * lib/test.c: Add aclui.h to includes.
Diffstat (limited to 'winsup/w32api')
-rw-r--r--winsup/w32api/ChangeLog6
-rw-r--r--winsup/w32api/include/aclui.h134
-rw-r--r--winsup/w32api/lib/aclui.def7
-rw-r--r--winsup/w32api/lib/test.c1
4 files changed, 148 insertions, 0 deletions
diff --git a/winsup/w32api/ChangeLog b/winsup/w32api/ChangeLog
index b0e10a570..5483e5362 100644
--- a/winsup/w32api/ChangeLog
+++ b/winsup/w32api/ChangeLog
@@ -1,3 +1,9 @@
+2004-04-23 Robert Wruck <wruck@tweerlei.de>
+
+ * include/aclui.h: New file.
+ * lib/aclui.def: New file.
+ * lib/test.c: Add aclui.h to includes.
+
2004-04-21 Danny Smith <dannysmith@users.sourceforge.net>
* include/winuser.h (SPI_GETACTIVEWINDOWTRACKING,
diff --git a/winsup/w32api/include/aclui.h b/winsup/w32api/include/aclui.h
new file mode 100644
index 000000000..61321f49e
--- /dev/null
+++ b/winsup/w32api/include/aclui.h
@@ -0,0 +1,134 @@
+#ifndef _ACLUI_H
+#define _ACLUI_H
+#if __GNUC__ >= 3
+#pragma GCC system_header
+#endif
+
+#ifndef __OBJC__
+#include <objbase.h>
+#include <commctrl.h>
+#include <accctrl.h>
+#endif
+
+#if !defined(_ACLUI_)
+#define ACLUIAPI DECLSPEC_IMPORT WINAPI
+#else
+#define ACLUIAPI WINAPI
+#endif
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+typedef struct _SI_OBJECT_INFO
+{
+ DWORD dwFlags;
+ HINSTANCE hInstance;
+ LPWSTR pszServerName;
+ LPWSTR pszObjectName;
+ LPWSTR pszPageTitle;
+ GUID guidObjectType;
+} SI_OBJECT_INFO, *PSI_OBJECT_INFO;
+
+/* values for SI_OBJECT_INFO.dwFlags */
+#define SI_EDIT_PERMS 0x00000000L
+#define SI_EDIT_OWNER 0x00000001L
+#define SI_EDIT_AUDITS 0x00000002L
+#define SI_CONTAINER 0x00000004L
+#define SI_READONLY 0x00000008L
+#define SI_ADVANCED 0x00000010L
+#define SI_RESET 0x00000020L
+#define SI_OWNER_READONLY 0x00000040L
+#define SI_EDIT_PROPERTIES 0x00000080L
+#define SI_OWNER_RECURSE 0x00000100L
+#define SI_NO_ACL_PROTECT 0x00000200L
+#define SI_NO_TREE_APPLY 0x00000400L
+#define SI_PAGE_TITLE 0x00000800L
+#define SI_SERVER_IS_DC 0x00001000L
+#define SI_RESET_DACL_TREE 0x00004000L
+#define SI_RESET_SACL_TREE 0x00008000L
+#define SI_OBJECT_GUID 0x00010000L
+#define SI_EDIT_EFFECTIVE 0x00020000L
+#define SI_RESET_DACL 0x00040000L
+#define SI_RESET_SACL 0x00080000L
+#define SI_RESET_OWNER 0x00100000L
+#define SI_NO_ADDITIONAL_PERMISSION 0x00200000L
+#define SI_MAY_WRITE 0x10000000L
+
+#define SI_EDIT_ALL (SI_EDIT_PERMS | SI_EDIT_OWNER | SI_EDIT_AUDITS)
+
+
+typedef struct _SI_ACCESS
+{
+ const GUID* pguid;
+ ACCESS_MASK mask;
+ LPCWSTR pszName;
+ DWORD dwFlags;
+} SI_ACCESS, *PSI_ACCESS;
+
+/* values for SI_ACCESS.dwFlags */
+#define SI_ACCESS_SPECIFIC 0x00010000L
+#define SI_ACCESS_GENERAL 0x00020000L
+#define SI_ACCESS_CONTAINER 0x00040000L
+#define SI_ACCESS_PROPERTY 0x00080000L
+
+
+typedef struct _SI_INHERIT_TYPE
+{
+ const GUID* pguid;
+ ULONG dwFlags;
+ LPCWSTR pszName;
+} SI_INHERIT_TYPE, *PSI_INHERIT_TYPE;
+
+/* values for SI_INHERIT_TYPE.dwFlags
+ INHERIT_ONLY_ACE, CONTAINER_INHERIT_ACE, OBJECT_INHERIT_ACE
+ defined elsewhere */
+
+
+typedef enum _SI_PAGE_TYPE
+{
+ SI_PAGE_PERM = 0,
+ SI_PAGE_ADVPERM,
+ SI_PAGE_AUDIT,
+ SI_PAGE_OWNER
+} SI_PAGE_TYPE;
+
+
+#define PSPCB_SI_INITDIALOG (WM_USER + 1)
+
+#ifndef __ISecurityInformation_INTERFACE_DEFINED__
+#define __ISecurityInformation_INTERFACE_DEFINED__
+#undef INTERFACE
+#define INTERFACE ISecurityInformation
+DECLARE_INTERFACE_(ISecurityInformation, IUnknown)
+{
+ STDMETHOD(QueryInterface)(THIS_ REFIID,PVOID*) PURE;
+ STDMETHOD_(ULONG,AddRef)(THIS) PURE;
+ STDMETHOD_(ULONG,Release)(THIS) PURE;
+
+ STDMETHOD(GetObjectInformation)(THIS_ PSI_OBJECT_INFO) PURE;
+ STDMETHOD(GetSecurity)(THIS_ SECURITY_INFORMATION,PSECURITY_DESCRIPTOR*,BOOL) PURE;
+ STDMETHOD(SetSecurity)(THIS_ SECURITY_INFORMATION,PSECURITY_DESCRIPTOR) PURE;
+ STDMETHOD(GetAccessRights)(THIS_ const GUID*,DWORD,PSI_ACCESS*,ULONG*,ULONG*) PURE;
+ STDMETHOD(MapGeneric)(THIS_ const GUID*,UCHAR*,ACCESS_MASK*) PURE;
+ STDMETHOD(GetInheritTypes)(THIS_ PSI_INHERIT_TYPE*,ULONG*) PURE;
+ STDMETHOD(PropertySheetPageCallback)(THIS_ HWND,UINT,SI_PAGE_TYPE) PURE;
+};
+typedef ISecurityInformation *LPSECURITYINFO;
+#endif
+
+/*
+ * TODO: ISecurityInformation2, IEffectivePermission, ISecurityObjectTypeInfo
+ */
+
+extern DECLSPEC_IMPORT const IID IID_ISecurityInformation;
+
+
+HPROPSHEETPAGE ACLUIAPI CreateSecurityPage(LPSECURITYINFO psi);
+BOOL ACLUIAPI EditSecurity(HWND hwndOwner, LPSECURITYINFO psi);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
diff --git a/winsup/w32api/lib/aclui.def b/winsup/w32api/lib/aclui.def
new file mode 100644
index 000000000..e55ae9074
--- /dev/null
+++ b/winsup/w32api/lib/aclui.def
@@ -0,0 +1,7 @@
+LIBRARY ACLUI.dll
+
+EXPORTS
+CreateSecurityPage@4
+EditSecurity@8
+IID_ISecurityInformation DATA
+
diff --git a/winsup/w32api/lib/test.c b/winsup/w32api/lib/test.c
index 786330fda..71f63c389 100644
--- a/winsup/w32api/lib/test.c
+++ b/winsup/w32api/lib/test.c
@@ -103,6 +103,7 @@
#include <exdisp.h>
#include <mshtml.h>
#include <servprov.h>
+#include <aclui.h>
#else
#undef BOOL