mirror of https://github.com/tongzx/nt5src
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.
1349 lines
52 KiB
1349 lines
52 KiB
/*++
|
|
|
|
Copyright (c) 1997 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
faxvrfy.c
|
|
|
|
Abstract:
|
|
|
|
This module verifies the minimal functionality of the Windows NT Fax Service.
|
|
|
|
Author:
|
|
|
|
Steven Kehrli (steveke) 11/15/1997
|
|
|
|
--*/
|
|
|
|
#include <windows.h>
|
|
#include <stdlib.h>
|
|
#include <commctrl.h>
|
|
#include <shellapi.h>
|
|
#include <winfax.h>
|
|
|
|
#include "faxrcv.h"
|
|
#include "faxvrfy.h"
|
|
#include "macros.h"
|
|
#include "macros.c"
|
|
|
|
#include "resource.h"
|
|
|
|
#include "startup.c"
|
|
#include "util.c"
|
|
#include "events.c"
|
|
#include "sndthrd.c"
|
|
|
|
// fnDialogProcSetup is the Setup Dialog Procedure
|
|
LRESULT CALLBACK fnDialogProcSetup (HWND hWnd, UINT iMsg, WPARAM wParam, LPARAM lParam);
|
|
|
|
VOID
|
|
fnUsageInfo(
|
|
HWND hWnd
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Displays the usage info
|
|
|
|
Return Value:
|
|
|
|
None
|
|
|
|
--*/
|
|
{
|
|
// szHelpFile is the name of the help file
|
|
WCHAR szHelpFile[MAX_PATH];
|
|
DWORD cb;
|
|
|
|
GetCurrentDirectory(sizeof(szHelpFile) / sizeof(WCHAR), szHelpFile);
|
|
lstrcat(szHelpFile, L"\\");
|
|
lstrcat(szHelpFile, FAXVRFY_HLP);
|
|
|
|
WinHelp(hWnd, szHelpFile, HELP_FINDER, 0);
|
|
}
|
|
|
|
int WINAPI WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, PSTR szCmdLine, int iCmdShow)
|
|
{
|
|
WNDCLASSEX wndclass;
|
|
MSG msg;
|
|
|
|
// hMutex is the handle to the mutex
|
|
HANDLE hMutex;
|
|
|
|
// argvW are the command line parameters
|
|
LPWSTR *argvW;
|
|
// argc is the count of command line parameters
|
|
INT argc;
|
|
INT iIndex;
|
|
|
|
// pFaxPortsConfigLocal is a pointer to the Fax Ports Configuration
|
|
PFAX_PORT_INFO pFaxPortsConfigLocal;
|
|
// pFaxSvcConfigLocal is a pointer to the fax service configuration
|
|
PFAX_CONFIGURATION pFaxSvcConfigLocal;
|
|
// hFaxPortHandle is the handle to a port
|
|
HANDLE hFaxPortHandle;
|
|
DWORD dwIndex;
|
|
UINT uRslt;
|
|
|
|
// hFaxDevicesKey is the handle to the fax devices registry key
|
|
HKEY hFaxDevicesKey;
|
|
// hFaxPortKey is the handle to the fax port registry key
|
|
HKEY hFaxPortKey;
|
|
// szFaxPortKey is the name of the fax port registry key
|
|
TCHAR szFaxPortKey[15];
|
|
// szFixModemClass is the modem class of the fax port
|
|
LPWSTR szFixModemClass;
|
|
DWORD cb;
|
|
|
|
// szText is a text string
|
|
WCHAR szText[MAX_STRINGLEN + 2];
|
|
|
|
// Set g_hInstance
|
|
g_hInstance = hInstance;
|
|
|
|
// Initialize the wndclass
|
|
wndclass.cbSize = sizeof(wndclass);
|
|
wndclass.style = CS_HREDRAW | CS_VREDRAW;
|
|
wndclass.lpfnWndProc = fnDialogProcSetup;
|
|
wndclass.cbClsExtra = 0;
|
|
wndclass.cbWndExtra = DLGWINDOWEXTRA;
|
|
wndclass.hInstance = g_hInstance;
|
|
wndclass.hIcon = LoadIcon(NULL, IDI_WINLOGO);
|
|
wndclass.hCursor = LoadCursor(NULL, IDC_ARROW);
|
|
wndclass.hbrBackground = (HBRUSH) (COLOR_INACTIVEBORDER + 1);
|
|
wndclass.lpszMenuName = MAKEINTRESOURCE(IDR_MENU);
|
|
wndclass.lpszClassName = FAXVRFY_NAME;
|
|
wndclass.hIconSm = LoadIcon(NULL, IDI_WINLOGO);
|
|
|
|
// See if FaxVrfy is already running
|
|
hMutex = CreateMutex(NULL, FALSE, FAXVRFY_NAME);
|
|
if (GetLastError() == ERROR_ALREADY_EXISTS) {
|
|
while (TRUE) {
|
|
// Wait for access to the mutex
|
|
WaitForSingleObject(hMutex, INFINITE);
|
|
|
|
// Find the window
|
|
g_hWndDlg = FindWindow(FAXVRFY_NAME, NULL);
|
|
if (g_hWndDlg) {
|
|
// Switch to that window
|
|
ShowWindow(g_hWndDlg, SW_RESTORE);
|
|
SetForegroundWindow(g_hWndDlg);
|
|
// Release access to the mutex
|
|
ReleaseMutex(hMutex);
|
|
return 0;
|
|
}
|
|
|
|
// Release access to the mutex
|
|
ReleaseMutex(hMutex);
|
|
|
|
// See if FaxVrfy is still running
|
|
CloseHandle(hMutex);
|
|
hMutex = CreateMutex(NULL, FALSE, FAXVRFY_NAME);
|
|
if (GetLastError() == ERROR_SUCCESS) {
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Initialize the local mem
|
|
MemInitializeMacro();
|
|
|
|
// Set the default caption
|
|
SetDefaultCaptionMacro(FAXVRFY_NAME);
|
|
|
|
// Initialize the common controls
|
|
InitCommonControls();
|
|
|
|
argvW = CommandLineToArgvW(GetCommandLine(), &argc);
|
|
for (iIndex = 0; iIndex < argc; iIndex++) {
|
|
if ((!lstrcmpi(FAXVRFY_CMD_HELP_1, argvW[iIndex])) || (!lstrcmpi(FAXVRFY_CMD_HELP_2, argvW[iIndex])) || (!lstrcmpi(FAXVRFY_CMD_HELP_3, argvW[iIndex])) || (!lstrcmpi(FAXVRFY_CMD_HELP_4, argvW[iIndex]))) {
|
|
fnUsageInfo(NULL);
|
|
return 0;
|
|
}
|
|
else if ((!lstrcmpi(FAXVRFY_CMD_BVT_1, argvW[iIndex])) || (!lstrcmpi(FAXVRFY_CMD_BVT_2, argvW[iIndex]))) {
|
|
g_bBVT = TRUE;
|
|
g_bGo = FALSE;
|
|
g_bNoCheck = FALSE;
|
|
g_bRasAvailable = FALSE;
|
|
}
|
|
else if ((!lstrcmpi(FAXVRFY_CMD_SEND_1, argvW[iIndex])) || (!lstrcmpi(FAXVRFY_CMD_SEND_2, argvW[iIndex]))) {
|
|
g_bSend = TRUE;
|
|
}
|
|
else if ((!lstrcmpi(FAXVRFY_CMD_RECEIVE_1, argvW[iIndex])) || (!lstrcmpi(FAXVRFY_CMD_RECEIVE_2, argvW[iIndex]))) {
|
|
g_bSend = FALSE;
|
|
}
|
|
else if ((!g_bBVT) && ((!lstrcmpi(FAXVRFY_CMD_GO_1, argvW[iIndex])) || (!lstrcmpi(FAXVRFY_CMD_GO_2, argvW[iIndex])))) {
|
|
g_bGo = TRUE;
|
|
}
|
|
else if ((!g_bBVT) && ((!lstrcmpi(FAXVRFY_CMD_NO_CHECK_1, argvW[iIndex])) || (!lstrcmpi(FAXVRFY_CMD_NO_CHECK_2, argvW[iIndex])))) {
|
|
g_bNoCheck = TRUE;
|
|
}
|
|
}
|
|
|
|
MemFreeMacro(argvW);
|
|
|
|
// Initialize NTLog
|
|
g_bNTLogAvailable = fnInitializeNTLog();
|
|
|
|
// Start the log file
|
|
fnStartLogFile();
|
|
|
|
// Verify fax is installed
|
|
uRslt = fnIsFaxInstalled();
|
|
if (uRslt) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, uRslt, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, uRslt, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel0;
|
|
}
|
|
|
|
// Verify com objects are installed
|
|
uRslt = fnIsComInstalled();
|
|
if (uRslt) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, uRslt, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, uRslt, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel0;
|
|
}
|
|
|
|
// Initialize FaxRcv
|
|
uRslt = fnInitializeFaxRcv();
|
|
if (uRslt) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, uRslt, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, uRslt, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel0;
|
|
}
|
|
|
|
if (!g_bBVT) {
|
|
g_bRasAvailable = fnInitializeRas();
|
|
}
|
|
|
|
// Create the Start event
|
|
g_hStartEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
// Create the Stop event
|
|
g_hStopEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
// Create the Exit event
|
|
g_hExitEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
// Create the Fax event
|
|
g_hFaxEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
// Create the RAS Passed event
|
|
g_hRasPassedEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
// Create the RAS Failed event
|
|
g_hRasFailedEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
// Create the Send Passed event
|
|
g_hSendPassedEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
// Create the Send Failed event
|
|
g_hSendFailedEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
|
|
|
// Connect to the Fax Service
|
|
if (!FaxConnectFaxServer(NULL, &g_hFaxSvcHandle)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_CONNECT_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_CONNECT_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel1;
|
|
}
|
|
|
|
// Get the Fax Ports Configuration
|
|
if (!FaxEnumPorts(g_hFaxSvcHandle, &g_pFaxPortsConfig, &g_dwNumPorts)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_ENUM_PORTS_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_ENUM_PORTS_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel2;
|
|
}
|
|
|
|
if (!g_dwNumPorts) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_PORTS_NOT_INSTALLED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_PORTS_NOT_INSTALLED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel3;
|
|
}
|
|
g_dwNumAvailPorts = g_dwNumPorts;
|
|
|
|
// Get the Fax Ports Configuration
|
|
if (!FaxEnumPorts(g_hFaxSvcHandle, &pFaxPortsConfigLocal, &g_dwNumPorts)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_ENUM_PORTS_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_ENUM_PORTS_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel3;
|
|
}
|
|
|
|
// Set the Fax Ports Configuration
|
|
for (dwIndex = 0; dwIndex < g_dwNumPorts; dwIndex++) {
|
|
pFaxPortsConfigLocal[dwIndex].Flags = FPF_RECEIVE | FPF_SEND;
|
|
if (!FaxOpenPort(g_hFaxSvcHandle, pFaxPortsConfigLocal[dwIndex].DeviceId, PORT_OPEN_MODIFY, &hFaxPortHandle)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_SET_PORT_FAILED, MB_ICONERROR, pFaxPortsConfigLocal[dwIndex].DeviceName);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_SET_PORT_FAILED, szText, MAX_STRINGLEN);
|
|
lstrcat(szText, L"\r\n");
|
|
fnWriteLogFile(TRUE, szText, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, szText, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
}
|
|
|
|
// Free the Fax Ports Configuration
|
|
FaxFreeBuffer(pFaxPortsConfigLocal);
|
|
goto ExitLevel4;
|
|
}
|
|
|
|
if (!FaxSetPort(hFaxPortHandle, (PFAX_PORT_INFO) &pFaxPortsConfigLocal[dwIndex])) {
|
|
FaxClose(hFaxPortHandle);
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_SET_PORT_FAILED, MB_ICONERROR, pFaxPortsConfigLocal[dwIndex].DeviceName);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_SET_PORT_FAILED, szText, MAX_STRINGLEN);
|
|
lstrcat(szText, L"\r\n");
|
|
fnWriteLogFile(TRUE, szText, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, szText, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
}
|
|
|
|
// Free the Fax Ports Configuration
|
|
FaxFreeBuffer(pFaxPortsConfigLocal);
|
|
goto ExitLevel4;
|
|
}
|
|
|
|
FaxClose(hFaxPortHandle);
|
|
}
|
|
|
|
// Free the Fax Ports Configuration
|
|
FaxFreeBuffer(pFaxPortsConfigLocal);
|
|
|
|
// Get the modem fax class
|
|
if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, FAXDEVICES_REGKEY, 0, KEY_ALL_ACCESS, &hFaxDevicesKey)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_OPEN_FAXDEVICES_REGKEY_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_OPEN_FAXDEVICES_REGKEY_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
goto ExitLevel4;
|
|
}
|
|
|
|
for (dwIndex = 0; dwIndex < g_dwNumPorts; dwIndex++) {
|
|
// Initialize the string representation of the DeviceId
|
|
ZeroMemory(szFaxPortKey, sizeof(szFaxPortKey));
|
|
// Set the string representation of the DeviceId
|
|
wsprintf(szFaxPortKey, L"%08u", g_pFaxPortsConfig[dwIndex].DeviceId);
|
|
lstrcat(szFaxPortKey, MODEM_REGKEY);
|
|
|
|
szFixModemClass = NULL;
|
|
if (!RegOpenKeyEx(hFaxDevicesKey, szFaxPortKey, 0, KEY_ALL_ACCESS, &hFaxPortKey)) {
|
|
if (!RegQueryValueEx(hFaxPortKey, FIXMODEMCLASS_REGVALUE, NULL, NULL, NULL, &cb)) {
|
|
if (cb) {
|
|
szFixModemClass = MemAllocMacro(cb);
|
|
if (RegQueryValueEx(hFaxPortKey, FIXMODEMCLASS_REGVALUE, NULL, NULL, (PBYTE) szFixModemClass, &cb)) {
|
|
MemFreeMacro(szFixModemClass);
|
|
szFixModemClass = NULL;
|
|
}
|
|
else if (!lstrcmp(L"", szFixModemClass)) {
|
|
MemFreeMacro(szFixModemClass);
|
|
szFixModemClass = NULL;
|
|
}
|
|
}
|
|
}
|
|
|
|
RegCloseKey(hFaxPortKey);
|
|
}
|
|
|
|
if (!szFixModemClass) {
|
|
szFixModemClass = MemAllocMacro(2 * sizeof(WCHAR));
|
|
lstrcpy(szFixModemClass, L"1");
|
|
}
|
|
|
|
LoadString(g_hInstance, IDS_FIXMODEMCLASS_DATA, szText, MAX_STRINGLEN);
|
|
lstrcat(szText, L"\r\n");
|
|
fnWriteLogFile(TRUE, szText, g_pFaxPortsConfig[dwIndex].DeviceName, szFixModemClass);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, szText, g_pFaxPortsConfig[dwIndex].DeviceName, szFixModemClass);
|
|
}
|
|
|
|
MemFreeMacro(szFixModemClass);
|
|
}
|
|
|
|
RegCloseKey(hFaxDevicesKey);
|
|
fnWriteLogFile(FALSE, L"\r\n");
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, L"\r\n");
|
|
}
|
|
|
|
// Get the Fax Service Configuration
|
|
if (!FaxGetConfiguration(g_hFaxSvcHandle, &g_pFaxSvcConfig)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_GET_CONFIG_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_GET_CONFIG_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel4;
|
|
}
|
|
|
|
// Get the Fax Service Configuration
|
|
if (!FaxGetConfiguration(g_hFaxSvcHandle, &pFaxSvcConfigLocal)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_GET_CONFIG_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_GET_CONFIG_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel5;
|
|
}
|
|
|
|
// Set the Fax Service Configuration
|
|
pFaxSvcConfigLocal->Retries = FAXSVC_RETRIES;
|
|
pFaxSvcConfigLocal->RetryDelay = FAXSVC_RETRYDELAY;
|
|
pFaxSvcConfigLocal->UseDeviceTsid = FALSE;
|
|
if (!FaxSetConfiguration(g_hFaxSvcHandle, pFaxSvcConfigLocal)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_SET_CONFIG_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_SET_CONFIG_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
// Free the Fax Service Configuration
|
|
FaxFreeBuffer(pFaxSvcConfigLocal);
|
|
goto ExitLevel5;
|
|
}
|
|
|
|
// Free the Fax Service Configuration
|
|
FaxFreeBuffer(pFaxSvcConfigLocal);
|
|
|
|
// Create the completion port
|
|
g_hCompletionPort = CreateIoCompletionPort(INVALID_HANDLE_VALUE, NULL, 0, 1);
|
|
// Initialize the Fax Event Queue
|
|
if (!FaxInitializeEventQueue(g_hFaxSvcHandle, g_hCompletionPort, 0, NULL, 0)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_EVENT_QUEUE_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_EVENT_QUEUE_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
|
|
goto ExitLevel6;
|
|
}
|
|
|
|
// Create the Fax Event Queue thread
|
|
CreateThread(NULL, 0, fnFaxEventQueueProc, NULL, 0, NULL);
|
|
|
|
// Create the Send thread
|
|
CreateThread(NULL, 0, fnSendProc, NULL, 0, NULL);
|
|
|
|
if (g_bBVT) {
|
|
wndclass.lpszMenuName = NULL;
|
|
}
|
|
|
|
RegisterClassEx(&wndclass);
|
|
|
|
// Create the Setup Dialog
|
|
g_hWndDlg = CreateDialog(g_hInstance, MAKEINTRESOURCE(IDD_SETUP), NULL, NULL);
|
|
SendMessage(g_hWndDlg, UM_FAXVRFY_INITIALIZE, 0, 0);
|
|
|
|
ShowWindow(g_hWndDlg, iCmdShow);
|
|
UpdateWindow(g_hWndDlg);
|
|
|
|
if ((g_bBVT) || (g_bGo)) {
|
|
PostMessage(GetDlgItem(g_hWndDlg, IDC_START_BUTTON), BM_CLICK, 0, 0);
|
|
}
|
|
|
|
while (GetMessage(&msg, NULL, 0, 0)) {
|
|
if (!IsDialogMessage(g_hWndDlg, &msg)) {
|
|
TranslateMessage(&msg);
|
|
DispatchMessage(&msg);
|
|
}
|
|
}
|
|
|
|
ExitLevel6:
|
|
if (g_hCompletionPort) {
|
|
CloseHandle(g_hCompletionPort);
|
|
}
|
|
|
|
// Restore the Fax Service Configuration
|
|
if (!FaxSetConfiguration(g_hFaxSvcHandle, g_pFaxSvcConfig)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_RESTORE_CONFIG_FAILED, MB_ICONERROR);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_RESTORE_CONFIG_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
}
|
|
|
|
ExitLevel5:
|
|
// Free the Fax Service Configuration
|
|
FaxFreeBuffer(g_pFaxSvcConfig);
|
|
|
|
ExitLevel4:
|
|
// Restore the Fax Ports Configuration
|
|
for (dwIndex = 0; dwIndex < g_dwNumPorts; dwIndex++) {
|
|
if (!FaxOpenPort(g_hFaxSvcHandle, g_pFaxPortsConfig[dwIndex].DeviceId, PORT_OPEN_MODIFY, &hFaxPortHandle)) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_RESTORE_PORT_FAILED, MB_ICONERROR, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_RESTORE_PORT_FAILED, szText, MAX_STRINGLEN);
|
|
lstrcat(szText, L"\r\n");
|
|
fnWriteLogFile(TRUE, szText, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, szText, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
}
|
|
|
|
continue;
|
|
}
|
|
|
|
if (!FaxSetPort(hFaxPortHandle, &g_pFaxPortsConfig[dwIndex])) {
|
|
if (!g_bBVT) {
|
|
MessageBoxMacro(NULL, IDS_FAX_RESTORE_PORT_FAILED, MB_ICONERROR, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
}
|
|
g_bTestFailed = TRUE;
|
|
|
|
LoadString(g_hInstance, IDS_FAX_RESTORE_PORT_FAILED, szText, MAX_STRINGLEN);
|
|
lstrcat(szText, L"\r\n");
|
|
fnWriteLogFile(TRUE, szText, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_SEV2 | TL_TEST, szText, g_pFaxPortsConfig[dwIndex].DeviceName);
|
|
}
|
|
}
|
|
|
|
FaxClose(hFaxPortHandle);
|
|
}
|
|
|
|
ExitLevel3:
|
|
// Free the Fax Ports Configuration
|
|
FaxFreeBuffer(g_pFaxPortsConfig);
|
|
|
|
ExitLevel2:
|
|
// Disconnect from the Fax Service
|
|
FaxClose(g_hFaxSvcHandle);
|
|
|
|
ExitLevel1:
|
|
CloseHandle(g_hSendFailedEvent);
|
|
CloseHandle(g_hSendPassedEvent);
|
|
CloseHandle(g_hRasFailedEvent);
|
|
CloseHandle(g_hRasPassedEvent);
|
|
CloseHandle(g_hFaxEvent);
|
|
CloseHandle(g_hExitEvent);
|
|
CloseHandle(g_hStopEvent);
|
|
CloseHandle(g_hStartEvent);
|
|
|
|
if (g_bRasAvailable) {
|
|
FreeLibrary(g_RasApi.hInstance);
|
|
}
|
|
|
|
ExitLevel0:
|
|
fnWriteLogFile(FALSE, L"\r\n");
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, L"\r\n");
|
|
}
|
|
|
|
if ((g_bTestFailed) || (g_dwNumTotal)) {
|
|
if (g_dwNumTotal) {
|
|
// Log the results
|
|
LoadString(g_hInstance, IDS_NUM_PASSED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(FALSE, szText, g_dwNumPassed);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, szText, g_dwNumPassed);
|
|
}
|
|
|
|
LoadString(g_hInstance, IDS_NUM_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(FALSE, szText, g_dwNumFailed);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, szText, g_dwNumFailed);
|
|
}
|
|
|
|
LoadString(g_hInstance, IDS_NUM_TOTAL, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(FALSE, szText, g_dwNumTotal);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, szText, g_dwNumTotal);
|
|
}
|
|
}
|
|
|
|
if ((g_bTestFailed) || (g_dwNumFailed)) {
|
|
fnWriteLogFile(FALSE, L"\r\n");
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, L"\r\n");
|
|
}
|
|
|
|
LoadString(g_hInstance, IDS_STATUS_TEST_FAILED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(FALSE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
}
|
|
else {
|
|
fnWriteLogFile(FALSE, L"\r\n");
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, L"\r\n");
|
|
}
|
|
|
|
LoadString(g_hInstance, IDS_STATUS_TEST_PASSED, szText, MAX_STRINGLEN);
|
|
fnWriteLogFile(FALSE, L"%s\r\n", szText);
|
|
if (g_bNTLogAvailable) {
|
|
g_NTLogApi.ptlLog(g_hLogFile, TLS_INFO | TL_TEST, L"%s\r\n", szText);
|
|
}
|
|
}
|
|
}
|
|
|
|
// Close the log file
|
|
fnCloseLogFile();
|
|
|
|
CloseHandle(hMutex);
|
|
|
|
return 0;
|
|
}
|
|
|
|
LRESULT CALLBACK fnDialogProcSetup (HWND hWnd, UINT iMsg, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
// hWndStatusList is the handle to the Status List
|
|
static HWND hWndStatusList;
|
|
// rcClient is the WindowRect of the Status List
|
|
RECT rcClient;
|
|
// lvc specifies the attributes of a particular column of the Status List
|
|
LV_COLUMN lvc;
|
|
// lvi specifies the attributes of a particular item of the Status List
|
|
LV_ITEM lvi;
|
|
|
|
// szText is a text string
|
|
WCHAR szText[MAX_STRINGLEN + 1];
|
|
// szFormatString is the format of the text string
|
|
WCHAR szFormatString[MAX_STRINGLEN + 1];
|
|
// szRasError is the Ras error string
|
|
WCHAR szRasError[MAX_STRINGLEN + 1];
|
|
|
|
// dwResourceId is the resource id
|
|
DWORD dwResourceId;
|
|
// szDeviceName is the device name
|
|
LPWSTR szDeviceName;
|
|
|
|
// szIniFile is the ini file name
|
|
static WCHAR szIniFile[_MAX_PATH + 1];
|
|
|
|
// szMissingInfo is the missing info
|
|
WCHAR szMissingInfo[MAX_STRINGLEN + 1];
|
|
// szMissingInfoError is the missing info error message
|
|
WCHAR szMissingInfoError[(MAX_STRINGLEN * 5) + 1];
|
|
|
|
DWORD dwStyle;
|
|
DWORD dwLevel;
|
|
|
|
switch (iMsg) {
|
|
case WM_CREATE:
|
|
// Get the Rect of the Setup Dialog
|
|
GetWindowRect(hWnd, &rcClient);
|
|
if (!g_bBVT) {
|
|
// Increase the bottom of the Setup Dialog Rect by the height of the menu
|
|
rcClient.bottom += GetSystemMetrics(SM_CYMENU);
|
|
}
|
|
// Resize the Setup Dialog
|
|
SetWindowPos(hWnd, NULL, 0, 0, rcClient.right - rcClient.left, rcClient.bottom - rcClient.top, SWP_NOMOVE | SWP_NOZORDER);
|
|
break;
|
|
|
|
case UM_FAXVRFY_INITIALIZE:
|
|
CheckMenuItem(GetMenu(hWnd), IDM_SEND, MF_BYCOMMAND | g_bSend ? MF_CHECKED : MF_UNCHECKED);
|
|
CheckMenuItem(GetMenu(hWnd), IDM_RECEIVE, MF_BYCOMMAND | g_bSend ? MF_UNCHECKED : MF_CHECKED);
|
|
|
|
// Limit the text length of edit controls
|
|
SendMessage(GetDlgItem(hWnd, IDC_SEND_NUMBER), EM_SETLIMITTEXT, PHONE_NUM_LEN, 0);
|
|
SendMessage(GetDlgItem(hWnd, IDC_RECEIVE_NUMBER), EM_SETLIMITTEXT, PHONE_NUM_LEN, 0);
|
|
SendMessage(GetDlgItem(hWnd, IDC_RAS_USER_NAME), EM_SETLIMITTEXT, UNLEN, 0);
|
|
SendMessage(GetDlgItem(hWnd, IDC_RAS_PASSWORD), EM_SETLIMITTEXT, PWLEN, 0);
|
|
SendMessage(GetDlgItem(hWnd, IDC_RAS_DOMAIN), EM_SETLIMITTEXT, DNLEN, 0);
|
|
|
|
// Get the handle to the Status List
|
|
hWndStatusList = GetDlgItem(hWnd, IDC_STATUS_LIST);
|
|
// Get the Rect of the Status List
|
|
GetWindowRect(hWndStatusList, &rcClient);
|
|
|
|
// Set common attributes for each column
|
|
lvc.mask = LVCF_FMT | LVCF_WIDTH | LVCF_TEXT | LVCF_SUBITEM;
|
|
lvc.fmt = LVCFMT_LEFT;
|
|
|
|
// Event Column
|
|
// Load the Event Column text
|
|
LoadString(g_hInstance, IDS_EVENT_LABEL, szText, MAX_STRINGLEN);
|
|
// Set the column text
|
|
lvc.pszText = szText;
|
|
// Set the width of the column to be about 2 / 5 of the width of the Status List, allowing for the width of the borders and scroll bar
|
|
lvc.cx = ((rcClient.right - rcClient.left - 4 * GetSystemMetrics(SM_CXBORDER) - GetSystemMetrics(SM_CXVSCROLL)) * 2) / 5;
|
|
// Indicate this is the first column
|
|
lvc.iSubItem = 0;
|
|
// Insert column into Status List
|
|
ListView_InsertColumn(hWndStatusList, 0, &lvc);
|
|
|
|
// Port Column
|
|
// Load the Port Column text
|
|
LoadString(g_hInstance, IDS_PORT_LABEL, szText, MAX_STRINGLEN);
|
|
// Set the column text
|
|
lvc.pszText = szText;
|
|
// Set the width of the column to be about 3 / 5 of the width of the Status List, allowing for the width of the borders and scroll bar
|
|
lvc.cx = (lvc.cx * 3) / 2;
|
|
// Indicate this is the second column
|
|
lvc.iSubItem = 1;
|
|
// Insert column into Status List
|
|
ListView_InsertColumn(hWndStatusList, 1, &lvc);
|
|
|
|
// Disable the Stop Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_STOP_BUTTON), FALSE);
|
|
|
|
// Get the current directory
|
|
GetCurrentDirectory(sizeof(szIniFile) / sizeof(WCHAR), szIniFile);
|
|
// Set the ini file name
|
|
lstrcat(szIniFile, L"\\");
|
|
lstrcat(szIniFile, FAXVRFY_INI);
|
|
|
|
// Get the strings from the ini file
|
|
GetPrivateProfileString(L"Fax", L"SendNumber", L"", g_szSndNumber, sizeof(g_szSndNumber), szIniFile);
|
|
if (fnIsStringASCII(g_szSndNumber)) {
|
|
SetDlgItemText(hWnd, IDC_SEND_NUMBER, g_szSndNumber);
|
|
}
|
|
else {
|
|
ZeroMemory(g_szSndNumber, sizeof(g_szSndNumber));
|
|
}
|
|
GetPrivateProfileString(L"Fax", L"ReceiveNumber", L"", g_szRcvNumber, sizeof(g_szRcvNumber), szIniFile);
|
|
if (fnIsStringASCII(g_szRcvNumber)) {
|
|
SetDlgItemText(hWnd, IDC_RECEIVE_NUMBER, g_szRcvNumber);
|
|
}
|
|
else {
|
|
ZeroMemory(g_szRcvNumber, sizeof(g_szRcvNumber));
|
|
}
|
|
|
|
if (g_bRasAvailable) {
|
|
if (GetPrivateProfileInt(L"RAS", L"Enabled", 0, szIniFile)) {
|
|
// Click the Fax Send check button
|
|
SendMessage(GetDlgItem(hWnd, IDC_RAS_ENABLED_BUTTON), BM_CLICK, 0, 0);
|
|
}
|
|
}
|
|
GetPrivateProfileString(L"RAS", L"UserName", L"", g_szRasUserName, sizeof(g_szRasUserName), szIniFile);
|
|
SetDlgItemText(hWnd, IDC_RAS_USER_NAME, g_szRasUserName);
|
|
ZeroMemory(g_szRasPassword, sizeof(g_szRasPassword));
|
|
GetPrivateProfileString(L"RAS", L"Domain", L"", g_szRasDomain, sizeof(g_szRasDomain), szIniFile);
|
|
SetDlgItemText(hWnd, IDC_RAS_DOMAIN, g_szRasDomain);
|
|
|
|
SendMessage(hWnd, UM_FAXVRFY_RESET, 0, 0);
|
|
|
|
return 0;
|
|
|
|
case UM_FAXVRFY_RESET:
|
|
// Enable or disable the Fax specific controls
|
|
EnableWindow(GetDlgItem(hWnd, IDC_SEND_NUMBER_STATIC), (!wParam && g_bSend) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_SEND_NUMBER), (!wParam && g_bSend) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RECEIVE_NUMBER_STATIC), (!wParam && g_bSend) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RECEIVE_NUMBER), (!wParam && g_bSend) ? TRUE : FALSE);
|
|
|
|
// Enable the RAS specific controls
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_ENABLED_BUTTON), (!wParam && g_bSend && g_bRasAvailable) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_USER_NAME_STATIC), (!wParam && g_bSend && g_bRasEnabled && g_bRasAvailable) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_USER_NAME), (!wParam && g_bSend && g_bRasEnabled && g_bRasAvailable) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_PASSWORD_STATIC), (!wParam && g_bSend && g_bRasEnabled && g_bRasAvailable) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_PASSWORD), (!wParam && g_bSend && g_bRasEnabled && g_bRasAvailable) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_DOMAIN_STATIC), (!wParam && g_bSend && g_bRasEnabled && g_bRasAvailable) ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_DOMAIN), (!wParam && g_bSend && g_bRasEnabled && g_bRasAvailable) ? TRUE : FALSE);
|
|
|
|
if (wParam) {
|
|
// Disable the Start Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_START_BUTTON), FALSE);
|
|
// Disable the Stop Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_STOP_BUTTON), FALSE);
|
|
// Enable the Exit Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_EXIT_BUTTON), TRUE);
|
|
|
|
// Disable the Option Menu
|
|
EnableMenuItem(GetMenu(hWnd), IDM_SEND, MF_BYCOMMAND | MF_GRAYED);
|
|
EnableMenuItem(GetMenu(hWnd), IDM_RECEIVE, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
// Set the focus to the Exit button
|
|
SendMessage(hWnd, WM_NEXTDLGCTL, (WPARAM) GetDlgItem(hWnd, IDC_EXIT_BUTTON), MAKELONG(TRUE, 0));
|
|
}
|
|
else {
|
|
// Enable the Start Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_START_BUTTON), TRUE);
|
|
// Disable the Stop Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_STOP_BUTTON), FALSE);
|
|
// Enable the Exit Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_EXIT_BUTTON), TRUE);
|
|
|
|
// Enable the Option Menu
|
|
EnableMenuItem(GetMenu(hWnd), IDM_SEND, MF_BYCOMMAND | MF_ENABLED);
|
|
EnableMenuItem(GetMenu(hWnd), IDM_RECEIVE, MF_BYCOMMAND | MF_ENABLED);
|
|
|
|
// Set the focus to the Start button
|
|
SendMessage(hWnd, WM_NEXTDLGCTL, (WPARAM) GetDlgItem(hWnd, IDC_START_BUTTON), MAKELONG(TRUE, 0));
|
|
}
|
|
return 0;
|
|
|
|
case UM_TIMEOUT_ENDED:
|
|
case UM_FAXSVC_ENDED:
|
|
g_bTestFailed = TRUE;
|
|
|
|
if (iMsg == UM_TIMEOUT_ENDED) {
|
|
// Update the status
|
|
SendMessage(hWnd, UM_UPDATE_STATUS, IDS_STATUS_TIMEOUT_ENDED, 0);
|
|
}
|
|
else if (iMsg == UM_FAXSVC_ENDED) {
|
|
// Post a completion packet to a completion port to exit the Fax Event Queue thread
|
|
fnPostExitToCompletionPort(g_hCompletionPort);
|
|
// Update the status
|
|
SendMessage(hWnd, UM_UPDATE_STATUS, IDS_STATUS_FAXSVC_ENDED, 0);
|
|
}
|
|
|
|
if ((!IsWindowEnabled(GetDlgItem(hWnd, IDC_START_BUTTON))) && (g_bSend)) {
|
|
// Update the status
|
|
SendMessage(hWnd, UM_ITERATION_FAILED, 0, 0);
|
|
}
|
|
|
|
SendMessage(hWnd, UM_FAXVRFY_RESET, 1, 0);
|
|
|
|
if (g_bBVT) {
|
|
SendMessage(GetDlgItem(g_hWndDlg, IDC_EXIT_BUTTON), BM_CLICK, 0, 0);
|
|
}
|
|
|
|
return 0;
|
|
|
|
case UM_ITERATION_STOPPED:
|
|
// Update the status
|
|
SendMessage(hWnd, UM_UPDATE_STATUS, IDS_STATUS_ITERATION_STOPPED, 0);
|
|
SendMessage(hWnd, UM_FAXVRFY_RESET, 0, 0);
|
|
|
|
return 0;
|
|
|
|
case UM_ITERATION_PASSED:
|
|
// Update the status
|
|
SendMessage(hWnd, UM_UPDATE_STATUS, IDS_STATUS_ITERATION_PASSED, 0);
|
|
SendMessage(hWnd, UM_FAXVRFY_RESET, 0, 0);
|
|
|
|
// Update the iterations
|
|
g_dwNumPassed++;
|
|
g_dwNumTotal++;
|
|
SetDlgItemInt(hWnd, IDC_NUM_PASSED, g_dwNumPassed, FALSE);
|
|
SetDlgItemInt(hWnd, IDC_NUM_TOTAL, g_dwNumTotal, FALSE);
|
|
|
|
if (g_bBVT) {
|
|
SendMessage(GetDlgItem(g_hWndDlg, IDC_EXIT_BUTTON), BM_CLICK, 0, 0);
|
|
}
|
|
|
|
return 0;
|
|
|
|
case UM_ITERATION_FAILED:
|
|
// Update the status
|
|
SendMessage(hWnd, UM_UPDATE_STATUS, IDS_STATUS_ITERATION_FAILED, 0);
|
|
SendMessage(hWnd, UM_FAXVRFY_RESET, 0, 0);
|
|
|
|
// Update the iterations
|
|
g_dwNumFailed++;
|
|
g_dwNumTotal++;
|
|
SetDlgItemInt(hWnd, IDC_NUM_FAILED, g_dwNumFailed, FALSE);
|
|
SetDlgItemInt(hWnd, IDC_NUM_TOTAL, g_dwNumTotal, FALSE);
|
|
|
|
if (g_bBVT) {
|
|
SendMessage(GetDlgItem(g_hWndDlg, IDC_EXIT_BUTTON), BM_CLICK, 0, 0);
|
|
}
|
|
|
|
return 0;
|
|
|
|
case UM_UPDATE_STATUS:
|
|
dwStyle = TLS_INFO;
|
|
dwLevel = TLS_VARIATION;
|
|
|
|
// Get the resource id
|
|
dwResourceId = (DWORD) wParam;
|
|
|
|
// Load the event text
|
|
LoadString(g_hInstance, dwResourceId, szFormatString, MAX_STRINGLEN);
|
|
|
|
// Set the event text
|
|
lstrcpy(szText, szFormatString);
|
|
szDeviceName = NULL;
|
|
|
|
switch (wParam) {
|
|
case IDS_STATUS_ITERATION_PASSED:
|
|
dwStyle = TLS_PASS;
|
|
break;
|
|
|
|
case IDS_STATUS_ITERATION_FAILED:
|
|
dwStyle = TLS_SEV2;
|
|
break;
|
|
|
|
case IDS_STATUS_TEST_PASSED:
|
|
dwStyle = TLS_PASS;
|
|
dwLevel = TL_TEST;
|
|
break;
|
|
|
|
case IDS_STATUS_RAS_FAILED:
|
|
case IDS_STATUS_TIMEOUT_ENDED:
|
|
case IDS_STATUS_FAX_SEND_FAILED:
|
|
case IDS_STATUS_FAX_INVALID:
|
|
case IDS_TIFF_INVALID_TIFF:
|
|
case IDS_TIFF_INVALID_IMAGEWIDTH:
|
|
case IDS_TIFF_INVALID_IMAGELENGTH:
|
|
case IDS_TIFF_INVALID_COMPRESSION:
|
|
case IDS_TIFF_INVALID_PHOTOMETRIC:
|
|
case IDS_TIFF_INVALID_XRESOLUTION:
|
|
case IDS_TIFF_INVALID_YRESOLUTION:
|
|
case IDS_TIFF_INVALID_SOFTWARE:
|
|
case IDS_TIFF_INVALID_PAGES:
|
|
case IDS_STATUS_FAX_NO_DIAL_TONE_ABORT:
|
|
case IDS_STATUS_FAX_BUSY_ABORT:
|
|
case IDS_STATUS_FAX_NO_ANSWER_ABORT:
|
|
case IDS_STATUS_FAX_FATAL_ERROR_ABORT:
|
|
dwStyle = TLS_SEV2;
|
|
break;
|
|
|
|
case IDS_STATUS_FAXSVC_ENDED:
|
|
dwStyle = TLS_SEV2;
|
|
dwLevel = TL_TEST;
|
|
break;
|
|
|
|
case IDS_STATUS_RAS_SPEED_SUSPECT:
|
|
case IDS_STATUS_FAX_NO_DIAL_TONE_RETRY:
|
|
case IDS_STATUS_FAX_BUSY_RETRY:
|
|
case IDS_STATUS_FAX_NO_ANSWER_RETRY:
|
|
case IDS_STATUS_FAX_FATAL_ERROR_RETRY:
|
|
case IDS_STATUS_FAX_FATAL_ERROR:
|
|
case IDS_STATUS_FAX_ABORTING:
|
|
dwStyle = TLS_WARN;
|
|
break;
|
|
|
|
case IDS_STATUS_DEVICE_POWERED_OFF:
|
|
case IDS_STATUS_DEVICE_POWERED_ON:
|
|
case IDS_STATUS_PORTS_NOT_AVAILABLE:
|
|
case IDS_STATUS_UNEXPECTED_STATE:
|
|
dwStyle = TLS_WARN;
|
|
dwLevel = TL_TEST;
|
|
break;
|
|
}
|
|
|
|
switch (wParam) {
|
|
case IDS_TIFF_INVALID_PAGES:
|
|
// Set the event text
|
|
wsprintf(szText, szFormatString, (DWORD) lParam, g_bBVT ? FAXBVT_PAGES : FAXWHQL_PAGES);
|
|
break;
|
|
|
|
case IDS_STATUS_RAS_STARTING:
|
|
case IDS_STATUS_FAX_STARTING:
|
|
// Set the event text
|
|
wsprintf(szText, szFormatString, (LPWSTR) lParam);
|
|
break;
|
|
|
|
case IDS_STATUS_RAS_LINESPEED:
|
|
// Set the event text
|
|
wsprintf(szText, szFormatString, ((PRAS_INFO) lParam)->dwBps);
|
|
|
|
// Find the device name
|
|
szDeviceName = ((PRAS_INFO) lParam)->szDeviceName;
|
|
break;
|
|
|
|
case IDS_STATUS_RAS_SPEED_SUSPECT:
|
|
// Set the exent text
|
|
wsprintf(szText, szFormatString, (DWORD) lParam);
|
|
break;
|
|
|
|
case IDS_STATUS_RAS_FAILED:
|
|
// Initialize szRasError
|
|
ZeroMemory(szRasError, sizeof(szRasError));
|
|
if (lParam) {
|
|
g_RasApi.RasGetErrorString((DWORD) lParam, szRasError, sizeof(szRasError) / sizeof(WCHAR));
|
|
}
|
|
|
|
// Set the event text
|
|
wsprintf(szText, szFormatString, szRasError);
|
|
break;
|
|
|
|
case IDS_STATUS_FAX_DIALING:
|
|
// Set the event text
|
|
wsprintf(szText, szFormatString, ((PFAX_DIALING_INFO) lParam)->dwAttempt);
|
|
|
|
// Find the device name
|
|
fnFindDeviceName(g_pFaxPortsConfig, g_dwNumPorts, ((PFAX_DIALING_INFO) lParam)->dwDeviceId, &szDeviceName);
|
|
break;
|
|
|
|
case IDS_STATUS_FAX_RECEIVED:
|
|
// Set the event text
|
|
wsprintf(szText, szFormatString, ((PFAX_RECEIVE_INFO) lParam)->szCopyTiffName);
|
|
|
|
// Find the device name
|
|
fnFindDeviceName(g_pFaxPortsConfig, g_dwNumPorts, ((PFAX_RECEIVE_INFO) lParam)->dwDeviceId, &szDeviceName);
|
|
|
|
break;
|
|
|
|
case IDS_STATUS_FAX_ID:
|
|
// Set the event text
|
|
wsprintf(szText, szFormatString, (LPWSTR) lParam);
|
|
|
|
break;
|
|
|
|
case IDS_STATUS_FAX_VERIFYING:
|
|
// Set the event text
|
|
wsprintf(szText, szFormatString, (LPWSTR) lParam);
|
|
break;
|
|
|
|
default:
|
|
// Find the device name
|
|
fnFindDeviceName(g_pFaxPortsConfig, g_dwNumPorts, (DWORD) lParam, &szDeviceName);
|
|
break;
|
|
}
|
|
|
|
// Indicate only pszText is valid
|
|
lvi.mask = LVIF_TEXT;
|
|
|
|
// Set the Event text
|
|
lvi.pszText = szText;
|
|
// Set the item number
|
|
lvi.iItem = ListView_GetItemCount(hWndStatusList);
|
|
// Indicate this is the first column
|
|
lvi.iSubItem = 0;
|
|
// Insert item into Status List
|
|
ListView_InsertItem(hWndStatusList, &lvi);
|
|
|
|
// Set the Port text
|
|
lvi.pszText = szDeviceName;
|
|
// Indicate this is the second column
|
|
lvi.iSubItem = 1;
|
|
// Set item in Status List
|
|
ListView_SetItem(hWndStatusList, &lvi);
|
|
|
|
if (szDeviceName) {
|
|
DebugMacro(L"%s: %s\n", szDeviceName, szText);
|
|
}
|
|
else {
|
|
DebugMacro(L"%s\n", szText);
|
|
}
|
|
|
|
if (szDeviceName) {
|
|
fnWriteLogFile(TRUE, L"%s: %s\r\n", szDeviceName, szText);
|
|
}
|
|
else {
|
|
fnWriteLogFile(TRUE, L"%s\r\n", szText);
|
|
}
|
|
|
|
if (g_bNTLogAvailable) {
|
|
if (szDeviceName) {
|
|
switch (dwLevel) {
|
|
case TLS_TEST:
|
|
g_NTLogApi.ptlLog(g_hLogFile, dwStyle | TL_TEST, L"%s: %s\r\n", szDeviceName, szText);
|
|
break;
|
|
|
|
case TLS_VARIATION:
|
|
g_NTLogApi.ptlLog(g_hLogFile, dwStyle | TL_VARIATION, L"%s: %s\r\n", szDeviceName, szText);
|
|
break;
|
|
}
|
|
}
|
|
else {
|
|
switch (dwLevel) {
|
|
case TLS_TEST:
|
|
g_NTLogApi.ptlLog(g_hLogFile, dwStyle | TL_TEST, L"%s\r\n", szText);
|
|
break;
|
|
|
|
case TLS_VARIATION:
|
|
g_NTLogApi.ptlLog(g_hLogFile, dwStyle | TL_VARIATION, L"%s\r\n", szText);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Scroll the Status List
|
|
ListView_EnsureVisible(hWndStatusList, lvi.iItem, FALSE);
|
|
return 0;
|
|
|
|
case WM_SETFOCUS:
|
|
// Verify correct control has the focus
|
|
if ((!IsWindowEnabled(GetDlgItem(hWnd, IDC_STOP_BUTTON))) && (SendMessage(GetDlgItem(hWnd, IDC_STOP_BUTTON), WM_GETDLGCODE, 0, 0) & DLGC_DEFPUSHBUTTON)) {
|
|
// Set the focus to the start button
|
|
SendMessage(hWnd, WM_NEXTDLGCTL, (WPARAM) GetDlgItem(hWnd, IDC_START_BUTTON), MAKELONG(TRUE, 0));
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_CLOSE:
|
|
if (IsWindowEnabled(GetDlgItem(hWnd, IDC_EXIT_BUTTON))) {
|
|
// Signal the Exit event
|
|
SetEvent(g_hExitEvent);
|
|
// Post a completion packet to a completion port to exit the Fax Event Queue thread
|
|
fnPostExitToCompletionPort(g_hCompletionPort);
|
|
// Close the application
|
|
DestroyWindow(hWnd);
|
|
PostQuitMessage(0);
|
|
}
|
|
return 0;
|
|
|
|
case WM_COMMAND:
|
|
switch (LOWORD(wParam)) {
|
|
case IDM_SEND:
|
|
if (!g_bSend) {
|
|
g_bSend = TRUE;
|
|
CheckMenuItem(GetMenu(hWnd), IDM_SEND, MF_BYCOMMAND | MF_CHECKED);
|
|
CheckMenuItem(GetMenu(hWnd), IDM_RECEIVE, MF_BYCOMMAND | MF_UNCHECKED);
|
|
SendMessage(hWnd, UM_FAXVRFY_RESET, 0, 0);
|
|
}
|
|
return 0;
|
|
|
|
case IDM_RECEIVE:
|
|
if (g_bSend) {
|
|
g_bSend = FALSE;
|
|
CheckMenuItem(GetMenu(hWnd), IDM_SEND, MF_BYCOMMAND | MF_UNCHECKED);
|
|
CheckMenuItem(GetMenu(hWnd), IDM_RECEIVE, MF_BYCOMMAND | MF_CHECKED);
|
|
SendMessage(hWnd, UM_FAXVRFY_RESET, 0, 0);
|
|
}
|
|
return 0;
|
|
|
|
case IDM_HELP:
|
|
fnUsageInfo(hWnd);
|
|
return 0;
|
|
|
|
case IDC_SEND_NUMBER:
|
|
if (HIWORD(wParam) == EN_CHANGE) {
|
|
if (!fnIsEditControlASCII(hWnd, IDC_SEND_NUMBER, PHONE_NUM_LEN + 1)) {
|
|
// Load the error text
|
|
LoadString(g_hInstance, IDS_ASCII_SEND_NUMBER, szText, MAX_STRINGLEN);
|
|
// Display the pop-up
|
|
MessageBox(hWnd, szText, FAXVRFY_NAME, MB_OK | MB_ICONERROR);
|
|
|
|
SetDlgItemText(hWnd, IDC_SEND_NUMBER, g_szSndNumber);
|
|
}
|
|
|
|
GetDlgItemText(hWnd, IDC_SEND_NUMBER, g_szSndNumber, PHONE_NUM_LEN + 1);
|
|
}
|
|
return 0;
|
|
|
|
case IDC_RECEIVE_NUMBER:
|
|
if (HIWORD(wParam) == EN_CHANGE) {
|
|
if (!fnIsEditControlASCII(hWnd, IDC_RECEIVE_NUMBER, PHONE_NUM_LEN + 1)) {
|
|
// Load the error text
|
|
LoadString(g_hInstance, IDS_ASCII_RECEIVE_NUMBER, szText, MAX_STRINGLEN);
|
|
// Display the pop-up
|
|
MessageBox(hWnd, szText, FAXVRFY_NAME, MB_OK | MB_ICONERROR);
|
|
|
|
SetDlgItemText(hWnd, IDC_RECEIVE_NUMBER, g_szRcvNumber);
|
|
}
|
|
|
|
GetDlgItemText(hWnd, IDC_RECEIVE_NUMBER, g_szRcvNumber, PHONE_NUM_LEN + 1);
|
|
}
|
|
return 0;
|
|
|
|
case IDC_RAS_ENABLED_BUTTON:
|
|
// RAS Enabled Check Box was clicked
|
|
g_bRasEnabled = IsDlgButtonChecked(hWnd, IDC_RAS_ENABLED_BUTTON);
|
|
// Enable or disable the RAS specific controls
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_USER_NAME_STATIC), g_bRasEnabled ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_USER_NAME), g_bRasEnabled ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_PASSWORD_STATIC), g_bRasEnabled ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_PASSWORD), g_bRasEnabled ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_DOMAIN_STATIC), g_bRasEnabled ? TRUE : FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_DOMAIN), g_bRasEnabled ? TRUE : FALSE);
|
|
return 0;
|
|
|
|
case IDC_START_BUTTON:
|
|
if (g_bSend) {
|
|
// Initialize szMissingInfoError
|
|
ZeroMemory(szMissingInfoError, sizeof(szMissingInfoError));
|
|
|
|
// Get send phone number
|
|
GetDlgItemText(hWnd, IDC_SEND_NUMBER, g_szSndNumber, PHONE_NUM_LEN + 1);
|
|
// Get receive phone number
|
|
GetDlgItemText(hWnd, IDC_RECEIVE_NUMBER, g_szRcvNumber, PHONE_NUM_LEN + 1);
|
|
|
|
// See if RAS is enabled
|
|
g_bRasEnabled = IsDlgButtonChecked(hWnd, IDC_RAS_ENABLED_BUTTON);
|
|
// Get RAS user name
|
|
GetDlgItemText(hWnd, IDC_RAS_USER_NAME, g_szRasUserName, UNLEN + 1);
|
|
// Get RAS password
|
|
GetDlgItemText(hWnd, IDC_RAS_PASSWORD, g_szRasPassword, PWLEN + 1);
|
|
// Get RAS domain
|
|
GetDlgItemText(hWnd, IDC_RAS_DOMAIN, g_szRasDomain, DNLEN + 1);
|
|
|
|
if (!lstrlen(g_szSndNumber)) {
|
|
// There is no send phone number
|
|
LoadString(g_hInstance, IDS_MISSING_INFO, szMissingInfoError, MAX_STRINGLEN);
|
|
LoadString(g_hInstance, IDS_NO_SEND_NUMBER, szMissingInfo, MAX_STRINGLEN);
|
|
lstrcat(szMissingInfoError, szMissingInfo);
|
|
}
|
|
|
|
if (!lstrlen(g_szRcvNumber)) {
|
|
// There is no receive phone number
|
|
if (lstrlen(szMissingInfoError)) {
|
|
lstrcat(szMissingInfoError, L"\n");
|
|
}
|
|
else {
|
|
LoadString(g_hInstance, IDS_MISSING_INFO, szMissingInfoError, MAX_STRINGLEN);
|
|
}
|
|
LoadString(g_hInstance, IDS_NO_RECEIVE_NUMBER, szMissingInfo, MAX_STRINGLEN);
|
|
lstrcat(szMissingInfoError, szMissingInfo);
|
|
}
|
|
|
|
if (g_bRasEnabled) {
|
|
if (!lstrlen(g_szRasUserName)) {
|
|
// There is no RAS user name
|
|
if (lstrlen(szMissingInfoError)) {
|
|
lstrcat(szMissingInfoError, L"\n");
|
|
}
|
|
else {
|
|
LoadString(g_hInstance, IDS_MISSING_INFO, szMissingInfoError, MAX_STRINGLEN);
|
|
}
|
|
LoadString(g_hInstance, IDS_NO_RAS_USER_NAME, szMissingInfo, MAX_STRINGLEN);
|
|
lstrcat(szMissingInfoError, szMissingInfo);
|
|
}
|
|
|
|
if (!lstrlen(g_szRasDomain)) {
|
|
// There is no RAS domain
|
|
if (lstrlen(szMissingInfoError)) {
|
|
lstrcat(szMissingInfoError, L"\n");
|
|
}
|
|
else {
|
|
LoadString(g_hInstance, IDS_MISSING_INFO, szMissingInfoError, MAX_STRINGLEN);
|
|
}
|
|
LoadString(g_hInstance, IDS_NO_RAS_DOMAIN, szMissingInfo, MAX_STRINGLEN);
|
|
lstrcat(szMissingInfoError, szMissingInfo);
|
|
}
|
|
}
|
|
|
|
if (lstrlen(szMissingInfoError)) {
|
|
// Display the missing info error pop-up
|
|
MessageBox(hWnd, szMissingInfoError, FAXVRFY_NAME, MB_OK | MB_ICONERROR);
|
|
return 0;
|
|
}
|
|
|
|
// Disable the Fax specific controls
|
|
EnableWindow(GetDlgItem(hWnd, IDC_SEND_NUMBER_STATIC), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_SEND_NUMBER), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RECEIVE_NUMBER), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RECEIVE_NUMBER_STATIC), FALSE);
|
|
|
|
// Disable the RAS specific controls
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_ENABLED_BUTTON), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_USER_NAME_STATIC), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_USER_NAME), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_PASSWORD_STATIC), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_PASSWORD), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_DOMAIN_STATIC), FALSE);
|
|
EnableWindow(GetDlgItem(hWnd, IDC_RAS_DOMAIN), FALSE);
|
|
|
|
// Set the strings to the ini file
|
|
WritePrivateProfileString(L"Fax", L"SendNumber", g_szSndNumber, szIniFile);
|
|
WritePrivateProfileString(L"Fax", L"ReceiveNumber", g_szRcvNumber, szIniFile);
|
|
WritePrivateProfileString(L"RAS", L"Enabled", g_bRasEnabled ? L"1" : L"0", szIniFile);
|
|
WritePrivateProfileString(L"RAS", L"UserName", g_szRasUserName, szIniFile);
|
|
WritePrivateProfileString(L"RAS", L"Domain", g_szRasDomain, szIniFile);
|
|
}
|
|
|
|
// Disable the Option Menu
|
|
EnableMenuItem(GetMenu(hWnd), IDM_SEND, MF_BYCOMMAND | MF_GRAYED);
|
|
EnableMenuItem(GetMenu(hWnd), IDM_RECEIVE, MF_BYCOMMAND | MF_GRAYED);
|
|
|
|
// Disable the Start Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_START_BUTTON), FALSE);
|
|
// Enable the Stop Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_STOP_BUTTON), TRUE);
|
|
// Disable the Exit Button
|
|
EnableWindow(GetDlgItem(hWnd, IDC_EXIT_BUTTON), FALSE);
|
|
|
|
// Set the focus to the Stop button
|
|
SendMessage(hWnd, WM_NEXTDLGCTL, (WPARAM) GetDlgItem(hWnd, IDC_STOP_BUTTON), MAKELONG(TRUE, 0));
|
|
|
|
// Update the status
|
|
SendMessage(g_hWndDlg, UM_UPDATE_STATUS, IDS_STATUS_ITERATION_STARTED, 0);
|
|
|
|
// Signal the Start event
|
|
SetEvent(g_hStartEvent);
|
|
return 0;
|
|
|
|
case IDC_STOP_BUTTON:
|
|
// Signal the Stop event
|
|
SetEvent(g_hStopEvent);
|
|
return 0;
|
|
|
|
case IDC_EXIT_BUTTON:
|
|
SendMessage(hWnd, WM_CLOSE, 0, 0);
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
return DefDlgProc(hWnd, iMsg, wParam, lParam);
|
|
}
|