You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
138 lines
5.0 KiB
138 lines
5.0 KiB
// ServMigr.h : Declaration of the CServMigr
|
|
|
|
#ifndef __SERVMIGR_H_
|
|
#define __SERVMIGR_H_
|
|
|
|
#include "resource.h" // main symbols
|
|
#include "TNode.hpp"
|
|
#include "EaLen.hpp"
|
|
#include "UString.hpp"
|
|
#include "ExtSeq.h"
|
|
#include <wincrypt.h>
|
|
#include "crypt.hxx"
|
|
|
|
#define LEN_Service 200
|
|
//#import "\bin\DBManager.tlb" no_namespace, named_guids
|
|
#import "DBMgr.tlb" no_namespace, named_guids
|
|
|
|
#include "CommaLog.hpp"
|
|
|
|
class TEntryNode : public TNode
|
|
{
|
|
WCHAR computer[LEN_Computer];
|
|
WCHAR service[LEN_Service];
|
|
WCHAR account[LEN_Account];
|
|
CSecureString cryptpassword;
|
|
public:
|
|
TEntryNode(WCHAR const * c,WCHAR const * s,WCHAR const * a,WCHAR const* p)
|
|
{
|
|
safecopy(computer,c);
|
|
safecopy(service,s);
|
|
safecopy(account,a);
|
|
cryptpassword = (p ? p: L""); // can throw exception
|
|
}
|
|
WCHAR const * GetComputer() { return computer; }
|
|
WCHAR const * GetService() { return service; }
|
|
WCHAR const * GetAccount() { return account; }
|
|
WCHAR const * GetPassword() // can throw exception
|
|
{
|
|
WCHAR* p;
|
|
if (!cryptpassword.GetString(&p))
|
|
{
|
|
_com_issue_error(SEC_E_DECRYPT_FAILURE);
|
|
}
|
|
|
|
return p;
|
|
}
|
|
void const ReleasePassword() { cryptpassword.ReleaseString(); }
|
|
void SetPassword(WCHAR const* p) { cryptpassword = (p ? p: L""); } // can throw exception
|
|
};
|
|
|
|
class TEntryList : public TNodeList
|
|
{
|
|
WCHAR file[LEN_Path];
|
|
public:
|
|
TEntryList(WCHAR const * filename) { safecopy(file,filename); LoadFromFile(file); }
|
|
DWORD LoadFromFile(WCHAR const * filename);
|
|
DWORD SaveToFile(WCHAR const * filename);
|
|
~TEntryList() { SaveToFile(file); DeleteAllListItems(TEntryNode); }
|
|
private:
|
|
HCRYPTPROV AcquireContext(bool bContainerMustExist);
|
|
};
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// CServMigr
|
|
class ATL_NO_VTABLE CServMigr :
|
|
public CComObjectRootEx<CComSingleThreadModel>,
|
|
public CComCoClass<CServMigr, &CLSID_ServMigr>,
|
|
public IDispatchImpl<IExtendAccountMigration, &IID_IExtendAccountMigration, &LIBID_SCMMIGRLib>,
|
|
public ISvcMgr
|
|
{
|
|
TEntryList m_List;
|
|
IIManageDBPtr m_pDB;
|
|
BOOL m_bFatal;
|
|
CPasswordLog m_passwordLog; //Password file
|
|
bool m_bTriedToOpenFile;
|
|
long m_Sequence;
|
|
|
|
_bstr_t m_strSourceDomain;
|
|
_bstr_t m_strSourceDomainFlat;
|
|
_bstr_t m_strTargetDomain;
|
|
_bstr_t m_strTargetDomainFlat;
|
|
_bstr_t m_strSourceSam;
|
|
_bstr_t m_strTargetSam;
|
|
|
|
public:
|
|
CServMigr() : m_List(L"SCMData.txt")
|
|
{
|
|
HRESULT hr = m_pDB.CreateInstance(CLSID_IManageDB);
|
|
|
|
if ( FAILED(hr) )
|
|
{
|
|
m_bFatal = TRUE;
|
|
}
|
|
else
|
|
{
|
|
m_bFatal = FALSE;
|
|
}
|
|
m_bTriedToOpenFile = FALSE;
|
|
m_Sequence = AREXT_DEFAULT_SEQUENCE_NUMBER;
|
|
}
|
|
|
|
DECLARE_REGISTRY_RESOURCEID(IDR_SvcMgr)
|
|
|
|
DECLARE_PROTECT_FINAL_CONSTRUCT()
|
|
|
|
BEGIN_COM_MAP(CServMigr)
|
|
COM_INTERFACE_ENTRY(IExtendAccountMigration)
|
|
COM_INTERFACE_ENTRY(ISvcMgr)
|
|
COM_INTERFACE_ENTRY(IDispatch)
|
|
END_COM_MAP()
|
|
|
|
// IExtendAccountMigration
|
|
public:
|
|
STDMETHOD(ProcessUndo)(/*[in]*/ IUnknown * pSource, /*[in]*/ IUnknown * pTarget, /*[in]*/ IUnknown * pMainSettings, /*[in, out]*/ IUnknown ** pPropToSet, /*[in,out]*/ EAMAccountStats* pStats);
|
|
STDMETHOD(PreProcessObject)(/*[in]*/ IUnknown * pSource, /*[in]*/ IUnknown * pTarget, /*[in]*/ IUnknown * pMainSettings, /*[in,out]*/ IUnknown ** ppPropsToSet, /*[in,out]*/ EAMAccountStats* pStats);
|
|
STDMETHOD(ProcessObject)(/*[in]*/ IUnknown * pSource, /*[in]*/ IUnknown * pTarget, /*[in]*/ IUnknown * pMainSettings, /*[in,out]*/ IUnknown ** ppPropsToSet, /*[in,out]*/ EAMAccountStats* pStats);
|
|
STDMETHOD(get_sDesc)(/*[out, retval]*/ BSTR *pVal);
|
|
STDMETHOD(put_sDesc)(/*[in]*/ BSTR newVal);
|
|
STDMETHOD(get_sName)(/*[out, retval]*/ BSTR *pVal);
|
|
STDMETHOD(put_sName)(/*[in]*/ BSTR newVal);
|
|
STDMETHOD(get_SequenceNumber)(/*[out, retval]*/ LONG * value) { (*value) = m_Sequence; return S_OK; }
|
|
protected:
|
|
// Helper functions
|
|
BOOL UpdateSCMs(IUnknown * pVarSet,WCHAR const * account, WCHAR const * password,WCHAR const * strSid,IIManageDB * pDB, EAMAccountStats* pStats);
|
|
HRESULT SaveEncryptedPassword(WCHAR const * server,WCHAR const * service,WCHAR const * account,WCHAR const * password);
|
|
DWORD DoUpdate(WCHAR const * acount,WCHAR const * password,WCHAR const * strSid,WCHAR const * computer,WCHAR const * service,BOOL bNeedToGrantLOS, EAMAccountStats* pStats);
|
|
BOOL GetDirectory(WCHAR* filename);
|
|
BOOL RetrieveOriginalAccount(_bstr_t &sSrcDom, _bstr_t &sSrcSAM);
|
|
_bstr_t GetUPNName(_bstr_t sSrcSAM);
|
|
|
|
// ISvcMgr
|
|
public:
|
|
STDMETHOD(TryUpdateSam)(BSTR computer,BSTR service,BSTR account);
|
|
STDMETHOD(TryUpdateSamWithPassword)(BSTR computer,BSTR service,BSTR account,BSTR password);
|
|
};
|
|
|
|
#endif //__SERVMIGR_H_
|