2013-11-17 14:05:29 +00:00
|
|
|
/*
|
|
|
|
* winsecur.h: some miscellaneous security-related helper functions,
|
|
|
|
* defined in winsecur.c, that use the advapi32 library. Also
|
|
|
|
* centralises the machinery for dynamically loading that library.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#if !defined NO_SECURITY
|
|
|
|
|
|
|
|
#include <aclapi.h>
|
|
|
|
|
|
|
|
#ifndef WINSECUR_GLOBAL
|
|
|
|
#define WINSECUR_GLOBAL extern
|
|
|
|
#endif
|
|
|
|
|
2013-11-17 14:05:41 +00:00
|
|
|
/*
|
|
|
|
* Functions loaded from advapi32.dll.
|
|
|
|
*/
|
2013-11-17 14:05:29 +00:00
|
|
|
DECL_WINDOWS_FUNCTION(WINSECUR_GLOBAL, BOOL, OpenProcessToken,
|
|
|
|
(HANDLE, DWORD, PHANDLE));
|
|
|
|
DECL_WINDOWS_FUNCTION(WINSECUR_GLOBAL, BOOL, GetTokenInformation,
|
|
|
|
(HANDLE, TOKEN_INFORMATION_CLASS,
|
|
|
|
LPVOID, DWORD, PDWORD));
|
|
|
|
DECL_WINDOWS_FUNCTION(WINSECUR_GLOBAL, BOOL, InitializeSecurityDescriptor,
|
|
|
|
(PSECURITY_DESCRIPTOR, DWORD));
|
|
|
|
DECL_WINDOWS_FUNCTION(WINSECUR_GLOBAL, BOOL, SetSecurityDescriptorOwner,
|
|
|
|
(PSECURITY_DESCRIPTOR, PSID, BOOL));
|
|
|
|
DECL_WINDOWS_FUNCTION(WINSECUR_GLOBAL, DWORD, GetSecurityInfo,
|
|
|
|
(HANDLE, SE_OBJECT_TYPE, SECURITY_INFORMATION,
|
|
|
|
PSID *, PSID *, PACL *, PACL *,
|
|
|
|
PSECURITY_DESCRIPTOR *));
|
2013-11-17 14:05:41 +00:00
|
|
|
DECL_WINDOWS_FUNCTION(WINSECUR_GLOBAL, DWORD, SetEntriesInAclA,
|
|
|
|
(ULONG, PEXPLICIT_ACCESS, PACL, PACL *));
|
2013-11-17 14:05:29 +00:00
|
|
|
int got_advapi(void);
|
2013-11-17 14:05:41 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Find the SID describing the current user. The return value (if not
|
|
|
|
* NULL for some error-related reason) is smalloced.
|
|
|
|
*/
|
2013-11-17 14:05:29 +00:00
|
|
|
PSID get_user_sid(void);
|
|
|
|
|
2013-11-17 14:05:41 +00:00
|
|
|
/*
|
|
|
|
* Construct a PSECURITY_DESCRIPTOR of the type used for named pipe
|
|
|
|
* servers, i.e. allowing access only to the current user id and also
|
|
|
|
* only local (i.e. not over SMB) connections.
|
|
|
|
*
|
2013-11-25 18:35:14 +00:00
|
|
|
* If this function returns TRUE, then 'psd' and 'acl' will have been
|
|
|
|
* filled in with memory allocated using LocalAlloc (and hence must be
|
|
|
|
* freed later using LocalFree). If it returns FALSE, then instead
|
|
|
|
* 'error' has been filled with a dynamically allocated error message.
|
2013-11-17 14:05:41 +00:00
|
|
|
*/
|
|
|
|
int make_private_security_descriptor(DWORD permissions,
|
|
|
|
PSECURITY_DESCRIPTOR *psd,
|
|
|
|
PACL *acl,
|
|
|
|
char **error);
|
|
|
|
|
2016-02-25 20:30:58 +00:00
|
|
|
int setprocessacl(char *error);
|
|
|
|
|
2013-11-17 14:05:29 +00:00
|
|
|
#endif
|