Windows2003-3790/inetsrv/pop3/admin/p3admin/p3userenum.cpp

160 lines
4.8 KiB
C++
Raw Normal View History

2001-01-01 00:00:00 +01:00
// P3UserEnum.cpp : Implementation of CP3UserEnum
#include "stdafx.h"
#include "P3Admin.h"
#include "P3UserEnum.h"
#include "P3User.h"
/////////////////////////////////////////////////////////////////////////////
// CP3UserEnum
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
CP3UserEnum::CP3UserEnum() :
m_pIUnk(NULL), m_pAdminX(NULL), m_hfSearch(INVALID_HANDLE_VALUE)
{
ZeroMemory( m_sDomainName, sizeof(m_sDomainName));
}
CP3UserEnum::~CP3UserEnum()
{
if ( NULL != m_pIUnk )
m_pIUnk->Release();
if ( INVALID_HANDLE_VALUE != m_hfSearch )
FindClose( m_hfSearch );
}
/////////////////////////////////////////////////////////////////////////////
// IEnumVARIANT
STDMETHODIMP CP3UserEnum::Next( /* [in] */ ULONG celt, /* [length_is][size_is][out] */ VARIANT __RPC_FAR *rgVar, /* [out] */ ULONG __RPC_FAR *pCeltFetched)
{
if ( NULL == rgVar || ( 1 != celt && NULL == pCeltFetched ))
return E_POINTER;
if ( NULL == m_pAdminX ) return E_POINTER;
ULONG nActual = 0;
HRESULT hr = S_OK;
VARIANT __RPC_FAR *pVar = rgVar;
VARIANT v;
WCHAR sBuffer[POP3_MAX_PATH];
LPWSTR ps = NULL;
IUnknown *pIUnk;
CComObject<CP3User> *p;
WIN32_FIND_DATA stFindData;
VariantInit( &v );
if ( S_OK == hr )
{
if ( INVALID_HANDLE_VALUE == m_hfSearch )
hr = m_pAdminX->InitFindFirstUser( m_hfSearch, m_sDomainName, sBuffer, sizeof( sBuffer )/sizeof(WCHAR) );
else
hr = m_pAdminX->GetNextUser( m_hfSearch, m_sDomainName, sBuffer, sizeof( sBuffer )/sizeof(WCHAR) );
}
if ( S_OK == hr )
{
hr = CComObject<CP3User>::CreateInstance( &p ); // Reference count still 0
if SUCCEEDED( hr )
{
// Increment the reference count on the source object and pass it to the new object
hr = m_pIUnk->QueryInterface(IID_IUnknown, reinterpret_cast<LPVOID*>( &pIUnk ));
if SUCCEEDED( hr )
{
hr = p->Init( pIUnk, m_pAdminX, m_sDomainName, sBuffer );
if SUCCEEDED( hr )
{
V_VT( &v ) = VT_DISPATCH;
hr = p->QueryInterface(IID_IDispatch, reinterpret_cast<void**>( &V_DISPATCH( &v )));
if SUCCEEDED( hr )
hr = VariantCopy( pVar, &v );
VariantClear( &v );
nActual++;
}
}
if FAILED( hr )
delete p;
}
}
if (pCeltFetched)
*pCeltFetched = nActual;
if (SUCCEEDED(hr) && (nActual < celt))
hr = S_FALSE;
return hr;
}
STDMETHODIMP CP3UserEnum::Skip(ULONG celt)
{
if ( NULL == m_pAdminX ) return E_POINTER;
HRESULT hr = S_OK;
WCHAR sBuffer[POP3_MAX_PATH];
WIN32_FIND_DATA stFindData;
while ( (S_OK == hr) && (0 < celt) )
{
hr = m_pAdminX->GetNextUser( m_hfSearch, m_sDomainName, sBuffer, sizeof( sBuffer )/sizeof(WCHAR) );
celt--;
}
return hr;
}
STDMETHODIMP CP3UserEnum::Reset(void)
{
CloseHandle( m_hfSearch );
m_hfSearch = INVALID_HANDLE_VALUE;
return S_OK;
}
STDMETHODIMP CP3UserEnum::Clone( /* [out] */ IEnumVARIANT __RPC_FAR *__RPC_FAR *ppEnum)
{
if ( NULL == ppEnum ) return E_INVALIDARG;
if ( NULL == m_pAdminX ) return E_POINTER;
HRESULT hr;
LPUNKNOWN pIUnk;
CComObject<CP3UserEnum> *p;
*ppEnum = NULL;
hr = CComObject<CP3UserEnum>::CreateInstance(&p); // Reference count still 0
if SUCCEEDED( hr )
{ // Increment the reference count on the source object and pass it to the new enumerator
hr = m_pIUnk->QueryInterface(IID_IUnknown, reinterpret_cast<LPVOID*>( &pIUnk ));
if SUCCEEDED( hr )
{
hr = p->Init( pIUnk, m_pAdminX, m_sDomainName ); // p must call release on pIUnk when done.
if SUCCEEDED( hr )
hr = p->QueryInterface( IID_IUnknown, reinterpret_cast<LPVOID*>( ppEnum ));
}
if FAILED( hr )
delete p; // Release
}
return hr;
}
//////////////////////////////////////////////////////////////////////
// Implementation: public
HRESULT CP3UserEnum::Init(IUnknown *pIUnk, CP3AdminWorker *p, LPCWSTR psDomainName )
{
if ( NULL == pIUnk )
return E_INVALIDARG;
if ( NULL == p )
return E_INVALIDARG;
if ( NULL == psDomainName )
return E_INVALIDARG;
HRESULT hr = S_OK;
m_pIUnk = pIUnk;
m_pAdminX = p;
wcsncpy( m_sDomainName, psDomainName, sizeof( m_sDomainName )/sizeof(WCHAR) );
return hr;
}