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.
2729 lines
85 KiB
2729 lines
85 KiB
// service.cpp : Implementation of CsmtpadmApp and DLL registration.
|
|
|
|
#include "stdafx.h"
|
|
#include <lmcons.h>
|
|
#include "IADM.h"
|
|
#include "imd.h"
|
|
#include "mdmsg.h"
|
|
#include "iisinfo.h"
|
|
#include "iiscnfgp.h"
|
|
|
|
#include "smtpprop.h"
|
|
#include "smtpadm.h"
|
|
#include "ipaccess.h"
|
|
#include "oleutil.h"
|
|
#include "metautil.h"
|
|
#include "smtpcmn.h"
|
|
#include "smtpapi.h"
|
|
|
|
#include "virsvr.h"
|
|
|
|
|
|
// Must define THIS_FILE_* macros to use SmtpCreateException()
|
|
|
|
#define THIS_FILE_HELP_CONTEXT 0
|
|
#define THIS_FILE_PROG_ID _T("Smtpadm.VirtualServer.1")
|
|
#define THIS_FILE_IID IID_ISmtpAdminVirtualServer
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
|
|
CSmtpAdminVirtualServer::CSmtpAdminVirtualServer () :
|
|
m_lPort (25 ),
|
|
m_lLogMethod ( 0 ),
|
|
m_dwServerState ( MD_SERVER_STATE_STOPPED ),
|
|
m_pPrivateIpAccess ( NULL ),
|
|
m_dwWin32ErrorCode ( NOERROR ),
|
|
m_pPrivateBindings ( NULL ),
|
|
m_lRouteAction ( 0 )
|
|
// CComBSTR's are initialized to NULL by default.
|
|
{
|
|
m_psaAdmins = NULL;
|
|
InitAsyncTrace ( );
|
|
|
|
// Create the Ip Access collection:
|
|
CComObject<CTcpAccess> * pIpAccess;
|
|
|
|
CComObject<CTcpAccess>::CreateInstance ( &pIpAccess );
|
|
pIpAccess->QueryInterface ( IID_ITcpAccess, (void **) &m_pIpAccess );
|
|
m_pPrivateIpAccess = pIpAccess;
|
|
}
|
|
|
|
CSmtpAdminVirtualServer::~CSmtpAdminVirtualServer ()
|
|
{
|
|
// All CComBSTR's are freed automatically.
|
|
if ( m_psaAdmins ) {
|
|
SafeArrayDestroy ( m_psaAdmins );
|
|
}
|
|
|
|
TermAsyncTrace ( );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::InterfaceSupportsErrorInfo(REFIID riid)
|
|
{
|
|
static const IID* arr[] =
|
|
{
|
|
&IID_ISmtpAdminVirtualServer,
|
|
};
|
|
|
|
for (int i=0;i<sizeof(arr)/sizeof(arr[0]);i++)
|
|
{
|
|
if (InlineIsEqualGUID(*arr[i],riid))
|
|
return S_OK;
|
|
}
|
|
return S_FALSE;
|
|
}
|
|
|
|
// Which service to configure:
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_Server ( BSTR * pstrServer )
|
|
{
|
|
return StdPropertyGet ( m_strServer, pstrServer );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_Server ( BSTR strServer )
|
|
{
|
|
VALIDATE_STRING ( strServer, MAXLEN_SERVER );
|
|
|
|
// If the server name changes, that means the client will have to
|
|
// call Get again:
|
|
|
|
// I assume this here:
|
|
_ASSERT ( sizeof (DWORD) == sizeof (int) );
|
|
|
|
return StdPropertyPutServerName ( &m_strServer, strServer, (DWORD *) &m_fGotProperties, 1);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_ServiceInstance ( long * plServiceInstance )
|
|
{
|
|
return StdPropertyGet ( m_dwServiceInstance, plServiceInstance );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_ServiceInstance ( long lServiceInstance )
|
|
{
|
|
// If the service instance changes, that means the client will have to
|
|
// call Get again:
|
|
|
|
// I assume this here:
|
|
_ASSERT ( sizeof (DWORD) == sizeof (int) );
|
|
|
|
return StdPropertyPut ( &m_dwServiceInstance, lServiceInstance, (DWORD *) &m_fGotProperties, 1 );
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_TcpAccess ( ITcpAccess ** ppTcpAccess )
|
|
{
|
|
return m_pIpAccess->QueryInterface ( IID_ITcpAccess, (void **) ppTcpAccess );
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_Bindings ( IServerBindings ** ppBindings )
|
|
{
|
|
TraceQuietEnter ( "CSmtpAdminVirtualServer::get_Bindings" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
|
|
if ( !m_pBindings ) {
|
|
ErrorTrace ( 0, "Didn't call get first" );
|
|
hr = SmtpCreateException ( IDS_SMTPEXCEPTION_DIDNT_CALL_GET );
|
|
goto Exit;
|
|
}
|
|
else {
|
|
hr = m_pBindings->QueryInterface ( IID_IServerBindings, (void **) ppBindings );
|
|
_ASSERT ( SUCCEEDED(hr) );
|
|
}
|
|
|
|
Exit:
|
|
if ( FAILED(hr) && hr != DISP_E_EXCEPTION ) {
|
|
hr = SmtpCreateExceptionFromHresult ( hr );
|
|
}
|
|
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_BindingsDispatch ( IDispatch ** ppBindings )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
CComPtr<IServerBindings> pBindings;
|
|
|
|
hr = get_Bindings ( &pBindings );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = pBindings->QueryInterface ( IID_IDispatch, (void **) ppBindings );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
Exit:
|
|
return hr;
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RoutingSource ( IRoutingSource ** ppRoutingSource )
|
|
{
|
|
TraceQuietEnter ( "CSmtpAdminVirtualServer::get_RoutingSource" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
|
|
hr = m_RoutingSource.QueryInterface ( IID_IRoutingSource, (void **) ppRoutingSource );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RoutingSourceDispatch ( IDispatch ** ppRoutingSource )
|
|
{
|
|
TraceQuietEnter ( "CSmtpAdminVirtualServer::get_RoutingSourceDispatch" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
|
|
hr = m_RoutingSource.QueryInterface ( IID_IDispatch, (void **) ppRoutingSource );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
|
|
|
|
// Server overridable Properties:
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_ServerBindings( SAFEARRAY ** ppsastrServerBindings )
|
|
{
|
|
return StdPropertyGet ( &m_mszServerBindings, ppsastrServerBindings );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_ServerBindings( SAFEARRAY * pstrServerBindings )
|
|
{
|
|
return StdPropertyPut ( &m_mszServerBindings, pstrServerBindings, &m_bvChangedFields, BitMask(ID_SERVER_BINDINGS));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_ServerBindingsVariant( SAFEARRAY ** ppsavarServerBindings )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * psastrServerBindings = NULL;
|
|
|
|
hr = get_ServerBindings ( &psastrServerBindings );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = StringArrayToVariantArray ( psastrServerBindings, ppsavarServerBindings );
|
|
|
|
Exit:
|
|
if ( psastrServerBindings ) {
|
|
SafeArrayDestroy ( psastrServerBindings );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_ServerBindingsVariant( SAFEARRAY * psavarServerBindings )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * psastrServerBindings = NULL;
|
|
|
|
hr = VariantArrayToStringArray ( psavarServerBindings, &psastrServerBindings );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = put_ServerBindings ( psastrServerBindings );
|
|
|
|
Exit:
|
|
if ( psastrServerBindings ) {
|
|
SafeArrayDestroy ( psastrServerBindings );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SecureBindings( SAFEARRAY ** ppsastrSecureBindings )
|
|
{
|
|
return StdPropertyGet ( &m_mszSecureBindings, ppsastrSecureBindings );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SecureBindings( SAFEARRAY * pstrSecureBindings )
|
|
{
|
|
return StdPropertyPut ( &m_mszSecureBindings, pstrSecureBindings, &m_bvChangedFields, BitMask(ID_SECURE_BINDINGS));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SecureBindingsVariant( SAFEARRAY ** ppsavarSecureBindings )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * psastrSecureServerBindings = NULL;
|
|
|
|
hr = get_SecureBindings ( &psastrSecureServerBindings );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = StringArrayToVariantArray ( psastrSecureServerBindings, ppsavarSecureBindings );
|
|
|
|
Exit:
|
|
if ( psastrSecureServerBindings ) {
|
|
SafeArrayDestroy ( psastrSecureServerBindings );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SecureBindingsVariant( SAFEARRAY * psavarSecureBindings )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * psastrSecureServerBindings = NULL;
|
|
|
|
hr = VariantArrayToStringArray ( psavarSecureBindings, &psastrSecureServerBindings );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = put_SecureBindings ( psastrSecureServerBindings );
|
|
|
|
Exit:
|
|
if ( psastrSecureServerBindings ) {
|
|
SafeArrayDestroy ( psastrSecureServerBindings );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_Port( long * plPort )
|
|
{
|
|
return StdPropertyGet ( m_lPort, plPort );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_Port( long lPort )
|
|
{
|
|
return StdPropertyPut ( &m_lPort, lPort, &m_bvChangedFields, BitMask(ID_PORT));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SSLPort( long * plSSLPort )
|
|
{
|
|
return StdPropertyGet ( m_lSSLPort, plSSLPort );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SSLPort( long lSSLPort )
|
|
{
|
|
return StdPropertyPut ( &m_lSSLPort, lSSLPort, &m_bvChangedFields, BitMask(ID_SSLPORT));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_OutboundPort( long * plOutboundPort )
|
|
{
|
|
return StdPropertyGet ( m_lOutboundPort, plOutboundPort );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_OutboundPort( long lOutboundPort )
|
|
{
|
|
return StdPropertyPut ( &m_lOutboundPort, lOutboundPort, &m_bvChangedFields, BitMask(ID_OUTBOUNDPORT));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_HopCount( long * plHopCount )
|
|
{
|
|
return StdPropertyGet ( m_lHopCount, plHopCount );
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_HopCount( long lHopCount )
|
|
{
|
|
return StdPropertyPut ( &m_lHopCount, lHopCount, &m_bvChangedFields, BitMask(ID_HOP_COUNT));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SmartHost( BSTR * pstrSmartHost )
|
|
{
|
|
return StdPropertyGet ( m_strSmartHost, pstrSmartHost );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SmartHost( BSTR strSmartHost )
|
|
{
|
|
return StdPropertyPut ( &m_strSmartHost, strSmartHost, &m_bvChangedFields, BitMask(ID_SMARTHOST));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_EnableDNSLookup( BOOL * pfEnableDNSLookup )
|
|
{
|
|
return StdPropertyGet ( m_fEnableDNSLookup, pfEnableDNSLookup );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_EnableDNSLookup( BOOL fEnableDNSLookup )
|
|
{
|
|
return StdPropertyPut ( &m_fEnableDNSLookup, fEnableDNSLookup, &m_bvChangedFields, BitMask(ID_ENABLEDNSLOOKUP));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_PostmasterEmail( BSTR * pstrPostmasterEmail )
|
|
{
|
|
return StdPropertyGet ( m_strPostmasterEmail, pstrPostmasterEmail );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_PostmasterEmail( BSTR strPostmasterEmail )
|
|
{
|
|
return StdPropertyPut ( &m_strPostmasterEmail, strPostmasterEmail, &m_bvChangedFields, BitMask(ID_POSTMASTEREMAIL));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_PostmasterName( BSTR * pstrPostmasterName )
|
|
{
|
|
return StdPropertyGet ( m_strPostmasterName, pstrPostmasterName );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_PostmasterName( BSTR strPostmasterName )
|
|
{
|
|
return StdPropertyPut ( &m_strPostmasterName, strPostmasterName, &m_bvChangedFields, BitMask(ID_POSTMASTERNAME));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_DefaultDomain( BSTR * pstrDefaultDomain )
|
|
{
|
|
return StdPropertyGet ( m_strDefaultDomain, pstrDefaultDomain );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_DefaultDomain( BSTR strDefaultDomain )
|
|
{
|
|
return StdPropertyPut ( &m_strDefaultDomain, strDefaultDomain, &m_bvChangedFields, BitMask(ID_DEFAULTDOMAIN));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_FQDN( BSTR * pstrFQDN )
|
|
{
|
|
return StdPropertyGet ( m_strFQDN, pstrFQDN );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_FQDN( BSTR strFQDN )
|
|
{
|
|
return StdPropertyPut ( &m_strFQDN, strFQDN, &m_bvChangedFields, BitMask(ID_FQDN));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_DropDir( BSTR * pstrDropDir )
|
|
{
|
|
return StdPropertyGet ( m_strDropDir, pstrDropDir );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_DropDir( BSTR strDropDir )
|
|
{
|
|
return StdPropertyPut ( &m_strDropDir, strDropDir, &m_bvChangedFields, BitMask(ID_DROPDIR));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_BadMailDir( BSTR * pstrBadMailDir )
|
|
{
|
|
return StdPropertyGet ( m_strBadMailDir, pstrBadMailDir );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_BadMailDir( BSTR strBadMailDir )
|
|
{
|
|
return StdPropertyPut ( &m_strBadMailDir, strBadMailDir, &m_bvChangedFields, BitMask(ID_BADMAILDIR));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_PickupDir( BSTR * pstrPickupDir )
|
|
{
|
|
return StdPropertyGet ( m_strPickupDir, pstrPickupDir );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_PickupDir( BSTR strPickupDir )
|
|
{
|
|
return StdPropertyPut ( &m_strPickupDir, strPickupDir, &m_bvChangedFields, BitMask(ID_PICKUPDIR));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_QueueDir( BSTR * pstrQueueDir )
|
|
{
|
|
return StdPropertyGet ( m_strQueueDir, pstrQueueDir );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_QueueDir( BSTR strQueueDir )
|
|
{
|
|
return StdPropertyPut ( &m_strQueueDir, strQueueDir, &m_bvChangedFields, BitMask(ID_QUEUEDIR));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_MaxInConnection( long * plMaxInConnection )
|
|
{
|
|
return StdPropertyGet ( m_lMaxInConnection, plMaxInConnection );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_MaxInConnection( long lMaxInConnection )
|
|
{
|
|
return StdPropertyPut ( &m_lMaxInConnection, lMaxInConnection, &m_bvChangedFields, BitMask(ID_MAXINCONNECTION));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_MaxOutConnection( long * plMaxOutConnection )
|
|
{
|
|
return StdPropertyGet ( m_lMaxOutConnection, plMaxOutConnection );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_MaxOutConnection( long lMaxOutConnection )
|
|
{
|
|
return StdPropertyPut ( &m_lMaxOutConnection, lMaxOutConnection, &m_bvChangedFields, BitMask(ID_MAXOUTCONNECTION));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_InConnectionTimeout( long * plInConnectionTimeout )
|
|
{
|
|
return StdPropertyGet ( m_lInConnectionTimeout, plInConnectionTimeout );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_InConnectionTimeout( long lInConnectionTimeout )
|
|
{
|
|
return StdPropertyPut ( &m_lInConnectionTimeout, lInConnectionTimeout, &m_bvChangedFields, BitMask(ID_INCONNECTIONTIMEOUT));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_OutConnectionTimeout( long * plOutConnectionTimeout )
|
|
{
|
|
return StdPropertyGet ( m_lOutConnectionTimeout, plOutConnectionTimeout );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_OutConnectionTimeout( long lOutConnectionTimeout )
|
|
{
|
|
return StdPropertyPut ( &m_lOutConnectionTimeout, lOutConnectionTimeout, &m_bvChangedFields, BitMask(ID_OUTCONNECTIONTIMEOUT));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_MaxMessageSize( long * plMaxMessageSize )
|
|
{
|
|
return StdPropertyGet ( m_lMaxMessageSize, plMaxMessageSize );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_MaxMessageSize( long lMaxMessageSize )
|
|
{
|
|
return StdPropertyPut ( &m_lMaxMessageSize, lMaxMessageSize, &m_bvChangedFields, BitMask(ID_MAXMESSAGESIZE));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_MaxSessionSize( long * plMaxSessionSize )
|
|
{
|
|
return StdPropertyGet ( m_lMaxSessionSize, plMaxSessionSize );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_MaxSessionSize( long lMaxSessionSize )
|
|
{
|
|
return StdPropertyPut ( &m_lMaxSessionSize, lMaxSessionSize, &m_bvChangedFields, BitMask(ID_MAXSESSIONSIZE));
|
|
}
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_MaxMessageRecipients( long * plMaxMessageRecipients )
|
|
{
|
|
return StdPropertyGet ( m_lMaxMessageRecipients, plMaxMessageRecipients );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_MaxMessageRecipients( long lMaxMessageRecipients )
|
|
{
|
|
return StdPropertyPut ( &m_lMaxMessageRecipients, lMaxMessageRecipients, &m_bvChangedFields, BitMask(ID_MAXMESSAGERECIPIENTS));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LocalRetries( long * plLocalRetries )
|
|
{
|
|
return StdPropertyGet ( m_lLocalRetries, plLocalRetries );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LocalRetries( long lLocalRetries )
|
|
{
|
|
return StdPropertyPut ( &m_lLocalRetries, lLocalRetries, &m_bvChangedFields, BitMask(ID_LOCALRETRIES));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LocalRetryTime( long * plLocalRetryTime )
|
|
{
|
|
return StdPropertyGet ( m_lLocalRetryTime, plLocalRetryTime );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LocalRetryTime( long lLocalRetryTime )
|
|
{
|
|
return StdPropertyPut ( &m_lLocalRetryTime, lLocalRetryTime, &m_bvChangedFields, BitMask(ID_LOCALRETRYTIME));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RemoteRetries( long * plRemoteRetries )
|
|
{
|
|
return StdPropertyGet ( m_lRemoteRetries, plRemoteRetries );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RemoteRetries( long lRemoteRetries )
|
|
{
|
|
return StdPropertyPut ( &m_lRemoteRetries, lRemoteRetries, &m_bvChangedFields, BitMask(ID_REMOTERETRIES));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RemoteRetryTime( long * plRemoteRetryTime )
|
|
{
|
|
return StdPropertyGet ( m_lRemoteRetryTime, plRemoteRetryTime );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RemoteRetryTime( long lRemoteRetryTime )
|
|
{
|
|
return StdPropertyPut ( &m_lRemoteRetryTime, lRemoteRetryTime, &m_bvChangedFields, BitMask(ID_REMOTERETRYTIME));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_ETRNDays( long * plETRNDays )
|
|
{
|
|
return StdPropertyGet ( m_lETRNDays, plETRNDays );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_ETRNDays( long lETRNDays )
|
|
{
|
|
return StdPropertyPut ( &m_lETRNDays, lETRNDays, &m_bvChangedFields, BitMask(ID_ETRNDAYS));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SendDNRToPostmaster( BOOL * pfSendDNRToPostmaster )
|
|
{
|
|
return StdPropertyGet ( m_fSendDNRToPostmaster, pfSendDNRToPostmaster );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SendDNRToPostmaster( BOOL fSendDNRToPostmaster )
|
|
{
|
|
return StdPropertyPut ( &m_fSendDNRToPostmaster, fSendDNRToPostmaster, &m_bvChangedFields, BitMask(ID_SENDDNRTOPOSTMASTER));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SendBadmailToPostmaster( BOOL * pfSendBadmailToPostmaster)
|
|
{
|
|
return StdPropertyGet ( m_fSendBadmailToPostmaster, pfSendBadmailToPostmaster );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SendBadmailToPostmaster( BOOL fSendBadmailToPostmaster )
|
|
{
|
|
return StdPropertyPut ( &m_fSendBadmailToPostmaster, fSendBadmailToPostmaster, &m_bvChangedFields, BitMask(ID_SENDBADMAILTOPOSTMASTER));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RoutingDLL( BSTR * pstrRoutingDLL )
|
|
{
|
|
return StdPropertyGet ( m_strRoutingDLL, pstrRoutingDLL );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RoutingDLL( BSTR strRoutingDLL )
|
|
{
|
|
return StdPropertyPut ( &m_strRoutingDLL, strRoutingDLL, &m_bvChangedFields, BitMask(ID_ROUTINGDLL));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RoutingSources ( SAFEARRAY ** ppsastrRoutingSources )
|
|
{
|
|
return StdPropertyGet ( &m_mszRoutingSources, ppsastrRoutingSources );
|
|
}
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RoutingSources ( SAFEARRAY * psastrRoutingSources )
|
|
{
|
|
return StdPropertyPut ( &m_mszRoutingSources, psastrRoutingSources, &m_bvChangedFields, BitMask(ID_ROUTINGSOURCES) );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RoutingSourcesVariant( SAFEARRAY ** ppsavarRoutingSources )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * psastrRoutingSources = NULL;
|
|
|
|
hr = get_RoutingSources ( &psastrRoutingSources );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = StringArrayToVariantArray ( psastrRoutingSources, ppsavarRoutingSources );
|
|
|
|
Exit:
|
|
if ( psastrRoutingSources ) {
|
|
SafeArrayDestroy ( psastrRoutingSources );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RoutingSourcesVariant( SAFEARRAY * psavarRoutingSources )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * psastrRoutingSources = NULL;
|
|
|
|
hr = VariantArrayToStringArray ( psavarRoutingSources, &psastrRoutingSources );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = put_RoutingSources ( psastrRoutingSources );
|
|
|
|
Exit:
|
|
if ( psastrRoutingSources ) {
|
|
SafeArrayDestroy ( psastrRoutingSources );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LocalDomains ( SAFEARRAY ** ppsastrLocalDomains )
|
|
{
|
|
return StdPropertyGet ( &m_mszLocalDomains, ppsastrLocalDomains );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LocalDomains ( SAFEARRAY * psastrLocalDomains )
|
|
{
|
|
return StdPropertyPut ( &m_mszLocalDomains, psastrLocalDomains, &m_bvChangedFields, BitMask(ID_LOCALDOMAINS) );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_DomainRouting ( SAFEARRAY ** ppsastrDomainRouting )
|
|
{
|
|
return StdPropertyGet ( &m_mszDomainRouting, ppsastrDomainRouting );
|
|
}
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_DomainRouting ( SAFEARRAY * psastrDomainRouting )
|
|
{
|
|
return StdPropertyPut ( &m_mszDomainRouting, psastrDomainRouting, &m_bvChangedFields, BitMask(ID_DOMAINROUTING) );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_DomainRoutingVariant( SAFEARRAY ** ppsavarDomainRouting )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * pstrDomainRouting = NULL;
|
|
|
|
hr = get_DomainRouting ( &pstrDomainRouting );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = StringArrayToVariantArray ( pstrDomainRouting, ppsavarDomainRouting );
|
|
|
|
Exit:
|
|
if ( pstrDomainRouting ) {
|
|
SafeArrayDestroy ( pstrDomainRouting );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_DomainRoutingVariant( SAFEARRAY * psastrDomainRouting )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * pstrDomainRouting = NULL;
|
|
|
|
hr = VariantArrayToStringArray ( psastrDomainRouting, &pstrDomainRouting );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = put_DomainRouting ( pstrDomainRouting );
|
|
|
|
Exit:
|
|
if ( pstrDomainRouting ) {
|
|
SafeArrayDestroy ( pstrDomainRouting );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_MasqueradeDomain( BSTR * pstrMasqueradeDomain )
|
|
{
|
|
return StdPropertyGet ( m_strMasqueradeDomain, pstrMasqueradeDomain );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_MasqueradeDomain( BSTR strMasqueradeDomain )
|
|
{
|
|
return StdPropertyPut ( &m_strMasqueradeDomain, strMasqueradeDomain, &m_bvChangedFields, BitMask(ID_MASQUERADE));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SendNdrTo( BSTR * pstrAddr )
|
|
{
|
|
return StdPropertyGet( m_strNdrAddr, pstrAddr );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SendNdrTo( BSTR strAddr )
|
|
{
|
|
return StdPropertyPut ( &m_strNdrAddr, strAddr, &m_bvChangedFields, BitMask(ID_SENDNDRTO));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SendBadTo( BSTR * pstrAddr )
|
|
{
|
|
return StdPropertyGet( m_strBadAddr, pstrAddr );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SendBadTo( BSTR strAddr )
|
|
{
|
|
return StdPropertyPut ( &m_strBadAddr, strAddr, &m_bvChangedFields, BitMask(ID_SENDBADTO));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RemoteSecurePort( long * plRemoteSecurePort )
|
|
{
|
|
return StdPropertyGet( m_lRemoteSecurePort, plRemoteSecurePort );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RemoteSecurePort( long lRemoteSecurePort )
|
|
{
|
|
return StdPropertyPut ( &m_lRemoteSecurePort, lRemoteSecurePort, &m_bvChangedFields, BitMask(ID_REMOTE_SECURE_PORT));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_ShouldDeliver( BOOL * pfShouldDeliver )
|
|
{
|
|
return StdPropertyGet( m_fShouldDeliver, pfShouldDeliver );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_ShouldDeliver( BOOL fShouldDeliver )
|
|
{
|
|
return StdPropertyPut ( &m_fShouldDeliver, fShouldDeliver, &m_bvChangedFields, BitMask(ID_SHOULD_DELIVER));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_AlwaysUseSsl( BOOL * pfAlwaysUseSsl )
|
|
{
|
|
return StdPropertyGet( m_fAlwaysUseSsl, pfAlwaysUseSsl );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_AlwaysUseSsl( BOOL fAlwaysUseSsl )
|
|
{
|
|
return StdPropertyPut ( &m_fAlwaysUseSsl, fAlwaysUseSsl, &m_bvChangedFields, BitMask(ID_ALWAYS_USE_SSL));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LimitRemoteConnections( BOOL * pfLimitRemoteConnections )
|
|
{
|
|
return StdPropertyGet( m_fLimitRemoteConnections, pfLimitRemoteConnections );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LimitRemoteConnections( BOOL fLimitRemoteConnections )
|
|
{
|
|
return StdPropertyPut ( &m_fLimitRemoteConnections, fLimitRemoteConnections, &m_bvChangedFields, BitMask(ID_LIMIT_REMOTE_CONNECTIONS));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_MaxOutConnPerDomain( long * plMaxOutConnPerDomain )
|
|
{
|
|
return StdPropertyGet( m_lMaxOutConnPerDomain, plMaxOutConnPerDomain );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_MaxOutConnPerDomain( long lMaxOutConnPerDomain )
|
|
{
|
|
return StdPropertyPut ( &m_lMaxOutConnPerDomain, lMaxOutConnPerDomain, &m_bvChangedFields, BitMask(ID_MAX_OUT_CONN_PER_DOMAIN));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_AllowVerify( BOOL * pfAllowVerify )
|
|
{
|
|
return StdPropertyGet( m_fAllowVerify, pfAllowVerify );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_AllowVerify( BOOL fAllowVerify )
|
|
{
|
|
return StdPropertyPut ( &m_fAllowVerify, fAllowVerify, &m_bvChangedFields, BitMask(ID_ALLOW_VERIFY));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_AllowExpand( BOOL * pfAllowExpand )
|
|
{
|
|
return StdPropertyGet( m_fAllowExpand, pfAllowExpand);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_AllowExpand( BOOL fAllowExpand )
|
|
{
|
|
return StdPropertyPut ( &m_fAllowExpand, fAllowExpand, &m_bvChangedFields, BitMask(ID_ALLOW_EXPAND));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_SmartHostType( long * plSmartHostType )
|
|
{
|
|
return StdPropertyGet( m_lSmartHostType, plSmartHostType );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_SmartHostType( long lSmartHostType )
|
|
{
|
|
return StdPropertyPut ( &m_lSmartHostType, lSmartHostType, &m_bvChangedFields, BitMask(ID_SMART_HOST_TYPE));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_BatchMessages( BOOL * pfBatchMessages )
|
|
{
|
|
return StdPropertyGet( m_fBtachMsgs, pfBatchMessages );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_BatchMessages( BOOL fBatchMessages )
|
|
{
|
|
return StdPropertyPut ( &m_fBtachMsgs, fBatchMessages, &m_bvChangedFields, BitMask(ID_BATCH_MSGS));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_BatchMessageLimit( long * plBatchMessageLimit )
|
|
{
|
|
return StdPropertyGet( m_lBatchMsgLimit, plBatchMessageLimit );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_BatchMessageLimit( long lBatchMessageLimit )
|
|
{
|
|
return StdPropertyPut ( &m_lBatchMsgLimit, lBatchMessageLimit, &m_bvChangedFields, BitMask(ID_BATCH_MSG_LIMIT));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_DoMasquerade( BOOL * pfDoMasquerade )
|
|
{
|
|
return StdPropertyGet( m_fDoMasquerade, pfDoMasquerade );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_DoMasquerade( BOOL fDoMasquerade )
|
|
{
|
|
return StdPropertyPut ( &m_fDoMasquerade, fDoMasquerade, &m_bvChangedFields, BitMask(ID_DO_MASQUERADE));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_Administrators ( SAFEARRAY ** ppsastrAdmins )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::get_Administrators" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
|
|
if ( m_psaAdmins ) {
|
|
hr = SafeArrayCopy ( m_psaAdmins, ppsastrAdmins );
|
|
}
|
|
else {
|
|
*ppsastrAdmins = NULL;
|
|
hr = NOERROR;
|
|
}
|
|
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_Administrators ( SAFEARRAY * psastrAdmins )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::put_Administrators" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
|
|
if ( m_psaAdmins ) {
|
|
SafeArrayDestroy ( m_psaAdmins );
|
|
}
|
|
|
|
if ( psastrAdmins ) {
|
|
hr = SafeArrayCopy ( psastrAdmins, &m_psaAdmins );
|
|
}
|
|
else {
|
|
m_psaAdmins = NULL;
|
|
hr = NOERROR;
|
|
}
|
|
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_AdministratorsVariant( SAFEARRAY ** ppsavarAdmins )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * psastrAdmins = NULL;
|
|
|
|
hr = get_Administrators ( &psastrAdmins );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = StringArrayToVariantArray ( psastrAdmins, ppsavarAdmins );
|
|
|
|
Exit:
|
|
if ( psastrAdmins ) {
|
|
SafeArrayDestroy ( psastrAdmins );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_AdministratorsVariant( SAFEARRAY * psavarAdmins )
|
|
{
|
|
HRESULT hr;
|
|
SAFEARRAY * psastrAdmins = NULL;
|
|
|
|
hr = VariantArrayToStringArray ( psavarAdmins, &psastrAdmins );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = put_Administrators ( psastrAdmins );
|
|
|
|
Exit:
|
|
if ( psastrAdmins ) {
|
|
SafeArrayDestroy ( psastrAdmins );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_AuthenticationPackages(BSTR *pstrAuthPackages)
|
|
{
|
|
return StdPropertyGet(m_strAuthPackages, pstrAuthPackages);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_AuthenticationPackages(BSTR strAuthPackages)
|
|
{
|
|
return StdPropertyPut(&m_strAuthPackages, strAuthPackages, &m_bvChangedFields,
|
|
BitMask(ID_AUTH_PACKAGES));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_ClearTextAuthPackage(BSTR *pstrAuthPackages)
|
|
{
|
|
return StdPropertyGet(m_strClearTextAuthPackage, pstrAuthPackages);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_ClearTextAuthPackage(BSTR strAuthPackages)
|
|
{
|
|
return StdPropertyPut(&m_strClearTextAuthPackage, strAuthPackages, &m_bvChangedFields,
|
|
BitMask(ID_CLEARTEXT_AUTH_PACKAGE));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_AuthenticationMethod(long *plAuthMethod)
|
|
{
|
|
return StdPropertyGet(m_lAuthMethod, plAuthMethod);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_AuthenticationMethod(long lAuthMethod)
|
|
{
|
|
return StdPropertyPut(&m_lAuthMethod, lAuthMethod, &m_bvChangedFields,
|
|
BitMask(ID_AUTH_METHOD));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_DefaultLogonDomain(BSTR *pstrLogonDomain)
|
|
{
|
|
return StdPropertyGet(m_strDefaultLogonDomain, pstrLogonDomain);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_DefaultLogonDomain(BSTR strLogonDomain)
|
|
{
|
|
return StdPropertyPut(&m_strDefaultLogonDomain, strLogonDomain, &m_bvChangedFields,
|
|
BitMask(ID_DEFAULT_LOGON_DOMAIN));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RouteAction(long *plRouteAction)
|
|
{
|
|
return StdPropertyGet(m_lRouteAction, plRouteAction);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RouteAction(long lRouteAction)
|
|
{
|
|
return StdPropertyPut(&m_lRouteAction, lRouteAction, &m_bvChangedFields,
|
|
BitMask(ID_ROUTE_ACTION));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RouteUserName(BSTR *pstrRouteUserName)
|
|
{
|
|
return StdPropertyGet(m_strRouteUserName, pstrRouteUserName);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RouteUserName(BSTR strRouteUserName)
|
|
{
|
|
return StdPropertyPut(&m_strRouteUserName, strRouteUserName, &m_bvChangedFields,
|
|
BitMask(ID_ROUTE_USER_NAME));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_RoutePassword(BSTR *pstrRoutePassword)
|
|
{
|
|
return StdPropertyGet(m_strRoutePassword, pstrRoutePassword);
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_RoutePassword(BSTR strRoutePassword)
|
|
{
|
|
return StdPropertyPut(&m_strRoutePassword, strRoutePassword, &m_bvChangedFields,
|
|
BitMask(ID_ROUTE_PASSWORD));
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LogFileDirectory( BSTR * pstrLogFileDirectory )
|
|
{
|
|
return StdPropertyGet ( m_strLogFileDirectory, pstrLogFileDirectory );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LogFileDirectory( BSTR strLogFileDirectory )
|
|
{
|
|
return StdPropertyPut ( &m_strLogFileDirectory, strLogFileDirectory, &m_bvChangedFields, BitMask(ID_LOGFILEDIRECTORY));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LogFilePeriod( long * plLogFilePeriod )
|
|
{
|
|
return StdPropertyGet ( m_lLogFilePeriod, plLogFilePeriod );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LogFilePeriod( long lLogFilePeriod )
|
|
{
|
|
return StdPropertyPut ( &m_lLogFilePeriod, lLogFilePeriod, &m_bvChangedFields, BitMask(ID_LOGFILEPERIOD));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LogFileTruncateSize( long * plLogFileTruncateSize )
|
|
{
|
|
return StdPropertyGet ( m_lLogFileTruncateSize, plLogFileTruncateSize );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LogFileTruncateSize( long lLogFileTruncateSize )
|
|
{
|
|
return StdPropertyPut ( &m_lLogFileTruncateSize, lLogFileTruncateSize, &m_bvChangedFields, BitMask(ID_LOGFILETRUNCATESIZE));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LogMethod( long * plLogMethod )
|
|
{
|
|
return StdPropertyGet ( m_lLogMethod, plLogMethod );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LogMethod( long lLogMethod )
|
|
{
|
|
return StdPropertyPut ( &m_lLogMethod, lLogMethod, &m_bvChangedFields, BitMask(ID_LOGMETHOD));
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_LogType( long * plLogType )
|
|
{
|
|
return StdPropertyGet ( m_lLogType, plLogType );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_LogType( long lLogType )
|
|
{
|
|
return StdPropertyPut ( &m_lLogType, lLogType, &m_bvChangedFields, BitMask(ID_LOGTYPE));
|
|
}
|
|
|
|
|
|
//
|
|
// Service State Properties:
|
|
//
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_AutoStart ( BOOL * pfAutoStart )
|
|
{
|
|
return StdPropertyGet ( m_fAutoStart, pfAutoStart );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_AutoStart ( BOOL fAutoStart )
|
|
{
|
|
return StdPropertyPut ( &m_fAutoStart, fAutoStart, &m_bvChangedFields, BitMask(ID_AUTOSTART) );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_ServerState ( DWORD * pdwServerState )
|
|
{
|
|
return StdPropertyGet ( (long)m_dwServerState, (long *)pdwServerState );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_Win32ErrorCode ( long * plWin32ErrorCode )
|
|
{
|
|
return StdPropertyGet ( m_dwWin32ErrorCode, plWin32ErrorCode );
|
|
}
|
|
|
|
|
|
// Service-specific properties:
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_Comment( BSTR * pstrComment )
|
|
{
|
|
return StdPropertyGet ( m_strComment, pstrComment );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_Comment( BSTR strComment )
|
|
{
|
|
return StdPropertyPut ( &m_strComment, strComment, &m_bvChangedFields, BitMask(ID_COMMENT));
|
|
}
|
|
|
|
/*
|
|
STDMETHODIMP CSmtpAdminVirtualServer::get_ErrorControl ( BOOL * pfErrorControl )
|
|
{
|
|
return StdPropertyGet ( m_fErrorControl, pfErrorControl );
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::put_ErrorControl ( BOOL fErrorControl )
|
|
{
|
|
return StdPropertyPut ( &m_fErrorControl, fErrorControl );
|
|
}
|
|
*/
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
// Methods:
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::BackupRoutingTable( BSTR strPath )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::BackupRoutingTable" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
DWORD dwErr = NOERROR;
|
|
|
|
dwErr = SmtpBackupRoutingTable (
|
|
(LPWSTR) m_strServer,
|
|
(LPWSTR) strPath,
|
|
(int)m_dwServiceInstance );
|
|
|
|
if ( dwErr != 0 ) {
|
|
ErrorTraceX ( (LPARAM) this, "Failed to backup routing table: %x", dwErr );
|
|
SetLastError( dwErr );
|
|
hr = SmtpCreateExceptionFromWin32Error ( dwErr );
|
|
goto Exit;
|
|
}
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
|
|
//$-------------------------------------------------------------------
|
|
//
|
|
// CSmtpAdminVirtualServer::Get
|
|
//
|
|
// Description:
|
|
//
|
|
// Gets server properties from the metabase.
|
|
//
|
|
// Parameters:
|
|
//
|
|
// (property) m_strServer
|
|
// (property) m_dwServiceInstance - which SMTP to talk to.
|
|
//
|
|
// Returns:
|
|
//
|
|
// E_POINTER, DISP_E_EXCEPTION, E_OUTOFMEMORY or NOERROR.
|
|
//
|
|
//--------------------------------------------------------------------
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::Get ( )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::Get" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
CComPtr<IMSAdminBase> pmetabase;
|
|
CComObject<CServerBindings> * pBindings = NULL;
|
|
|
|
// Create the bindings collection:
|
|
m_pBindings.Release ();
|
|
|
|
hr = CComObject<CServerBindings>::CreateInstance ( &pBindings );
|
|
if ( FAILED(hr) ) {
|
|
FatalTrace ( (LPARAM) this, "Could not create bindings collection" );
|
|
goto Exit;
|
|
}
|
|
|
|
hr = pBindings->QueryInterface ( IID_IServerBindings, (void **) &m_pBindings );
|
|
_ASSERT ( SUCCEEDED(hr) );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
m_pPrivateBindings = pBindings;
|
|
|
|
|
|
// Validate Server & Service Instance:
|
|
|
|
// Talk to the metabase:
|
|
hr = m_mbFactory.GetMetabaseObject ( m_strServer, &pmetabase );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = GetPropertiesFromMetabase ( pmetabase );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
StateTrace ( 0, "Successfully got service properties" );
|
|
m_fGotProperties = TRUE;
|
|
m_bvChangedFields = 0;
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
|
|
return hr;
|
|
|
|
// CComPtr automatically releases the metabase handle.
|
|
}
|
|
|
|
//$-------------------------------------------------------------------
|
|
//
|
|
// CSmtpAdminVirtualServer::Set
|
|
//
|
|
// Description:
|
|
//
|
|
// Sends server properties to the metabase.
|
|
//
|
|
// Parameters:
|
|
//
|
|
// (property) m_strServer
|
|
// fFailIfChanged - return an error if the metabase has changed?
|
|
//
|
|
// Returns:
|
|
//
|
|
// E_POINTER, DISP_E_EXCEPTION, E_OUTOFMEMORY or NOERROR.
|
|
//
|
|
//--------------------------------------------------------------------
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::Set ( BOOL fFailIfChanged )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::Set" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
CComPtr<IMSAdminBase> pmetabase;
|
|
|
|
|
|
// Make sure the client call Get first:
|
|
if ( !m_fGotProperties ) {
|
|
ErrorTrace ( 0, "Didn't call get first" );
|
|
|
|
hr = SmtpCreateException ( IDS_SMTPEXCEPTION_DIDNT_CALL_GET );
|
|
goto Exit;
|
|
}
|
|
|
|
// Validate Server & Service Instance:
|
|
if ( m_dwServiceInstance == 0 ) {
|
|
return SmtpCreateException ( IDS_SMTPEXCEPTION_SERVICE_INSTANCE_CANT_BE_ZERO );
|
|
}
|
|
|
|
if ( !m_fGotProperties ) {
|
|
return SmtpCreateException ( IDS_SMTPEXCEPTION_DIDNT_CALL_GET );
|
|
}
|
|
|
|
// Validate data members:
|
|
if ( !ValidateStrings () ) {
|
|
hr = E_OUTOFMEMORY;
|
|
goto Exit;
|
|
}
|
|
|
|
if ( !ValidateProperties ( ) ) {
|
|
hr = SmtpCreateExceptionFromWin32Error ( ERROR_INVALID_PARAMETER );
|
|
goto Exit;
|
|
}
|
|
|
|
hr = m_mbFactory.GetMetabaseObject ( m_strServer, &pmetabase );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = SendPropertiesToMetabase ( fFailIfChanged, pmetabase );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
StateTrace ( 0, "Successfully set service properties" );
|
|
|
|
// successfully saved, reset change field bitmap
|
|
m_bvChangedFields = 0;
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
|
|
#define MAX_SLEEP_INST 30000
|
|
#define SLEEP_INTERVAL 500
|
|
|
|
HRESULT CSmtpAdminVirtualServer::ControlService (
|
|
IMSAdminBase * pMetabase,
|
|
DWORD ControlCode,
|
|
DWORD dwDesiredState,
|
|
DWORD dwPendingState
|
|
)
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::ControlService" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
DWORD dwCurrentState = dwPendingState;
|
|
DWORD dwOldState = dwPendingState;
|
|
DWORD dwSleepTotal = 0;
|
|
|
|
hr = CheckServiceState ( pMetabase, &dwCurrentState );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
if ( dwCurrentState == dwDesiredState ) {
|
|
// Nothing to do...
|
|
goto Exit;
|
|
}
|
|
|
|
dwOldState = dwCurrentState;
|
|
|
|
//
|
|
// Special case: trying to start a paused service:
|
|
//
|
|
|
|
if ( dwDesiredState == MD_SERVER_STATE_STARTED &&
|
|
dwCurrentState == MD_SERVER_STATE_PAUSED ) {
|
|
|
|
ControlCode = MD_SERVER_COMMAND_CONTINUE;
|
|
dwPendingState = MD_SERVER_STATE_CONTINUING;
|
|
}
|
|
|
|
hr = WriteStateCommand ( pMetabase, ControlCode );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
for(dwSleepTotal = 0, dwCurrentState = dwPendingState;
|
|
(dwCurrentState == dwPendingState || dwCurrentState == dwOldState) && (dwSleepTotal < MAX_SLEEP_INST);
|
|
dwSleepTotal += SLEEP_INTERVAL
|
|
)
|
|
{
|
|
Sleep ( SLEEP_INTERVAL );
|
|
|
|
hr = CheckServiceState ( pMetabase, &dwCurrentState );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
if ( m_dwWin32ErrorCode != NOERROR ) {
|
|
//
|
|
// The service gave an error code.
|
|
//
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
if ( dwSleepTotal >= MAX_SLEEP_INST ) {
|
|
hr = HRESULT_FROM_WIN32 ( ERROR_SERVICE_REQUEST_TIMEOUT );
|
|
goto Exit;
|
|
}
|
|
|
|
Exit:
|
|
// m_State = TranslateServerState ( dwCurrentState );
|
|
|
|
m_dwServerState = dwCurrentState;
|
|
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
HRESULT CSmtpAdminVirtualServer::WriteStateCommand ( IMSAdminBase * pMetabase, DWORD ControlCode )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
CMetabaseKey metabase ( pMetabase );
|
|
BOOL fRet = TRUE;
|
|
TCHAR szInstancePath [ METADATA_MAX_NAME_LEN ];
|
|
|
|
GetMDInstancePath ( szInstancePath, m_dwServiceInstance );
|
|
|
|
hr = metabase.Open ( szInstancePath, METADATA_PERMISSION_WRITE );
|
|
if( FAILED(hr) )
|
|
{
|
|
hr = SmtpCreateExceptionFromWin32Error( GetLastError() );
|
|
goto Exit;
|
|
}
|
|
|
|
fRet = fRet && StdPutMetabaseProp ( &metabase, MD_WIN32_ERROR, NOERROR, _T(""), IIS_MD_UT_SERVER, METADATA_VOLATILE );
|
|
fRet = fRet && StdPutMetabaseProp ( &metabase, MD_SERVER_COMMAND, ControlCode );
|
|
if ( !fRet ) {
|
|
hr = SmtpCreateExceptionFromWin32Error ( GetLastError () );
|
|
goto Exit;
|
|
}
|
|
|
|
Exit:
|
|
return hr;
|
|
}
|
|
|
|
HRESULT CSmtpAdminVirtualServer::CheckServiceState ( IMSAdminBase * pMetabase, DWORD * pdwState )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
CMetabaseKey metabase ( pMetabase );
|
|
TCHAR szInstancePath [ METADATA_MAX_NAME_LEN ];
|
|
BOOL fRet = TRUE;
|
|
|
|
*pdwState = MD_SERVER_STATE_INVALID;
|
|
|
|
GetMDInstancePath ( szInstancePath, m_dwServiceInstance );
|
|
hr = metabase.Open ( szInstancePath );
|
|
if( FAILED(hr) )
|
|
{
|
|
hr = SmtpCreateExceptionFromWin32Error( GetLastError() );
|
|
goto Exit;
|
|
}
|
|
|
|
fRet = metabase.GetDword ( MD_WIN32_ERROR, &m_dwWin32ErrorCode );
|
|
fRet = metabase.GetDword ( MD_SERVER_STATE, pdwState );
|
|
|
|
Exit:
|
|
if ( !fRet ) {
|
|
hr = HRESULT_FROM_WIN32( GetLastError () );
|
|
}
|
|
return hr;
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::Start ( )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::Start" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
CComPtr<IMSAdminBase> pmetabase;
|
|
|
|
hr = m_mbFactory.GetMetabaseObject ( m_strServer, &pmetabase );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = ControlService (
|
|
pmetabase,
|
|
MD_SERVER_COMMAND_START,
|
|
MD_SERVER_STATE_STARTED,
|
|
MD_SERVER_STATE_STARTING
|
|
);
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::Pause ( )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::Pause" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
CComPtr<IMSAdminBase> pmetabase;
|
|
|
|
hr = m_mbFactory.GetMetabaseObject ( m_strServer, &pmetabase );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = ControlService (
|
|
pmetabase,
|
|
MD_SERVER_COMMAND_PAUSE,
|
|
MD_SERVER_STATE_PAUSED,
|
|
MD_SERVER_STATE_PAUSING
|
|
);
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::Continue ( )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::Pause" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
CComPtr<IMSAdminBase> pmetabase;
|
|
|
|
hr = m_mbFactory.GetMetabaseObject ( m_strServer, &pmetabase );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = ControlService (
|
|
pmetabase,
|
|
MD_SERVER_COMMAND_CONTINUE,
|
|
MD_SERVER_STATE_STARTED,
|
|
MD_SERVER_STATE_CONTINUING
|
|
);
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
STDMETHODIMP CSmtpAdminVirtualServer::Stop ( )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::Start" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
CComPtr<IMSAdminBase> pmetabase;
|
|
|
|
hr = m_mbFactory.GetMetabaseObject ( m_strServer, &pmetabase );
|
|
if ( FAILED(hr) ) {
|
|
goto Exit;
|
|
}
|
|
|
|
hr = ControlService (
|
|
pmetabase,
|
|
MD_SERVER_COMMAND_STOP,
|
|
MD_SERVER_STATE_STOPPED,
|
|
MD_SERVER_STATE_STOPPING
|
|
);
|
|
|
|
Exit:
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
}
|
|
|
|
|
|
//$-------------------------------------------------------------------
|
|
//
|
|
// CSmtpAdminVirtualServer::GetPropertiesFromMetabase
|
|
//
|
|
// Description:
|
|
//
|
|
// Asks the metabase for each property in this class.
|
|
// This class's properties come from /LM/SmtpSvc/
|
|
//
|
|
// Parameters:
|
|
//
|
|
// pMetabase - The metabase object
|
|
//
|
|
// Returns:
|
|
//
|
|
//
|
|
//--------------------------------------------------------------------
|
|
|
|
HRESULT CSmtpAdminVirtualServer::GetPropertiesFromMetabase ( IMSAdminBase * pMetabase )
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::GetPropertiesFromMetabase" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
CMetabaseKey metabase ( pMetabase );
|
|
BOOL fRet = TRUE;
|
|
|
|
TCHAR szInstancePath [ METADATA_MAX_NAME_LEN ];
|
|
WCHAR wszDefaultComment[128]={0};
|
|
|
|
PSECURITY_DESCRIPTOR pSD = NULL;
|
|
DWORD cbSD = 0;
|
|
|
|
GetMDInstancePath ( szInstancePath, m_dwServiceInstance );
|
|
wsprintfW( wszDefaultComment, L"[SMTP Virtual Server #%d]", m_dwServiceInstance );
|
|
|
|
hr = metabase.Open ( szInstancePath );
|
|
if( FAILED(hr) )
|
|
{
|
|
hr = SmtpCreateExceptionFromWin32Error( GetLastError() );
|
|
goto Exit;
|
|
}
|
|
|
|
// Overridable server properties:
|
|
|
|
hr = m_RoutingSource.Get(&metabase);
|
|
BAIL_ON_FAILURE(hr);
|
|
#if 0
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SECURE_PORT, DEFAULT_SSLPORT, &m_lSSLPort ) && fRet;
|
|
#endif
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_REMOTE_SMTP_PORT, DEFAULT_OUTBOND_PORT, &m_lOutboundPort ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SMARTHOST_NAME, DEFAULT_SMART_HOST, &m_strSmartHost ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_HOP_COUNT, DEFAULT_HOP_COUNT, &m_lHopCount ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_REVERSE_NAME_LOOKUP,DEFAULT_ENABLE_DNS_LOOKUP, &m_fEnableDNSLookup ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_POSTMASTER_EMAIL, DEFAULT_POSTMASTER_EMAIL, &m_strPostmasterEmail ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_POSTMASTER_NAME, DEFAULT_POSTMASTER_NAME, &m_strPostmasterName ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_FQDN_VALUE, DEFAULT_FQDN, &m_strFQDN ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_DEFAULT_DOMAIN_VALUE, DEFAULT_DEFAULT_DOMAIN, &m_strDefaultDomain ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAIL_DROP_DIR, DEFAULT_DROP_DIR, &m_strDropDir ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_BAD_MAIL_DIR, DEFAULT_BADMAIL_DIR, &m_strBadMailDir ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAIL_PICKUP_DIR, DEFAULT_PICKUP_DIR, &m_strPickupDir ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAIL_QUEUE_DIR, DEFAULT_QUEUE_DIR, &m_strQueueDir ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAX_OUTBOUND_CONNECTION, DEFAULT_MAX_OUT_CONNECTION, &m_lMaxOutConnection ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_REMOTE_TIMEOUT, DEFAULT_OUT_CONNECTION_TIMEOUT, &m_lOutConnectionTimeout ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAX_MSG_SIZE, DEFAULT_MAX_MESSAGE_SIZE, &m_lMaxMessageSize ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAX_MSG_SIZE_B4_CLOSE, DEFAULT_MAX_SESSION_SIZE, &m_lMaxSessionSize ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAX_RECIPIENTS, DEFAULT_MAX_MESSAGE_RECIPIENTS, &m_lMaxMessageRecipients ) && fRet;
|
|
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_LOCAL_RETRY_ATTEMPTS, DEFAULT_LOCAL_RETRIES, &m_lLocalRetries) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_LOCAL_RETRY_MINUTES, DEFAULT_LOCAL_RETRY_TIME, &m_lLocalRetryTime) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_REMOTE_RETRY_ATTEMPTS, DEFAULT_REMOTE_RETRIES, &m_lRemoteRetries) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_REMOTE_RETRY_MINUTES, DEFAULT_REMOTE_RETRY_TIME, &m_lRemoteRetryTime) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_ETRN_DAYS, DEFAULT_ETRN_DAYS, &m_lETRNDays) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_ROUTING_DLL, DEFAULT_ROUTING_DLL, &m_strRoutingDLL) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_ROUTING_SOURCES, DEFAULT_ROUTING_SOURCES, &m_mszRoutingSources) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_LOCAL_DOMAINS, DEFAULT_LOCAL_DOMAINS, &m_mszLocalDomains) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_DOMAIN_ROUTING, DEFAULT_DOMAIN_ROUTING, &m_mszDomainRouting) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MASQUERADE_NAME, DEFAULT_MASQUERADE_DOMAIN, &m_strMasqueradeDomain) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SEND_NDR_TO, DEFAULT_SENDNDRTO, &m_strNdrAddr) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SEND_BAD_TO, DEFAULT_SENDBADTO, &m_strBadAddr) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_REMOTE_SECURE_PORT, DEFAULT_REMOTE_SECURE_PORT, &m_lRemoteSecurePort) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SHOULD_DELIVER, DEFAULT_SHOULD_DELIVER, &m_fShouldDeliver ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_ALWAYS_USE_SSL, DEFAULT_ALWAYS_USE_SSL, &m_fAlwaysUseSsl ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_LIMIT_REMOTE_CONNECTIONS, DEFAULT_LIMIT_REMOTE_CONNECTIONS, &m_fLimitRemoteConnections ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAX_OUT_CONN_PER_DOMAIN, DEFAULT_MAX_OUT_CONN_PER_DOMAIN, &m_lMaxOutConnPerDomain ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SMARTHOST_TYPE, DEFAULT_SMART_HOST_TYPE, &m_lSmartHostType ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_BATCH_MSG_LIMIT, DEFAULT_BATCH_MSG_LIMIT, &m_lBatchMsgLimit ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_DO_MASQUERADE, DEFAULT_DO_MASQUERADE, &m_fDoMasquerade ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_ROUTE_ACTION, DEFAULT_ROUTE_ACTION, &m_lRouteAction ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_ROUTE_USER_NAME, DEFAULT_ROUTE_USER_NAME, &m_strRouteUserName ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_ROUTE_PASSWORD, DEFAULT_ROUTE_PASSWORD, &m_strRoutePassword ) && fRet;
|
|
|
|
//
|
|
// IIS common propperties
|
|
//
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SERVER_BINDINGS, DEFAULT_SERVER_BINDINGS, &m_mszServerBindings ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SECURE_BINDINGS, DEFAULT_SECURE_BINDINGS, &m_mszSecureBindings ) && fRet;
|
|
// fRet = StdGetMetabaseProp ( &metabase, MD_PORT, DEFAULT_PORT, &m_lPort ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_MAX_CONNECTIONS, DEFAULT_MAX_IN_CONNECTION, &m_lMaxInConnection ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_CONNECTION_TIMEOUT,DEFAULT_IN_CONNECTION_TIMEOUT, &m_lInConnectionTimeout ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_NTAUTHENTICATION_PROVIDERS, DEFAULT_AUTH_PACKAGES, &m_strAuthPackages) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SMTP_CLEARTEXT_AUTH_PROVIDER, DEFAULT_CLEARTEXT_AUTH_PACKAGE, &m_strClearTextAuthPackage) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_AUTHORIZATION, DEFAULT_AUTHENTICATION, &m_lAuthMethod) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SASL_LOGON_DOMAIN, DEFAULT_LOGON_DOMAIN, &m_strDefaultLogonDomain) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_LOGFILE_DIRECTORY, DEFAULT_LOGFILE_DIRECTORY, &m_strLogFileDirectory) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_LOGFILE_PERIOD, DEFAULT_LOGFILE_PERIOD, &m_lLogFilePeriod) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_LOGFILE_TRUNCATE_SIZE,DEFAULT_LOGFILE_TRUNCATE_SIZE, &m_lLogFileTruncateSize) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_LOG_TYPE, DEFAULT_LOG_TYPE, &m_lLogType) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SERVER_AUTOSTART, DEFAULT_AUTOSTART, &m_fAutoStart ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SERVER_COMMENT, wszDefaultComment, &m_strComment ) && fRet;
|
|
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_SERVER_STATE, MD_SERVER_STATE_STOPPED, &m_dwServerState ) && fRet;
|
|
fRet = StdGetMetabaseProp ( &metabase, MD_WIN32_ERROR, NOERROR, &m_dwWin32ErrorCode ) && fRet;
|
|
|
|
// Get the admin ACL
|
|
pSD = NULL;
|
|
cbSD = 0;
|
|
|
|
hr = metabase.GetDataSize ( _T(""), MD_ADMIN_ACL, BINARY_METADATA, &cbSD );
|
|
if( SUCCEEDED(hr) )
|
|
{
|
|
_ASSERT ( cbSD != 0 );
|
|
pSD = (PSECURITY_DESCRIPTOR) new char [ cbSD ];
|
|
|
|
if( NULL == pSD )
|
|
{
|
|
hr = E_OUTOFMEMORY;
|
|
goto Exit;
|
|
}
|
|
|
|
hr = NOERROR;
|
|
hr = metabase.GetBinary ( MD_ADMIN_ACL, pSD, cbSD );
|
|
BAIL_ON_FAILURE(hr);
|
|
}
|
|
|
|
//
|
|
// Get the tcp access restrictions:
|
|
//
|
|
|
|
hr = m_pPrivateIpAccess->GetFromMetabase ( &metabase );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
// Check all property strings:
|
|
// If any string is NULL, it is because we failed to allocate memory:
|
|
if ( !ValidateStrings () ) {
|
|
|
|
hr = E_OUTOFMEMORY;
|
|
goto Exit;
|
|
}
|
|
|
|
// We can only fail from memory allocations:
|
|
_ASSERT ( fRet );
|
|
|
|
// Save the last changed time for this key:
|
|
m_ftLastChanged.dwHighDateTime = 0;
|
|
m_ftLastChanged.dwLowDateTime = 0;
|
|
|
|
hr = pMetabase->GetLastChangeTime ( metabase.QueryHandle(), _T(""), &m_ftLastChanged, FALSE );
|
|
if ( FAILED (hr) ) {
|
|
ErrorTraceX ( (LPARAM) this, "Failed to get last change time: %x", hr );
|
|
// Ignore this error.
|
|
hr = NOERROR;
|
|
}
|
|
|
|
// Extract the bindings:
|
|
hr = MDBindingsToIBindings ( &m_mszServerBindings, TRUE, m_pBindings );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
hr = MDBindingsToIBindings ( &m_mszSecureBindings, FALSE, m_pBindings );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
// Extract the Administrator list:
|
|
if ( m_psaAdmins ) {
|
|
SafeArrayDestroy ( m_psaAdmins );
|
|
m_psaAdmins = NULL;
|
|
}
|
|
if ( pSD ) {
|
|
hr = AclToAdministrators ( m_strServer, pSD, &m_psaAdmins );
|
|
BAIL_ON_FAILURE(hr);
|
|
}
|
|
|
|
// Validate the data received from the metabase:
|
|
_ASSERT ( ValidateStrings () );
|
|
_ASSERT ( ValidateProperties( ) );
|
|
|
|
if ( !ValidateProperties( ) ) {
|
|
CorrectProperties ();
|
|
}
|
|
|
|
Exit:
|
|
delete (char*) pSD;
|
|
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
|
|
// CMetabaseKey automatically closes its handle
|
|
}
|
|
|
|
//$-------------------------------------------------------------------
|
|
//
|
|
// CSmtpAdminVirtualServer::SendPropertiesToMetabase
|
|
//
|
|
// Description:
|
|
//
|
|
// Saves each property to the metabase.
|
|
// This class's properties go into /LM/SmtpSvc/
|
|
//
|
|
// Parameters:
|
|
//
|
|
// fFailIfChanged - Return a failure code if the metabase
|
|
// has changed since last get.
|
|
// pMetabase - the metabase object.
|
|
//
|
|
// Returns:
|
|
//
|
|
//
|
|
//--------------------------------------------------------------------
|
|
|
|
HRESULT CSmtpAdminVirtualServer::SendPropertiesToMetabase (
|
|
BOOL fFailIfChanged,
|
|
IMSAdminBase * pMetabase
|
|
)
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::SendPropertiesToMetabase" );
|
|
|
|
HRESULT hr = NOERROR;
|
|
CMetabaseKey metabase ( pMetabase );
|
|
BOOL fRet = TRUE;
|
|
TCHAR szInstancePath [ METADATA_MAX_NAME_LEN ];
|
|
|
|
//
|
|
// Set the admin acl:
|
|
//
|
|
|
|
PSECURITY_DESCRIPTOR pSD = NULL;
|
|
DWORD cbSD = 0;
|
|
|
|
// if ( m_bvChangedFields & CHNG_ADMINACL ) {
|
|
if ( m_psaAdmins ) {
|
|
hr = AdministratorsToAcl ( m_strServer, m_psaAdmins, &pSD, &cbSD );
|
|
BAIL_ON_FAILURE(hr);
|
|
}
|
|
// }
|
|
|
|
|
|
// Open metabase key
|
|
GetMDInstancePath ( szInstancePath, m_dwServiceInstance );
|
|
hr = metabase.Open ( szInstancePath, METADATA_PERMISSION_WRITE );
|
|
if ( FAILED(hr) ) {
|
|
ErrorTraceX ( (LPARAM) this, "Failed to open instance key, %x", GetLastError() );
|
|
|
|
// !!!magnush - Should we return a simple Service doesn't exist error code?
|
|
hr = SmtpCreateExceptionFromWin32Error ( GetLastError () );
|
|
goto Exit;
|
|
}
|
|
|
|
// Does the client care if the key has changed?
|
|
if ( fFailIfChanged ) {
|
|
|
|
// Did the key change?
|
|
if ( HasKeyChanged ( pMetabase, metabase.QueryHandle(), &m_ftLastChanged ) ) {
|
|
|
|
StateTrace ( (LPARAM) this, "Metabase has changed, not setting properties" );
|
|
// !!!magnush - Return the appropriate error code:
|
|
hr = E_FAIL;
|
|
goto Exit;
|
|
}
|
|
}
|
|
|
|
// Extract the bindings:
|
|
if( !(m_bvChangedFields & BitMask(ID_SERVER_BINDINGS)) )
|
|
{
|
|
hr = IBindingsToMDBindings ( m_pBindings, TRUE, &m_mszServerBindings );
|
|
BAIL_ON_FAILURE(hr);
|
|
m_bvChangedFields |= BitMask(ID_SERVER_BINDINGS);
|
|
}
|
|
|
|
if( !(m_bvChangedFields & BitMask(ID_SECURE_BINDINGS)) )
|
|
{
|
|
hr = IBindingsToMDBindings ( m_pBindings, FALSE, &m_mszSecureBindings );
|
|
BAIL_ON_FAILURE(hr);
|
|
m_bvChangedFields |= BitMask(ID_SECURE_BINDINGS);
|
|
}
|
|
|
|
//
|
|
// The general procedure here is to keep setting metabase properties
|
|
// as long as nothing has gone wrong. This is done by short-circuiting
|
|
// the statement by ANDing it with the status code. This makes the code
|
|
// much more concise.
|
|
//
|
|
|
|
fRet = TRUE;
|
|
|
|
// Overridable server properties:
|
|
hr = m_RoutingSource.Set(&metabase);
|
|
BAIL_ON_FAILURE(hr);
|
|
#if 0
|
|
if ( m_bvChangedFields & BitMask(ID_SSLPORT) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_SECURE_PORT, m_lSSLPort ) && fRet;
|
|
}
|
|
#endif
|
|
if ( m_bvChangedFields & BitMask(ID_OUTBOUNDPORT) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_REMOTE_SMTP_PORT, m_lOutboundPort ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_HOP_COUNT) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_HOP_COUNT, m_lHopCount ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_SMARTHOST) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_SMARTHOST_NAME, m_strSmartHost ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_ENABLEDNSLOOKUP) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_REVERSE_NAME_LOOKUP,m_fEnableDNSLookup ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_POSTMASTEREMAIL) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_POSTMASTER_EMAIL, m_strPostmasterEmail ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_POSTMASTERNAME) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_POSTMASTER_NAME, m_strPostmasterName ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_FQDN) )
|
|
{
|
|
if( m_strFQDN.m_str && m_strFQDN.m_str[0] )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_FQDN_VALUE, m_strFQDN ) && fRet;
|
|
}
|
|
else
|
|
{
|
|
if( !metabase.DeleteData( _T(""), MD_FQDN_VALUE, STRING_METADATA ) )
|
|
{
|
|
// not an error if data not exists on the instance level
|
|
fRet = fRet && ( GetLastError() == MD_ERROR_DATA_NOT_FOUND );
|
|
}
|
|
}
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_DEFAULTDOMAIN) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_DEFAULT_DOMAIN_VALUE, m_strDefaultDomain ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_DROPDIR) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAIL_DROP_DIR, m_strDropDir ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_BADMAILDIR) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_BAD_MAIL_DIR, m_strBadMailDir ) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_PICKUPDIR) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAIL_PICKUP_DIR, m_strPickupDir ) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_QUEUEDIR) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAIL_QUEUE_DIR, m_strQueueDir ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_MAXOUTCONNECTION) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAX_OUTBOUND_CONNECTION, m_lMaxOutConnection ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_OUTCONNECTIONTIMEOUT) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_REMOTE_TIMEOUT, m_lOutConnectionTimeout ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_MAXMESSAGESIZE) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAX_MSG_SIZE, m_lMaxMessageSize ) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_MAXSESSIONSIZE) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAX_MSG_SIZE_B4_CLOSE, m_lMaxSessionSize ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_MAXMESSAGERECIPIENTS) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAX_RECIPIENTS, m_lMaxMessageRecipients ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_LOCALRETRYTIME) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_LOCAL_RETRY_MINUTES, m_lLocalRetryTime) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_REMOTERETRYTIME) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_REMOTE_RETRY_MINUTES, m_lRemoteRetryTime) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_ETRNDAYS) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_ETRN_DAYS, m_lETRNDays) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_ROUTINGDLL) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_ROUTING_DLL, m_strRoutingDLL) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_ROUTINGSOURCES) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_ROUTING_SOURCES, &m_mszRoutingSources) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_LOCALDOMAINS) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_LOCAL_DOMAINS, &m_mszLocalDomains) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_DOMAINROUTING) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_DOMAIN_ROUTING, &m_mszDomainRouting) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_LOCALRETRIES) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_LOCAL_RETRY_ATTEMPTS, m_lLocalRetries) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_REMOTERETRIES) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_REMOTE_RETRY_ATTEMPTS, m_lRemoteRetries) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_MASQUERADE) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MASQUERADE_NAME, m_strMasqueradeDomain) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_SENDNDRTO) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_SEND_NDR_TO, m_strNdrAddr) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_SENDBADTO) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_SEND_BAD_TO, m_strBadAddr) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_REMOTE_SECURE_PORT) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_REMOTE_SECURE_PORT, m_lRemoteSecurePort) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_SHOULD_DELIVER) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_SHOULD_DELIVER, m_fShouldDeliver) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_ALWAYS_USE_SSL) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_ALWAYS_USE_SSL, m_fAlwaysUseSsl) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_LIMIT_REMOTE_CONNECTIONS) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_LIMIT_REMOTE_CONNECTIONS, m_fLimitRemoteConnections) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_MAX_OUT_CONN_PER_DOMAIN) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAX_OUT_CONN_PER_DOMAIN, m_lMaxOutConnPerDomain) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_SMART_HOST_TYPE) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_SMARTHOST_TYPE, m_lSmartHostType) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_BATCH_MSG_LIMIT) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_BATCH_MSG_LIMIT, m_lBatchMsgLimit) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_DO_MASQUERADE) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_DO_MASQUERADE, m_fDoMasquerade) && fRet;
|
|
}
|
|
|
|
// outbound security
|
|
if ( m_bvChangedFields & BitMask(ID_ROUTE_ACTION) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_ROUTE_ACTION, m_lRouteAction) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_ROUTE_USER_NAME) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_ROUTE_USER_NAME, m_strRouteUserName) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_ROUTE_PASSWORD) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_ROUTE_PASSWORD, m_strRoutePassword) && fRet;
|
|
}
|
|
|
|
//
|
|
// IIS common properties
|
|
//
|
|
if ( m_bvChangedFields & BitMask(ID_SERVER_BINDINGS) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_SERVER_BINDINGS, &m_mszServerBindings ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_SECURE_BINDINGS) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_SECURE_BINDINGS, &m_mszSecureBindings ) && fRet;
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_MAXINCONNECTION) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_MAX_CONNECTIONS, m_lMaxInConnection ) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_INCONNECTIONTIMEOUT) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_CONNECTION_TIMEOUT,m_lInConnectionTimeout ) && fRet;
|
|
}
|
|
|
|
if (m_bvChangedFields & BitMask(ID_AUTH_PACKAGES))
|
|
{
|
|
fRet = fRet && StdPutMetabaseProp(&metabase, MD_NTAUTHENTICATION_PROVIDERS, m_strAuthPackages);
|
|
}
|
|
|
|
if (m_bvChangedFields & BitMask(ID_CLEARTEXT_AUTH_PACKAGE))
|
|
{
|
|
fRet = fRet && StdPutMetabaseProp(&metabase, MD_SMTP_CLEARTEXT_AUTH_PROVIDER, m_strClearTextAuthPackage);
|
|
}
|
|
|
|
if (m_bvChangedFields & BitMask(ID_AUTH_METHOD))
|
|
{
|
|
fRet = fRet && StdPutMetabaseProp(&metabase, MD_AUTHORIZATION, m_lAuthMethod);
|
|
}
|
|
|
|
if (m_bvChangedFields & BitMask(ID_DEFAULT_LOGON_DOMAIN))
|
|
{
|
|
fRet = fRet && StdPutMetabaseProp(&metabase, MD_SASL_LOGON_DOMAIN, m_strDefaultLogonDomain);
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_LOGFILEDIRECTORY) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_LOGFILE_DIRECTORY, m_strLogFileDirectory) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_LOGFILEPERIOD) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_LOGFILE_PERIOD, m_lLogFilePeriod) && fRet;
|
|
}
|
|
if ( m_bvChangedFields & BitMask(ID_LOGFILETRUNCATESIZE) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_LOGFILE_TRUNCATE_SIZE, m_lLogFileTruncateSize) && fRet;
|
|
}
|
|
// if ( m_bvChangedFields & BitMask(ID_LOGMETHOD) )
|
|
// {
|
|
// fRet = StdPutMetabaseProp ( &metabase, MD_LOG_TYPE, m_lLogMethod) && fRet;
|
|
// }
|
|
if ( m_bvChangedFields & BitMask(ID_LOGTYPE) )
|
|
{
|
|
fRet = StdPutMetabaseProp ( &metabase, MD_LOG_TYPE, m_lLogType) && fRet;
|
|
}
|
|
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_AUTOSTART) ) {
|
|
fRet = fRet && StdPutMetabaseProp ( &metabase, MD_SERVER_AUTOSTART, m_fAutoStart );
|
|
}
|
|
|
|
if ( m_bvChangedFields & BitMask(ID_COMMENT) ) {
|
|
fRet = fRet && StdPutMetabaseProp ( &metabase, MD_SERVER_COMMENT, m_strComment );
|
|
}
|
|
|
|
#if 0
|
|
// if ( m_bvChangedFields & CHNG_ADMINACL ) {
|
|
if ( pSD ) {
|
|
hr = metabase.SetData ( _T(""), MD_ADMIN_ACL, IIS_MD_UT_SERVER, BINARY_METADATA, pSD, cbSD, METADATA_INHERIT | METADATA_REFERENCE);
|
|
BAIL_ON_FAILURE(hr);
|
|
}
|
|
else {
|
|
pMetabase->DeleteData ( metabase.QueryHandle(), _T(""), MD_ADMIN_ACL, BINARY_METADATA );
|
|
}
|
|
// }
|
|
#endif
|
|
|
|
// if ( m_bvChangedFields & CHNG_IPACCESS ) {
|
|
hr = m_pPrivateIpAccess->SendToMetabase ( &metabase );
|
|
BAIL_ON_FAILURE(hr);
|
|
// }
|
|
|
|
// Save the data to the metabase:
|
|
// hr = metabase.Close();
|
|
// BAIL_ON_FAILURE(hr);
|
|
metabase.Close();
|
|
|
|
hr = pMetabase->SaveData ();
|
|
if ( FAILED (hr) ) {
|
|
ErrorTraceX ( (LPARAM) this, "Failed SaveData call (%x)", hr );
|
|
}
|
|
|
|
// Save the last changed time for this key:
|
|
m_ftLastChanged.dwHighDateTime = 0;
|
|
m_ftLastChanged.dwLowDateTime = 0;
|
|
|
|
hr = pMetabase->GetLastChangeTime ( metabase.QueryHandle(), _T(""), &m_ftLastChanged, FALSE );
|
|
if ( FAILED (hr) ) {
|
|
ErrorTraceX ( (LPARAM) this, "Failed to get last change time: %x", hr );
|
|
// Ignore this error.
|
|
hr = NOERROR;
|
|
}
|
|
|
|
Exit:
|
|
delete (char*) pSD;
|
|
|
|
if( SUCCEEDED(hr) && !fRet )
|
|
{
|
|
hr = SmtpCreateExceptionFromWin32Error ( GetLastError () );
|
|
}
|
|
|
|
TraceFunctLeave ();
|
|
return hr;
|
|
|
|
// CMetabaseKey automatically closes its handle
|
|
}
|
|
|
|
//$-------------------------------------------------------------------
|
|
//
|
|
// CSmtpAdminVirtualServer::ValidateStrings
|
|
//
|
|
// Description:
|
|
//
|
|
// Checks to make sure each string property is non-null.
|
|
//
|
|
// Returns:
|
|
//
|
|
// FALSE if any string property is NULL.
|
|
//
|
|
//--------------------------------------------------------------------
|
|
|
|
BOOL CSmtpAdminVirtualServer::ValidateStrings ( ) const
|
|
{
|
|
TraceFunctEnter ( "CSmtpAdminVirtualServer::ValidateStrings" );
|
|
|
|
// Check all property strings:
|
|
// If any string is NULL, return FALSE:
|
|
|
|
if (
|
|
!m_strSmartHost ||
|
|
!m_strPostmasterEmail ||
|
|
!m_strPostmasterName ||
|
|
!m_strDefaultDomain ||
|
|
!m_strBadMailDir ||
|
|
!m_strPickupDir ||
|
|
!m_strQueueDir ||
|
|
!m_strRoutingDLL ||
|
|
!m_strLogFileDirectory
|
|
) {
|
|
|
|
ErrorTrace ( (LPARAM) this, "String validation failed" );
|
|
|
|
TraceFunctLeave ();
|
|
return FALSE;
|
|
}
|
|
|
|
_ASSERT ( IS_VALID_STRING ( m_strSmartHost ) );
|
|
_ASSERT ( IS_VALID_STRING ( m_strPostmasterEmail ) );
|
|
_ASSERT ( IS_VALID_STRING ( m_strPostmasterName ) );
|
|
|
|
_ASSERT ( IS_VALID_STRING ( m_strDefaultDomain ) );
|
|
|
|
_ASSERT ( IS_VALID_STRING ( m_strBadMailDir ) );
|
|
_ASSERT ( IS_VALID_STRING ( m_strPickupDir ) );
|
|
_ASSERT ( IS_VALID_STRING ( m_strQueueDir ) );
|
|
|
|
_ASSERT ( IS_VALID_STRING ( m_strRoutingDLL ) );
|
|
|
|
_ASSERT ( IS_VALID_STRING ( m_strLogFileDirectory ) );
|
|
|
|
TraceFunctLeave ();
|
|
return TRUE;
|
|
}
|
|
|
|
//$-------------------------------------------------------------------
|
|
//
|
|
// CSmtpAdminVirtualServer::ValidateProperties
|
|
//
|
|
// Description:
|
|
//
|
|
// Checks to make sure all parameters are valid.
|
|
//
|
|
// Parameters:
|
|
//
|
|
//
|
|
// Returns:
|
|
//
|
|
//
|
|
//--------------------------------------------------------------------
|
|
|
|
BOOL CSmtpAdminVirtualServer::ValidateProperties ( ) const
|
|
{
|
|
BOOL fRet = TRUE;
|
|
|
|
_ASSERT ( ValidateStrings () );
|
|
|
|
/*
|
|
fRet = fRet && PV_MinMax ( m_lPort, MIN_PORT, MAX_PORT );
|
|
fRet = fRet && PV_MinMax ( m_lSSLPort, MIN_SSLPORT, MAX_SSLPORT );
|
|
fRet = fRet && PV_MinMax ( m_lOutboundPort, MIN_OUTBOND_PORT, MAX_OUTBOND_PORT );
|
|
|
|
fRet = fRet && PV_MinMax ( m_lMaxInConnection, MIN_MAX_IN_CONNECTION, MAX_MAX_IN_CONNECTION );
|
|
fRet = fRet && PV_MinMax ( m_lMaxOutConnection, MIN_MAX_OUT_CONNECTION, MAX_MAX_OUT_CONNECTION );
|
|
fRet = fRet && PV_MinMax ( m_lInConnectionTimeout, MIN_IN_CONNECTION_TIMEOUT, MAX_IN_CONNECTION_TIMEOUT );
|
|
fRet = fRet && PV_MinMax ( m_lOutConnectionTimeout, MIN_OUT_CONNECTION_TIMEOUT, MAX_OUT_CONNECTION_TIMEOUT );
|
|
|
|
fRet = fRet && PV_MinMax ( m_lMaxMessageSize, MIN_MAX_MESSAGE_SIZE, MAX_MAX_MESSAGE_SIZE );
|
|
fRet = fRet && PV_MinMax ( m_lMaxSessionSize, MIN_MAX_SESSION_SIZE, MAX_MAX_SESSION_SIZE );
|
|
fRet = fRet && PV_MinMax ( m_lMaxMessageRecipients, MIN_MAX_MESSAGE_RECIPIENTS, MAX_MAX_MESSAGE_RECIPIENTS );
|
|
|
|
fRet = fRet && PV_MinMax ( m_lLocalRetries, MIN_LOCAL_RETRIES, MAX_LOCAL_RETRIES );
|
|
fRet = fRet && PV_MinMax ( m_lLocalRetryTime, MIN_LOCAL_RETRY_TIME, MAX_LOCAL_RETRY_TIME );
|
|
fRet = fRet && PV_MinMax ( m_lRemoteRetries, MIN_REMOTE_RETRIES, MAX_REMOTE_RETRIES );
|
|
fRet = fRet && PV_MinMax ( m_lRemoteRetryTime, MIN_REMOTE_RETRY_TIME, MAX_REMOTE_RETRY_TIME );
|
|
fRet = fRet && PV_MinMax ( m_lETRNDays, MIN_ETRN_DAYS, MAX_ETRN_DAYS );
|
|
|
|
// fRet = fRet && PV_MinMax ( m_lRTType, MIN_RTTYPE, MAX_RTTYPE );
|
|
|
|
fRet = fRet && PV_MinMax ( m_lLogFilePeriod, MIN_LOGFILE_PERIOD, MAX_LOGFILE_PERIOD );
|
|
fRet = fRet && PV_MinMax ( m_lLogFileTruncateSize, MIN_LOGFILE_TRUNCATE_SIZE, MAX_LOGFILE_TRUNCATE_SIZE );
|
|
fRet = fRet && PV_MinMax ( m_lLogMethod, MIN_LOG_METHOD, MAX_LOG_METHOD );
|
|
fRet = fRet && PV_MinMax ( m_lLogType, MIN_LOG_TYPE, MAX_LOG_TYPE );
|
|
|
|
fRet = fRet && PV_Boolean ( m_fEnableDNSLookup );
|
|
fRet = fRet && PV_Boolean ( m_fSendDNRToPostmaster );
|
|
fRet = fRet && PV_Boolean ( m_fSendBadmailToPostmaster );
|
|
fRet = fRet && PV_Boolean ( m_fAutoStart );
|
|
*/
|
|
return fRet;
|
|
}
|
|
|
|
void CSmtpAdminVirtualServer::CorrectProperties ( )
|
|
{
|
|
/*
|
|
if ( m_strServer && !PV_MaxChars ( m_strServer, MAXLEN_SERVER ) ) {
|
|
m_strServer[ MAXLEN_SERVER - 1 ] = NULL;
|
|
}
|
|
if ( !PV_MinMax ( m_dwArticleTimeLimit, MIN_ARTICLETIMELIMIT, MAX_ARTICLETIMELIMIT ) ) {
|
|
m_dwArticleTimeLimit = DEFAULT_ARTICLETIMELIMIT;
|
|
}
|
|
if ( !PV_MinMax ( m_dwHistoryExpiration, MIN_HISTORYEXPIRATION, MAX_HISTORYEXPIRATION ) ) {
|
|
m_dwHistoryExpiration = DEFAULT_HISTORYEXPIRATION;
|
|
}
|
|
if ( !PV_Boolean ( m_fHonorClientMsgIDs ) ) {
|
|
m_fHonorClientMsgIDs = !!m_fHonorClientMsgIDs;
|
|
}
|
|
if ( !PV_MaxChars ( m_strSmtpServer, MAXLEN_SMTPSERVER ) ) {
|
|
m_strSmtpServer[ MAXLEN_SMTPSERVER - 1 ] = NULL;
|
|
}
|
|
if ( !PV_Boolean ( m_fAllowClientPosts ) ) {
|
|
m_fAllowClientPosts = !!m_fAllowClientPosts;
|
|
}
|
|
if ( !PV_Boolean ( m_fAllowFeedPosts ) ) {
|
|
m_fAllowFeedPosts = !!m_fAllowFeedPosts;
|
|
}
|
|
if ( !PV_Boolean ( m_fAllowControlMsgs ) ) {
|
|
m_fAllowControlMsgs = !!m_fAllowControlMsgs;
|
|
}
|
|
if ( !PV_MaxChars ( m_strDefaultModeratorDomain, MAXLEN_DEFAULTMODERATORDOMAIN ) ) {
|
|
m_strDefaultModeratorDomain[ MAXLEN_DEFAULTMODERATORDOMAIN - 1] = NULL;
|
|
}
|
|
if ( !PV_MinMax ( m_dwCommandLogMask, MIN_COMMANDLOGMASK, MAX_COMMANDLOGMASK ) ) {
|
|
m_dwCommandLogMask = DEFAULT_COMMANDLOGMASK;
|
|
}
|
|
if ( !PV_Boolean ( m_fDisableNewnews ) ) {
|
|
m_fDisableNewnews = !!m_fDisableNewnews;
|
|
}
|
|
if ( !PV_MinMax ( m_dwExpireRunFrequency, MIN_EXPIRERUNFREQUENCY, MAX_EXPIRERUNFREQUENCY ) ) {
|
|
m_dwExpireRunFrequency = DEFAULT_EXPIRERUNFREQUENCY;
|
|
}
|
|
if ( !PV_MinMax ( m_dwShutdownLatency, MIN_SHUTDOWNLATENCY, MAX_SHUTDOWNLATENCY ) ) {
|
|
m_dwShutdownLatency = DEFAULT_SHUTDOWNLATENCY;
|
|
}
|
|
*/
|
|
|
|
_ASSERT ( ValidateProperties ( ) );
|
|
}
|
|
|
|
|
|
HRESULT AclToAdministrators ( LPCTSTR strServer, PSECURITY_DESCRIPTOR pSDRelative, SAFEARRAY ** ppsaAdmins )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
SAFEARRAY * psaResult = NULL;
|
|
SAFEARRAYBOUND rgsaBound[1];
|
|
DWORD cbAcl;
|
|
long cAdmins;
|
|
long i;
|
|
|
|
PSECURITY_DESCRIPTOR pSD = NULL;
|
|
PACL pAcl;
|
|
BOOL fDaclPresent;
|
|
BOOL fDaclDef;
|
|
|
|
pSD = (PSECURITY_DESCRIPTOR)pSDRelative;
|
|
if (pSD == NULL)
|
|
{
|
|
//
|
|
// Empty...
|
|
//
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
if (!IsValidSecurityDescriptor(pSD))
|
|
{
|
|
return GetLastError();
|
|
}
|
|
|
|
_VERIFY(GetSecurityDescriptorDacl(pSD, &fDaclPresent, &pAcl, &fDaclDef));
|
|
if (!fDaclPresent || pAcl == NULL)
|
|
{
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
if (!IsValidAcl(pAcl))
|
|
{
|
|
return GetLastError();
|
|
}
|
|
|
|
cAdmins = pAcl->AceCount;
|
|
cbAcl = pAcl->AclSize;
|
|
|
|
rgsaBound[0].lLbound = 0;
|
|
rgsaBound[0].cElements = cAdmins;
|
|
psaResult = SafeArrayCreate ( VT_BSTR, 1, rgsaBound );
|
|
|
|
if ( !psaResult ) {
|
|
BAIL_WITH_FAILURE ( hr, E_OUTOFMEMORY );
|
|
}
|
|
|
|
for ( i = 0; i < cAdmins; i++ ) {
|
|
PVOID pAce;
|
|
PACE_HEADER pAceHeader;
|
|
PSID pSID;
|
|
|
|
if ( GetAce(pAcl, i, &pAce) ) {
|
|
pAceHeader = (PACE_HEADER)pAce;
|
|
|
|
if ( pAceHeader->AceType == ACCESS_ALLOWED_ACE_TYPE ) {
|
|
CComBSTR str;
|
|
|
|
pSID = (PSID)&((PACCESS_ALLOWED_ACE)pAce)->SidStart;
|
|
|
|
hr = SidToString ( pSID, &str );
|
|
BAIL_ON_FAILURE(hr);
|
|
|
|
hr = SafeArrayPutElement ( psaResult, &i, (PVOID) str );
|
|
BAIL_ON_FAILURE(hr);
|
|
}
|
|
}
|
|
}
|
|
|
|
if ( *ppsaAdmins ) {
|
|
SafeArrayDestroy ( *ppsaAdmins );
|
|
}
|
|
*ppsaAdmins = psaResult;
|
|
|
|
Exit:
|
|
return hr;
|
|
}
|
|
|
|
|
|
PSID
|
|
GetOwnerSID()
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Arguments:
|
|
|
|
Return Value:
|
|
|
|
Owner sid
|
|
|
|
--*/
|
|
{
|
|
PSID pSID = NULL;
|
|
|
|
SID_IDENTIFIER_AUTHORITY NtAuthority = SECURITY_NT_AUTHORITY;
|
|
if (!AllocateAndInitializeSid(
|
|
&NtAuthority,
|
|
2,
|
|
SECURITY_BUILTIN_DOMAIN_RID,
|
|
DOMAIN_ALIAS_RID_ADMINS,
|
|
0, 0, 0, 0, 0, 0,
|
|
&pSID))
|
|
{
|
|
_ASSERT( 0 );
|
|
//TRACEEOLID("Unable to get primary SID " << ::GetLastError());
|
|
}
|
|
|
|
return pSID;
|
|
}
|
|
|
|
|
|
HRESULT AdministratorsToAcl (
|
|
LPCTSTR strServer,
|
|
SAFEARRAY * psaAdmins,
|
|
PSECURITY_DESCRIPTOR* ppSD,
|
|
DWORD * pcbSD
|
|
)
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
long lBound;
|
|
long uBound;
|
|
long i;
|
|
BOOL fRet;
|
|
DWORD cbAcl;
|
|
PACL pAclResult = NULL;
|
|
PSID pSID;
|
|
|
|
*ppSD = NULL;
|
|
*pcbSD = 0;
|
|
|
|
if ( psaAdmins == NULL ) {
|
|
lBound = 0;
|
|
uBound = -1;
|
|
}
|
|
else {
|
|
SafeArrayGetLBound ( psaAdmins, 1, &lBound );
|
|
SafeArrayGetUBound ( psaAdmins, 1, &uBound );
|
|
}
|
|
|
|
// Do we have an array of Domain\Usernames?
|
|
if ( lBound > uBound ) {
|
|
// Nothing in the array, so the ACL is NULL.
|
|
goto Exit;
|
|
}
|
|
|
|
//
|
|
// Calculate ACL size:
|
|
//
|
|
cbAcl = sizeof (ACL);
|
|
|
|
for ( i = lBound; i <= uBound ; i++ ) {
|
|
CComBSTR str;
|
|
|
|
pSID = NULL;
|
|
|
|
SafeArrayGetElement ( psaAdmins, &i, &str );
|
|
|
|
hr = StringToSid ( strServer, str, &pSID );
|
|
|
|
if ( SUCCEEDED(hr) && pSID) {
|
|
cbAcl += GetLengthSid ( pSID );
|
|
cbAcl += sizeof ( ACCESS_ALLOWED_ACE );
|
|
cbAcl -= sizeof (DWORD);
|
|
delete pSID;
|
|
}
|
|
hr = NOERROR;
|
|
|
|
}
|
|
|
|
pAclResult = (PACL) new char [ cbAcl ];
|
|
if ( !pAclResult ) {
|
|
BAIL_WITH_FAILURE(hr, E_OUTOFMEMORY);
|
|
}
|
|
|
|
fRet = InitializeAcl ( pAclResult, cbAcl, ACL_REVISION );
|
|
_ASSERT ( fRet );
|
|
if ( !fRet ) {
|
|
BAIL_WITH_FAILURE(hr, RETURNCODETOHRESULT(GetLastError() ) );
|
|
}
|
|
|
|
//
|
|
// Create ACL:
|
|
//
|
|
for ( i = lBound; i <= uBound; i++ ) {
|
|
CComBSTR str;
|
|
PSID pSID;
|
|
|
|
pSID = NULL;
|
|
|
|
SafeArrayGetElement ( psaAdmins, &i, &str );
|
|
|
|
hr = StringToSid ( strServer, str, &pSID );
|
|
if ( SUCCEEDED(hr) ) {
|
|
fRet = AddAccessAllowedAce (
|
|
pAclResult,
|
|
ACL_REVISION,
|
|
FILE_GENERIC_READ | FILE_GENERIC_WRITE | FILE_GENERIC_EXECUTE,
|
|
pSID
|
|
);
|
|
|
|
delete pSID;
|
|
if ( !fRet ) {
|
|
BAIL_WITH_FAILURE(hr, RETURNCODETOHRESULT(GetLastError() ) );
|
|
}
|
|
}
|
|
hr = NOERROR;
|
|
|
|
}
|
|
|
|
//
|
|
// Build the security descriptor
|
|
//
|
|
PSECURITY_DESCRIPTOR pSD;
|
|
pSD = new char[SECURITY_DESCRIPTOR_MIN_LENGTH];
|
|
|
|
if( NULL == pSD )
|
|
{
|
|
hr = E_OUTOFMEMORY;
|
|
goto Exit;
|
|
}
|
|
|
|
_VERIFY(InitializeSecurityDescriptor(pSD, SECURITY_DESCRIPTOR_REVISION));
|
|
_VERIFY(SetSecurityDescriptorDacl(pSD, TRUE, pAclResult, FALSE));
|
|
|
|
//
|
|
// Set owner and primary group
|
|
//
|
|
pSID = GetOwnerSID();
|
|
_ASSERT(pSID);
|
|
_VERIFY(SetSecurityDescriptorOwner(pSD, pSID, TRUE));
|
|
_VERIFY(SetSecurityDescriptorGroup(pSD, pSID, TRUE));
|
|
|
|
//
|
|
// Convert to self-relative
|
|
//
|
|
PSECURITY_DESCRIPTOR pSDSelfRelative;
|
|
pSDSelfRelative = NULL;
|
|
DWORD dwSize;
|
|
dwSize = 0L;
|
|
MakeSelfRelativeSD(pSD, pSDSelfRelative, &dwSize);
|
|
pSDSelfRelative = new char[dwSize];
|
|
|
|
if( NULL == pSDSelfRelative )
|
|
{
|
|
hr = E_OUTOFMEMORY;
|
|
goto Exit;
|
|
}
|
|
|
|
MakeSelfRelativeSD(pSD, pSDSelfRelative, &dwSize);
|
|
|
|
//
|
|
// Clean up
|
|
//
|
|
delete (char*)pSD;
|
|
FreeSid( pSID );
|
|
|
|
|
|
_ASSERT ( SUCCEEDED(hr) );
|
|
*ppSD = pSDSelfRelative;
|
|
*pcbSD = dwSize;
|
|
|
|
Exit:
|
|
if ( FAILED(hr) ) {
|
|
delete pAclResult;
|
|
}
|
|
return hr;
|
|
}
|
|
|
|
HRESULT SidToString ( PSID pSID, BSTR * pStr )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
BOOL fLookup;
|
|
SID_NAME_USE SidToNameUse;
|
|
WCHAR wszUsername [ PATHLEN ];
|
|
DWORD cbUsername = sizeof ( wszUsername );
|
|
WCHAR wszDomain [ PATHLEN ];
|
|
DWORD cbDomain = sizeof ( wszDomain );
|
|
WCHAR wszResult [ 2 * PATHLEN + 2 ];
|
|
|
|
fLookup = LookupAccountSid (
|
|
// wszSearchDomain,
|
|
NULL,
|
|
pSID,
|
|
wszUsername,
|
|
&cbUsername,
|
|
wszDomain,
|
|
&cbDomain,
|
|
&SidToNameUse
|
|
);
|
|
|
|
if ( !fLookup ) {
|
|
BAIL_WITH_FAILURE(hr, RETURNCODETOHRESULT (GetLastError ()) );
|
|
}
|
|
|
|
wsprintf ( wszResult, _T("%s\\%s"), wszDomain, wszUsername );
|
|
|
|
*pStr = ::SysAllocString ( wszResult );
|
|
|
|
Exit:
|
|
if ( *pStr ) {
|
|
return NOERROR;
|
|
}
|
|
else {
|
|
return E_OUTOFMEMORY;
|
|
}
|
|
}
|
|
|
|
//-------------------------------------------------------------------------
|
|
// Description:
|
|
// Returns the SID for a an account (given as a COMPUTER/USER)
|
|
// Parameters:
|
|
// strSystemName - Name of "computer" on which account is
|
|
// str - Name of user account to look up
|
|
// ppSID - Out parameter; This function allocates a SID for the
|
|
// accountand returns a pointer to it .
|
|
// Returns:
|
|
// S_OK on success. Caller frees *ppSID using delete.
|
|
// Error HRESULT otherwise. *ppSID will be NULL.
|
|
//-------------------------------------------------------------------------
|
|
HRESULT StringToSid ( LPCWSTR strSystemName, LPWSTR str, PSID * ppSID )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
BOOL fLookup;
|
|
WCHAR wszRefDomain[PATHLEN];
|
|
DWORD cbRefDomain = sizeof ( wszRefDomain );
|
|
DWORD cbSid = 0;
|
|
SID_NAME_USE SidNameUse;
|
|
|
|
*ppSID = NULL;
|
|
|
|
if ( str[0] == '\\' ) {
|
|
//
|
|
// Skip the initial \, this is for BUILTIN usernames:
|
|
//
|
|
|
|
str++;
|
|
}
|
|
|
|
_ASSERT ( str[0] != '\\' );
|
|
|
|
fLookup = LookupAccountName (
|
|
strSystemName,
|
|
str,
|
|
*ppSID,
|
|
&cbSid,
|
|
wszRefDomain,
|
|
&cbRefDomain,
|
|
&SidNameUse
|
|
);
|
|
|
|
// First lookup will fail, but the size will be right:
|
|
if ( GetLastError() != ERROR_INSUFFICIENT_BUFFER ) {
|
|
DWORD dw;
|
|
|
|
dw = GetLastError ();
|
|
BAIL_WITH_FAILURE(hr, RETURNCODETOHRESULT ( GetLastError () ) );
|
|
}
|
|
|
|
*ppSID = (LPVOID) new char [ cbSid ];
|
|
if ( !*ppSID ) {
|
|
BAIL_WITH_FAILURE(hr, E_OUTOFMEMORY);
|
|
}
|
|
|
|
fLookup = LookupAccountName (
|
|
strSystemName,
|
|
str,
|
|
*ppSID,
|
|
&cbSid,
|
|
wszRefDomain,
|
|
&cbRefDomain,
|
|
&SidNameUse
|
|
);
|
|
|
|
if ( !fLookup ) {
|
|
DWORD dw;
|
|
|
|
dw = GetLastError ();
|
|
BAIL_WITH_FAILURE(hr, RETURNCODETOHRESULT ( GetLastError () ) );
|
|
}
|
|
|
|
Exit:
|
|
if(FAILED(hr) && *ppSID != NULL) {
|
|
delete (*ppSID);
|
|
*ppSID = NULL;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
|