3824 lines
		
	
	
		
			97 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			3824 lines
		
	
	
		
			97 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 		
 | |
| // Mail and Chat Server for BPQ32 Packet Switch
 | |
| //
 | |
| //	Configuration Module
 | |
| 
 | |
| #include "bpqmail.h"
 | |
| 
 | |
| 
 | |
| #define C_PAGES 7
 | |
| 
 | |
| int CurrentPage=0;				// Page currently on show in tabbed Dialog
 | |
| 
 | |
| #define BBSPARAMS 0
 | |
| #define ISPPARAMS 1
 | |
| #define MAINTPARAMS 2
 | |
| #define WELCOMEMSGS 3
 | |
| #define PROMPTS 4
 | |
| #define FILTERS 5
 | |
| #define WPUPDATE 6
 | |
| 
 | |
| typedef struct tag_dlghdr {
 | |
| 
 | |
| HWND hwndTab; // tab control
 | |
| HWND hwndDisplay; // current child dialog box
 | |
| RECT rcDisplay; // display rectangle for the tab control
 | |
| 
 | |
| 
 | |
| DLGTEMPLATE *apRes[C_PAGES];
 | |
| 
 | |
| } DLGHDR;
 | |
| 
 | |
| HWND hwndDlg;		// Config Dialog
 | |
| HWND hwndDisplay;   // Current child dialog box
 | |
| 
 | |
| HWND hCheck[33];
 | |
| HWND hNullCheck[33];
 | |
| HWND hSendMF[33];
 | |
| HWND hSendHDDR[33];
 | |
| HWND hLabel[33];
 | |
| HWND hUIBox[33];
 | |
| HFONT hFont;
 | |
| LOGFONT LFTTYFONT ;
 | |
| 
 | |
| char CurrentConfigCall[20];		// Current user or bbs
 | |
| int CurrentConfigIndex;			// Index of current user record
 | |
| int CurrentMsgIndex;			// Index of current Msg record
 | |
| struct UserInfo * CurrentBBS;	// User Record of selected BBS iin Forwarding Config;
 | |
| 
 | |
| struct UserInfo * MsgBBSList[NBBBS+2] = {0}; // Sorted BBS List
 | |
| 
 | |
| char InfoBoxText[100];			// Text to display in Config Info Popup
 | |
| 
 | |
| char Filter_FROM[20];
 | |
| char Filter_TO[20];
 | |
| char Filter_VIA[60];				// Filters for Edit Message Dialog
 | |
| char Filter_BID[16];				// Filters for Edit Message Dialog
 | |
| 
 | |
| extern char LTFROMString[2048];
 | |
| extern char LTTOString[2048];
 | |
| extern char LTATString[2048];
 | |
| VOID * GetOverrideFromString(char * input);
 | |
| 
 | |
| extern time_t MaintClock;			// Time to run housekeeping
 | |
| 
 | |
| DLGTEMPLATE * WINAPI DoLockDlgRes(LPCSTR lpszResName);
 | |
| VOID WINAPI OnSelChanged(HWND hwndDlg);
 | |
| VOID WINAPI OnChildDialogInit(HWND hwndDlg);
 | |
| VOID WINAPI OnTabbedDialogInit(HWND hwndDlg);
 | |
| VOID SaveWPConfig(HWND hDlg);
 | |
| PrintMessage(struct MsgInfo * Msg);
 | |
| BOOL ForwardMessagetoFile(struct MsgInfo * Msg, FILE * Handle);
 | |
| VOID TidyPrompts();
 | |
| struct UserInfo * FindBBS(char * Name);
 | |
| 
 | |
| INT_PTR CALLBACK UIDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
 | |
| INT_PTR CALLBACK EditMsgTextDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam);
 | |
| 
 | |
| VOID SaveMAINTConfigFromDialog();
 | |
| VOID TidyWelcomeMsg(char ** pPrompt);
 | |
| 
 | |
| // POP3 Password is encrypted by xor'ing it with an MD5 hash of the hostname and pop3 server name
 | |
| 
 | |
| 
 | |
| double GetDlgItemFloat(HWND hDlg, int DlgItem, BOOL *lpTranslated, BOOL bSigned)
 | |
| {
 | |
| 	char Num[32];
 | |
| 	double ret = 0.0;
 | |
| 
 | |
| 	GetDlgItemText(hDlg, DlgItem, Num, 31);
 | |
| 	return atof(Num);
 | |
| }
 | |
| 
 | |
| 
 | |
| BOOL SetDlgItemFloat(HWND hDlg, int DlgItem, double Value, BOOL bSigned)
 | |
| {
 | |
| 	char Num[32];
 | |
| 
 | |
| 	sprintf(Num, "%.2f", Value);
 | |
| 
 | |
| 	while (Num[strlen(Num) -1] == '0')
 | |
| 		Num[strlen(Num) -1] = 0;
 | |
| 
 | |
| 	if (Num[strlen(Num) -1] == '.')
 | |
| 		Num[strlen(Num) -1] = 0;
 | |
| 
 | |
| 	return SetDlgItemText(hDlg, DlgItem, Num);
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| int ww, wh, w, h, hpos, vpos;
 | |
| int xmargin;
 | |
| int ymargin;
 | |
| 
 | |
| INT_PTR CALLBACK ConfigWndProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| 	RECT Rect;
 | |
| 	SCROLLINFO Sinfo;
 | |
| 
 | |
| 	int ret;
 | |
| 		
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 
 | |
| 	switch (message)
 | |
| 	{
 | |
| 	case WM_INITDIALOG:
 | |
| 
 | |
| 		ShowScrollBar(hDlg, SB_BOTH, FALSE);		// Hide them till needed
 | |
| 		OnTabbedDialogInit(hDlg);
 | |
| 
 | |
| 		// initialise scroll bars
 | |
| 
 | |
| 		xmargin = 6;
 | |
| 		ymargin = 2 + GetSystemMetrics(SM_CYCAPTION);
 | |
| 		hpos = vpos = 0;
 | |
| 
 | |
| 		return (INT_PTR)TRUE;
 | |
| 		
 | |
| 	case WM_SIZE:
 | |
| 		
 | |
| 		w = LOWORD(lParam);
 | |
| 		h = HIWORD(lParam);
 | |
| 
 | |
| 		// If window is smaller than client area enable scroll bars
 | |
| 
 | |
| 		ret = GetWindowRect(hwndDisplay, &Rect);
 | |
| 		ww = Rect.right - Rect.left;
 | |
| 		wh = Rect.bottom - Rect.top;
 | |
| 
 | |
| 		if (ww <= w && (wh + ymargin) <= h)
 | |
| 		{
 | |
| 			ShowScrollBar(hDlg, SB_BOTH, FALSE);	// Hide them till needed
 | |
| 			MoveWindow(hwndDisplay, xmargin, ymargin, ww, wh, TRUE);
 | |
| 			hpos = vpos = 0;
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		ShowScrollBar(hDlg, SB_BOTH, TRUE);	
 | |
| 
 | |
| 		Sinfo.cbSize = sizeof(SCROLLINFO);
 | |
| 		Sinfo.fMask = SIF_ALL;
 | |
| 		Sinfo.nMin = 0;
 | |
| 		Sinfo.nMax = ww + xmargin;
 | |
| 		Sinfo.nPage = w;
 | |
| 		Sinfo.nPos = hpos;
 | |
| 		SetScrollInfo(hDlg, SB_HORZ, &Sinfo, TRUE);
 | |
| 
 | |
| 		Sinfo.cbSize = sizeof(SCROLLINFO);
 | |
| 		Sinfo.fMask = SIF_ALL;
 | |
| 		Sinfo.nMin = 0;
 | |
| 		Sinfo.nMax = wh + ymargin;
 | |
| 		Sinfo.nPage = h;
 | |
| 		Sinfo.nPos = hpos;
 | |
| 		SetScrollInfo(hDlg, SB_VERT, &Sinfo, TRUE);
 | |
| 
 | |
| 		return TRUE;
 | |
| 
 | |
| 	case WM_HSCROLL:
 | |
| 
 | |
| 		switch (LOWORD(wParam))
 | |
| 		{
 | |
| 		case SB_PAGELEFT:
 | |
| 
 | |
| 			hpos -= 20;
 | |
| 			if (hpos < 0)
 | |
| 				hpos = 0;
 | |
| 
 | |
| 			goto UpdateHPos;
 | |
| 
 | |
| 		case SB_LINELEFT:
 | |
| 
 | |
| 			if (hpos)
 | |
| 				hpos --;
 | |
| 
 | |
| 			goto UpdateHPos;
 | |
| 
 | |
| 		case SB_PAGERIGHT:
 | |
| 
 | |
| 			hpos += 20;
 | |
| 			goto UpdateHPos;
 | |
| 
 | |
| 		case SB_LINERIGHT:
 | |
| 
 | |
| 			hpos++;
 | |
| 			goto UpdateHPos;
 | |
| 
 | |
| 		case SB_THUMBPOSITION:
 | |
| 
 | |
| 			hpos = HIWORD(wParam);
 | |
| 
 | |
| UpdateHPos:
 | |
| 			// Need to update Scroll Bar
 | |
| 
 | |
| 			Sinfo.cbSize = sizeof(SCROLLINFO);
 | |
| 			Sinfo.fMask = SIF_ALL;
 | |
| 			Sinfo.nMin = 0;
 | |
| 			Sinfo.nMax = ww + xmargin;
 | |
| 			Sinfo.nPage = w;
 | |
| 			Sinfo.nPos = hpos;
 | |
| 			SetScrollInfo(hDlg, SB_HORZ, &Sinfo, TRUE);
 | |
| 
 | |
| 			// Move Client Window
 | |
| 
 | |
| 			MoveWindow(hwndDisplay, xmargin - hpos , ymargin - vpos , ww, wh, TRUE);
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		return TRUE;
 | |
| 
 | |
| 		
 | |
| 	case WM_VSCROLL:
 | |
| 
 | |
| 		switch (LOWORD(wParam))
 | |
| 		{
 | |
| 		case SB_PAGEUP:
 | |
| 
 | |
| 			vpos -= 20;
 | |
| 			if (vpos < 0)
 | |
| 				vpos = 0;
 | |
| 
 | |
| 			goto UpdateVPos;
 | |
| 
 | |
| 		case SB_LINEUP:
 | |
| 
 | |
| 			if (vpos)
 | |
| 				vpos --;
 | |
| 
 | |
| 			goto UpdateVPos;
 | |
| 
 | |
| 		case SB_PAGEDOWN:
 | |
| 
 | |
| 			vpos += 20;
 | |
| 			goto UpdateVPos;
 | |
| 
 | |
| 		case SB_LINEDOWN:
 | |
| 
 | |
| 			vpos++;
 | |
| 			goto UpdateVPos;
 | |
| 
 | |
| 		case SB_THUMBPOSITION:
 | |
| 
 | |
| 			vpos = HIWORD(wParam);
 | |
| 
 | |
| UpdateVPos:
 | |
| 			// Need to update Scroll Bar
 | |
| 
 | |
| 			Sinfo.cbSize = sizeof(SCROLLINFO);
 | |
| 			Sinfo.fMask = SIF_ALL;
 | |
| 			Sinfo.nMin = 0;
 | |
| 			Sinfo.nMax = wh + ymargin;
 | |
| 			Sinfo.nPage = h;
 | |
| 			Sinfo.nPos = vpos;
 | |
| 			SetScrollInfo(hDlg, SB_VERT, &Sinfo, TRUE);
 | |
| 
 | |
| 			// Move Client Window
 | |
| 
 | |
| 			MoveWindow(hwndDisplay, xmargin - hpos , ymargin - vpos , ww, wh, TRUE);
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		return TRUE;
 | |
| 
 | |
| 
 | |
| 	case WM_NOTIFY:
 | |
| 
 | |
| 		switch (((LPNMHDR)lParam)->code)
 | |
| 		{
 | |
| 		case TCN_SELCHANGE:
 | |
| 
 | |
| 			OnSelChanged(hDlg);
 | |
| 
 | |
| 			// Check if scroll now needed
 | |
| 
 | |
| 			ret = GetWindowRect(hwndDisplay, &Rect);
 | |
| 			ww = Rect.right - Rect.left;
 | |
| 			wh = Rect.bottom - Rect.top;
 | |
| 
 | |
| 			if (ww <= w && (wh + 27) <= h)
 | |
| 			{
 | |
| 				ShowScrollBar(hDlg, SB_BOTH, FALSE);	// Hide them till needed
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 			ShowScrollBar(hDlg, SB_BOTH, TRUE);	
 | |
| 
 | |
| 			return TRUE;
 | |
| 			// More cases on WM_NOTIFY switch.
 | |
| 		case NM_CHAR:
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 	case WM_CTLCOLORDLG:
 | |
| 
 | |
| 		return (LONG)bgBrush;
 | |
| 
 | |
| 	case WM_CTLCOLORSTATIC:
 | |
|     {
 | |
|         HDC hdcStatic = (HDC)wParam;
 | |
| 		SetTextColor(hdcStatic, RGB(0, 0, 0));
 | |
|         SetBkMode(hdcStatic, TRANSPARENT);
 | |
|         return (LONG)bgBrush;
 | |
|     }
 | |
| 
 | |
| 	
 | |
| 	case WM_KEYUP:
 | |
| 
 | |
| 		if (wParam == VK_TAB)
 | |
| 			return TRUE;
 | |
| 
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 
 | |
| 		switch (LOWORD(wParam))
 | |
| 		{
 | |
| 
 | |
| 		case IDOK:
 | |
| 		case IDCANCEL:
 | |
| 
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return FALSE;
 | |
| 
 | |
| }
 | |
| 
 | |
| INT_PTR CALLBACK InfoDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| 	int Command;
 | |
| 		
 | |
| 	UNREFERENCED_PARAMETER(lParam);
 | |
| 
 | |
| 	switch (message)
 | |
| 	{
 | |
| 	case WM_INITDIALOG:
 | |
| 
 | |
| 		SetDlgItemText(hDlg, 5050, InfoBoxText);
 | |
| 
 | |
| 		return (INT_PTR)TRUE;
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 
 | |
| 		Command = LOWORD(wParam);
 | |
| 
 | |
| 		switch (Command)
 | |
| 		{
 | |
| 		case 0:
 | |
| 		case IDCANCEL:
 | |
| 
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 			return (INT_PTR)TRUE;
 | |
| 
 | |
| 		}
 | |
| 		break;
 | |
| 	}
 | |
| 	
 | |
| 	return (INT_PTR)FALSE;
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| INT_PTR CALLBACK ChildDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| //	This processes messages from controls on the tab subpages
 | |
| 	int Command;
 | |
| 
 | |
| 	switch (message)
 | |
| 	{
 | |
| 	case WM_NOTIFY:
 | |
| 
 | |
|         switch (((LPNMHDR)lParam)->code)
 | |
|         {
 | |
| 		case TCN_SELCHANGE:
 | |
| 			 OnSelChanged(hDlg);
 | |
| 				 return TRUE;
 | |
|          // More cases on WM_NOTIFY switch.
 | |
| 		case NM_CHAR:
 | |
| 			return TRUE;
 | |
|         }
 | |
| 
 | |
|        break;
 | |
| 	case WM_INITDIALOG:
 | |
| 		OnChildDialogInit( hDlg);
 | |
| 		return (INT_PTR)TRUE;
 | |
| 
 | |
| 	case WM_CTLCOLORDLG:
 | |
| 
 | |
|         return (LONG)bgBrush;
 | |
| 
 | |
|     case WM_CTLCOLORSTATIC:
 | |
|     {
 | |
|         HDC hdcStatic = (HDC)wParam;
 | |
| 		SetTextColor(hdcStatic, RGB(0, 0, 0));
 | |
|         SetBkMode(hdcStatic, TRANSPARENT);
 | |
|         return (LONG)bgBrush;
 | |
|     }
 | |
| 
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 
 | |
| 		Command = LOWORD(wParam);
 | |
| 
 | |
| 		if (Command == 2002)
 | |
| 			return TRUE;
 | |
| 
 | |
| 		switch (Command)
 | |
| 		{
 | |
| 
 | |
| 		case IDOK:
 | |
| 		case IDCANCEL:
 | |
| 
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 			return (INT_PTR)TRUE;
 | |
| 
 | |
| 		case IDC_UICONFIG:
 | |
| 			
 | |
| 			DialogBox(hInst, MAKEINTRESOURCE(IDD_UICONFIG), hWnd, UIDialogProc);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_BBSSAVE:
 | |
| 			
 | |
| 			SaveBBSConfig();
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_ISPSAVE:
 | |
| 			
 | |
| 			SaveISPConfig();
 | |
| 			return TRUE;
 | |
| 
 | |
| 
 | |
| 		case IDM_MAINTSAVE:
 | |
| 
 | |
| 			SaveMAINTConfigFromDialog();
 | |
| 			return TRUE;
 | |
| 
 | |
| 
 | |
| 		case IDM_MSGSAVE:
 | |
| 
 | |
| 			SaveWelcomeMsgs();
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDM_PROMPTSAVE:
 | |
| 
 | |
| 			SavePrompts();
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_FILTERSAVE:
 | |
| 
 | |
| 			SaveFilters(hDlg);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_WPSAVE:
 | |
| 
 | |
| 			SaveWPConfig(hDlg);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		}
 | |
| 		break;
 | |
| 
 | |
| 	}	
 | |
| 	return (INT_PTR)FALSE;
 | |
| }
 | |
| 
 | |
| 
 | |
| //The following function processes the WM_INITDIALOG message for the main dialog box. The function allocates the DLGHDR structure, loads the dialog template resources for the child dialog boxes, and creates the tab control.
 | |
| 
 | |
| //The size of each child dialog box is specified by the DLGTEMPLATE structure. The function examines the size of each dialog box and uses the macro for the TCM_ADJUSTRECT message to calculate an appropriate size for the tab control. Then it sizes the dialog box and positions the two buttons accordingly. This example sends TCM_ADJUSTRECT by using the TabCtrl_AdjustRect macro.
 | |
| 
 | |
| VOID WINAPI OnTabbedDialogInit(HWND hDlg)
 | |
| {
 | |
| 	DLGHDR *pHdr = (DLGHDR *) LocalAlloc(LPTR, sizeof(DLGHDR));
 | |
| 	DWORD dwDlgBase = GetDialogBaseUnits();
 | |
| 	int cxMargin = LOWORD(dwDlgBase) / 4;
 | |
| 	int cyMargin = HIWORD(dwDlgBase) / 8;
 | |
| 
 | |
| 	TC_ITEM tie;
 | |
| 	RECT rcTab;
 | |
| 
 | |
| 	int i, pos;
 | |
| 	INITCOMMONCONTROLSEX init;
 | |
| 
 | |
| 	hwndDlg = hDlg;			// Save Window Handle
 | |
| 
 | |
| 	// Save a pointer to the DLGHDR structure.
 | |
| 
 | |
| 	SetWindowLong(hwndDlg, GWL_USERDATA, (LONG) pHdr);
 | |
| 
 | |
| 	// Create the tab control.
 | |
| 
 | |
| 
 | |
| 	init.dwICC=ICC_STANDARD_CLASSES;
 | |
| 	init.dwSize=sizeof(init);
 | |
| 	i=InitCommonControlsEx(&init);
 | |
| 
 | |
| 	pHdr->hwndTab = CreateWindow(WC_TABCONTROL, "", WS_CHILD | WS_CLIPSIBLINGS | WS_VISIBLE,
 | |
| 		0, 0, 100, 100, hwndDlg, NULL, hInst, NULL);
 | |
| 
 | |
| 	if (pHdr->hwndTab == NULL) {
 | |
| 
 | |
| 	// handle error
 | |
| 
 | |
| 	}
 | |
| 
 | |
| 	// Add a tab for each of the child dialog boxes.
 | |
| 
 | |
| 	tie.mask = TCIF_TEXT | TCIF_IMAGE;
 | |
| 
 | |
| 	tie.iImage = -1;
 | |
| 
 | |
| 	tie.pszText = "BBS Params";
 | |
| 	TabCtrl_InsertItem(pHdr->hwndTab, 0, &tie);
 | |
| 
 | |
| 	tie.pszText = "ISP Interface";
 | |
| 	TabCtrl_InsertItem(pHdr->hwndTab, 1, &tie);
 | |
| 
 | |
|  	tie.pszText = "Housekeeping";
 | |
| 	TabCtrl_InsertItem(pHdr->hwndTab, 2, &tie);
 | |
| 
 | |
| 	tie.pszText = "Welcome Msgs";
 | |
| 	TabCtrl_InsertItem(pHdr->hwndTab, 3, &tie);
 | |
| 
 | |
| 	tie.pszText = "Prompts";
 | |
| 	TabCtrl_InsertItem(pHdr->hwndTab, 4, &tie);
 | |
| 
 | |
| 	tie.pszText = "Msg Filters";
 | |
| 	TabCtrl_InsertItem(pHdr->hwndTab, 5, &tie);
 | |
| 
 | |
| 	tie.pszText = "WP Update";
 | |
| 	TabCtrl_InsertItem(pHdr->hwndTab, 6, &tie);
 | |
| 
 | |
| 	// Lock the resources for the three child dialog boxes.
 | |
| 
 | |
| 	pHdr->apRes[0] = DoLockDlgRes("BBS_CONFIG");
 | |
| 	pHdr->apRes[1] = DoLockDlgRes("ISP_CONFIG");
 | |
| 	pHdr->apRes[2] = DoLockDlgRes("MAINT");
 | |
| 	pHdr->apRes[3] = DoLockDlgRes("WELCOMEMSG");
 | |
| 	pHdr->apRes[4] = DoLockDlgRes("BBSPROMPTS");
 | |
| 	pHdr->apRes[5] = DoLockDlgRes("FILTERS");
 | |
| 	pHdr->apRes[6] = DoLockDlgRes("WPUPDATE");
 | |
| 
 | |
| 	// Determine the bounding rectangle for all child dialog boxes.
 | |
| 
 | |
| 	SetRectEmpty(&rcTab);
 | |
| 
 | |
| 	for (i = 0; i < C_PAGES-1; i++)
 | |
| 	{
 | |
| 		if (pHdr->apRes[i]->cx > rcTab.right)
 | |
| 			rcTab.right = pHdr->apRes[i]->cx;
 | |
| 
 | |
| 		if (pHdr->apRes[i]->cy > rcTab.bottom)
 | |
| 			rcTab.bottom = pHdr->apRes[i]->cy;
 | |
| 
 | |
| 	}
 | |
| 
 | |
| 	MapDialogRect(hwndDlg, &rcTab);
 | |
| 
 | |
| //	rcTab.right = rcTab.right * LOWORD(dwDlgBase) / 4;
 | |
| 
 | |
| //	rcTab.bottom = rcTab.bottom * HIWORD(dwDlgBase) / 8;
 | |
| 
 | |
| 	// Calculate how large to make the tab control, so
 | |
| 
 | |
| 	// the display area can accomodate all the child dialog boxes.
 | |
| 
 | |
| 	TabCtrl_AdjustRect(pHdr->hwndTab, TRUE, &rcTab);
 | |
| 
 | |
| 	OffsetRect(&rcTab, cxMargin - rcTab.left, cyMargin - rcTab.top);
 | |
| 
 | |
| 	// Calculate the display rectangle.
 | |
| 
 | |
| 	CopyRect(&pHdr->rcDisplay, &rcTab);
 | |
| 
 | |
| 	TabCtrl_AdjustRect(pHdr->hwndTab, FALSE, &pHdr->rcDisplay);
 | |
| 
 | |
| 	// Set the size and position of the tab control, buttons,
 | |
| 
 | |
| 	// and dialog box.
 | |
| 
 | |
| 	SetWindowPos(pHdr->hwndTab, NULL, rcTab.left, rcTab.top, rcTab.right - rcTab.left, rcTab.bottom - rcTab.top, SWP_NOZORDER);
 | |
| 
 | |
| 	// Move the Buttons to bottom of page
 | |
| 
 | |
| 	pos=rcTab.left+cxMargin;
 | |
| 
 | |
| 	
 | |
| 	// Size the dialog box.
 | |
| 
 | |
| 	SetWindowPos(hwndDlg, NULL, 0, 0, rcTab.right + cyMargin + 2 * GetSystemMetrics(SM_CXDLGFRAME),
 | |
| 		rcTab.bottom  + 2 * cyMargin + 2 * GetSystemMetrics(SM_CYDLGFRAME) + GetSystemMetrics(SM_CYCAPTION),
 | |
| 		SWP_NOMOVE | SWP_NOZORDER);
 | |
| 
 | |
| 	// Simulate selection of the first item.
 | |
| 
 | |
| 	OnSelChanged(hwndDlg);
 | |
| 
 | |
| }
 | |
| 
 | |
| // DoLockDlgRes - loads and locks a dialog template resource.
 | |
| 
 | |
| // Returns a pointer to the locked resource.
 | |
| 
 | |
| // lpszResName - name of the resource
 | |
| 
 | |
| DLGTEMPLATE * WINAPI DoLockDlgRes(LPCSTR lpszResName)
 | |
| {
 | |
| 	HRSRC hrsrc = FindResource(NULL, lpszResName, RT_DIALOG);
 | |
| 	HGLOBAL hglb = LoadResource(hInst, hrsrc);
 | |
| 
 | |
| 	return (DLGTEMPLATE *) LockResource(hglb);
 | |
| }
 | |
| 
 | |
| //The following function processes the TCN_SELCHANGE notification message for the main dialog box. The function destroys the dialog box for the outgoing page, if any. Then it uses the CreateDialogIndirect function to create a modeless dialog box for the incoming page.
 | |
| 
 | |
| // OnSelChanged - processes the TCN_SELCHANGE notification.
 | |
| 
 | |
| // hwndDlg - handle of the parent dialog box
 | |
| 
 | |
| VOID WINAPI OnSelChanged(HWND hwndDlg)
 | |
| {
 | |
| 	char Nodes[1000]="";
 | |
| 	char Text[10000]="";
 | |
| 	char Line[80];
 | |
| 	struct Override ** Call;
 | |
| 	char Time[10];
 | |
| 
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 
 | |
| 	CurrentPage = TabCtrl_GetCurSel(pHdr->hwndTab);
 | |
| 
 | |
| 	// Destroy the current child dialog box, if any.
 | |
| 
 | |
| 	if (pHdr->hwndDisplay != NULL)
 | |
| 
 | |
| 		DestroyWindow(pHdr->hwndDisplay);
 | |
| 
 | |
| 	// Create the new child dialog box.
 | |
| 
 | |
| 	pHdr->hwndDisplay = CreateDialogIndirect(hInst, pHdr->apRes[CurrentPage], hwndDlg, ChildDialogProc);
 | |
| 
 | |
| 	hwndDisplay = pHdr->hwndDisplay;		// Save
 | |
| 
 | |
| 	// Fill in the controls
 | |
| 
 | |
| 	switch (CurrentPage)
 | |
| 	{
 | |
| 	case BBSPARAMS:
 | |
| 		
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_BBSCall, BBSName);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_SYSOPCALL, SYSOPCall);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_SYSTOSYSOPCALL, SendSYStoSYSOPCall);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_BBSTOSYSOPCALL, SendBBStoSYSOPCall);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_DONTHOLDNEW, DontHoldNewUsers);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_FORWARDTOBBS, ForwardToMe);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_NONAME, AllowAnon);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_USERRKILLT, !UserCantKillT);		// Note negative logic
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_NOHOMEBBS, DontNeedHomeBBS);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_DONTCHECKFROM, DontCheckFromCall);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_DEFAULTNOWINLINK, DefaultNoWINLINK);
 | |
