|
|
/////////////////////////////////////////////////////////////////////////////
// FILE : ppFaxServerLogging.cpp //
// //
// DESCRIPTION : prop pages of //
// //
// AUTHOR : yossg //
// //
// HISTORY : //
// Oct 25 1999 yossg created //
// Nov 3 1999 yossg OnInitDialog, SetProps //
// Nov 15 1999 yossg Call RPC func //
// Nov 24 1999 yossg OnApply create call to all tabs from parent //
// Dec 10 2000 yossg Update Windows XP //
// //
// Copyright (C) 1999 Microsoft Corporation All Rights Reserved //
// //
/////////////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include "MSFxsSnp.h"
#include "ppFaxServerLogging.h"
#include "FaxServer.h"
#include "FaxServerNode.h"
#include "FxsValid.h"
#include "dlgutils.h"
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[] = __FILE__; #endif
//
// Constructor
//
CppFaxServerLogging::CppFaxServerLogging( LONG_PTR hNotificationHandle, CSnapInItem *pNode, BOOL fIsLocalServer, HINSTANCE hInst) : CPropertyPageExImpl<CppFaxServerLogging>(pNode, NULL) { m_pParentNode = static_cast <CFaxServerNode *> (pNode); m_pFaxActLogConfig = NULL;
m_fIsDialogInitiated = FALSE; m_fIsDirty = FALSE;
m_fIsLocalServer = fIsLocalServer; }
//
// Destructor
//
CppFaxServerLogging::~CppFaxServerLogging() { if (NULL != m_pFaxActLogConfig) { FaxFreeBuffer( m_pFaxActLogConfig ); } }
//////////////////////////////////////////////////////////////////////////////
// CppFaxServerLogging message handlers
/*
- CppFaxServerLogging::InitRPC - * Purpose: * Initiates the configuration structure from RPC get Call. * * Arguments: * * Return: * OLE error code */ HRESULT CppFaxServerLogging::InitRPC( ) { DEBUG_FUNCTION_NAME( _T("CppFaxServerLogging::InitRPC")); HRESULT hRc = S_OK; DWORD ec = ERROR_SUCCESS;
//
// get RPC Handle
//
if (!m_pFaxServer->GetFaxServerHandle()) { ec= GetLastError(); DebugPrintEx( DEBUG_ERR, _T("Failed to GetFaxServerHandle. (ec: %ld)"), ec);
goto Error; }
//
// Retrieve the fax activity logging configuration structure
//
if (!FaxGetActivityLoggingConfiguration(m_pFaxServer->GetFaxServerHandle(), &m_pFaxActLogConfig)) { ec = GetLastError(); DebugPrintEx( DEBUG_ERR, _T("Fail to get Activity logging configuration. (ec: %ld)"), ec);
if (IsNetworkError(ec)) { DebugPrintEx( DEBUG_ERR, _T("Network Error was found. (ec: %ld)"), ec); m_pFaxServer->Disconnect(); }
goto Error; } //For max verification
ATLASSERT(m_pFaxActLogConfig);
m_bstrLastGoodFolder = m_pFaxActLogConfig->lptstrDBPath ? m_pFaxActLogConfig->lptstrDBPath : TEXT(""); if (!m_bstrLastGoodFolder) { DebugPrintEx( DEBUG_ERR, TEXT("Failed to allocate string (m_bstrLastGoodFolder).")); ec = ERROR_OUTOFMEMORY; goto Error; }
ATLASSERT(ERROR_SUCCESS == ec); DebugPrintEx( DEBUG_MSG, _T("Succeed to get acitivity logging configuration."));
goto Exit;
Error: ATLASSERT(ERROR_SUCCESS != ec); hRc = HRESULT_FROM_WIN32(ec); ATLASSERT(NULL != m_pParentNode); m_pParentNode->NodeMsgBox(GetFaxServerErrorMsg(ec)); Exit: return (hRc); }
/*
- CppFaxServerLogging::OnInitDialog - * Purpose: * Initiates all controls when dialog is called. * * Arguments: * * Return: * OLE error code */ LRESULT CppFaxServerLogging::OnInitDialog( UINT uiMsg, WPARAM wParam, LPARAM lParam, BOOL& fHandled ) { DEBUG_FUNCTION_NAME( _T("CppFaxServerLogging::PageInitDialog"));
UNREFERENCED_PARAMETER( uiMsg ); UNREFERENCED_PARAMETER( wParam ); UNREFERENCED_PARAMETER( lParam ); UNREFERENCED_PARAMETER( fHandled );
BOOL fToCheck; UINT CheckState1; UINT CheckState2;
//
// Attach & limit length
//
m_LogFileBox.Attach(GetDlgItem(IDC_LOG_FILE_EDIT)); m_LogFileBox.SetLimitText(MAX_DIR_PATH); SHAutoComplete (GetDlgItem(IDC_LOG_FILE_EDIT), SHACF_FILESYSTEM); //
// init controls
//
ATLASSERT(NULL != m_pFaxActLogConfig);
//
// To-log activity checkboxes
//
fToCheck = m_pFaxActLogConfig->bLogIncoming; CheckState1 = (fToCheck) ? BST_CHECKED : BST_UNCHECKED; CheckDlgButton(IDC_INCOMING_LOG_CHECK, CheckState1);
fToCheck = m_pFaxActLogConfig->bLogOutgoing; CheckState2 = (fToCheck) ? BST_CHECKED : BST_UNCHECKED; CheckDlgButton(IDC_OUTGOING_LOG_CHECK, CheckState2);
//
// Log file address
//
m_LogFileBox.SetWindowText(m_pFaxActLogConfig->lptstrDBPath ? m_pFaxActLogConfig->lptstrDBPath : TEXT(""));
//
// Inactivate m_LogFileBox
//
if ( !(CheckState1 || CheckState2) ) { EnableDataBasePath(FALSE); } else { EnableDataBasePath(TRUE); // To check IsLocalServer for Browse button
}
m_fIsDialogInitiated = TRUE;
return(1); }
/*
- CppFaxServerLogging::SetProps - * Purpose: * Sets properties on apply. * * Arguments: * IN pCtrlFocus - focus pointer (int) * * Return: * OLE error code */ HRESULT CppFaxServerLogging::SetProps(int *pCtrlFocus) { DEBUG_FUNCTION_NAME( _T("CppFaxServerLogging::SetProps")); HRESULT hRc = S_OK; DWORD ec = ERROR_SUCCESS; BOOL fSkipMessage = FALSE;
CComBSTR bstrLogFile;
UINT uRetIDS = 0;
FAX_ACTIVITY_LOGGING_CONFIG FaxActLogConfig;
HINSTANCE hInst = _Module.GetResourceInstance();
//
// Collect all data and init the structure's fields
// uses Copy() to copy and also allocate before
//
ZeroMemory (&FaxActLogConfig, sizeof(FAX_ACTIVITY_LOGGING_CONFIG));
//
// Size of struct.
//
FaxActLogConfig.dwSizeOfStruct = sizeof(FAX_ACTIVITY_LOGGING_CONFIG);
//
// To log incoming activity
//
if (IsDlgButtonChecked(IDC_INCOMING_LOG_CHECK) == BST_CHECKED) { FaxActLogConfig.bLogIncoming = TRUE; } else { FaxActLogConfig.bLogIncoming = FALSE; }
//
// To log outgoing activity
//
if (IsDlgButtonChecked(IDC_OUTGOING_LOG_CHECK) == BST_CHECKED) { FaxActLogConfig.bLogOutgoing = TRUE; } else { FaxActLogConfig.bLogOutgoing = FALSE; }
if ( FaxActLogConfig.bLogIncoming || FaxActLogConfig.bLogOutgoing ) { //
// Log file
//
if ( !m_LogFileBox.GetWindowText(&bstrLogFile) ) { *pCtrlFocus = IDC_LOG_FILE_EDIT; DebugPrintEx( DEBUG_ERR, TEXT("Failed to GetWindowText(&bstrLogFile)")); } if (!IsNotEmptyString(bstrLogFile)) { DebugPrintEx( DEBUG_ERR, _T("Log file path string empty or spaces only.")); uRetIDS = IDS_LOG_PATH_EMPTY;
*pCtrlFocus = IDC_LOG_FILE_EDIT; goto Error; } FaxActLogConfig.lptstrDBPath = bstrLogFile; //
// follow-up for an OnApply following submition
// with both unchecked IDC_OUTGOING_LOG_CHECK and IDC_INCOMING_LOG_CHECK
//
m_bstrLastGoodFolder = bstrLogFile; if (!m_bstrLastGoodFolder) { *pCtrlFocus = IDC_LOG_FILE_EDIT; DebugPrintEx( DEBUG_ERR, TEXT("Failed to allocate string (m_bstrLastGoodFolder).")); ec = ERROR_OUTOFMEMORY; goto Error; } } else { FaxActLogConfig.lptstrDBPath = m_bstrLastGoodFolder; }
//
// get RPC Handle
//
if (!m_pFaxServer->GetFaxServerHandle()) { ec= GetLastError(); DebugPrintEx( DEBUG_ERR, _T("Failed to GetFaxServerHandle. (ec: %ld)"), ec); goto Error; }
//
// Set Config
//
if (!FaxSetActivityLoggingConfiguration(m_pFaxServer->GetFaxServerHandle(), &FaxActLogConfig)) { ec = GetLastError(); DebugPrintEx(DEBUG_ERR, _T("Fail to Set Activity Logging configuration. (ec: %ld)"), ec);
//
// Try to adjust folder
//
PropSheet_SetCurSelByID( GetParent(), IDD); GotoDlgCtrl(GetDlgItem(IDC_LOG_FILE_EDIT));
ec = AskUserAndAdjustFaxFolder(m_hWnd, m_pFaxServer->GetServerName(), FaxActLogConfig.lptstrDBPath, ec); if(ERROR_SUCCESS != ec) { if(ERROR_BAD_PATHNAME == ec) { //
// The error message has been shown by AskUserAndAdjustFaxFolder
//
fSkipMessage = TRUE; } goto Error; }
//
// The folder has been adjusted, set it again
//
if (!FaxSetActivityLoggingConfiguration(m_pFaxServer->GetFaxServerHandle(), &FaxActLogConfig)) { ec = GetLastError(); DebugPrintEx(DEBUG_ERR, _T("Fail to Set Activity Logging configuration. (ec: %ld)"), ec); goto Error; } }
ATLASSERT(S_OK == hRc); m_fIsDirty = FALSE;
DebugPrintEx(DEBUG_MSG, _T("Succeed to set Activity Logging configuration."));
return hRc;
Error: ATLASSERT(ERROR_SUCCESS != ec); hRc = HRESULT_FROM_WIN32(ec);
DWORD dwIDS = 0; switch (ec) { case ERROR_DISK_FULL: DebugPrintEx( DEBUG_ERR, _T("ERROR_DISK_FULL == ec")); dwIDS = IDS_LOGGING_ERROR_DISK_FULL; break;
case FAX_ERR_FILE_ACCESS_DENIED: DebugPrintEx( DEBUG_ERR, _T("FAX_ERR_FILE_ACCESS_DENIED == ec")); dwIDS = IDS_LOGGING_FAX_ERR_FILE_ACCESS_DENIED; break;
default: dwIDS = GetFaxServerErrorMsg(ec); break; }
if (dwIDS && !fSkipMessage) { PropSheet_SetCurSelByID( GetParent(), IDD); ATLASSERT(::IsWindow(m_hWnd)); PageError(dwIDS, m_hWnd); }
if (IsNetworkError(ec)) { DebugPrintEx(DEBUG_ERR, _T("Network Error was found. (ec: %ld)"), ec); m_pFaxServer->Disconnect(); }
return hRc; }
/*
- CppFaxServerLogging::PreApply - * Purpose: * Checks properties before apply. * * Arguments: * * Return: * OLE error code */ HRESULT CppFaxServerLogging::PreApply(int *pCtrlFocus, UINT * puIds) { HRESULT hRc = S_OK; //
// PreApply Checks
//
if (!AllReadyToApply(/*fSilent =*/ FALSE, pCtrlFocus , puIds)) { SetModified(FALSE); hRc = E_FAIL ; } else { SetModified(TRUE); }
return(hRc); }
/*
- CppFaxServerLogging::OnApply - * Purpose: * Calls PreApply and SetProp to Apply changes. * * Arguments: * * Return: * TRUE or FALSE */ BOOL CppFaxServerLogging::OnApply() { DEBUG_FUNCTION_NAME( _T("CppFaxServerLogging::OnApply"));
HRESULT hRc = S_OK; int CtrlFocus = 0; UINT uIds = 0;
if (!m_fIsDirty) { return TRUE; }
hRc = PreApply(&CtrlFocus, &uIds); if (FAILED(hRc)) { if (PropSheet_SetCurSelByID( GetParent(), IDD) ) { PageError(uIds, m_hWnd, _Module.GetResourceInstance()); if (CtrlFocus) { GotoDlgCtrl(GetDlgItem(CtrlFocus)); } } return FALSE; } else //(Succeeded(hRc))
{ hRc = SetProps(&CtrlFocus); if (FAILED(hRc)) { //Error Msg by called func.
if (CtrlFocus) { GotoDlgCtrl(GetDlgItem(CtrlFocus)); } return FALSE; } else //(Succeeded(hRc))
{ return TRUE; } }
}
/*
+ Routine Description: + * Browse for a directory * * Arguments: * * hwndDlg - Specifies the dialog window on which the Browse button is displayed * * Return Value: * * TRUE if successful, FALSE if the user presses Cancel - - */ BOOL CppFaxServerLogging::BrowseForFile( WORD wNotifyCode, WORD wID, HWND hwndDlg, BOOL& bHandled ) { UNREFERENCED_PARAMETER( wNotifyCode ); UNREFERENCED_PARAMETER( wID ); UNREFERENCED_PARAMETER( hwndDlg ); UNREFERENCED_PARAMETER( bHandled );
DEBUG_FUNCTION_NAME( _T("CppFaxServerLogging::BrowseForFile"));
BOOL fResult = FALSE;
WCHAR szBrowseFile[MAX_PATH]={0}; WCHAR szBrowseDlgTitle[FXS_MAX_TITLE_LEN]; CComBSTR bstrOldPath; unsigned int len;
unsigned long ulBrowseFlags;
//
// Collecting the browse dialog headline
//
if (!LoadString( _Module.GetResourceInstance(), IDS_GET_LOG_FILE, szBrowseDlgTitle, FXS_MAX_TITLE_LEN)) { DWORD ec; ec = GetLastError(); if (ec == ERROR_NOT_ENOUGH_MEMORY) { DebugPrintEx( DEBUG_ERR, _T("Out of Memory - fail to load string.")); DlgMsgBox(this, IDS_MEMORY); return fResult; } DebugPrintEx( DEBUG_ERR, _T("Failed to load titile string - unexpected behavior.")); szBrowseDlgTitle[0] = 0; }
//
// Collecting the old path from the calling dialog edit box
//
if(! GetDlgItemText( IDC_LOG_FILE_EDIT, bstrOldPath.m_str)) { DebugPrintEx( DEBUG_ERR, _T("Failed to collect old path from the property page edit box.")); szBrowseFile[0] = 0; } else { len = bstrOldPath.Length(); if ( len > MAX_PATH ) { DebugPrintEx( DEBUG_ERR, _T("Old Path Length is bigger then alowed maximal path.")); szBrowseFile[0] = 0; } else { wcsncpy(szBrowseFile, bstrOldPath, ARR_SIZE(szBrowseFile)-1); } }
//
// Preparing the browse dialog style flags.
//
ulBrowseFlags = BIF_BROWSEINCLUDEFILES | //the files also flag
BIF_STATUSTEXT | BIF_NEWDIALOGSTYLE | BIF_NONEWFOLDERBUTTON | BIF_VALIDATE;
//
// Invoke the browse dialog with a function based on
// Shell functions.
//
if (InvokeBrowseDialog(szBrowseFile, MAX_DIR_PATH, szBrowseDlgTitle, ulBrowseFlags, this)) { SetDlgItemText(IDC_LOG_FILE_EDIT, szBrowseFile); fResult = TRUE; }
return fResult; }
/*
- CppFaxServerLogging::SetApplyButton - * Purpose: * Modify Apply buttton. * * Arguments: * * Return: * 1 */ LRESULT CppFaxServerLogging::SetApplyButton(WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled) { if (!m_fIsDialogInitiated) //event receieved in too early stage
{ return 0; } else { m_fIsDirty = TRUE; } SetModified(TRUE); bHandled = TRUE; return(1); }
/*
- CppFaxServerLogging::OnCheckboxClicked - * Purpose: * Gray/Ungray controls * Enable apply button. * * Arguments: * * Return: * 1 */ LRESULT CppFaxServerLogging::OnCheckboxClicked(WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled) { BOOL fActivate = FALSE; if (!m_fIsDialogInitiated) //event receieved in too early stage
{ return 1; } else { m_fIsDirty = TRUE; }
if ( BST_CHECKED == IsDlgButtonChecked(IDC_INCOMING_LOG_CHECK) || BST_CHECKED == IsDlgButtonChecked(IDC_OUTGOING_LOG_CHECK) ) { if (AllReadyToApply(TRUE)) { SetModified(TRUE); } else { SetModified(FALSE); } fActivate = TRUE;
} else { SetModified(TRUE); } EnableDataBasePath(fActivate);
return(1); }
/*
- CppFaxServerLogging::OnCheckboxClicked - * Purpose: * Gray/Ungray controls * Enable apply button. * * Arguments: * * Return: * 1 */ LRESULT CppFaxServerLogging::OnTextChanged(WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled) { BOOL fActivate = FALSE;
if (!m_fIsDialogInitiated) //event receieved in too early stage
{ return 1; } else { m_fIsDirty = TRUE; }
if (AllReadyToApply(TRUE)) { SetModified(TRUE); } else { SetModified(FALSE); }
return(1); }
/*
- CppFaxServerLogging::AllReadyToApply - * Purpose: * This function validate that no zero length strings * are found data areas that should be saved. * * Arguments: * [in] fSilent - boolean who defines if to pop up messages (FALSE) * or not.(TRUE) * * Return: * BOOOLEAN */ BOOL CppFaxServerLogging::AllReadyToApply(BOOL fSilent, int *pCtrlFocus, UINT *pIds) { DEBUG_FUNCTION_NAME( _T("CppFaxServerLogging::AllReadyToApply")); DWORD ec = ERROR_SUCCESS; if ( BST_CHECKED == IsDlgButtonChecked(IDC_INCOMING_LOG_CHECK) || BST_CHECKED == IsDlgButtonChecked(IDC_OUTGOING_LOG_CHECK) ) { if ( !m_LogFileBox.GetWindowTextLength() ) { ec = GetLastError(); DebugPrintEx( DEBUG_ERR, _T("Zero text length - m_LogFileBox. (ec: %ld)"), ec); if (!fSilent) { *pCtrlFocus = IDC_LOG_FILE_EDIT; *pIds = IDS_LOG_PATH_EMPTY; } return FALSE; } }
ATLASSERT(ERROR_SUCCESS == ec); //
// Cheers!
// ...every thing ready to apply now.
//
return TRUE; }
/*
- CppFaxServerLogging::EnableDataBasePath - * Purpose: * Enable/dissable the data base path controls. * * Arguments: * [in] state - boolean value to enable TRUE or FALSE to disable * * Return: * void */ void CppFaxServerLogging::EnableDataBasePath(BOOL fState) { ::EnableWindow(GetDlgItem(IDC_LOG_FILE_EDIT), fState); ::EnableWindow(GetDlgItem(IDC_LOG_BROWSE_BUTTON), fState && m_fIsLocalServer); ::EnableWindow(GetDlgItem(IDC_DATABASE_FSTATIC), fState); }
//////////////////////////////////////////////////////////////////////////////
/*++
CppFaxServerLogging::OnHelpRequest
This is called in response to the WM_HELP Notify message and to the WM_CONTEXTMENU Notify message.
WM_HELP Notify message. This message is sent when the user presses F1 or <Shift>-F1 over an item or when the user clicks on the ? icon and then presses the mouse over an item.
WM_CONTEXTMENU Notify message. This message is sent when the user right clicks over an item and then clicks "What's this?"
--*/
/////////////////////////////////////////////////////////////////////////////
LRESULT CppFaxServerLogging::OnHelpRequest(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& /*bHandled*/) { DEBUG_FUNCTION_NAME(_T("CppFaxServerLogging::OnHelpRequest")); switch (uMsg) { case WM_HELP: WinContextHelp(((LPHELPINFO)lParam)->dwContextId, m_hWnd); break; case WM_CONTEXTMENU: WinContextHelp(::GetWindowContextHelpId((HWND)wParam), m_hWnd); break; }
return TRUE; }
/////////////////////////////////////////////////////////////////////////////
|