Leaked source code of windows server 2003
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

// 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_