| 
 | |
| 		
 | |
| 		
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_HRoute, HRoute);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_BaseDir, BaseDirRaw);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_BBSAppl, BBSApplNum, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_BBSStreams, MaxStreams, FALSE);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_ENABLEUI, EnableUI);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, MAILFOR_MINS, MailForInterval, FALSE);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_REFUSEBULLS, RefuseBulls);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_KNOWNUSERS, OnlyKnown);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_POP3Port, POP3InPort, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_NNTPPort, NNTPInPort, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_SMTPPort, SMTPInPort, FALSE);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_REMOTEEMAIL, RemoteEmail);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_AMPR, AMPRDomain);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_FORWARDAMPR, SendAMPRDirect);
 | |
| 
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 	case ISPPARAMS:
 | |
| 		
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_ISP_Gateway_Enabled, ISP_Gateway_Enabled);
 | |
|  		
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_POP3Timer, ISPPOP3Interval, FALSE);
 | |
| 
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_MyMailDomain, MyDomain);
 | |
| 
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_ISPSMTPName, ISPSMTPName);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, SMTP_EHELO, ISPEHLOName);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_ISPSMTPPort, ISPSMTPPort, FALSE);
 | |
| 
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_ISPPOP3Name, ISPPOP3Name);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_ISPPOP3Port, ISPPOP3Port, FALSE);
 | |
| 
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_ISPAccountName, ISPAccountName);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_ISPAccountPass, ISPAccountPass);
 | |
| 
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, ISP_SMTP_AUTH, SMTPAuthNeeded);
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 	case MAINTPARAMS:
 | |
| 
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_MAXMSG, MaxMsgno, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_BIDLIFETIME, BidLifetime, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_USERLIFETIME, UserLifetime, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_LOGLIFETIME, LogAge, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDC_MAINTINTERVAL, MaintInterval, FALSE);
 | |
| 		sprintf(Time, "%04d", MaintTime);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_MAINTTIME, Time);
 | |
| 
 | |
| 		SetDlgItemFloat(pHdr->hwndDisplay, IDM_PR, PR, FALSE);
 | |
| 		SetDlgItemFloat(pHdr->hwndDisplay, IDM_PUR, PUR, FALSE);
 | |
| 		SetDlgItemFloat(pHdr->hwndDisplay, IDM_PF, PF, FALSE);
 | |
| 		SetDlgItemFloat(pHdr->hwndDisplay, IDM_PNF, PNF, FALSE);
 | |
| 
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDM_BF, BF, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDM_BNF, BNF, FALSE);
 | |
| 
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDM_NTSD, NTSD, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDM_NTSF, NTSF, FALSE);
 | |
| 		SetDlgItemInt(pHdr->hwndDisplay, IDM_NTSU, NTSU, FALSE);
 | |
| 
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_DELETETORECYCLE, DeletetoRecycleBin);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_MAINTNOMAIL, SuppressMaintEmail);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_MAINTSAVEREG, SaveRegDuringMaint);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_OVERRIDEUNSENT, OverrideUnsent);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_MAINTNONDELIVERY , SendNonDeliveryMsgs);
 | |
| 		CheckDlgButton(pHdr->hwndDisplay, IDC_MAINTTRAFFIC, GenerateTrafficReport);
 | |
| 
 | |
| 		if (LTFROM)
 | |
| 		{
 | |
| 			Call = LTFROM;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s, %d\r\n", Call[0]->Call, Call[0]->Days);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_LTFROM, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (LTTO)
 | |
| 		{
 | |
| 			Call = LTTO;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s, %d\r\n", Call[0]->Call, Call[0]->Days);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_LTTO, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (LTAT)
 | |
| 		{
 | |
| 			Call = LTAT;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s, %d\r\n", Call[0]->Call, Call[0]->Days);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_LTAT, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 
 | |
| 	case WELCOMEMSGS:
 | |
| 
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_USERMSG, WelcomeMsg);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_NEWUSERMSG, NewWelcomeMsg);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_EXPERTUSERMSG, ExpertWelcomeMsg);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_SIGNOFF, SignoffMsg);
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 	case PROMPTS:
 | |
| 
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_USERMSG, Prompt);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_NEWUSERMSG, NewPrompt);
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDM_EXPERTUSERMSG, ExpertPrompt);
 | |
| 
 | |
| 		break;
 | |
| 	case FILTERS:
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (RejFrom)
 | |
