linbpq/BPQMailConfig.c

3822 lines
96 KiB
C
Raw Permalink Normal View History

2022-08-28 09:35:46 +01:00
// 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);
// 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);
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;
}