2020-09-30 16:53:55 +02:00

79 lines
3.0 KiB
C++

// UserRights.h : Declaration of the CUserRights
#ifndef __USERRIGHTS_H_
#define __USERRIGHTS_H_
#include "resource.h" // main symbols
#include <comdef.h>
#include "ntsecapi.h"
#include "CommaLog.hpp"
class PrivNode;
class PrivList;
/////////////////////////////////////////////////////////////////////////////
// CUserRights
class ATL_NO_VTABLE CUserRights :
public CComObjectRootEx<CComSingleThreadModel>,
public CComCoClass<CUserRights, &CLSID_UserRights>,
public IDispatchImpl<IUserRights, &IID_IUserRights, &LIBID_MCSDCTWORKEROBJECTSLib>
{
BOOL m_bNoChange;
BOOL m_bUseDisplayName;
BOOL m_bRemove;
_bstr_t m_SourceComputer;
_bstr_t m_TargetComputer;
LSA_HANDLE m_SrcPolicy;
LSA_HANDLE m_TgtPolicy;
public:
CUserRights()
{
m_bNoChange = FALSE;
m_bUseDisplayName = FALSE;
m_bRemove = FALSE;
m_SrcPolicy = 0;
m_TgtPolicy = 0;
}
~CUserRights();
DECLARE_REGISTRY_RESOURCEID(IDR_USERRIGHTS)
DECLARE_NOT_AGGREGATABLE(CUserRights)
DECLARE_PROTECT_FINAL_CONSTRUCT()
BEGIN_COM_MAP(CUserRights)
COM_INTERFACE_ENTRY(IUserRights)
COM_INTERFACE_ENTRY(IDispatch)
END_COM_MAP()
// IUserRights
public:
STDMETHOD(GetRightsOfUser)(BSTR server, BSTR user, SAFEARRAY ** rights);
STDMETHOD(GetUsersWithRight)(BSTR server, BSTR right, /*[out]*/ SAFEARRAY ** users);
STDMETHOD(GetRights)(BSTR server, /*[out]*/ SAFEARRAY ** rights);
STDMETHOD(RemoveUserRight)(BSTR server, BSTR username, BSTR right);
STDMETHOD(AddUserRight)(BSTR server, BSTR username, BSTR right);
STDMETHOD(ExportUserRights)(BSTR server, BSTR filename, BOOL bAppendToFile);
STDMETHOD(get_RemoveOldRightsFromTargetAccounts)(/*[out, retval]*/ BOOL *pVal);
STDMETHOD(put_RemoveOldRightsFromTargetAccounts)(/*[in]*/ BOOL newVal);
STDMETHOD(get_NoChange)(/*[out, retval]*/ BOOL *pVal);
STDMETHOD(put_NoChange)(/*[in]*/ BOOL newVal);
STDMETHOD(CopyUserRights)(BSTR sourceUserName, BSTR targetUserName);
STDMETHOD(OpenTargetServer)(BSTR computerName);
STDMETHOD(OpenSourceServer)(BSTR serverName);
STDMETHOD(CopyUserRightsWithSids)(BSTR sourceUserName, BSTR sourceSID,BSTR targetUserName,BSTR targetSID);
STDMETHOD(AddUserRights)(BSTR bstrServer, BSTR bstrSid, SAFEARRAY* psaRights);
STDMETHOD(RemoveUserRights)(BSTR bstrServer, BSTR bstrSid, SAFEARRAY* psaRights);
protected:
DWORD CopyUserRightsInternal(WCHAR * sourceUserName,WCHAR * tgtUserName, WCHAR * sourceSid, WCHAR * targetSid,BOOL noChange, BOOL remove);
DWORD EnumerateAccountsWithRight(LSA_HANDLE policy, WCHAR * server,LSA_UNICODE_STRING * pRight, CommaDelimitedLog * pLog);
DWORD SafeArrayFromPrivList(PrivList * privList, SAFEARRAY ** pArray);
HRESULT SetRights(PWSTR pszServer, PSID pSid, SAFEARRAY* psaRights, bool bEnable);
};
#endif //__USERRIGHTS_H_