| 		{
 | |
| 			char ** Call = RejFrom;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s\r\n", Call[0]);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_REJFROM, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (RejTo)
 | |
| 		{
 | |
| 			char ** Call = RejTo;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s\r\n", Call[0]);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_REJTO, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (RejAt)
 | |
| 		{
 | |
| 			char ** Call = RejAt;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s\r\n", Call[0]);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_REJAT, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (RejBID)
 | |
| 		{
 | |
| 			char ** Call = RejBID;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s\r\n", Call[0]);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_REJBID, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (HoldFrom)
 | |
| 		{
 | |
| 			char ** Call = HoldFrom;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s\r\n", Call[0]);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_HOLDFROM, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (HoldTo)
 | |
| 		{
 | |
| 			char ** Call = HoldTo;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s\r\n", Call[0]);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_HOLDTO, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (HoldAt)
 | |
| 		{
 | |
| 			char ** Call = HoldAt;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s\r\n", Call[0]);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_HOLDAT, Text);
 | |
| 
 | |
| 		Text[0] = 0;
 | |
| 
 | |
| 		if (HoldBID)
 | |
| 		{
 | |
| 			char ** Call = HoldBID;
 | |
| 			while(Call[0])
 | |
| 			{
 | |
| 				sprintf(Line, "%s\r\n", Call[0]);
 | |
| 				strcat(Text, Line);
 | |
| 				Call++;
 | |
| 			}
 | |
| 		}
 | |
| 		SetDlgItemText(pHdr->hwndDisplay, IDC_HOLDBID, Text);
 | |
| 
 | |
| 
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 	case WPUPDATE:
 | |
| 
 | |
| 		if (SendWPAddrs)
 | |
| 		{
 | |
| 			char ** Calls = SendWPAddrs;
 | |
| 			char Text[10000]="";
 | |
| 
 | |
| 			while(Calls[0])
 | |
| 			{
 | |
| 				strcat(Text, Calls[0]);
 | |
| 				strcat(Text, "\r\n");
 | |
| 				Calls++;
 | |
| 			}
 | |
| 			
 | |
| 			SetDlgItemText(hwndDisplay, IDC_WPTO, Text);
 | |
| 		}
 | |
| 		
 | |
| 		SendDlgItemMessage(hwndDisplay, IDC_WPTYPE, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "B");
 | |
| 		SendDlgItemMessage(hwndDisplay, IDC_WPTYPE, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "P");
 | |
| 
 | |
| 
 | |
| 		SendDlgItemMessage(hwndDisplay, IDC_WPTYPE, CB_SETCURSEL, SendWPType, 0);
 | |
| 
 | |
| 		CheckDlgButton(hwndDisplay, IDC_SENDWP, SendWP);
 | |
| //		CheckDlgButton(hwndDisplay, IDC_SENDWP, NoWPGuesses);
 | |
| 		CheckDlgButton(hwndDisplay, IDC_FILTERWPB, FilterWPBulls);
 | |
| 
 | |
| 		break;
 | |
| 	}
 | |
| 
 | |
| 	ShowWindow(pHdr->hwndDisplay, SW_SHOWNORMAL);
 | |
| }
 | |
| 
 | |
| //The following function processes the WM_INITDIALOG message for each of the child dialog boxes. You cannot specify the position of a dialog box created using the CreateDialogIndirect function. This function uses the SetWindowPos function to position the child dialog within the tab control's display area.
 | |
| 
 | |
| // OnChildDialogInit - Positions the child dialog box to fall
 | |
| 
 | |
| // within the display area of the tab control.
 | |
| 
 | |
| VOID WINAPI OnChildDialogInit(HWND hwndDlg)
 | |
| {
 | |
| 	HWND hwndParent = GetParent(hwndDlg);
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndParent, GWL_USERDATA);
 | |
| 
 | |
| 	SetWindowPos(hwndDlg, HWND_TOP, pHdr->rcDisplay.left, pHdr->rcDisplay.top, 0, 0, SWP_NOSIZE);
 | |
| }
 | |
| 
 | |
| void SetForwardingPage(HWND hDlg, struct UserInfo * user)
 | |
| {
 | |
| 
 | |
| 	struct	BBSForwardingInfo * ForwardingInfo = user->ForwardingInfo;
 | |
| 	char ** Calls;
 | |
| 	char Text[100000]="";
 | |
| 
 | |
| 	Calls = ForwardingInfo->TOCalls;
 | |
| 
 | |
| 	if (Calls)
 | |
| 	{
 | |
| 		while(Calls[0])
 | |
| 		{
 | |
| 			strcat(Text, Calls[0]);
 | |
| 			strcat(Text, "\r\n");
 | |
| 			Calls++;
 | |
| 		}
 | |
| 	}
 | |
| 	SetDlgItemText(hDlg, IDC_TOCALLS, Text);
 | |
| 
 | |
| 	Text[0] = 0;
 | |
| 
 | |
| 	Calls = ForwardingInfo->ATCalls;
 | |
| 
 | |
| 	if (Calls)
 | |
| 	{
 | |
| 		while(Calls[0])
 | |
| 		{
 | |
| 			strcat(Text, Calls[0]);
 | |
| 			strcat(Text, "\r\n");
 | |
| 			Calls++;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	SetDlgItemText(hDlg, IDC_ATCALLS, Text);
 | |
| 
 | |
| 	Text[0] = 0;
 | |
| 	Calls = ForwardingInfo->Haddresses;
 | |
| 
 | |
| 	if (Calls)
 | |
| 	{
 | |
| 		while(Calls[0])
 | |
| 		{
 | |
| 			strcat(Text, Calls[0]);
 | |
| 			strcat(Text, "\r\n");
 | |
| 			Calls++;
 | |
| 		}
 | |
| 			
 | |
| 	}
 | |
| 
 | |
| 	SetDlgItemText(hDlg, IDC_HROUTES, Text);
 | |
| 
 | |
| 	Text[0] = 0;
 | |
| 	Calls = ForwardingInfo->HaddressesP;
 | |
| 
 | |
| 	if (Calls)
 | |
| 	{
 | |
| 		while(Calls[0])
 | |
| 		{
 | |
| 			strcat(Text, Calls[0]);
 | |
| 			strcat(Text, "\r\n");
 | |
| 			Calls++;
 | |
| 		}
 | |
| 			
 | |
| 	}
 | |
| 
 | |
| 	SetDlgItemText(hDlg, IDC_HROUTESP, Text);
 | |
| 
 | |
| 	Text[0] = 0;
 | |
| 
 | |
| 	Calls = ForwardingInfo->FWDTimes;
 | |
| 
 | |
| 	if (Calls)
 | |
| 	{
 | |
| 		while(Calls[0])
 | |
| 		{
 | |
| 			strcat(Text, Calls[0]);
 | |
| 			strcat(Text, "\r\n");
 | |
| 			Calls++;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	SetDlgItemText(hDlg, IDC_FWDTIMES, Text);
 | |
| 
 | |
| 	Text[0] = 0;
 | |
| 	Calls = ForwardingInfo->ConnectScript;
 | |
| 
 | |
| 	if (Calls)
 | |
| 	{
 | |
| 		while(Calls[0])
 | |
| 		{
 | |
| 			strcat(Text, Calls[0]);
 | |
| 			strcat(Text, "\r\n");
 | |
| 			Calls++;
 | |
| 		}
 | |
| 			
 | |
| 	}
 | |
| 
 | |
| 	SetDlgItemText(hDlg, IDC_CALL, Text);
 | |
| 
 | |
| 	if (ForwardingInfo->AllowB1 || ForwardingInfo->AllowB2)
 | |
| 		ForwardingInfo->AllowCompressed = TRUE;
 | |
| 
 | |
| 	CheckDlgButton(hDlg, IDC_FWDENABLE, ForwardingInfo->Enabled);
 | |
| 	CheckDlgButton(hDlg, IDC_REVERSE, ForwardingInfo->ReverseFlag);
 | |
| 	CheckDlgButton(hDlg, IDC_BLOCKED, ForwardingInfo->AllowBlocked);
 | |
| 	CheckDlgButton(hDlg, IDC_ALLOWCOMP, ForwardingInfo->AllowCompressed);
 | |
| 	CheckDlgButton(hDlg, IDC_USEB1, ForwardingInfo->AllowB1);
 | |
| 	CheckDlgButton(hDlg, IDC_USEB2, ForwardingInfo->AllowB2);
 | |
| 	CheckDlgButton(hDlg, IDC_CTRLZ, ForwardingInfo->SendCTRLZ);
 | |
| 	CheckDlgButton(hDlg, IDC_PERSONALONLY, ForwardingInfo->PersonalOnly);
 | |
| 	CheckDlgButton(hDlg, IDC_SENDNEW, ForwardingInfo->SendNew);
 | |
| 	SetDlgItemInt(hDlg, IDC_FWDINT, ForwardingInfo->FwdInterval, FALSE);
 | |
| 	SetDlgItemInt(hDlg, IDC_REVFWDINT, ForwardingInfo->RevFwdInterval, FALSE);
 | |
| 	SetDlgItemInt(hDlg, IDC_MAXBLOCK, ForwardingInfo->MaxFBBBlockSize, FALSE);
 | |
| 	SetDlgItemInt(hDlg, IDC_CONTIMEOUT, ForwardingInfo->ConTimeout, FALSE);
 | |
| 	SetDlgItemText(hDlg, IDC_BBSHA, ForwardingInfo->BBSHA);
 | |
| 
 | |
| 	SetFocus(GetDlgItem(hDlg, IDC_TOCALLS)); 
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| int Do_BBS_Sel_Changed(HWND hDlg)
 | |
| {
 | |
| 	// Update BBS display with newly selected BBS
 | |
| 
 | |
| 	struct UserInfo * user;
 | |
| 
 | |
| 	int Sel = SendDlgItemMessage(hDlg, IDC_BBS, CB_GETCURSEL, 0, 0);
 | |
| 
 | |
| 	SendDlgItemMessage(hDlg, IDC_BBS, CB_GETLBTEXT, Sel, (LPARAM)(LPCTSTR)&CurrentConfigCall);
 | |
| 
 | |
| 	for (user = BBSChain; user; user = user->BBSNext)
 | |
| 	{
 | |
| 		if (strcmp(user->Call, CurrentConfigCall) == 0)
 | |
| 		{
 | |
| 			CurrentBBS = user;
 | |
| 			SetForwardingPage(hDlg, user);			// moved to separate routine as also called from copy config
 | |
| 		}
 | |
| 	}
 | |
| 	return 0;
 | |
| 
 | |
| }
 | |
| int Sel;
 | |
| 
 | |
| int Do_User_Sel_Changed(HWND hDlg)
 | |
| {
 | |
| 
 | |
| 	// Update BBS display with newly selected BBS
 | |
| 
 | |
| 	struct UserInfo * user;
 | |
| 
 | |
| 	Sel = SendDlgItemMessage(hDlg, IDC_USER, CB_GETCURSEL, 0, 0);
 | |
| 
 | |
| 	if (Sel == -1)
 | |
| 		SendDlgItemMessage(hDlg, IDC_USER, WM_GETTEXT, Sel, (LPARAM)(LPCTSTR)&CurrentConfigCall);
 | |
| 	else
 | |
| 		SendDlgItemMessage(hDlg, IDC_USER, CB_GETLBTEXT, Sel, (LPARAM)(LPCTSTR)&CurrentConfigCall);
 | |
| 
 | |
| 	for (CurrentConfigIndex = 1; CurrentConfigIndex <= NumberofUsers; CurrentConfigIndex++)
 | |
| 	{
 | |
| 		user = UserRecPtr[CurrentConfigIndex];
 | |
| 
 | |
| 		if (_stricmp(user->Call, CurrentConfigCall) == 0)
 | |
| 		{
 | |
| 			struct tm *tm;
 | |
| 			char Date[80];
 | |
| 			char * Dateptr;
 | |
| 			int i, n, s;
 | |
| 			char SSID[10];
 | |
| 
 | |
| 			int	ConnectsIn;
 | |
| 			int ConnectsOut;
 | |
| 			int MsgsReceived;
 | |
| 			int MsgsSent;
 | |
| 			int MsgsRejectedIn;
 | |
| 			int MsgsRejectedOut;
 | |
| 			int BytesForwardedIn;
 | |
| 			int BytesForwardedOut;
 | |
| //			char MsgsIn[80];
 | |
| //			char MsgsOut[80];
 | |
| //			char BytesIn[80];
 | |
| //			char BytesOut[80];
 | |
| //			char RejIn[80];
 | |
| //			char RejOut[80];
 | |
| 
 | |
| 			i = 0;
 | |
| 
 | |
| 			ConnectsIn = user->Total.ConnectsIn - user->Last.ConnectsIn;
 | |
| 			ConnectsOut = user->Total.ConnectsOut - user->Last.ConnectsOut;
 | |
| 
 | |
| 			MsgsReceived = MsgsSent = MsgsRejectedIn = MsgsRejectedOut = BytesForwardedIn = BytesForwardedOut = 0;
 | |
| 
 | |
| 			for (n = 0; n < 4; n++)
 | |
| 			{
 | |
| 				MsgsReceived +=	user->Total.MsgsReceived[n] - user->Last.MsgsReceived[n];	
 | |
| 				MsgsSent += user->Total.MsgsSent[n] - user->Last.MsgsSent[n];
 | |
| 				BytesForwardedIn += user->Total.BytesForwardedIn[n] - user->Last.BytesForwardedIn[n];
 | |
| 				BytesForwardedOut += user->Total.BytesForwardedOut[n] - user->Last.BytesForwardedOut[n];
 | |
| 				MsgsRejectedIn += user->Total.MsgsRejectedIn[n] - user->Last.MsgsRejectedIn[n];
 | |
| 				MsgsRejectedOut += user->Total.MsgsRejectedOut[n] - user->Last.MsgsRejectedOut[n];
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 
 | |
| 			SetDlgItemText(hDlg, IDC_NAME, user->Name);
 | |
| 			SetDlgItemText(hDlg, IDC_PASSWORD, user->pass);
 | |
| 			SetDlgItemText(hDlg, IDC_QTH, user->Address);
 | |
| 			SetDlgItemText(hDlg, IDC_UZIP, user->ZIP);
 | |
| 			SetDlgItemText(hDlg, IDC_HOMEBBS, user->HomeBBS);
 | |
| 			SetDlgItemText(hDlg, IDC_CMSPASS, user->CMSPass);
 | |
| 			
 | |
| 			SetDlgItemInt(hDlg, IDC_LASTLISTED, user->lastmsg, TRUE);
 | |
| 
 | |
| 			CheckDlgButton(hDlg, IDC_SYSOP, (user->flags & F_SYSOP));
 | |
| 			CheckDlgButton(hDlg, IDC_BBSFLAG, (user->flags & F_BBS));
 | |
| 			CheckDlgButton(hDlg, IDC_PMSFLAG, (user->flags & F_PMS));
 | |
| 			CheckDlgButton(hDlg, IDC_EXPERT, (user->flags & F_Expert));
 | |
| 			CheckDlgButton(hDlg, IDC_EXCLUDED, (user->flags & F_Excluded));
 | |
| 			CheckDlgButton(hDlg, IDC_EMAIL, (user->flags & F_EMAIL));
 | |
| 			CheckDlgButton(hDlg, IDC_HOLDMAIL, (user->flags & F_HOLDMAIL));
 | |
| 			CheckDlgButton(hDlg, ALLOW_BULLS, (user->flags & F_NOBULLS) == 0);	// Node inverted flag
 | |
| 			CheckDlgButton(hDlg, IDC_NTSMPS, (user->flags & F_NTSMPS));
 | |
| 			CheckDlgButton(hDlg, IDC_APRSMFOR, (user->flags & F_APRSMFOR));
 | |
| 			CheckDlgButton(hDlg, IDC_POLLRMS, (user->flags & F_POLLRMS));
 | |
| 			CheckDlgButton(hDlg, IDC_SYSOP_IN_LM, (user->flags & F_SYSOP_IN_LM));
 | |
| 			CheckDlgButton(hDlg, RMS_EXPRESS_USER, (user->flags & F_Temp_B2_BBS));
 | |
| 			CheckDlgButton(hDlg, NO_WINLINKdotORG, (user->flags & F_NOWINLINK));
 | |
| 			CheckDlgButton(hDlg, IDC_RMSREDIRECT, (user->flags & F_RMSREDIRECT));
 | |
| 			
 | |
| 			EnableWindow(GetDlgItem(hDlg, IDC_SYSOP_IN_LM), user->flags & F_SYSOP);
 | |
| 
 | |
| 			SetDlgItemInt(hDlg, CONN_IN, ConnectsIn, FALSE);
 | |
| 			SetDlgItemInt(hDlg, CONN_OUT, ConnectsOut, FALSE);
 | |
| 			SetDlgItemInt(hDlg, MSGS_IN, MsgsReceived, FALSE);
 | |
| 			SetDlgItemInt(hDlg, MSGS_OUT, MsgsSent, FALSE);
 | |
| 			SetDlgItemInt(hDlg, REJECTS_IN, MsgsRejectedIn, FALSE);
 | |
| 			SetDlgItemInt(hDlg, REJECTS_OUT, MsgsRejectedOut, FALSE);
 | |
| 			SetDlgItemInt(hDlg, BYTES_IN, BytesForwardedIn, FALSE);
 | |
| 			SetDlgItemInt(hDlg, BYTES_OUT, BytesForwardedOut, FALSE);
 | |
| 
 | |
| /*
 | |
| 			for (i = 0; i < 3; i++)
 | |
| 			{
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_RESETCONTENT,0 , 0);
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)" ");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"1");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"2");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"3");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"4");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"5");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"6");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"7");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"8");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"9");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"10");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"11");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"12");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"13");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"14");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1 + i, CB_ADDSTRING,0 , (LPARAM)"15");
 | |
| 			}
 | |
| */			
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID1, WM_SETTEXT, 0, (LPARAM)"-");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID2, WM_SETTEXT, 0, (LPARAM)"-");
 | |
| 			SendDlgItemMessage(hDlg, RMS_SSID3, WM_SETTEXT, 0, (LPARAM)"-");
 | |
| 
 | |
| 			i = 0;
 | |
| 			for (s = 0; s < 16; s++)
 | |
| 			{
 | |
| 				if (user->RMSSSIDBits & (1 << s))
 | |
| 				{
 | |
| 					if (s)
 | |
| 						sprintf(SSID, "%d", s);
 | |
| 					else
 | |
| 						SSID[0] = 0;
 | |
| 
 | |
| 					SendDlgItemMessage(hDlg, RMS_SSID1 + i++, WM_SETTEXT, 0, (LPARAM)SSID);
 | |
| //					SendDlgItemMessage(hDlg, RMS_SSID1 + i++, CB_SETCURSEL, s, 0);
 | |
| 					if (i == 3)
 | |
| 						break;
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			tm = gmtime((time_t *)&user->TimeLastConnected);	
 | |
| 			Dateptr = asctime(tm);
 | |
| 			strcpy(Date, Dateptr);
 | |
| 
 | |
| 			SetDlgItemText(hDlg, LASTCONNECT, Date);
 | |
| 
 | |
| 			i = (user->flags >> 28);
 | |
| 			sprintf(SSID, "%d", i);
 | |
| 
 | |
| 			if (i == 0)
 | |
| 				SSID[0] = 0;
 | |
| 
 | |
| 			SendDlgItemMessage(hDlg, IDC_APRSSSID, WM_SETTEXT, 0, (LPARAM)SSID);
 | |
| 
 | |
| 			return 0;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// Typing in new user
 | |
| 
 | |
| 	CurrentConfigIndex = -1;
 | |
| 
 | |
| 	SetDlgItemText(hDlg, IDC_NAME, "");
 | |
| 	SetDlgItemText(hDlg, IDC_PASSWORD, "");
 | |
| 	SetDlgItemText(hDlg, IDC_CMSPASS, "");
 | |
| 	
 | |
| 	SetDlgItemText(hDlg, IDC_QTH, "");
 | |
| 	SetDlgItemText(hDlg, IDC_UZIP, "");
 | |
| 	SetDlgItemText(hDlg, IDC_HOMEBBS, "");
 | |
| 	SetDlgItemInt(hDlg, IDC_LASTLISTED, LatestMsg, FALSE);
 | |
| 
 | |
| 	CheckDlgButton(hDlg, IDC_SYSOP, FALSE);
 | |
| 	CheckDlgButton(hDlg, IDC_BBSFLAG, FALSE);
 | |
| 	CheckDlgButton(hDlg, IDC_PMSFLAG, FALSE);
 | |
| 	CheckDlgButton(hDlg, IDC_EXPERT, FALSE);
 | |
| 	CheckDlgButton(hDlg, IDC_EXCLUDED, FALSE);
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| VOID Do_Add_User(HWND hDlg)
 | |
| {
 | |
| 	struct UserInfo * user;
 | |
| 	int n;
 | |
| 
 | |
| 	SendDlgItemMessage(hDlg, IDC_USER, WM_GETTEXT, 19, (LPARAM)(LPCTSTR)&CurrentConfigCall);
 | |
| 	
 | |
| 	if (LookupCall(CurrentConfigCall))
 | |
| 		sprintf(InfoBoxText, "User %s already exists", CurrentConfigCall);
 | |
| 	else if	((strlen(CurrentConfigCall) < 3) || (strlen(CurrentConfigCall) > MAXUSERNAMELEN))
 | |
| 		sprintf(InfoBoxText, "User %s is invalid", CurrentConfigCall);
 | |
| 	else
 | |
| 	{
 | |
| 		user = AllocateUserRecord(CurrentConfigCall);
 | |
| 		user->Temp = zalloc(sizeof (struct TempUserInfo));
 | |
| 
 | |
| 		CurrentConfigIndex=NumberofUsers;
 | |
| 		Do_Save_User(hDlg, FALSE);
 | |
| 		sprintf(InfoBoxText, "User %s added and info saved", CurrentConfigCall);
 | |
| 	}	
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| 	SendDlgItemMessage(hDlg, IDC_USER, CB_RESETCONTENT, 0, 0);
 | |
| 
 | |
| 	for (n = 1; n <= NumberofUsers; n++)
 | |
| 	{
 | |
| 		SendDlgItemMessage(hDlg, IDC_USER, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR)UserRecPtr[n]->Call);
 | |
| 	} 
 | |
| 
 | |
| 	return;
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| VOID Do_Delete_User(HWND hDlg)
 | |
| {
 | |
| 	struct UserInfo * user;
 | |
| 	int n;
 | |
| 
 | |
| 
 | |
| 	if (CurrentConfigIndex == -1)
 | |
| 	{
 | |
| 		sprintf(InfoBoxText, "Please select a user to delete");
 | |
| 		DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	user = UserRecPtr[CurrentConfigIndex];
 | |
| 
 | |
| 	if (_stricmp(CurrentConfigCall, user->Call) != 0)
 | |
| 	{
 | |
| 		sprintf(InfoBoxText, "Inconsistancy detected - user not deleted");
 | |
| 		DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	for (n = CurrentConfigIndex; n < NumberofUsers; n++)
 | |
| 	{
 | |
| 		UserRecPtr[n] = UserRecPtr[n+1];		// move down all following entries
 | |
| 	}
 | |
| 	
 | |
| 	NumberofUsers--;
 | |
| 
 | |
| 	SendDlgItemMessage(hDlg, IDC_USER, CB_RESETCONTENT, 0, 0);
 | |
| 
 | |
| 	for (n = 1; n <= NumberofUsers; n++)
 | |
| 	{
 | |
| 		SendDlgItemMessage(hDlg, IDC_USER, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR)UserRecPtr[n]->Call);
 | |
| 	} 
 | |
| 
 | |
| 	sprintf(InfoBoxText, "User %s deleted", user->Call);
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| 	if (user->flags & F_BBS)	// was a BBS?
 | |
| 		DeleteBBS(user);
 | |
| 	
 | |
| 	free(user);
 | |
| 
 | |
| 	// Position to same place in list
 | |
| 
 | |
| 	SendDlgItemMessage(hDlg, IDC_USER, CB_SETCURSEL, Sel, 0);
 | |
| 	Do_User_Sel_Changed(hDlg);
 | |
| 
 | |
| 	return;
 | |
| 
 | |
| }
 | |
| VOID Do_Save_User(HWND hDlg, BOOL ShowBox)
 | |
| {
 | |
| 	struct UserInfo * user;
 | |
| 	BOOL OK;
 | |
| 	char RMSSSID[10];
 | |
| 	unsigned int SSID;
 | |
| 
 | |
| 	if (CurrentConfigIndex == -1)
 | |
| 	{
 | |
| 		sprintf(InfoBoxText, "Please select a user to save");
 | |
| 		DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	user = UserRecPtr[CurrentConfigIndex];
 | |
| 
 | |
| 	if (strcmp(CurrentConfigCall, user->Call) != 0)
 | |
| 	{
 | |
| 		sprintf(InfoBoxText, "Inconsistancy detected - information not saved");
 | |
| 		DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	GetDlgItemText(hDlg, IDC_NAME, user->Name, 17);
 | |
| 	GetDlgItemText(hDlg, IDC_PASSWORD, user->pass, 12);
 | |
| 	GetDlgItemText(hDlg, IDC_QTH, user->Address, 60);
 | |
| 	GetDlgItemText(hDlg, IDC_UZIP, user->ZIP, 8);
 | |
| 	GetDlgItemText(hDlg, IDC_HOMEBBS, user->HomeBBS, 40);
 | |
| 	GetDlgItemText(hDlg, IDC_CMSPASS, user->CMSPass, 15);
 | |
| 
 | |
| 	user->lastmsg = GetDlgItemInt(hDlg, IDC_LASTLISTED, &OK, FALSE);
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_BBSFLAG))
 | |
| 	{
 | |
| 		// If BBS Flag has changed, must set up or delete forwarding info
 | |
| 
 | |
| 		if ((user->flags & F_BBS) == 0)
 | |
| 		{
 | |
| 			// New BBS
 | |
| 
 | |
| 			if(SetupNewBBS(user))
 | |
| 			{
 | |
| 				user->flags |= F_BBS;
 | |
| 				user->flags &= ~F_Temp_B2_BBS;			// Clear RMS Express User
 | |
| 				CheckDlgButton(hDlg, RMS_EXPRESS_USER, (user->flags & F_Temp_B2_BBS));
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				// Failed - too many bbs's defined
 | |
| 
 | |
| 				sprintf(InfoBoxText, "Cannot set user to be a BBS - you already have 80 BBS's defined");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 				user->flags &= ~F_BBS;
 | |
| 				CheckDlgButton(hDlg, IDC_BBSFLAG, (user->flags & F_BBS));
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		if (user->flags & F_BBS)
 | |
| 		{
 | |
| 			//was a BBS
 | |
| 
 | |
| 			user->flags &= ~F_BBS;
 | |
| 			DeleteBBS(user);
 | |
| 		}
 | |
| 	}
 | |
| 			
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_PMSFLAG))
 | |
| 		user->flags |= F_PMS; else user->flags &= ~F_PMS;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_EXPERT))
 | |
| 		user->flags |= F_Expert; else user->flags &= ~F_Expert;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_EXCLUDED))
 | |
| 		user->flags |= F_Excluded; else user->flags &= ~F_Excluded;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_SYSOP))
 | |
| 		user->flags |= F_SYSOP; else user->flags &= ~F_SYSOP;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_EMAIL))
 | |
| 		user->flags |= F_EMAIL; else user->flags &= ~F_EMAIL;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_HOLDMAIL))
 | |
| 		user->flags |= F_HOLDMAIL; else user->flags &= ~F_HOLDMAIL;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, ALLOW_BULLS) == 0)
 | |
| 		user->flags |= F_NOBULLS; else user->flags &= ~F_NOBULLS;		// Note flag inverted
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_APRSMFOR))
 | |
| 		user->flags |= F_APRSMFOR; else user->flags &= ~F_APRSMFOR;
 | |
| 	
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_NTSMPS))
 | |
| 		user->flags |= F_NTSMPS; else user->flags &= ~F_NTSMPS;
 | |
| 	
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_RMSREDIRECT))
 | |
| 		user->flags |= F_RMSREDIRECT; else user->flags &= ~F_RMSREDIRECT;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_POLLRMS))
 | |
| 		user->flags |= F_POLLRMS; else user->flags &= ~F_POLLRMS;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, IDC_SYSOP_IN_LM))
 | |
| 		user->flags |= F_SYSOP_IN_LM; else user->flags &= ~F_SYSOP_IN_LM;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, RMS_EXPRESS_USER))
 | |
| 		user->flags |= F_Temp_B2_BBS; else user->flags &= ~F_Temp_B2_BBS;
 | |
| 
 | |
| 	if (IsDlgButtonChecked(hDlg, NO_WINLINKdotORG))
 | |
| 		user->flags |= F_NOWINLINK; else user->flags &= ~F_NOWINLINK;
 | |
| 
 | |
| //	if (user->flags & F_BBS)
 | |
| //		user->flags &= ~F_Temp_B2_BBS;		// Can't be both
 | |
| 
 | |
| 
 | |
| 	user->RMSSSIDBits = 0;
 | |
| 
 | |
| 	SendDlgItemMessage(hDlg, RMS_SSID1, WM_GETTEXT, 3, (LPARAM)(LPCTSTR)&RMSSSID);
 | |
| 
 | |
| 	if (RMSSSID[0] != '-')
 | |
| 	{
 | |
| 		SSID = atoi(RMSSSID);
 | |
| 		user->RMSSSIDBits |= (1 << (SSID));
 | |
| 	}
 | |
| 	SendDlgItemMessage(hDlg, RMS_SSID2, WM_GETTEXT, 3, (LPARAM)(LPCTSTR)&RMSSSID);
 | |
| 	
 | |
| 	if (RMSSSID[0] != '-')
 | |
| 	{
 | |
| 		SSID = atoi(RMSSSID);
 | |
| 		user->RMSSSIDBits |= (1 << (SSID));
 | |
| 	}
 | |
| 
 | |
| 	SendDlgItemMessage(hDlg, RMS_SSID3, WM_GETTEXT, 3, (LPARAM)(LPCTSTR)&RMSSSID);
 | |
| 
 | |
| 	if (RMSSSID[0] != '-')
 | |
| 	{
 | |
| 		SSID = atoi(RMSSSID);
 | |
| 		user->RMSSSIDBits |= (1 << (SSID));
 | |
| 	}
 | |
| 
 | |
| 	SendDlgItemMessage(hDlg, IDC_APRSSSID, WM_GETTEXT, 3, (LPARAM)(LPCTSTR)&RMSSSID);
 | |
| 
 | |
| 	SSID = atoi(RMSSSID);
 | |
| 	SSID &= 15;
 | |
| 
 | |
| 	user->flags &= 0x0fffffff;
 | |
| 	user->flags |= (SSID << 28);
 | |
| 
 | |
| 	SaveUserDatabase();
 | |
| 
 | |
| 	UpdateWPWithUserInfo(user);
 | |
| 
 | |
| 
 | |
| 	if (ShowBox)
 | |
| 	{
 | |
| 		sprintf(InfoBoxText, "User information saved");
 | |
| 		DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 	}				
 | |
| }
 | |
| 
 | |
| int compare(const void *arg1, const void *arg2);
 | |
| 
 | |
| int Do_Msg_Sel_Changed(HWND hDlg)
 | |
| {
 | |
| 	// Update Msg display with newly selected Msg
 | |
| 
 | |
| 	struct MsgInfo * Msg;
 | |
| 	char MsgnoText[10];
 | |
| 	int Msgno;
 | |
| 	int Sel = SendDlgItemMessage(hDlg, 0, LB_GETCURSEL, 0, 0);
 | |
| 	char Size[10];
 | |
| 
 | |
| 	if (Sel != -1)
 | |
| 	{
 | |
| 		SendDlgItemMessage(hDlg, 0, LB_GETTEXT, Sel, (LPARAM)(LPCTSTR)&MsgnoText);
 | |
| 		Msgno = atoi(MsgnoText);
 | |
| 	}
 | |
| 	
 | |
| 	for (CurrentMsgIndex = 1; CurrentMsgIndex <= NumberofMessages; CurrentMsgIndex++)
 | |
| 	{
 | |
| 		Msg = MsgHddrPtr[CurrentMsgIndex];
 | |
| 
 | |
| 		if (Msg->number == Msgno)
 | |
| 		{
 | |
| 			struct UserInfo * USER;
 | |
| 			int i = 0, n;
 | |
| 			UINT State;
 | |
| 
 | |
| 			SetDlgItemText(hDlg, 6001, Msg->from);
 | |
| 			SetDlgItemText(hDlg, 6002, Msg->bid);
 | |
| 			SetDlgItemText(hDlg, 6003, Msg->to);
 | |
| 			SetDlgItemText(hDlg, EMAILFROM, Msg->emailfrom);
 | |
| 			SetDlgItemText(hDlg, 6004, Msg->via);
 | |
| 			SetDlgItemText(hDlg, 6005, Msg->title);
 | |
| 			sprintf(Size, "%d", Msg->length);
 | |
| 
 | |
| 			SetDlgItemText(hDlg, 6018, FormatDateAndTime((time_t)Msg->datecreated, FALSE));
 | |
| 			SetDlgItemText(hDlg, 6019, FormatDateAndTime((time_t)Msg->datereceived, FALSE));
 | |
| 			SetDlgItemText(hDlg, 6021, FormatDateAndTime((time_t)Msg->datechanged, FALSE));
 | |
| 			SetDlgItemText(hDlg, 6020, Size);
 | |
| 
 | |
| 			if (Msg->type  == 'B')
 | |
| 				SendDlgItemMessage(hDlg, IDC_MSGTYPE, CB_SETCURSEL, 0, 0);
 | |
| 			else if (Msg->type  == 'P')
 | |
| 				SendDlgItemMessage(hDlg, IDC_MSGTYPE, CB_SETCURSEL, 1, 0);
 | |
| 			else
 | |
| 				SendDlgItemMessage(hDlg, IDC_MSGTYPE, CB_SETCURSEL, 2, 0);
 | |
| 
 | |
| 			switch(Msg->status)
 | |
| 			{
 | |
| 			case 'N': Sel = MSGSTATUS_N; break;
 | |
| 			case 'Y': Sel = MSGSTATUS_Y; break;
 | |
| 			case 'F': Sel = MSGSTATUS_F; break;
 | |
| 			case 'K': Sel = MSGSTATUS_K; break;
 | |
| 			case 'H': Sel = MSGSTATUS_H; break;
 | |
| 			case 'D': Sel = MSGSTATUS_D; break;
 | |
| 			case '$': Sel = MSGSTATUS_$; break;
 | |
| 			}
 | |
| 
 | |
| 			// Get a sorted list of BBS records
 | |
| 
 | |
| 			for (n = 1; n <= NumberofUsers; n++)
 | |
| 			{
 | |
| 				USER = UserRecPtr[n];
 | |
| 
 | |
| 				if ((USER->flags & F_BBS) && USER->BBSNumber)
 | |
| 					MsgBBSList[i++] = USER;
 | |
| 			}
 | |
| 
 | |
| 			qsort((void *)MsgBBSList, i, 4, compare );
 | |
| 
 | |
| 			SendDlgItemMessage(hDlg, IDC_MSGSTATUS, CB_SETCURSEL, Sel, 0);
 | |
| 
 | |
| 			for (n = 0; n <= NBBBS; n++)
 | |
| 			{
 | |
| 				State = BST_INDETERMINATE;
 | |
| 
 | |
| 				USER = MsgBBSList[n];
 | |
| 				
 | |
| 				if (USER)
 | |
| 				{
 | |
| 					if (memcmp(Msg->fbbs, zeros, NBMASK) != 0)	
 | |
| 						if (check_fwd_bit(Msg->fbbs, USER->BBSNumber))
 | |
| 							State = BST_UNCHECKED;
 | |
| 					if (memcmp(Msg->forw, zeros, NBMASK) != 0)	
 | |
| 						if (check_fwd_bit(Msg->forw, USER->BBSNumber))
 | |
| 							State = BST_CHECKED;
 | |
| 				
 | |
| 					SetDlgItemText(hDlg, n + 25, USER->Call);
 | |
| 				}
 | |
| 				else
 | |
| 					SetDlgItemText(hDlg, n + 25, "");
 | |
| 
 | |
| 				CheckDlgButton(hDlg, n + 25, State);	
 | |
| 			}
 | |
| 
 | |
| 			return 0;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	CurrentMsgIndex = -1;
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| VOID Do_Save_Msg(HWND hDlg)
 | |
| {
 | |
| 	struct MsgInfo * Msg;
 | |
| 	struct UserInfo * user;
 | |
| 
 | |
| 	char status[2];
 | |
| 	int i, n, BBSNumber;
 | |
| 	BOOL toforward, forwarded;
 | |
| 
 | |
| 	if (CurrentMsgIndex == -1)
 | |
| 	{
 | |
| 		sprintf(InfoBoxText, "Please select a message to save");
 | |
| 		DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	Msg = MsgHddrPtr[CurrentMsgIndex];
 | |
| 
 | |
| 	GetDlgItemText(hDlg, 6001, Msg->from, 7);
 | |
| 	GetDlgItemText(hDlg, 6002, Msg->bid, 13);
 | |
| 	GetDlgItemText(hDlg, 6003, Msg->to, 7);
 | |
| 	GetDlgItemText(hDlg, 6004, Msg->via, 41);
 | |
| 	GetDlgItemText(hDlg, 6005, Msg->title, 61);
 | |
| 	GetDlgItemText(hDlg, EMAILFROM, Msg->emailfrom, 41);
 | |
| 
 | |
| 	GetDlgItemText(hDlg, IDC_MSGTYPE, status, 2);
 | |
| 	Msg->type = status[0];
 | |
| 
 | |
| 	// Check each BBS to for Farwardind State
 | |
| 
 | |
| 	for (i = 0; i < NBBBS; i++)
 | |
| 	{
 | |
| 		n = IsDlgButtonChecked(hDlg, i + 25);
 | |
| 
 | |
| 		user = MsgBBSList[i];
 | |
| 
 | |
| 		if (user)
 | |
| 		{
 | |
| 			BBSNumber = user->BBSNumber;	
 | |
| 
 | |
| //			if (BBSNumber == 31)
 | |
| //				n = n;
 | |
| 
 | |
| 			toforward = check_fwd_bit(Msg->fbbs, BBSNumber);
 | |
| 			forwarded = check_fwd_bit(Msg->forw, BBSNumber);
 | |
| 
 | |
| 			if (n == BST_INDETERMINATE)
 | |
| 			{
 | |
| 				if ((!toforward) && (!forwarded))
 | |
| 				{
 | |
| 					// No Change
 | |
| 					continue;
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					clear_fwd_bit(Msg->fbbs, BBSNumber);
 | |
| 					if (toforward)
 | |
| 						user->ForwardingInfo->MsgCount--;
 | |
| 
 | |
| 					clear_fwd_bit(Msg->forw, BBSNumber);
 | |
| 				}
 | |
| 			}
 | |
| 			else if (n == BST_UNCHECKED)
 | |
| 			{
 | |
| 				if (toforward)
 | |
| 				{
 | |
| 					// No Change
 | |
| 					continue;
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					set_fwd_bit(Msg->fbbs, BBSNumber);
 | |
| 					user->ForwardingInfo->MsgCount++;
 | |
| 					clear_fwd_bit(Msg->forw, BBSNumber);
 | |
| 					if (FirstMessageIndextoForward > CurrentMsgIndex)
 | |
| 						FirstMessageIndextoForward = CurrentMsgIndex;
 | |
| 				}
 | |
| 			}
 | |
| 			else if (n == BST_CHECKED)
 | |
| 			{
 | |
| 				if (forwarded)
 | |
| 				{
 | |
| 					// No Change
 | |
| 					continue;
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					set_fwd_bit(Msg->forw, BBSNumber);
 | |
| 					clear_fwd_bit(Msg->fbbs, BBSNumber);
 | |
| 					if (toforward)
 | |
| 						user->ForwardingInfo->MsgCount--;
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	GetDlgItemText(hDlg, IDC_MSGSTATUS, status, 2);
 | |
| 	
 | |
| 	if (Msg->status != status[0])
 | |
| 	{
 | |
| 		// Need to take action if killing message
 | |
| 
 | |
| 		Msg->status = status[0];
 | |
| 		if (status[0] == 'K')
 | |
| 			FlagAsKilled(Msg, FALSE);					// Clear forwarding bits
 | |
| 	}
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Message Updated");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| 	Msg->datechanged=time(NULL);
 | |
| 
 | |
| 	SaveMessageDatabase();		
 | |
| 
 | |
| 	Do_Msg_Sel_Changed(hDlg);				// Refresh
 | |
| }
 | |
| 
 | |
| VOID SaveBBSConfig()
 | |
| {
 | |
| 	BOOL OK1,OK2,OK3,OK4;
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 	HKEY hKey=0;
 | |
| 	
 | |
| 	GetDlgItemText(hwndDisplay, IDC_BBSCall, BBSName, 50);
 | |
| 	GetDlgItemText(hwndDisplay, IDC_SYSOPCALL, SYSOPCall, 50);
 | |
| 	GetDlgItemText(hwndDisplay, IDC_HRoute, HRoute, 50);
 | |
| 	GetDlgItemText(hwndDisplay, IDC_BaseDir, BaseDirRaw, MAX_PATH -1);
 | |
| 	EnableUI = IsDlgButtonChecked(hwndDisplay, IDC_ENABLEUI);
 | |
| 	RefuseBulls = IsDlgButtonChecked(hwndDisplay, IDC_REFUSEBULLS);
 | |
| 	OnlyKnown = IsDlgButtonChecked(hwndDisplay, IDC_KNOWNUSERS);
 | |
| 	MailForInterval = GetDlgItemInt(hwndDisplay, MAILFOR_MINS, &OK1, FALSE);
 | |
| 	SendSYStoSYSOPCall = IsDlgButtonChecked(hwndDisplay, IDC_SYSTOSYSOPCALL);
 | |
| 	SendBBStoSYSOPCall = IsDlgButtonChecked(hwndDisplay, IDC_BBSTOSYSOPCALL);
 | |
| 	DontHoldNewUsers = IsDlgButtonChecked(hwndDisplay, IDC_DONTHOLDNEW);
 | |
| 	ForwardToMe = IsDlgButtonChecked(hwndDisplay, IDC_FORWARDTOBBS);
 | |
| 	DontNeedHomeBBS = IsDlgButtonChecked(hwndDisplay, IDC_NOHOMEBBS);
 | |
| 	DontCheckFromCall = IsDlgButtonChecked(hwndDisplay, IDC_DONTCHECKFROM);
 | |
| 	AllowAnon = IsDlgButtonChecked(hwndDisplay, IDC_NONAME);
 | |
| 	UserCantKillT = !IsDlgButtonChecked(hwndDisplay, IDC_USERRKILLT);	// Reverse logic
 | |
| 	DefaultNoWINLINK = IsDlgButtonChecked(hwndDisplay, IDC_DEFAULTNOWINLINK);
 | |
| 
 | |
| 	BBSApplNum = GetDlgItemInt(hwndDisplay, IDC_BBSAppl, &OK1, FALSE);
 | |
| 	MaxStreams = GetDlgItemInt(hwndDisplay, IDC_BBSStreams, &OK2, FALSE);
 | |
| 	POP3InPort = GetDlgItemInt(hwndDisplay, IDC_POP3Port, &OK3, FALSE);
 | |
| 	SMTPInPort = GetDlgItemInt(hwndDisplay, IDC_SMTPPort, &OK4, FALSE);
 | |
| 	NNTPInPort = GetDlgItemInt(hwndDisplay, IDC_NNTPPort, &OK3, FALSE);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDC_AMPR, AMPRDomain, 50);
 | |
| 	SendAMPRDirect= IsDlgButtonChecked(hwndDisplay, IDC_FORWARDAMPR);
 | |
| 	RemoteEmail = IsDlgButtonChecked(hwndDisplay, IDC_REMOTEEMAIL);
 | |
| 
 | |
| 	strlop(BBSName, '-');
 | |
| 	strlop(SYSOPCall, '-');
 | |
| 
 | |
| 	SaveConfig(ConfigName);
 | |
| 	GetConfig(ConfigName);
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Warning - Program must be restarted for changes to be effective");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| }
 | |
| 	
 | |
| 
 | |
| VOID SaveISPConfig()
 | |
| {
 | |
| 	BOOL OK1,OK2,OK3;
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 		
 | |
| 	ISP_Gateway_Enabled = IsDlgButtonChecked(hwndDisplay, IDC_ISP_Gateway_Enabled);
 | |
| 
 | |
| 	SMTPAuthNeeded = IsDlgButtonChecked(hwndDisplay, ISP_SMTP_AUTH);
 | |
| 
 | |
| 	ISPPOP3Interval = GetDlgItemInt(hwndDisplay, IDC_POP3Timer, &OK1, FALSE);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDC_MyMailDomain, MyDomain, 50);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDC_ISPSMTPName, ISPSMTPName, 50);
 | |
| 	ISPSMTPPort = GetDlgItemInt(hwndDisplay, IDC_ISPSMTPPort, &OK2, FALSE);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, SMTP_EHELO, ISPEHLOName, 50);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDC_ISPPOP3Name, ISPPOP3Name, 50);
 | |
| 	ISPPOP3Port = GetDlgItemInt(hwndDisplay, IDC_ISPPOP3Port, &OK3, FALSE);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDC_ISPAccountName, ISPAccountName, 50);
 | |
| 	GetDlgItemText(hwndDisplay, IDC_ISPAccountPass, ISPAccountPass, 50);
 | |
| 
 | |
| 	EncryptedPassLen = EncryptPass(ISPAccountPass, EncryptedISPAccountPass);
 | |
| 
 | |
| 	SaveConfig(ConfigName);
 | |
| 	GetConfig(ConfigName);
 | |
| 
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Configuration Saved");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| }
 | |
| 
 | |
| VOID SaveFWDConfig(HWND hDlg)
 | |
| {
 | |
| 	int OK, n;
 | |
| 	char BBSHA[50];
 | |
| 
 | |
| 	ReaddressLocal = IsDlgButtonChecked(hDlg, IDC_READDRESSLOCAL);
 | |
| 	ReaddressReceived = IsDlgButtonChecked(hDlg, IDC_READDRESSRXED);
 | |
| 	WarnNoRoute = IsDlgButtonChecked(hDlg, IDC_WARNNOROUTE);
 | |
| 	Localtime = IsDlgButtonChecked(hDlg, IDC_USELOCALTIME);
 | |
| 	MaxTXSize = GetDlgItemInt(hDlg, IDC_MAXSEND, &OK, FALSE);
 | |
| 	MaxRXSize = GetDlgItemInt(hDlg, IDC_MAXRECV, &OK, FALSE);
 | |
| 	MaxAge = GetDlgItemInt(hDlg, IDC_MAXAGE, &OK, FALSE);
 | |
| 	SendPtoMultiple = IsDlgButtonChecked(hDlg, IDC_MULTIP);
 | |
| 	FOURCHARCONT = IsDlgButtonChecked(hDlg, IDC_FOURCHARCONTINENT);
 | |
| 
 | |
| 	
 | |
| 	// Reinitialise Aliases
 | |
| 
 | |
| 	n = 0;
 | |
| 
 | |
| 	if (Aliases)
 | |
| 	{
 | |
| 		while(Aliases[n])
 | |
| 		{
 | |
| 			free(Aliases[n]->Dest);
 | |
| 			free(Aliases[n]);
 | |
| 			n++;
 | |
| 		}
 | |
| 
 | |
| 		free(Aliases);
 | |
| 		Aliases = NULL;
 | |
| 		FreeList(AliasText);
 | |
| 	}
 | |
| 
 | |
| 	AliasText = GetMultiLineDialogParam(hDlg, IDC_ALIAS);
 | |
| 	SetupFwdAliases();
 | |
| 
 | |
| 	if (CurrentBBS)
 | |
| 	{
 | |
| 		struct	BBSForwardingInfo * ForwardingInfo = CurrentBBS->ForwardingInfo;
 | |
| 
 | |
| 		ForwardingInfo->ATCalls = GetMultiLineDialogParam(hDlg, IDC_ATCALLS);
 | |
| 		ForwardingInfo->TOCalls = GetMultiLineDialogParam(hDlg, IDC_TOCALLS);
 | |
| 		ForwardingInfo->Haddresses = GetMultiLineDialogParam(hDlg, IDC_HROUTES);
 | |
| 		ForwardingInfo->HaddressesP = GetMultiLineDialogParam(hDlg, IDC_HROUTESP);
 | |
| 		ForwardingInfo->ConnectScript = GetMultiLineDialogParam(hDlg, IDC_CALL);
 | |
| 		ForwardingInfo->FWDTimes = GetMultiLineDialogParam(hDlg, IDC_FWDTIMES);
 | |
| 
 | |
| 
 | |
| 		ForwardingInfo->Enabled = IsDlgButtonChecked(hDlg, IDC_FWDENABLE);
 | |
| 		ForwardingInfo->ReverseFlag = IsDlgButtonChecked(hDlg, IDC_REVERSE);
 | |
| 		ForwardingInfo->AllowB2 = IsDlgButtonChecked(hDlg, IDC_USEB2);
 | |
| 		ForwardingInfo->PersonalOnly = IsDlgButtonChecked(hDlg, IDC_PERSONALONLY);
 | |
| 		ForwardingInfo->SendNew = IsDlgButtonChecked(hDlg, IDC_SENDNEW);
 | |
| 		ForwardingInfo->AllowB1 = IsDlgButtonChecked(hDlg, IDC_USEB1);
 | |
| 		ForwardingInfo->SendCTRLZ = IsDlgButtonChecked(hDlg, IDC_CTRLZ);
 | |
| 		ForwardingInfo->AllowBlocked = IsDlgButtonChecked(hDlg, IDC_BLOCKED);
 | |
| 		ForwardingInfo->AllowCompressed = IsDlgButtonChecked(hDlg, IDC_ALLOWCOMP);
 | |
| 		ForwardingInfo->FwdInterval = GetDlgItemInt(hDlg, IDC_FWDINT, &OK, FALSE);
 | |
| 		ForwardingInfo->RevFwdInterval = GetDlgItemInt(hDlg, IDC_REVFWDINT, &OK, FALSE);
 | |
| 		ForwardingInfo->MaxFBBBlockSize = GetDlgItemInt(hDlg, IDC_MAXBLOCK, &OK, FALSE);
 | |
| 		ForwardingInfo->ConTimeout = GetDlgItemInt(hDlg, IDC_CONTIMEOUT,&OK , FALSE);
 | |
| 
 | |
| 		GetDlgItemText(hDlg, IDC_BBSHA, BBSHA, 50);
 | |
| 		if (ForwardingInfo->BBSHA)
 | |
| 			free(ForwardingInfo->BBSHA);
 | |
| 		ForwardingInfo->BBSHA = _strdup(BBSHA);
 | |
| 	}
 | |
| 
 | |
| 	SaveConfig(ConfigName);
 | |
| 	GetConfig(ConfigName);
 | |
| 
 | |
| 	if (CurrentBBS)
 | |
| 		ReinitializeFWDStruct(CurrentBBS);	
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Forwarding information saved");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| }
 | |
| 
 | |
| VOID CopyFwdConfig(HWND hDlg)
 | |
| {
 | |
| 	char FromBBS[11] = "";
 | |
| 	struct UserInfo * OldBBS;
 | |
| 
 | |
| 	if (CurrentBBS == NULL)
 | |
| 	{
 | |
| 		sprintf(InfoBoxText, "Please select a BBS to copy to");
 | |
| 		DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	// Get call to copy from 
 | |
| 
 | |
| 	GetDlgItemText(hDlg, COPYFROMCALL, FromBBS, 10);
 | |
| 
 | |
| 	OldBBS = FindBBS(FromBBS);
 | |
| 
 | |
| 	if (OldBBS == NULL)
 | |
| 	{
 | |
| 		sprintf(InfoBoxText, "BBS %s not found", FromBBS);
 | |
| 		DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	// Set current info from OldBBS
 | |
| 
 | |
| 	SetForwardingPage(hDlg, OldBBS);			// moved to separate routine as also called from copy config
 | |
| 
 | |
| //	sprintf(InfoBoxText, "Forwarding information saved");
 | |
| //	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| VOID SaveMAINTConfigFromDialog()
 | |
| {
 | |
| 	BOOL OK1;
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 
 | |
| 	MaxMsgno = GetDlgItemInt(hwndDisplay, IDC_MAXMSG, &OK1, FALSE);
 | |
| 
 | |
| 	if (MaxMsgno > 99000) MaxMsgno = 99000;
 | |
| 
 | |
| 	BidLifetime = GetDlgItemInt(hwndDisplay, IDC_BIDLIFETIME, &OK1, FALSE);
 | |
| 	LogAge = GetDlgItemInt(hwndDisplay, IDC_LOGLIFETIME, &OK1, FALSE);
 | |
| 	UserLifetime = GetDlgItemInt(hwndDisplay, IDC_USERLIFETIME, &OK1, FALSE);
 | |
| 	MaintInterval = GetDlgItemInt(hwndDisplay, IDC_MAINTINTERVAL, &OK1, FALSE);
 | |
| 	MaintTime = GetDlgItemInt(hwndDisplay, IDC_MAINTTIME, &OK1, FALSE);
 | |
| 	PR = GetDlgItemFloat(hwndDisplay, IDM_PR, &OK1, FALSE);
 | |
| 	PUR = GetDlgItemFloat(hwndDisplay, IDM_PUR, &OK1, FALSE);
 | |
| 	PF = GetDlgItemFloat(hwndDisplay, IDM_PF, &OK1, FALSE);
 | |
| 	PNF = GetDlgItemFloat(hwndDisplay, IDM_PNF, &OK1, FALSE);
 | |
| 	BF = GetDlgItemInt(hwndDisplay, IDM_BF, &OK1, FALSE);
 | |
| 	BNF = GetDlgItemInt(hwndDisplay, IDM_BNF, &OK1, FALSE);
 | |
| 	NTSD = GetDlgItemInt(hwndDisplay, IDM_NTSD, &OK1, FALSE);
 | |
| 	NTSF = GetDlgItemInt(hwndDisplay, IDM_NTSF, &OK1, FALSE);
 | |
| 	NTSU = GetDlgItemInt(hwndDisplay, IDM_NTSU, &OK1, FALSE);
 | |
| 	DeletetoRecycleBin = IsDlgButtonChecked(hwndDisplay, IDC_DELETETORECYCLE);
 | |
| 	SuppressMaintEmail = IsDlgButtonChecked(hwndDisplay, IDC_MAINTNOMAIL);
 | |
| 	SaveRegDuringMaint = IsDlgButtonChecked(hwndDisplay, IDC_MAINTSAVEREG);
 | |
| 	OverrideUnsent = IsDlgButtonChecked(hwndDisplay, IDC_OVERRIDEUNSENT);
 | |
| 	SendNonDeliveryMsgs = IsDlgButtonChecked(hwndDisplay, IDC_MAINTNONDELIVERY);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDM_LTFROM, LTFROMString, 2048);
 | |
| 	LTFROM = GetOverrideFromString(LTFROMString);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDM_LTTO, LTTOString, 2048);
 | |
| 	LTTO = GetOverrideFromString(LTTOString);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDM_LTAT, LTATString, 2048);
 | |
| 	LTAT = GetOverrideFromString(LTATString);
 | |
|  
 | |
| 	// Calulate time to run Housekeeping
 | |
| 	{
 | |
| 		struct tm *tm;
 | |
| 		time_t now;
 | |
| 
 | |
| 		now = time(NULL);
 | |
| 
 | |
| 		tm = gmtime(&now);
 | |
| 
 | |
| 		tm->tm_hour = MaintTime / 100;
 | |
| 		tm->tm_min = MaintTime % 100;
 | |
| 		tm->tm_sec = 0;
 | |
| 
 | |
| 		MaintClock = _mkgmtime(tm);
 | |
| 
 | |
| 		while (MaintClock < now)
 | |
| 			MaintClock += MaintInterval * 3600;
 | |
| 
 | |
| 		Debugprintf("Maint Clock %d NOW %d Time to HouseKeeping %d", MaintClock, now, MaintClock - now);
 | |
| 	}
 | |
| 	
 | |
| 	SaveConfig(ConfigName);
 | |
| 	GetConfig(ConfigName);
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Configuration Saved");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| }
 | |
| 
 | |
| VOID SaveWelcomeMsgs()
 | |
| {
 | |
| 	char Value[10000];
 | |
| 
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDM_USERMSG, Value, 10000);
 | |
| 
 | |
| 	free(WelcomeMsg);
 | |
| 	WelcomeMsg = _strdup(Value);
 | |
| 	
 | |
| 	GetDlgItemText(hwndDisplay, IDM_NEWUSERMSG, Value, 10000);
 | |
| 
 | |
| 	free(NewWelcomeMsg);
 | |
| 	NewWelcomeMsg = _strdup(Value);
 | |
| 	
 | |
| 	GetDlgItemText(hwndDisplay, IDM_EXPERTUSERMSG, Value, 10000);
 | |
| 
 | |
| 	free(ExpertWelcomeMsg);
 | |
| 	ExpertWelcomeMsg = _strdup(Value);
 | |
| 	
 | |
| 	GetDlgItemText(hwndDisplay, IDM_SIGNOFF, SignoffMsg, 99);
 | |
| 
 | |
| 	if (SignoffMsg[0])
 | |
| 		if (SignoffMsg[strlen(SignoffMsg) - 1] != 13)
 | |
| 			strcat(SignoffMsg, "\r");
 | |
| 
 | |
| 	TidyWelcomeMsg(&WelcomeMsg);
 | |
| 	TidyWelcomeMsg(&NewWelcomeMsg);
 | |
| 	TidyWelcomeMsg(&ExpertWelcomeMsg);
 | |
| 
 | |
| 		// redisplay, in case tidy has changed them
 | |
| 
 | |
| 	SetDlgItemText(hwndDisplay, IDM_USERMSG, WelcomeMsg);
 | |
| 	SetDlgItemText(hwndDisplay, IDM_NEWUSERMSG, NewWelcomeMsg);
 | |
| 	SetDlgItemText(hwndDisplay, IDM_EXPERTUSERMSG, ExpertWelcomeMsg);
 | |
| 
 | |
| 
 | |
| 	SaveConfig(ConfigName);
 | |
| 	GetConfig(ConfigName);
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Configuration Saved");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| }
 | |
| 
 | |
| VOID SavePrompts()
 | |
| {
 | |
| 	char Value[10000];
 | |
| 
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 
 | |
| 	GetDlgItemText(hwndDisplay, IDM_USERMSG, Value, 10000);
 | |
| 
 | |
| 	free(Prompt);
 | |
| 	Prompt = _strdup(Value);
 | |
| 	
 | |
| 	GetDlgItemText(hwndDisplay, IDM_NEWUSERMSG, Value, 10000);
 | |
| 
 | |
| 	free(NewPrompt);
 | |
| 	NewPrompt = _strdup(Value);
 | |
| 	
 | |
| 	GetDlgItemText(hwndDisplay, IDM_EXPERTUSERMSG, Value, 10000);
 | |
| 
 | |
| 	free(ExpertPrompt);
 | |
| 	ExpertPrompt = _strdup(Value);
 | |
| 	
 | |
| 	TidyPrompts();
 | |
| 
 | |
| 	// redisplay, in case tidy has changed them
 | |
| 
 | |
| 	SetDlgItemText(hwndDisplay, IDM_USERMSG, Prompt);
 | |
| 	SetDlgItemText(hwndDisplay, IDM_NEWUSERMSG, NewPrompt);
 | |
| 	SetDlgItemText(hwndDisplay, IDM_EXPERTUSERMSG, ExpertPrompt);
 | |
| 
 | |
| 	SaveConfig(ConfigName);
 | |
| 	GetConfig(ConfigName);
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Configuration Saved");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| }
 | |
| 
 | |
| 
 | |
| VOID SaveWPConfig(HWND hDlg)
 | |
| {
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 
 | |
| 	SendWP = IsDlgButtonChecked(hwndDisplay, IDC_SENDWP);
 | |
| 	SendWPType = SendDlgItemMessage(hwndDisplay, IDC_WPTYPE, CB_GETCURSEL, 0, 0);
 | |
| 	FilterWPBulls = IsDlgButtonChecked(hwndDisplay, IDC_FILTERWPB);
 | |
| 
 | |
| 	SendWPAddrs = GetMultiLineDialogParam(hDlg, IDC_WPTO);
 | |
| 
 | |
| 	SaveConfig(ConfigName);
 | |
| 	GetConfig(ConfigName);
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Configuration Saved");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| }
 | |
| 
 | |
| 
 | |
| VOID SaveFilters(HWND hDlg)
 | |
| {
 | |
| 	DLGHDR *pHdr = (DLGHDR *) GetWindowLong(hwndDlg, GWL_USERDATA);
 | |
| 
 | |
| 	RejFrom = GetMultiLineDialogParam(hDlg, IDC_REJFROM);
 | |
| 	RejTo = GetMultiLineDialogParam(hDlg, IDC_REJTO);
 | |
| 	RejAt = GetMultiLineDialogParam(hDlg, IDC_REJAT);
 | |
| 	RejBID = GetMultiLineDialogParam(hDlg, IDC_REJBID);
 | |
| 
 | |
| 	HoldFrom = GetMultiLineDialogParam(hDlg, IDC_HOLDFROM);
 | |
| 	HoldTo = GetMultiLineDialogParam(hDlg, IDC_HOLDTO);
 | |
| 	HoldAt = GetMultiLineDialogParam(hDlg, IDC_HOLDAT);
 | |
| 	HoldBID = GetMultiLineDialogParam(hDlg, IDC_HOLDBID);
 | |
| 
 | |
| 	SaveConfig(ConfigName);
 | |
| 	GetConfig(ConfigName);
 | |
| 
 | |
| 	sprintf(InfoBoxText, "Configuration Saved");
 | |
| 	DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| VOID * GetMultiLineDialogParam(HWND hDialog, int DLGItem)
 | |
| {
 | |
| 	char Text[32768];
 | |
| 	char Val[32768];
 | |
| 	char * ptr1, * ptr2;
 | |
| 	char * MultiString = NULL;
 | |
| 	const char * ptr;
 | |
| 	int Count = 0;
 | |
| 	char ** Value;
 | |
| 
 | |
| 	int Len = GetDlgItemText(hDialog, DLGItem, Text, 10000);
 | |
| 
 | |
| 	// replace crlf with '|'
 | |
| 
 | |
| 	if (Text[strlen(Text)-1] != '\n')			// no terminating crlf?
 | |
| 		strcat(Text, "\r\n");
 | |
| 
 | |
| 	ptr1 = Text;
 | |
| 	ptr2 = Val;
 | |
| 		
 | |
| 	while (*ptr1)
 | |
| 	{
 | |
| 		if (*ptr1 == '\r')
 | |
| 		{
 | |
| 			while (*(ptr1+2) == '\r')			// Blank line
 | |
| 				ptr1+=2;
 | |
| 
 | |
| 			*++ptr1 = '|';
 | |
| 		}
 | |
| 		*ptr2++= *ptr1++;
 | |
| 	}
 | |
| 
 | |
| 	*ptr2++ = 0;
 | |
| 
 | |
| 	Value = zalloc(4);				// always NULL entry on end even if no values
 | |
| 	Value[0] = NULL;
 | |
| 
 | |
| 	ptr = Val;
 | |
| 	
 | |
| 	while (ptr && strlen(ptr))
 | |
| 	{
 | |
| 		ptr1 = strchr(ptr, '|');
 | |
| 			
 | |
| 		if (ptr1)
 | |
| 			*(ptr1++) = 0;
 | |
| 
 | |
| 		if (ptr[0] == 0)		// Just had a | (empty string)
 | |
| 			break;
 | |
| 
 | |
| 		Value = realloc(Value, (Count+2) * sizeof(void *));
 | |
| 			
 | |
| 		Value[Count++] = _strdup(ptr);
 | |
| 		ptr = ptr1;
 | |
| 	}
 | |
| 
 | |
| 	Value[Count] = NULL;
 | |
| 	return Value;
 | |
| }
 | |
| 
 | |
| BOOL GetConfigFromRegistry()
 | |
| {
 | |
| 	HKEY hKey=0;
 | |
| 	int retCode,Type,Vallen, i;
 | |
| 	char Size[80];
 | |
| 	char * ptr;
 | |
| 
 | |
| 	// Get Config From Registry
 | |
| 
 | |
| 	sprintf(BaseDirRaw, "%s/BPQMailChat", GetBPQDirectory());
 | |
| 
 | |
| 	retCode = RegOpenKeyEx (REGTREE,
 | |
|                  "SOFTWARE\\G8BPQ\\BPQ32\\BPQMailChat", 0, KEY_ALL_ACCESS, &hKey);
 | |
| 
 | |
| 	if (retCode != ERROR_SUCCESS)
 | |
| 		return FALSE;
 | |
| 
 | |
| 	{
 | |
| 		Vallen=4;
 | |
| 		retCode += RegQueryValueEx(hKey,"Streams",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&MaxStreams,(ULONG *)&Vallen);
 | |
| 		
 | |
| 		Vallen=4;
 | |
| 		retCode += RegQueryValueEx(hKey,"BBSApplNum",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&BBSApplNum,(ULONG *)&Vallen);
 | |
| 		
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey, "EnableUI", 0, &Type, (UCHAR *)&EnableUI, &Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey, "MailForInterval", 0, &Type, (UCHAR *)&MailForInterval, &Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey, "RefuseBulls", 0, &Type, (UCHAR *)&RefuseBulls, &Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"SendSYStoSYSOPCall",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&SendSYStoSYSOPCall,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"SendBBStoSYSOPCall",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&SendBBStoSYSOPCall,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"DontHoldNewUsers",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&DontHoldNewUsers,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"ForwardToMe",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ForwardToMe,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"AllowAnon",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&AllowAnon,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"DontNeedHomeBBS",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&DontNeedHomeBBS,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"MaxTXSize",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&MaxTXSize,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"MaxRXSize",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&MaxRXSize,(ULONG *)&Vallen);
 | |
| 
 | |
| 		AliasText = RegGetMultiStringValue(hKey,  "FWD Aliases");
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey, "Readdress Local",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ReaddressLocal, &Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey, "Readdress Received",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ReaddressReceived, &Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey, "Warn No Route",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&WarnNoRoute, &Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey, "Localtime",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&Localtime, &Vallen);
 | |
| 
 | |
| 		Vallen=100;
 | |
| 		retCode += RegQueryValueEx(hKey, "BBSName",0 , &Type, (UCHAR *)&BBSName, &Vallen);
 | |
| 
 | |
| 		sprintf(SignoffMsg, "73 de %s\r", BBSName);	// Default
 | |
| 
 | |
| 		Vallen=100;
 | |
| 		retCode += RegQueryValueEx(hKey, "MailForText",0 , &Type, (UCHAR *)&MailForText, &Vallen);
 | |
| 
 | |
| 		Vallen=100;
 | |
| 		retCode += RegQueryValueEx(hKey,"SYSOPCall",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&SYSOPCall,(ULONG *)&Vallen);
 | |
| 				
 | |
| 		Vallen=100;
 | |
| 		retCode += RegQueryValueEx(hKey,"H-Route",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&HRoute,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=MAX_PATH;
 | |
| 		retCode += RegQueryValueEx(hKey,"BaseDir",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&BaseDirRaw,(ULONG *)&Vallen);
 | |
| 
 | |
| 		ptr = &BaseDirRaw[strlen(BaseDirRaw) -1];
 | |
| 
 | |
| 		if (*ptr == '\\' || *ptr == '/')
 | |
| 			*ptr = 0;
 | |
| 
 | |
| 		ExpandEnvironmentStrings(BaseDirRaw, BaseDir, MAX_PATH);
 | |
| 		// Get length of Chatnodes String
 | |
| 				
 | |
| 		Vallen=4;
 | |
| 		retCode += RegQueryValueEx(hKey,"SMTPPort",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&SMTPInPort,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		retCode += RegQueryValueEx(hKey,"POP3Port",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&POP3InPort,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"NNTPPort",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&NNTPInPort,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		retCode += RegQueryValueEx(hKey,"SMTPGatewayEnabled",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ISP_Gateway_Enabled,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"RemoteEmail",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&RemoteEmail,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 
 | |
| 		retCode += RegQueryValueEx(hKey,"POP3 Polling Interval",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ISPPOP3Interval,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=50;
 | |
| 		retCode += RegQueryValueEx(hKey,"MyDomain",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&MyDomain,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=50;
 | |
| 		retCode += RegQueryValueEx(hKey,"ISPSMTPName",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ISPSMTPName,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=50;
 | |
| 		retCode += RegQueryValueEx(hKey,"ISPPOP3Name",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ISPPOP3Name,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		retCode += RegQueryValueEx(hKey,"ISPSMTPPort",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ISPSMTPPort,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		retCode += RegQueryValueEx(hKey,"ISPPOP3Port",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ISPPOP3Port,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=50;
 | |
| 		retCode += RegQueryValueEx(hKey,"ISPAccountName",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&ISPAccountName,(ULONG *)&Vallen);
 | |
| 
 | |
| 		EncryptedPassLen=50;
 | |
| 		retCode += RegQueryValueEx(hKey,"ISPAccountPass",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&EncryptedISPAccountPass,(ULONG *)&EncryptedPassLen);
 | |
| 
 | |
| 		DecryptPass(EncryptedISPAccountPass, ISPAccountPass, EncryptedPassLen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"AuthenticateSMTP",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&SMTPAuthNeeded,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"Log_BBS",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&LogBBS,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"Log_TCP",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&LogTCP,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"Log_CHAT",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&LogCHAT,(ULONG *)&Vallen);
 | |
| 
 | |
| 		Vallen=80;
 | |
| 		RegQueryValueEx(hKey,"MonitorSize",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&Size,(ULONG *)&Vallen);
 | |
| 
 | |
| 		sscanf(Size,"%d,%d,%d,%d",&MonitorRect.left,&MonitorRect.right,&MonitorRect.top,&MonitorRect.bottom);
 | |
| 
 | |
| 		Vallen=80;
 | |
| 		RegQueryValueEx(hKey,"WindowSize",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&Size,(ULONG *)&Vallen);
 | |
| 
 | |
| 		sscanf(Size,"%d,%d,%d,%d",&MainRect.left,&MainRect.right,&MainRect.top,&MainRect.bottom);
 | |
| 
 | |
| 		// Get Welcome Messages
 | |
| 
 | |
| 		Vallen=0;
 | |
| 		
 | |
| 		RegQueryValueEx(hKey,"WelcomeMsg",0,	(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 		if (Vallen)
 | |
| 		{
 | |
| 			WelcomeMsg = malloc(Vallen);
 | |
| 			RegQueryValueEx(hKey,"WelcomeMsg",0, (ULONG *)&Type, WelcomeMsg, (ULONG *)&Vallen);
 | |
| 		}
 | |
| 		else
 | |
| 			WelcomeMsg = _strdup("Hello $I. Latest Message is $L, Last listed is $Z\r\n");
 | |
| 
 | |
| 		RegQueryValueEx(hKey,"NewUserWelcomeMsg",0,	(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 		if (Vallen)
 | |
| 		{
 | |
| 			NewWelcomeMsg = malloc(Vallen);
 | |
| 			RegQueryValueEx(hKey,"NewUserWelcomeMsg",0, (ULONG *)&Type, NewWelcomeMsg, (ULONG *)&Vallen);
 | |
| 		}
 | |
| 		else
 | |
| 			
 | |
| 			NewWelcomeMsg = _strdup("Hello $I. Latest Message is $L, Last listed is $Z\r\n");
 | |
| 
 | |
| 		Vallen=0;
 | |
| 		
 | |
| 		RegQueryValueEx(hKey,"ExpertWelcomeMsg",0,	(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 		if (Vallen)
 | |
| 		{
 | |
| 			ExpertWelcomeMsg = malloc(Vallen);
 | |
| 			RegQueryValueEx(hKey,"ExpertWelcomeMsg",0, (ULONG *)&Type, ExpertWelcomeMsg, (ULONG *)&Vallen);
 | |
| 		}
 | |
| 		else
 | |
| 			ExpertWelcomeMsg = _strdup("");
 | |
| 
 | |
| 		Vallen = 99;
 | |
| 		RegQueryValueEx(hKey,"SignoffMsg",0, (ULONG *)&Type, &SignoffMsg[0], (ULONG *)&Vallen);
 | |
| 
 | |
| 		// Get Prompts
 | |
| 
 | |
| 		Vallen=0;
 | |
| 		
 | |
| 		RegQueryValueEx(hKey,"Prompt",0,	(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 		if (Vallen)
 | |
| 		{
 | |
| 			Prompt = malloc(Vallen + 3);
 | |
| 			RegQueryValueEx(hKey,"Prompt",0, (ULONG *)&Type, Prompt, (ULONG *)&Vallen);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			Prompt = malloc(20);
 | |
| 			sprintf(Prompt, "de %s>\r\n", BBSName);
 | |
| 		}
 | |
| 
 | |
| 		RegQueryValueEx(hKey,"NewUserPrompt",0,	(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 		if (Vallen)
 | |
| 		{
 | |
| 			NewPrompt = malloc(Vallen + 3);
 | |
| 			RegQueryValueEx(hKey,"NewUserPrompt",0, (ULONG *)&Type, NewPrompt, (ULONG *)&Vallen);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			NewPrompt = malloc(20);
 | |
| 			sprintf(NewPrompt, "de %s>\r\n", BBSName);
 | |
| 		}
 | |
| 
 | |
| 		RegQueryValueEx(hKey,"ExpertPrompt",0,	(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 		if (Vallen)
 | |
| 		{
 | |
| 			ExpertPrompt = malloc(Vallen);
 | |
| 			RegQueryValueEx(hKey,"ExpertPrompt",0, (ULONG *)&Type, ExpertPrompt, (ULONG *)&Vallen);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			ExpertPrompt = malloc(20);
 | |
| 			sprintf(ExpertPrompt, "de %s>\r\n", BBSName);
 | |
| 		}
 | |
| 
 | |
| 		TidyPrompts();
 | |
| 
 | |
| 		RegQueryValueEx(hKey,"NewUserWelcomeMsg",0,	(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 		if (Vallen)
 | |
| 		{
 | |
| 			NewWelcomeMsg = malloc(Vallen);
 | |
| 			RegQueryValueEx(hKey,"NewUserWelcomeMsg",0, (ULONG *)&Type, NewWelcomeMsg, (ULONG *)&Vallen);
 | |
| 		}
 | |
| 		else
 | |
| 			
 | |
| 			NewWelcomeMsg = _strdup("Hello $I. Latest Message is $L, Last listed is $Z\r\n");
 | |
| 
 | |
| 		Vallen=0;
 | |
| 		
 | |
| 		RegQueryValueEx(hKey,"ExpertWelcomeMsg",0,	(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 		if (Vallen)
 | |
| 		{
 | |
| 			ExpertWelcomeMsg = malloc(Vallen);
 | |
| 			RegQueryValueEx(hKey,"ExpertWelcomeMsg",0, (ULONG *)&Type, ExpertWelcomeMsg, (ULONG *)&Vallen);
 | |
| 		}
 | |
| 		else
 | |
| 			ExpertWelcomeMsg = _strdup("");
 | |
| 
 | |
| 		Vallen=80;
 | |
| 
 | |
| 
 | |
| 		RejFrom = RegGetMultiStringValue(hKey,  "RejFrom");
 | |
| 		RejTo = RegGetMultiStringValue(hKey,  "RejTo");
 | |
| 		RejAt = RegGetMultiStringValue(hKey,  "RejAt");
 | |
| 
 | |
| 		HoldFrom = RegGetMultiStringValue(hKey,  "HoldFrom");
 | |
| 		HoldTo = RegGetMultiStringValue(hKey,  "HoldTo");
 | |
| 		HoldAt = RegGetMultiStringValue(hKey,  "HoldAt");
 | |
| 
 | |
| 		// Send WP Params
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey, "SendWP", 0, &Type, (UCHAR *)&SendWP, &Vallen);
 | |
| 
 | |
| 		Vallen=10;
 | |
| 		RegQueryValueEx(hKey,"SendWPTO",0, &Type, &SendWPTO[0],&Vallen);
 | |
| 
 | |
| 		Vallen=80;
 | |
| 		RegQueryValueEx(hKey,"SendWPVIA",0,	&Type,&SendWPVIA[0],&Vallen);
 | |
| 
 | |
| 		Vallen=4;
 | |
| 		RegQueryValueEx(hKey,"SendWPType",0, &Type, (UCHAR *)&SendWPType, &Vallen);
 | |
| 
 | |
| 
 | |
| 		if (RegQueryValueEx(hKey,"Version",0, (ULONG *)&Type, (UCHAR *)&Size, (ULONG *)&Vallen) == 0)
 | |
| 			sscanf(Size,"%d,%d,%d,%d", &LastVer[0], &LastVer[1], &LastVer[2], &LastVer[3]);
 | |
| 
 | |
| /*
 | |
| 		if ((LastVer[3] != Ver[3]) || (LastVer[2] != Ver[2]) ||
 | |
| 			(LastVer[1] != Ver[1]) || (LastVer[0] != Ver[0]))
 | |
| 		{
 | |
| 			// New Version Detected
 | |
| 
 | |
| 			if (LastVer[0] == 0)
 | |
| 			{
 | |
| 				// Pre Version Checking
 | |
| 
 | |
| 				MessageBox(NULL, "WARNING - This seems to be the first time you have run this version.\r\n"
 | |
| 					"Forwarding has changed significantly. Please read the docs and make the necessary\r\n"
 | |
| 					"changes to Forwarding Config. The Software will try to fill in the BBS HA fields from the WP\r\n"
 | |
| 					"Database, but check them, and complete the  new 'Hierarchical Routes (Flood Bulls)' field.\r\n"
 | |
| 					"Network access has been  disabled by setting BBS Streams to zero to prevent messages\r\n"
 | |
| 					"being lost or incorrecly forwarded. Once you are happy with the forwarding config\r\n"
 | |
| 					"you can reset BBS Streams.",
 | |
| 						"BPQMailChat", MB_ICONINFORMATION);
 | |
| 
 | |
| 				MaxStreams = 0;
 | |
| 				
 | |
| 				RegSetValueEx(hKey, "Streams", 0, REG_DWORD,(BYTE *)&MaxStreams, 4);
 | |
| 
 | |
| 			}
 | |
| 		}
 | |
| */
 | |
| 		RegCloseKey(hKey);
 | |
| 
 | |
| 		for (i=1; i<=32; i++)
 | |
| 		{
 | |
| 			int retCode;
 | |
| 			char Key[100];
 | |
| 			
 | |
| 			sprintf(Key, "SOFTWARE\\G8BPQ\\BPQ32\\BPQMailChat\\UIPort%d", i);
 | |
| 
 | |
| 			retCode = RegOpenKeyEx (REGTREE,
 | |
|                               Key,
 | |
|                               0,
 | |
|                               KEY_QUERY_VALUE,
 | |
|                               &hKey);
 | |
| 
 | |
| 			if (retCode == ERROR_SUCCESS)
 | |
| 			{
 | |
| 				Vallen=4;
 | |
| 				RegQueryValueEx(hKey,"Enabled",0,			
 | |
| 					(ULONG *)&Type,(UCHAR *)&UIEnabled[i],(ULONG *)&Vallen);
 | |
| 
 | |
| 				UIMF[i] = UIEnabled[i];		// Defaults
 | |
| 				UIHDDR[i] = UIEnabled[i];
 | |
| 
 | |
| 				Vallen=4;
 | |
| 				RegQueryValueEx(hKey,"SendMF",0,			
 | |
| 					(ULONG *)&Type,(UCHAR *)&UIMF[i],(ULONG *)&Vallen);
 | |
| 		
 | |
| 				Vallen=4;
 | |
| 				RegQueryValueEx(hKey,"SendHDDR",0,			
 | |
| 					(ULONG *)&Type,(UCHAR *)&UIHDDR[i],(ULONG *)&Vallen);
 | |
| 
 | |
| 				Vallen=4;
 | |
| 				RegQueryValueEx(hKey,"SendNull",0,			
 | |
| 					(ULONG *)&Type,(UCHAR *)&UINull[i],(ULONG *)&Vallen);
 | |
| 
 | |
| 				Vallen=0;
 | |
| 				RegQueryValueEx(hKey,"Digis",0,			
 | |
| 					(ULONG *)&Type, NULL, (ULONG *)&Vallen);
 | |
| 
 | |
| 				if (Vallen)
 | |
| 				{
 | |
| 					UIDigi[i] = malloc(Vallen);
 | |
| 					RegQueryValueEx(hKey,"Digis",0,			
 | |
| 						(ULONG *)&Type, UIDigi[i], (ULONG *)&Vallen);
 | |
| 				}
 | |
| 
 | |
| 			//	retCode = RegSetValueEx(hKey, "Digis",0, REG_SZ,(BYTE *)UIDigi[i], strlen(UIDigi[i]));
 | |
| 
 | |
| 				RegCloseKey(hKey);
 | |
| 			}
 | |
| 		}
 | |
| 	
 | |
| 		retCode += RegOpenKeyEx (REGTREE,
 | |
|                               "SOFTWARE\\G8BPQ\\BPQ32\\BPQMailChat\\Housekeeping",
 | |
|                               0,
 | |
|                               KEY_QUERY_VALUE,
 | |
|                               &hKey);
 | |
| 		
 | |
| 		if (retCode == ERROR_SUCCESS)
 | |
| 		{
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey,"LastHouseKeepingTime",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&LastHouseKeepingTime,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey,"LastTrafficTime",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&LastTrafficTime,(ULONG *)&Vallen);
 | |
| 
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"MaxMsgno",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&MaxMsgno,(ULONG *)&Vallen);
 | |
| 
 | |
| 			if (MaxMsgno > 99000) MaxMsgno = 99000;
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey,"LogLifetime",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&LogAge,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"BidLifetime",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&BidLifetime,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey,"UserLifetime",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&UserLifetime,(ULONG *)&Vallen);
 | |
| 
 | |
| 	
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"MaintInterval",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&MaintInterval,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"MaintTime",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&MaintTime,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"PR",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&PR,(ULONG *)&Vallen);
 | |
| 		
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"PUR",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&PUR,(ULONG *)&Vallen);
 | |
| 		
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"PF",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&PF,(ULONG *)&Vallen);
 | |
| 		
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"PNF",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&PNF,(ULONG *)&Vallen);
 | |
| 		
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"BF",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&BF,(ULONG *)&Vallen);
 | |
| 		
 | |
| 			Vallen=4;
 | |
| 			retCode += RegQueryValueEx(hKey,"BNF",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&BNF,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey,"NTSD",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&NTSD,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey,"NTSU",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&NTSU,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey,"NTSF",0,			
 | |
| 			(ULONG *)&Type,(UCHAR *)&NTSF,(ULONG *)&Vallen);
 | |
| 
 | |
| //			Vallen=4;
 | |
| //			retCode += RegQueryValueEx(hKey, "AP", 0,			
 | |
| //				(ULONG *)&Type,(UCHAR *)&AP,(ULONG *)&Vallen);
 | |
| 				
 | |
| //			Vallen=4;
 | |
| //			retCode += RegQueryValueEx(hKey, "AB", 0,			
 | |
| //				(ULONG *)&Type,(UCHAR *)&AB,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey, "DeletetoRecycleBin", 0,			
 | |
| 				(ULONG *)&Type,(UCHAR *)&DeletetoRecycleBin,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey, "SuppressMaintEmail", 0,			
 | |
| 				(ULONG *)&Type,(UCHAR *)&SuppressMaintEmail,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey, "MaintSaveReg", 0,			
 | |
| 				(ULONG *)&Type,(UCHAR *)&SaveRegDuringMaint,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey, "OverrideUnsent", 0,			
 | |
| 				(ULONG *)&Type,(UCHAR *)&OverrideUnsent,(ULONG *)&Vallen);
 | |
| 
 | |
| 			Vallen=4;
 | |
| 			RegQueryValueEx(hKey, "SendNonDeliveryMsgs", 0,			
 | |
| 				(ULONG *)&Type,(UCHAR *)&SendNonDeliveryMsgs,(ULONG *)&Vallen);
 | |
| 
 | |
| 			LTFROM = RegGetOverrides(hKey, "LTFROM");
 | |
| 			LTTO = RegGetOverrides(hKey, "LTTO");
 | |
| 			LTAT = RegGetOverrides(hKey, "LTAT");
 | |
| 		}
 | |
| 
 | |
| 		return TRUE;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| 
 | |
| INT_PTR CALLBACK UserEditDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| 	int Command, n;
 | |
| 		
 | |
| 	UNREFERENCED_PARAMETER(lParam);
 | |
| 	switch (message)
 | |
| 	{
 | |
| 
 | |
| 	case WM_INITDIALOG:
 | |
| 
 | |
| 		for (n = 1; n <= NumberofUsers; n++)
 | |
| 		{
 | |
| 			SendDlgItemMessage(hDlg, IDC_USER, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR)UserRecPtr[n]->Call);
 | |
| 		} 
 | |
| 
 | |
| 		return (INT_PTR)TRUE;
 | |
| 
 | |
| 		
 | |
| 	case WM_CTLCOLORDLG:
 | |
| 
 | |
|         return (LONG)bgBrush;
 | |
| 
 | |
|     case WM_CTLCOLORSTATIC:
 | |
|     {
 | |
|         HDC hdcStatic = (HDC)wParam;
 | |
| 		SetTextColor(hdcStatic, RGB(0, 0, 0));
 | |
|         SetBkMode(hdcStatic, TRANSPARENT);
 | |
|         return (LONG)bgBrush;
 | |
|     }
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 
 | |
| 		Command = LOWORD(wParam);
 | |
| 
 | |
| 		switch (Command)
 | |
| 		{
 | |
| 
 | |
| 		case IDOK:
 | |
| 		case IDCANCEL:
 | |
| 
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 			return (INT_PTR)TRUE;
 | |
| 
 | |
| 
 | |
| 		case IDC_USER:
 | |
| 
 | |
| 			// User Selection Changed
 | |
| 
 | |
| 			Do_User_Sel_Changed(hDlg);
 | |
| 
 | |
| 			return TRUE;
 | |
| 
 | |
| 
 | |
| 		case IDC_ADDUSER:
 | |
| 
 | |
| 			Do_Add_User(hDlg);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_DELETEUSER:
 | |
| 
 | |
| 			Do_Delete_User(hDlg);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_SAVEUSER:
 | |
| 
 | |
| 			Do_Save_User(hDlg, TRUE);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		}
 | |
| 		break;
 | |
| 	}
 | |
| 	
 | |
| 	return (INT_PTR)FALSE;
 | |
| }
 | |
| 
 | |
| INT_PTR CALLBACK MsgEditDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| 	int Command, n;
 | |
| 	char msgno[20];
 | |
| 	struct MsgInfo * Msg;
 | |
| 
 | |
| 	UNREFERENCED_PARAMETER(lParam);
 | |
| 	switch (message)
 | |
| 	{
 | |
| 
 | |
| 	case WM_INITDIALOG:
 | |
| 
 | |
| 		for (n = NumberofMessages; n >= 1; n--)
 | |
| 		{
 | |
| 			sprintf_s(msgno, sizeof(msgno), "%d", MsgHddrPtr[n]->number);
 | |
| 			SendDlgItemMessage(hDlg, 0, LB_ADDSTRING, 0, (LPARAM)msgno);
 | |
| 		} 
 | |
| 
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGTYPE, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "B");
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGTYPE, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "P");
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGTYPE, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "T");
 | |
| 
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGSTATUS, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "N");
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGSTATUS, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "Y");
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGSTATUS, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "F");
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGSTATUS, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "K");
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGSTATUS, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "H");
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGSTATUS, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "D");
 | |
| 		SendDlgItemMessage(hDlg, IDC_MSGSTATUS, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR) "$");
 | |
| 
 | |
| 		CheckDlgButton(hDlg,205, BST_INDETERMINATE);
 | |
| 		CheckDlgButton(hDlg,206, BST_UNCHECKED);
 | |
| 		CheckDlgButton(hDlg,207, BST_CHECKED);
 | |
| 
 | |
| 		return (INT_PTR)TRUE;
 | |
| 
 | |
| 	case WM_CTLCOLORDLG:
 | |
| 
 | |
|         return (LONG)bgBrush;
 | |
| 
 | |
|     case WM_CTLCOLORSTATIC:
 | |
|     {
 | |
|         HDC hdcStatic = (HDC)wParam;
 | |
| 		SetTextColor(hdcStatic, RGB(0, 0, 0));
 | |
|         SetBkMode(hdcStatic, TRANSPARENT);
 | |
|         return (LONG)bgBrush;
 | |
|     }
 | |
| 
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 
 | |
| 		Command = LOWORD(wParam);
 | |
| 
 | |
| 		switch (Command)
 | |
| 		{
 | |
| 
 | |
| 		case IDOK:
 | |
| 		case IDCANCEL:
 | |
| 
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 			return (INT_PTR)TRUE;
 | |
| 
 | |
| 		case 0:
 | |
| 
 | |
| 			// Msg Selection Changed
 | |
| 
 | |
| 			Do_Msg_Sel_Changed(hDlg);
 | |
| 
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_EDITTEXT:
 | |
| 
 | |
| 			if (CurrentMsgIndex == -1)
 | |
| 			{
 | |
| 				sprintf(InfoBoxText, "Please select a message to Edit");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 			if (SendDlgItemMessage(hDlg, 0, LB_GETSELCOUNT, 0, 0) > 1)
 | |
| 			{
 | |
| 				sprintf(InfoBoxText, "Please select only one message");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 			DialogBox(hInst, MAKEINTRESOURCE(IDD_EDITMSGTEXT), hDlg, EditMsgTextDialogProc);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_SAVEMSG:
 | |
| 
 | |
| 			if (SendDlgItemMessage(hDlg, 0, LB_GETSELCOUNT, 0, 0) > 1)
 | |
| 			{
 | |
| 				sprintf(InfoBoxText, "Please select only one message");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 			Do_Save_Msg(hDlg);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_EXPORT:
 | |
| 		{
 | |
| 			struct MsgInfo * Msg;
 | |
| 			char FileName[MAX_PATH] = "Export.out";
 | |
| 			OPENFILENAME Ofn; 
 | |
| 			int Count;
 | |
| 			int * Indexes;
 | |
| 			int i;
 | |
| 			char MsgnoText[10];
 | |
| 			int Msgno;
 | |
| 
 | |
| 			if (CurrentMsgIndex == -1)
 | |
| 			{
 | |
| 				sprintf(InfoBoxText, "Please select a message to Export");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 			Count = SendDlgItemMessage(hDlg, 0, LB_GETSELCOUNT, 0, 0);
 | |
| 
 | |
| 			Indexes = malloc(Count * sizeof(void *));
 | |
| 
 | |
| 			SendDlgItemMessage(hDlg, 0, LB_GETSELITEMS , Count, (LPARAM)&Indexes[0]);
 | |
| 
 | |
| 			memset(&Ofn, 0, sizeof(Ofn));
 | |
|  
 | |
| 			Ofn.lStructSize = sizeof(OPENFILENAME); 
 | |
| 			Ofn.hInstance = hInst;
 | |
| 			Ofn.hwndOwner = hDlg; 
 | |
| 			Ofn.lpstrFilter = NULL; 
 | |
| 			Ofn.lpstrFile= FileName; 
 | |
| 			Ofn.nMaxFile = sizeof(FileName)/ sizeof(*FileName); 
 | |
| 			Ofn.lpstrFileTitle = NULL; 
 | |
| 			Ofn.nMaxFileTitle = 0; 
 | |
| 			Ofn.lpstrInitialDir = (LPSTR)NULL; 
 | |
| 			Ofn.Flags = OFN_SHOWHELP | OFN_OVERWRITEPROMPT; 
 | |
| 			Ofn.lpstrTitle = NULL;//; 
 | |
| 
 | |
| 			if (GetSaveFileName(&Ofn))
 | |
| 			{
 | |
| 				FILE * Handle = fopen(FileName, "ab");
 | |
| 
 | |
| 				if (Handle == NULL) 
 | |
| 				{
 | |
| 					sprintf(InfoBoxText, "Failed to open Export File %s", FileName);
 | |
| 					DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 					return TRUE;
 | |
| 				}
 | |
| 
 | |
| //				SetFilePointer(Handle, 0, 0, FILE_END);
 | |
| 
 | |
| 				for (i = 0; i < Count; i++)
 | |
| 				{
 | |
| 					Msg = MsgHddrPtr[Indexes[i]];
 | |
| 					SendDlgItemMessage(hDlg, 0, LB_GETTEXT, Indexes[i], (LPARAM)(LPCTSTR)&MsgnoText);
 | |
| 					Msgno = atoi(MsgnoText);
 | |
| 
 | |
| 					for (CurrentMsgIndex = 1; CurrentMsgIndex <= NumberofMessages; CurrentMsgIndex++)
 | |
| 					{
 | |
| 						Msg = MsgHddrPtr[CurrentMsgIndex];
 | |
| 
 | |
| 						if (Msg->number == Msgno)
 | |
| 						{
 | |
| 							ForwardMessagetoFile(Msg, Handle);
 | |
| 							break;
 | |
| 						}
 | |
| 					}
 | |
| 				}
 | |
| 				fclose(Handle);
 | |
| 			}
 | |
| 
 | |
| 			free(Indexes);
 | |
| 
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		case IDC_SAVETOFILE:
 | |
| 		{
 | |
| 			struct MsgInfo * Msg;
 | |
| 			char * MailBuffer;
 | |
| 			char FileName[MAX_PATH] = "";
 | |
| 			int Files = 0;
 | |
| 			int BodyLen;
 | |
| 			char * ptr;
 | |
| 			HANDLE hFile = INVALID_HANDLE_VALUE;
 | |
| 			int WriteLen=0;
 | |
| 			OPENFILENAME Ofn; 
 | |
| 			char Hddr[1000];
 | |
| 			char FullTo[100];
 | |
| 
 | |
| 			if (CurrentMsgIndex == -1)
 | |
| 			{
 | |
| 				sprintf(InfoBoxText, "Please select a message to Save");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 			if (SendDlgItemMessage(hDlg, 0, LB_GETSELCOUNT, 0, 0) > 1)
 | |
| 			{
 | |
| 				sprintf(InfoBoxText, "Please select only one message");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 			Msg = MsgHddrPtr[CurrentMsgIndex];
 | |
| 
 | |
| 			MailBuffer = ReadMessageFile(Msg->number);
 | |
| 			BodyLen = Msg->length;
 | |
| 
 | |
| 			sprintf(FileName, "MSG%05d.txt", Msg->number); 
 | |
| 
 | |
| 			ptr = MailBuffer;
 | |
| 
 | |
| 			if (_stricmp(Msg->to, "RMS") == 0)
 | |
| 				 sprintf(FullTo, "RMS:%s", Msg->via);
 | |
| 			else
 | |
| 			if (Msg->to[0] == 0)
 | |
| 				sprintf(FullTo, "smtp:%s", Msg->via);
 | |
| 			else
 | |
| 				strcpy(FullTo, Msg->to);
 | |
| 
 | |
| 			sprintf(Hddr, "From: %s%s\r\nTo: %s\r\nType/Status: %c%c\r\nDate/Time: %s\r\nBid: %s\r\nTitle: %s\r\n\r\n",
 | |
| 				Msg->from, Msg->emailfrom, FullTo, Msg->type, Msg->status, FormatDateAndTime((time_t)Msg->datecreated, FALSE), Msg->bid, Msg->title);
 | |
| 
 | |
| 			if (Msg->B2Flags & B2Msg)
 | |
| 			{
 | |
| 			// Remove B2 Headers (up to the File: Line)
 | |
| 			
 | |
| 				char * bptr;
 | |
| 				bptr = strstr(ptr, "Body:");
 | |
| 				if (bptr)
 | |
| 				{
 | |
| 					BodyLen = atoi(bptr + 5);
 | |
| 					bptr = strstr(bptr, "\r\n\r\n");
 | |
| 
 | |
| 					if (bptr)
 | |
| 						ptr = bptr+4;
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			memset(&Ofn, 0, sizeof(Ofn));
 | |
|  
 | |
| 			Ofn.lStructSize = sizeof(OPENFILENAME); 
 | |
| 			Ofn.hInstance = hInst;
 | |
| 			Ofn.hwndOwner = hDlg; 
 | |
| 			Ofn.lpstrFilter = NULL; 
 | |
| 			Ofn.lpstrFile= FileName; 
 | |
| 			Ofn.nMaxFile = sizeof(FileName)/ sizeof(*FileName); 
 | |
| 			Ofn.lpstrFileTitle = NULL; 
 | |
| 			Ofn.nMaxFileTitle = 0; 
 | |
| 			Ofn.lpstrInitialDir = (LPSTR)NULL; 
 | |
| 			Ofn.Flags = OFN_SHOWHELP | OFN_OVERWRITEPROMPT; 
 | |
| 			Ofn.lpstrTitle = NULL;//; 
 | |
| 
 | |
| 			if (GetSaveFileName(&Ofn))
 | |
| 			{
 | |
| 				hFile = CreateFile(FileName,
 | |
| 					GENERIC_WRITE, FILE_SHARE_READ, NULL,
 | |
| 					CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
 | |
| 
 | |
| 				if (hFile != INVALID_HANDLE_VALUE)
 | |
| 				{
 | |
| 					WriteFile(hFile, Hddr, strlen(Hddr), &WriteLen, NULL);
 | |
| 					WriteFile(hFile, ptr, BodyLen, &WriteLen, NULL);
 | |
| 					CloseHandle(hFile);
 | |
| 				}
 | |
| 			}
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		
 | |
| 
 | |
| 		case IDC_PRINTMSG:
 | |
| 		{
 | |
| 			int Count;
 | |
| 			int * Indexes;
 | |
| 
 | |
| 			if (CurrentMsgIndex == -1)
 | |
| 			{
 | |
| 				sprintf(InfoBoxText, "Please select a message to Print");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 			Count = SendDlgItemMessage(hDlg, 0, LB_GETSELCOUNT, 0, 0);
 | |
| 
 | |
| 			Indexes = malloc(Count * sizeof(void *));
 | |
| 
 | |
| 			SendDlgItemMessage(hDlg, 0, LB_GETSELITEMS , Count, (LPARAM)&Indexes[0]);
 | |
| 
 | |
| 			PrintMessages(hDlg, Count, Indexes);
 | |
| 
 | |
| 			free(Indexes);
 | |
| 	
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 		case FILTER_FROM:
 | |
| 		case FILTER_TO:
 | |
| 		case FILTER_VIA:
 | |
| 		case FILTER_BID:
 | |
| 
 | |
| 			if (HIWORD(wParam) == 0x300)
 | |
| 			{
 | |
| 				GetDlgItemText(hDlg, FILTER_FROM, Filter_FROM, 10);
 | |
| 				GetDlgItemText(hDlg, FILTER_TO, Filter_TO, 10);
 | |
| 				GetDlgItemText(hDlg, FILTER_VIA, Filter_VIA, 50);
 | |
| 				GetDlgItemText(hDlg, FILTER_BID, Filter_BID, 14);
 | |
| 
 | |
| 				SendDlgItemMessage(hDlg, 0, LB_RESETCONTENT, 0, 0);
 | |
| 				
 | |
| 				for (n = NumberofMessages; n >= 1; n--)
 | |
| 				{
 | |
| 					Msg = MsgHddrPtr[n];
 | |
| 					
 | |
| 					if ((!Filter_TO[0] || strstr(Msg->to, Filter_TO)) &&
 | |
| 						(!Filter_FROM[0] || strstr(Msg->from, Filter_FROM)) &&
 | |
| 						(!Filter_BID[0] || strstr(Msg->bid, Filter_BID)) &&
 | |
| 						(!Filter_VIA[0] || strstr(Msg->via, Filter_VIA)))
 | |
| 					{
 | |
| 						sprintf_s(msgno, sizeof(msgno), "%d", Msg->number);
 | |
| 						SendDlgItemMessage(hDlg, 0, LB_ADDSTRING, 0, (LPARAM)msgno);
 | |
| 					} 
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			return TRUE;
 | |
| 
 | |
| 		}
 | |
| 		break;
 | |
| 	}
 | |
| 	
 | |
| 	return (INT_PTR)FALSE;
 | |
| }
 | |
| 
 | |
| char HRHelpMsg[] = 
 | |
| "Please read the following carefully, as forwarding is handled rather differently from other BBS software\r\n" 
 | |
| "Private Messages, and Bulls that have not reached their target area (eg a Bull sent to ALL@GBR from the\r\n"
 | |
| "USA) are forwarded to only one define define BBS1 with HR EU and BBS2 with HR GBR.EU, a message for GBR.EU\r\n"
 | |
| "will be sent to BBS2. Any other EU message (eg FRA.EU) would be sent to BBS2."
 | |
| "\r\n\r\n"
 | |
| "Bulls which have reached their target will be sent to ALL BBS's where the BBS HA matches all elements\r\n"
 | |
| "of the HA of the message\r\n So if a BBS had\r\n"
 | |
| "GBR.EU It would match messages sent to EU or GBR.EU, but not FRA.EU.\r\n"
 | |
| "If you want to send only Bulls addressed to a lower level then add the number of levels to ignore after the string\r\n"
 | |
| "So #23.GBR.EU,2 would match only Bulls for #23, and not GBR or EU\r\r"
 | |
| "The software assumes an implied WW on the end of all aadresses, but only if there is something in the field\r\n"
 | |
| "So you need an explicit WW to send to everyone. So a BBS with WW in the HA will get all Bulls, and any Personal\r\n"
 | |
| "Messages that don't have a more explicit route via another BBS"
 | |
| ;
 | |
| 
 | |
| INT_PTR CALLBACK HRHelpProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| 	UNREFERENCED_PARAMETER(lParam);
 | |
| 	switch (message)
 | |
| 	{
 | |
| 	case WM_INITDIALOG:
 | |
| 
 | |
| 		SetDlgItemText(hDlg, IDC_HRTEXT, HRHelpMsg);
 | |
| 
 | |
| 		return (INT_PTR)TRUE;
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 		if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
 | |
| 		{
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 			return (INT_PTR)TRUE;
 | |
| 		}
 | |
| 			return (INT_PTR)TRUE;
 | |
| 
 | |
| 		break;
 | |
| 	}
 | |
| 	return (INT_PTR)FALSE;
 | |
| }
 | |
| 
 | |
| #include <htmlhelp.h>
 | |
| 
 | |
| int scrolledx; scrolledy;
 | |
| 
 | |
| INT_PTR CALLBACK FwdEditDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| 	int Command;
 | |
| 	struct UserInfo * user;
 | |
| 	RECT Rect;
 | |
| 	SCROLLINFO Sinfo;
 | |
| 	int deltax, deltay;
 | |
| 
 | |
| 	UNREFERENCED_PARAMETER(lParam);
 | |
| 	switch (message)
 | |
| 	{
 | |
| 
 | |
| 	case WM_INITDIALOG:
 | |
| 
 | |
| 		for (user = BBSChain; user; user = user->BBSNext)
 | |
| 		{
 | |
| 			SendDlgItemMessage(hDlg, IDC_BBS, CB_ADDSTRING, 0, (LPARAM)(LPCTSTR)user->Call);
 | |
| 		}  
 | |
| 
 | |
| 		SetDlgItemInt(hDlg, IDC_MAXSEND, MaxTXSize, FALSE);
 | |
| 		SetDlgItemInt(hDlg, IDC_MAXRECV, MaxRXSize, FALSE);
 | |
| 		SetDlgItemInt(hDlg, IDC_MAXAGE, MaxAge, FALSE);
 | |
| 
 | |
| 		if (Aliases)
 | |
| 		{
 | |
| 			char Text[100000] = "";
 | |
| 			int i=0;
 | |
| 
 | |
| 			while(Aliases[i])
 | |
| 			{
 | |
| 				strcat(Text, Aliases[i]->Dest);
 | |
| 				strcat(Text, ":");
 | |
| 				strcat(Text, Aliases[i]->Alias);
 | |
| 				strcat(Text, "\r\n");
 | |
| 				i++;
 | |
| 			}
 | |
| 			SetDlgItemText(hDlg, IDC_ALIAS, Text);
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		CheckDlgButton(hDlg, IDC_READDRESSLOCAL, ReaddressLocal);
 | |
| 		CheckDlgButton(hDlg, IDC_READDRESSRXED, ReaddressReceived);
 | |
| 		CheckDlgButton(hDlg, IDC_WARNNOROUTE, WarnNoRoute);
 | |
| 		CheckDlgButton(hDlg, IDC_USELOCALTIME, Localtime);
 | |
| 		CheckDlgButton(hDlg, IDC_MULTIP, SendPtoMultiple);
 | |
| 		CheckDlgButton(hDlg, IDC_FOURCHARCONTINENT, FOURCHARCONT);
 | |
| 
 | |
| 		CurrentBBS = NULL;
 | |
| 
 | |
| 		ww = 0;
 | |
| 		wh = 0;
 | |
| 
 | |
| 		ShowScrollBar(hDlg, SB_BOTH, FALSE);		// Hide them till needed
 | |
| 
 | |
| 		xmargin = 6;
 | |
| 		ymargin = 2 + GetSystemMetrics(SM_CYCAPTION);
 | |
| 		scrolledx = scrolledy = 0;
 | |
| 
 | |
| 		GetWindowRect(hDlg, &Rect);
 | |
| 		ww = Rect.right - Rect.left;
 | |
| 		wh = Rect.bottom - Rect.top;
 | |
| 
 | |
| 		return (INT_PTR)TRUE;
 | |
| 		
 | |
| 	case WM_SIZE:
 | |
| 		
 | |
| 		w = LOWORD(lParam);
 | |
| 		h = HIWORD(lParam);
 | |
| 
 | |
| 		// If window is smaller than client area enable scroll bars
 | |
| 
 | |
| 		if (w >= ww && (h + ymargin) >= wh)
 | |
| 		{
 | |
| 			ShowScrollBar(hDlg, SB_BOTH, FALSE);	// Hide them till needed
 | |
| //			MoveWindow(hwndDisplay, xmargin, ymargin, ww, wh, TRUE);
 | |
| 			ScrollWindow(hDlg, scrolledx, scrolledy, 0, 0);
 | |
| 			scrolledx = scrolledy = 0;
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		ShowScrollBar(hDlg, SB_BOTH, TRUE);	
 | |
| 
 | |
| 		Sinfo.cbSize = sizeof(SCROLLINFO);
 | |
| 		Sinfo.fMask = SIF_ALL;
 | |
| 		Sinfo.nMin = 0;
 | |
| 		Sinfo.nMax = ww + xmargin;
 | |
| 		Sinfo.nPage = w;
 | |
| 		Sinfo.nPos = hpos;
 | |
| 		SetScrollInfo(hDlg, SB_HORZ, &Sinfo, TRUE);
 | |
| 
 | |
| 		Sinfo.cbSize = sizeof(SCROLLINFO);
 | |
| 		Sinfo.fMask = SIF_ALL;
 | |
| 		Sinfo.nMin = 0;
 | |
| 		Sinfo.nMax = wh + ymargin;
 | |
| 		Sinfo.nPage = h;
 | |
| 		Sinfo.nPos = hpos;
 | |
| 		SetScrollInfo(hDlg, SB_VERT, &Sinfo, TRUE);
 | |
| 		
 | |
| 		return TRUE;
 | |
| 
 | |
| 	case WM_HSCROLL:
 | |
| 
 | |
| 		switch (LOWORD(wParam))
 | |
| 		{
 | |
| 		case SB_PAGELEFT:
 | |
| 
 | |
| 			goto UpdateHPos;
 | |
| 
 | |
| 		case SB_LINELEFT:
 | |
| 
 | |
| 			goto UpdateHPos;
 | |
| 
 | |
| 		case SB_PAGERIGHT:
 | |
| 
 | |
| 			goto UpdateHPos;
 | |
| 
 | |
| 		case SB_LINERIGHT:
 | |
| 
 | |
| 			hpos++;
 | |
| 			goto UpdateHPos;
 | |
| 
 | |
| 		case SB_THUMBPOSITION:
 | |
| 
 | |
| 			deltax = hpos - HIWORD(wParam);
 | |
| 			
 | |
| 			ScrollWindow(hDlg, deltax, 0, 0, 0);
 | |
| 			scrolledx -= deltax;
 | |
| 
 | |
| 			hpos = hpos -= deltax;
 | |
| 
 | |
| UpdateHPos:
 | |
| 			// Need to update Scroll Bar
 | |
| 
 | |
| 			Sinfo.cbSize = sizeof(SCROLLINFO);
 | |
| 			Sinfo.fMask = SIF_ALL;
 | |
| 			Sinfo.nMin = 0;
 | |
| 			Sinfo.nMax = ww + xmargin;
 | |
| 			Sinfo.nPage = w;
 | |
| 			Sinfo.nPos = hpos;
 | |
| 			SetScrollInfo(hDlg, SB_HORZ, &Sinfo, TRUE);
 | |
| 
 | |
| 			// Move Client Window
 | |
| 
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		return TRUE;
 | |
| 
 | |
| 		
 | |
| 	case WM_VSCROLL:
 | |
| 
 | |
| 		switch (LOWORD(wParam))
 | |
| 		{
 | |
| 		case SB_PAGEUP:
 | |
| 
 | |
| 			goto UpdateVPos;
 | |
| 
 | |
| 		case SB_LINEUP:
 | |
| 
 | |
| 			goto UpdateVPos;
 | |
| 
 | |
| 		case SB_PAGEDOWN:
 | |
| 
 | |
| 			goto UpdateVPos;
 | |
| 
 | |
| 		case SB_LINEDOWN:
 | |
| 
 | |
| 			goto UpdateVPos;
 | |
| 
 | |
| 		case SB_THUMBPOSITION:
 | |
| 
 | |
| 			deltay = vpos - HIWORD(wParam);
 | |
| 			
 | |
| 			ScrollWindow(hDlg,0,  deltay, 0, 0);
 | |
| 			scrolledy -= deltay;
 | |
| 
 | |
| 			vpos = vpos -= deltay;
 | |
| 
 | |
| UpdateVPos:
 | |
| 			// Need to update Scroll Bar
 | |
| 
 | |
| 			Sinfo.cbSize = sizeof(SCROLLINFO);
 | |
| 			Sinfo.fMask = SIF_ALL;
 | |
| 			Sinfo.nMin = 0;
 | |
| 			Sinfo.nMax = wh + ymargin;
 | |
| 			Sinfo.nPage = h;
 | |
| 			Sinfo.nPos = vpos;
 | |
| 			SetScrollInfo(hDlg, SB_VERT, &Sinfo, TRUE);
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		return TRUE;
 | |
| 
 | |
| 
 | |
| 
 | |
| 	case WM_CTLCOLORDLG:
 | |
| 
 | |
|         return (LONG)bgBrush;
 | |
| 
 | |
|     case WM_CTLCOLORSTATIC:
 | |
|     {
 | |
|         HDC hdcStatic = (HDC)wParam;
 | |
| 		SetTextColor(hdcStatic, RGB(0, 0, 0));
 | |
|         SetBkMode(hdcStatic, TRANSPARENT);
 | |
|         return (LONG)bgBrush;
 | |
|     }
 | |
| 
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 
 | |
| 		Command = LOWORD(wParam);
 | |
| 
 | |
| 		switch (Command)
 | |
| 		{
 | |
| 
 | |
| 		case IDOK:
 | |
| 		case IDCANCEL:
 | |
| 
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 			return (INT_PTR)TRUE;
 | |
| 
 | |
| 		case IDC_BBS:
 | |
| 
 | |
| 			// BBS Selection Changed
 | |
| 
 | |
| 			Do_BBS_Sel_Changed(hDlg);
 | |
| 
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_HRHELP:
 | |
| 			
 | |
| 			ShellExecute(hDlg,"open",
 | |
| 				"http://www.cantab.net/users/john.wiseman/Documents/BPQ Mail and Chat Server Mail Forwarding.htm",
 | |
| 				"", NULL, SW_SHOWNORMAL); 
 | |
| 
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case IDC_FWDSAVE:
 | |
| 			
 | |
| 			SaveFWDConfig(hDlg);
 | |
| 			return TRUE;
 | |
| 
 | |
| 		case COPYCONFIG:
 | |
| 			
 | |
| 			CopyFwdConfig(hDlg);
 | |
| 			return TRUE;
 | |
| 
 | |
| 
 | |
| 		}
 | |
| 		break;
 | |
| 	}
 | |
| 	
 | |
| 	return (INT_PTR)FALSE;
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| int CreateDialogLine(HWND hWnd, int i, int row)
 | |
| {
 | |
| 	char PortNo[60];
 | |
| 	char PortDesc[31];
 | |
| 
 | |
| 	// Only allow UI on ax.25 ports
 | |
| 
 | |
| 	struct _EXTPORTDATA * PORTVEC;
 | |
| 
 | |
| 	PORTVEC = (struct _EXTPORTDATA * )GetPortTableEntryFromSlot(i);
 | |
| 
 | |
| 	if (PORTVEC->PORTCONTROL.PORTTYPE == 16)		// EXTERNAL
 | |
| 		if (PORTVEC->PORTCONTROL.PROTOCOL == 10)	// Pactor/WINMOR
 | |
| 			if (PORTVEC->PORTCONTROL.UICAPABLE == 0)
 | |
| 				return FALSE;
 | |
| 
 | |
| 	GetPortDescription(i, PortDesc);
 | |
| 	sprintf(PortNo, "Port %2d %30s", GetPortNumber(i), PortDesc);
 | |
| 	
 | |
| 	hCheck[i] = CreateWindow(WC_BUTTON , "", BS_AUTOCHECKBOX  | WS_CHILD | WS_VISIBLE,
 | |
|                  10,row+5,14,14, hWnd, NULL, hInst, NULL);
 | |
| 
 | |
| 	Button_SetCheck(hCheck[i], UIEnabled[i]);
 | |
| 
 | |
| 	hLabel[i] = CreateWindow(WC_STATIC , PortNo,  WS_CHILD | WS_VISIBLE,
 | |
|                  30,row+5,300,22, hWnd, NULL, hInst, NULL);
 | |
| 	
 | |
| 	SendMessage(hLabel[i], WM_SETFONT,(WPARAM) hFont, 0);
 | |
| 
 | |
| 
 | |
| 	hUIBox[i] = CreateWindowEx(WS_EX_CLIENTEDGE, WC_EDIT , "", WS_CHILD | WS_BORDER | WS_VISIBLE | ES_UPPERCASE,
 | |
|                  315,row,200,22, hWnd, NULL, hInst, NULL);
 | |
| 
 | |
| 	SendMessage(hUIBox[i], WM_SETFONT,(WPARAM) hFont, 0);
 | |
| 	SetWindowText(hUIBox[i], UIDigi[i]);
 | |
| 
 | |
| 	hSendMF[i] = CreateWindow(WC_BUTTON , "", BS_AUTOCHECKBOX  | WS_CHILD | WS_VISIBLE,
 | |
|                  550,row+4,14,14, hWnd, NULL, hInst, NULL);
 | |
| 
 | |
| 	hSendHDDR[i] = CreateWindow(WC_BUTTON , "", BS_AUTOCHECKBOX  | WS_CHILD | WS_VISIBLE,
 | |
|                  610,row+4,14,14, hWnd, NULL, hInst, NULL);
 | |
| 
 | |
| 	hNullCheck[i] = CreateWindow(WC_BUTTON , "", BS_AUTOCHECKBOX  | WS_CHILD | WS_VISIBLE,
 | |
|                  670,row+4,14,14, hWnd, NULL, hInst, NULL);
 | |
| 
 | |
| 	Button_SetCheck(hSendMF[i], UIMF[i]);
 | |
| 	Button_SetCheck(hSendHDDR[i], UIHDDR[i]);
 | |
| 	Button_SetCheck(hNullCheck[i], UINull[i]);
 | |
| 
 | |
| 	return TRUE;
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | |
| DoUICheck(int i)
 | |
| {
 | |
| 	return TRUE;
 | |
| }
 | |
| DoUIBox(int i)
 | |
| {
 | |
| 	return TRUE;
 | |
| }
 | |
| 
 | |
| GetUIConfig()
 | |
| {
 | |
| 	int Num = GetNumberofPorts();
 | |
| 	int i, Len;
 | |
| 
 | |
| 	Free_UI();
 | |
| 
 | |
| 	for (i=1; i<=Num; i++)
 | |
| 	{
 | |
| 		UIEnabled[i] =  Button_GetCheck(hCheck[i]);
 | |
| 		UINull[i] =  Button_GetCheck(hNullCheck[i]);
 | |
| 		UIMF[i] =  Button_GetCheck(hSendMF[i]);
 | |
| 		UIHDDR[i] =  Button_GetCheck(hSendHDDR[i]);
 | |
| 	
 | |
| 		Len = GetWindowTextLength(hUIBox[i]);
 | |
| 	
 | |
| 		UIDigi[i] = malloc(Len+1);
 | |
| 		GetWindowText(hUIBox[i], UIDigi[i], Len+1);
 | |
| 	}
 | |
| 
 | |
| 	return TRUE;
 | |
| }
 | |
| 
 | |
| INT_PTR CALLBACK UIDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| 	int Command, i;
 | |
| 	RECT Rect;
 | |
| 	int Row = 80;
 | |
| 
 | |
| 	switch (message)
 | |
| 	{
 | |
| 	case WM_INITDIALOG:
 | |
| 
 | |
| 		SetDlgItemText(hDlg, IDC_MAILFOR, MailForText); 
 | |
| 
 | |
| 		for (i = 1; i <= GetNumberofPorts(); i++)
 | |
| 		{
 | |
| 			if (CreateDialogLine(hDlg, i, Row))
 | |
| 				Row += 30;
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		GetWindowRect(hDlg, &Rect);      
 | |
| 		SetWindowPos(hDlg, HWND_TOP, Rect.left, Rect.top, 800, Row+100, 0);
 | |
| 		SetWindowPos(GetDlgItem(hDlg, IDOK), NULL, 300, Row+20, 70, 30, 0);
 | |
| 		SetWindowPos(GetDlgItem(hDlg, IDCANCEL), NULL, 400, Row+20, 80, 30, 0);
 | |
| 
 | |
| 
 | |
| 		return (INT_PTR)TRUE;
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 
 | |
| 		Command = LOWORD(wParam);
 | |
| 
 | |
| 		switch (Command)
 | |
| 		{
 | |
| 			case IDCANCEL:
 | |
| 
 | |
| 				EndDialog(hDlg, LOWORD(wParam));
 | |
| 				return (INT_PTR)TRUE;
 | |
| 		
 | |
| 			case IDOK:
 | |
| 
 | |
| 				GetDlgItemText(hDlg, IDC_MAILFOR, MailForText, 99); 
 | |
| 				GetUIConfig();
 | |
| 
 | |
| 				SaveConfig(ConfigName);
 | |
| 	
 | |
| 				sprintf(InfoBoxText, "Configuration Saved");
 | |
| 				DialogBox(hInst, MAKEINTRESOURCE(IDD_USERADDED_BOX), hWnd, InfoDialogProc);
 | |
| 
 | |
| 				EndDialog(hDlg, LOWORD(wParam));
 | |
| 				return (INT_PTR)TRUE;
 | |
| 
 | |
| 			case 0:
 | |
| 
 | |
| 				for (i = 1; i <= 32; i++)
 | |
| 				{
 | |
| 					if (lParam == (LPARAM)hCheck[i])
 | |
| 					{
 | |
| 						DoUICheck(i);
 | |
| 						break;
 | |
| 					}
 | |
| 					else if (lParam == (LPARAM)hUIBox[i])
 | |
| 					{
 | |
| 						DoUIBox(i);
 | |
| 						return TRUE;
 | |
| 					
 | |
| 					}
 | |
| 				}
 | |
| 		}
 | |
| 
 | |
| 		break;
 | |
| 		}
 | |
| 	
 | |
| 	return (INT_PTR)FALSE;
 | |
| }
 | |
| 
 | |
| INT_PTR CALLBACK EditMsgTextDialogProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
 | |
| {
 | |
| 	struct MsgInfo * Msg;
 | |
| 	char * MsgBytes;
 | |
| 	int Cmd = LOWORD(wParam);
 | |
| 
 | |
| 	switch (message)
 | |
| 	{
 | |
| 	case WM_INITDIALOG:
 | |
| 	{
 | |
| 		HWND hWndEdit = GetDlgItem(hDlg, IDC_MESSAGE); 
 | |
| 
 | |
| 		Msg = MsgHddrPtr[CurrentMsgIndex];
 | |
| 
 | |
| 		MsgBytes = ReadMessageFile(Msg->number);
 | |
| 
 | |
| 		// See if Multipart
 | |
| 
 | |
| 		if (Msg->B2Flags & Attachments)
 | |
| 			EnableWindow(GetDlgItem(hDlg, IDC_SAVEATTACHMENTS), TRUE);
 | |
| 
 | |
| 		if (MsgBytes)
 | |
| 		{
 | |
| 			SetDlgItemText(hDlg, IDC_MESSAGE, MsgBytes); 
 | |
| 			SendDlgItemMessage(hDlg, IDC_MESSAGE, EM_SETSEL, -1, 0);
 | |
| 
 | |
| 			free (MsgBytes);
 | |
| 		}
 | |
| 		return TRUE; 
 | |
| 	}
 | |
| 
 | |
| 	case WM_SIZING:
 | |
| 	{
 | |
| 		HWND hWndEdit = GetDlgItem(hDlg, IDC_MESSAGE); 
 | |
| 
 | |
| 		LPRECT lprc = (LPRECT) lParam;
 | |
| 		int Height = lprc->bottom-lprc->top;
 | |
| 		int Width = lprc->right-lprc->left;
 | |
| 
 | |
| 		MoveWindow(hWndEdit, 5, 50, Width-20, Height - 95, TRUE);
 | |
| 
 | |
| 		return TRUE;
 | |
| 	}
 | |
| 
 | |
| 	case WM_ACTIVATE:
 | |
| 
 | |
| 		SendDlgItemMessage(hDlg, IDC_MESSAGE, EM_SETSEL, -1, 0);
 | |
| 
 | |
| 		break;
 | |
| 
 | |
| 
 | |
| 	case WM_COMMAND:
 | |
| 
 | |
| 		if (Cmd == IDC_SAVEATTACHMENTS)
 | |
| 		{
 | |
| 			struct MsgInfo * Msg;
 | |
| 			char * MailBuffer;
 | |
| 			char FileName[100][MAX_PATH] = {""};
 | |
| 			int FileLen[100];
 | |
| 			int Files = 0;
 | |
| 			int BodyLen;
 | |
| 			int i;
 | |
| 			char * ptr;
 | |
| 
 | |
| 			HANDLE hFile = INVALID_HANDLE_VALUE;
 | |
| 			int WriteLen=0;
 | |
| 
 | |
| 			Msg = MsgHddrPtr[CurrentMsgIndex];
 | |
| 
 | |
| 			MailBuffer = ReadMessageFile(Msg->number);
 | |
| 
 | |
| 			ptr = MailBuffer;
 | |
| 
 | |
| 			while(*ptr != 13)
 | |
| 			{
 | |
| 				char * ptr2 = strchr(ptr, 10);	// Find CR
 | |
| 
 | |
| 				if (memcmp(ptr, "Body: ", 6) == 0)
 | |
| 				{
 | |
| 					BodyLen = atoi(&ptr[6]);
 | |
| 				}
 | |
| 
 | |
| 				if (memcmp(ptr, "File: ", 6) == 0)
 | |
| 				{
 | |
| 					char * ptr1 = strchr(&ptr[6], ' ');	// Find Space
 | |
| 
 | |
| 					FileLen[Files] = atoi(&ptr[6]);
 | |
| 
 | |
| 					memcpy(FileName[Files++], &ptr1[1], (ptr2-ptr1 - 2));
 | |
| 				}
 | |
| 				
 | |
| 				ptr = ptr2;
 | |
| 				ptr++;
 | |
| 			}
 | |
| 
 | |
| 			ptr += 4;			// Over Blank Line and Separator
 | |
| 			ptr += BodyLen;		// to first file
 | |
| 
 | |
| 			for (i = 0; i < Files; i++)
 | |
| 			{
 | |
| 				OPENFILENAME Ofn; 
 | |
| 				memset(&Ofn, 0, sizeof(Ofn));
 | |
|  
 | |
| 				Ofn.lStructSize = sizeof(OPENFILENAME); 
 | |
| 				Ofn.hInstance = hInst;
 | |
| 				Ofn.hwndOwner = hDlg; 
 | |
| 				Ofn.lpstrFilter = NULL; 
 | |
| 				Ofn.lpstrFile= FileName[i]; 
 | |
| 				Ofn.nMaxFile = sizeof(FileName[i])/ sizeof(*FileName[i]); 
 | |
| 				Ofn.lpstrFileTitle = NULL; 
 | |
| 				Ofn.nMaxFileTitle = 0; 
 | |
| 				Ofn.lpstrInitialDir = (LPSTR)NULL; 
 | |
| 				Ofn.Flags = OFN_SHOWHELP | OFN_OVERWRITEPROMPT; 
 | |
| 				Ofn.lpstrTitle = NULL;//; 
 | |
| 
 | |
| 				if (GetSaveFileName(&Ofn))
 | |
| 				{
 | |
| 					hFile = CreateFile(FileName[i],
 | |
| 						GENERIC_WRITE, FILE_SHARE_READ, NULL,
 | |
| 						CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
 | |
| 
 | |
| 					if (hFile != INVALID_HANDLE_VALUE)
 | |
| 					{
 | |
| 						WriteFile(hFile, ptr, FileLen[i], &WriteLen, NULL);
 | |
| 						CloseHandle(hFile);
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				ptr += FileLen[i];
 | |
| 				ptr +=2;				// Over separator - I don't think there should be one
 | |
| 			}
 | |
| 		}
 | |
| 				
 | |
| 		if (Cmd == IDSAVE)
 | |
| 		{
 | |
| 			struct MsgInfo * Msg;
 | |
| 			char * via = NULL;
 | |
| 			int MsgLen;
 | |
| 			char * MailBuffer;
 | |
| 			char MsgFile[MAX_PATH];
 | |
| 			HANDLE hFile = INVALID_HANDLE_VALUE;
 | |
| 			int WriteLen=0;
 | |
| 
 | |
| 			Msg = MsgHddrPtr[CurrentMsgIndex];
 | |
| 
 | |
| 			if (Msg->B2Flags & Attachments)
 | |
| 			{
 | |
| 				MessageBox(NULL, "It isn't safe to save messages with attachments", "BPQMail", MB_ICONERROR);
 | |
| 				return TRUE;
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 			MsgLen = SendDlgItemMessage(hDlg, IDC_MESSAGE, WM_GETTEXTLENGTH, 0 ,0);
 | |
| 
 | |
| 			if (MsgLen)
 | |
| 			{
 | |
| 				MailBuffer = malloc(MsgLen+1);
 | |
| 				GetDlgItemText(hDlg, IDC_MESSAGE, MailBuffer, MsgLen+1);
 | |
| 			}
 | |
| 
 | |
| 			Msg->datechanged = time(NULL);
 | |
| 			Msg->length = MsgLen;
 | |
| 
 | |
| 			sprintf_s(MsgFile, sizeof(MsgFile), "%s/m_%06d.mes", MailDir, Msg->number);
 | |
| 	
 | |
| 			hFile = CreateFile(MsgFile,
 | |
| 					GENERIC_WRITE,
 | |
| 					FILE_SHARE_READ,
 | |
| 					NULL,
 | |
| 					CREATE_ALWAYS,
 | |
| 					FILE_ATTRIBUTE_NORMAL,
 | |
| 					NULL);
 | |
| 
 | |
| 			if (hFile != INVALID_HANDLE_VALUE)
 | |
| 			{
 | |
| 				WriteFile(hFile, MailBuffer, Msg->length, &WriteLen, NULL);
 | |
| 				CloseHandle(hFile);
 | |
| 			}
 | |
| 
 | |
| 			free(MailBuffer);
 | |
| 
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 
 | |
| 			return TRUE;
 | |
| 		}
 | |
| 
 | |
| 		if (Cmd == IDCANCEL)
 | |
| 		{
 | |
| 			EndDialog(hDlg, LOWORD(wParam));
 | |
| 			return (INT_PTR)TRUE;
 | |
| 		}
 | |
| 
 | |
| 		return (INT_PTR)TRUE;
 | |
| 
 | |
| 		break;
 | |
| 	}
 | |
| 	return (INT_PTR)FALSE;
 | |
| }
 |