summaryrefslogtreecommitdiff
path: root/protocols/ConnectionNotify/src/ConnectionNotify.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/ConnectionNotify/src/ConnectionNotify.cpp')
-rw-r--r--protocols/ConnectionNotify/src/ConnectionNotify.cpp522
1 files changed, 44 insertions, 478 deletions
diff --git a/protocols/ConnectionNotify/src/ConnectionNotify.cpp b/protocols/ConnectionNotify/src/ConnectionNotify.cpp
index 2ea63878f5..a82c7830d5 100644
--- a/protocols/ConnectionNotify/src/ConnectionNotify.cpp
+++ b/protocols/ConnectionNotify/src/ConnectionNotify.cpp
@@ -13,26 +13,15 @@ HANDLE hExceptionsMutex = nullptr;
DWORD FilterOptionsThreadId;
DWORD ConnectionCheckThreadId;
-BYTE settingSetColours = 0;
-COLORREF settingBgColor;
-COLORREF settingFgColor;
-int settingInterval = 0;
-int settingInterval1 = 0;
-BYTE settingResolveIp = 0;
-BOOL settingStatus[STATUS_COUNT];
-int settingFiltersCount = 0;
-BOOL settingDefaultAction = TRUE;
-WORD settingStatusMask = 0;
-
-struct CONNECTION *first = nullptr;
-struct CONNECTION *connExceptions = nullptr;
-struct CONNECTION *connCurrentEdit;
-struct CONNECTION *connExceptionsTmp = nullptr;
-struct CONNECTION *connCurrentEditModal = nullptr;
+
+CONNECTION *first = nullptr;
+CONNECTION *connExceptions = nullptr;
+CONNECTION *connCurrentEdit;
int currentStatus = ID_STATUS_OFFLINE, diffstat = 0;
-BOOL bOptionsOpen = FALSE;
wchar_t *tcpStates[] = { L"CLOSED", L"LISTEN", L"SYN_SENT", L"SYN_RCVD", L"ESTAB", L"FIN_WAIT1", L"FIN_WAIT2", L"CLOSE_WAIT", L"CLOSING", L"LAST_ACK", L"TIME_WAIT", L"DELETE_TCB" };
+int ConnectionNotifyOptInit(WPARAM wParam, LPARAM);
+
/////////////////////////////////////////////////////////////////////////////////////////
PLUGININFOEX pluginInfoEx = {
@@ -83,11 +72,11 @@ BOOL strrep(wchar_t *src, wchar_t *needle, wchar_t *newstring)
return TRUE;
}
-void saveSettingsConnections(struct CONNECTION *connHead)
+void saveSettingsConnections(CONNECTION *connHead)
{
char buff[128];
int i = 0;
- struct CONNECTION *tmp = connHead;
+ CONNECTION *tmp = connHead;
while (tmp != nullptr) {
mir_snprintf(buff, "%dFilterIntIp", i);
@@ -105,20 +94,20 @@ void saveSettingsConnections(struct CONNECTION *connHead)
i++;
tmp = tmp->next;
}
- settingFiltersCount = i;
- g_plugin.setDword("FiltersCount", settingFiltersCount);
+ g_plugin.iFiltersCount = i;
+ g_plugin.setDword("g_plugin.iFiltersCount", g_plugin.iFiltersCount);
}
//load filters from db
-struct CONNECTION* LoadSettingsConnections()
+CONNECTION* LoadSettingsConnections()
{
- struct CONNECTION *connHead = nullptr;
+ CONNECTION *connHead = nullptr;
DBVARIANT dbv;
char buff[128];
int i = 0;
- for (i = settingFiltersCount - 1; i >= 0; i--) {
- struct CONNECTION *conn = (struct CONNECTION*)mir_alloc(sizeof(struct CONNECTION));
+ for (i = g_plugin.iFiltersCount - 1; i >= 0; i--) {
+ CONNECTION *conn = (CONNECTION*)mir_alloc(sizeof(CONNECTION));
mir_snprintf(buff, "%dFilterIntIp", i);
if (!g_plugin.getWString(buff, &dbv))
wcsncpy(conn->strIntIp, dbv.pwszVal, _countof(conn->strIntIp));
@@ -149,446 +138,24 @@ struct CONNECTION* LoadSettingsConnections()
//called to load settings from database
void LoadSettings()
{
- settingInterval = g_plugin.getDword("Interval", 500);
- settingInterval1 = g_plugin.getDword("PopupInterval", 0);
- settingResolveIp = g_plugin.getByte("ResolveIp", TRUE);
- settingDefaultAction = g_plugin.getByte("FilterDefaultAction", TRUE);
-
- settingSetColours = g_plugin.getByte("PopupSetColours", 0);
- settingBgColor = g_plugin.getDword("PopupBgColor", (DWORD)0xFFFFFF);
- settingFgColor = g_plugin.getDword("PopupFgColor", (DWORD)0x000000);
- settingFiltersCount = g_plugin.getDword("FiltersCount", 0);
- settingStatusMask = g_plugin.getWord("StatusMask", 16);
- for (int i = 0; i < STATUS_COUNT; i++) {
+ g_plugin.iInterval = g_plugin.getDword("Interval", 500);
+ g_plugin.iInterval1 = g_plugin.getDword("PopupInterval", 0);
+ g_plugin.bResolveIp = g_plugin.getByte("ResolveIp", TRUE);
+ g_plugin.iDefaultAction = g_plugin.getByte("FilterDefaultAction", TRUE);
+
+ g_plugin.bSetColours = g_plugin.getByte("PopupSetColours", 0);
+ g_plugin.BgColor = g_plugin.getDword("PopupBgColor", (DWORD)0xFFFFFF);
+ g_plugin.FgColor = g_plugin.getDword("PopupFgColor", (DWORD)0x000000);
+ g_plugin.iFiltersCount = g_plugin.getDword("g_plugin.iFiltersCount", 0);
+ g_plugin.iStatusMask = g_plugin.getWord("StatusMask", 16);
+ for (int i = 0; i < MAX_STATUS_COUNT; i++) {
char buff[128];
mir_snprintf(buff, "Status%d", i);
- settingStatus[i] = (g_plugin.getByte(buff, 0) == 1);
- }
-}
-
-void fillExceptionsListView(HWND hwndDlg)
-{
- LVITEM lvI = { 0 };
-
- int i = 0;
- struct CONNECTION *tmp = connExceptionsTmp;
- HWND hwndList = GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS);
- ListView_DeleteAllItems(hwndList);
-
- // Some code to create the list-view control.
- // Initialize LVITEM members that are common to all
- // items.
- lvI.mask = LVIF_TEXT;
- while (tmp) {
- wchar_t tmpAddress[25];
- lvI.iItem = i++;
- lvI.iSubItem = 0;
- lvI.pszText = tmp->PName;
- ListView_InsertItem(hwndList, &lvI);
- lvI.iSubItem = 1;
- if (tmp->intIntPort == -1)
- mir_snwprintf(tmpAddress, L"%s:*", tmp->strIntIp);
- else
- mir_snwprintf(tmpAddress, L"%s:%d", tmp->strIntIp, tmp->intIntPort);
- lvI.pszText = tmpAddress;
- ListView_SetItem(hwndList, &lvI);
- lvI.iSubItem = 2;
- if (tmp->intExtPort == -1)
- mir_snwprintf(tmpAddress, L"%s:*", tmp->strExtIp);
- else
- mir_snwprintf(tmpAddress, L"%s:%d", tmp->strExtIp, tmp->intExtPort);
- lvI.pszText = tmpAddress;
- ListView_SetItem(hwndList, &lvI);
- lvI.iSubItem = 3;
- lvI.pszText = tmp->Pid ? LPGENW("Show") : LPGENW("Hide");
- ListView_SetItem(hwndList, &lvI);
-
- tmp = tmp->next;
- }
-
-}
-//filter editor dialog box procedure opened modally from options dialog
-static INT_PTR CALLBACK FilterEditProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
-{
- switch (message) {
- case WM_INITDIALOG:
- {
- struct CONNECTION *conn = (struct CONNECTION*)lParam;
- TranslateDialogDefault(hWnd);
- connCurrentEditModal = conn;
- SetDlgItemText(hWnd, ID_TEXT_NAME, conn->PName);
- SetDlgItemText(hWnd, ID_TXT_LOCAL_IP, conn->strIntIp);
- SetDlgItemText(hWnd, ID_TXT_REMOTE_IP, conn->strExtIp);
-
- if (conn->intIntPort == -1)
- SetDlgItemText(hWnd, ID_TXT_LOCAL_PORT, L"*");
- else
- SetDlgItemInt(hWnd, ID_TXT_LOCAL_PORT, conn->intIntPort, FALSE);
-
- if (conn->intExtPort == -1)
- SetDlgItemText(hWnd, ID_TXT_REMOTE_PORT, L"*");
- else
- SetDlgItemInt(hWnd, ID_TXT_REMOTE_PORT, conn->intExtPort, FALSE);
-
- SendDlgItemMessage(hWnd, ID_CBO_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Always show popup"));
- SendDlgItemMessage(hWnd, ID_CBO_ACTION, CB_ADDSTRING, 0, (LPARAM)TranslateT("Never show popup"));
- SendDlgItemMessage(hWnd, ID_CBO_ACTION, CB_SETCURSEL, conn->Pid == 0 ? 1 : 0, 0);
- return TRUE;
- }
- case WM_COMMAND:
- switch (LOWORD(wParam)) {
- case ID_OK:
- {
- wchar_t tmpPort[6];
- GetDlgItemText(hWnd, ID_TXT_LOCAL_PORT, tmpPort, _countof(tmpPort));
- if (tmpPort[0] == '*')
- connCurrentEditModal->intIntPort = -1;
- else
- connCurrentEditModal->intIntPort = GetDlgItemInt(hWnd, ID_TXT_LOCAL_PORT, nullptr, FALSE);
- GetDlgItemText(hWnd, ID_TXT_REMOTE_PORT, tmpPort, _countof(tmpPort));
- if (tmpPort[0] == '*')
- connCurrentEditModal->intExtPort = -1;
- else
- connCurrentEditModal->intExtPort = GetDlgItemInt(hWnd, ID_TXT_REMOTE_PORT, nullptr, FALSE);
-
- GetDlgItemText(hWnd, ID_TXT_LOCAL_IP, connCurrentEditModal->strIntIp, _countof(connCurrentEditModal->strIntIp));
- GetDlgItemText(hWnd, ID_TXT_REMOTE_IP, connCurrentEditModal->strExtIp, _countof(connCurrentEditModal->strExtIp));
- GetDlgItemText(hWnd, ID_TEXT_NAME, connCurrentEditModal->PName, _countof(connCurrentEditModal->PName));
-
- connCurrentEditModal->Pid = !(BOOL)SendDlgItemMessage(hWnd, ID_CBO_ACTION, CB_GETCURSEL, 0, 0);
-
- connCurrentEditModal = nullptr;
- EndDialog(hWnd, IDOK);
- return TRUE;
- }
- case ID_CANCEL:
- connCurrentEditModal = nullptr;
- EndDialog(hWnd, IDCANCEL);
- return TRUE;
- }
- return FALSE;
- break;
- case WM_CLOSE:
- {
- connCurrentEditModal = nullptr;
- EndDialog(hWnd, IDCANCEL);
- break;
- }
+ g_plugin.iStatus[i] = (g_plugin.getByte(buff, 0) == 1);
}
- return FALSE;
-}
-
-//options page on miranda called
-INT_PTR CALLBACK DlgProcConnectionNotifyOpts(HWND hwndDlg, UINT msg, WPARAM wParam, LPARAM lParam)
-{
- HWND hwndList;
- switch (msg) {
- case WM_INITDIALOG://initialize dialog, so set properties from db.
- {
- LVCOLUMN lvc = { 0 };
- LVITEM lvI = { 0 };
- wchar_t buff[256];
- bOptionsOpen = TRUE;
- TranslateDialogDefault(hwndDlg);//translate miranda function
- #ifdef _WIN64
- mir_snwprintf(buff, L"%d.%d.%d.%d/64", HIBYTE(HIWORD(pluginInfoEx.version)), LOBYTE(HIWORD(pluginInfoEx.version)), HIBYTE(LOWORD(pluginInfoEx.version)), LOBYTE(LOWORD(pluginInfoEx.version)));
- #else
- mir_snwprintf(buff, L"%d.%d.%d.%d/32", HIBYTE(HIWORD(pluginInfoEx.version)), LOBYTE(HIWORD(pluginInfoEx.version)), HIBYTE(LOWORD(pluginInfoEx.version)), LOBYTE(LOWORD(pluginInfoEx.version)));
- #endif
- SetDlgItemText(hwndDlg, IDC_VERSION, buff);
- LoadSettings();
- //connExceptionsTmp=LoadSettingsConnections();
- SetDlgItemInt(hwndDlg, IDC_INTERVAL, settingInterval, FALSE);
- SetDlgItemInt(hwndDlg, IDC_INTERVAL1, settingInterval1, TRUE);
- CheckDlgButton(hwndDlg, IDC_SETCOLOURS, settingSetColours ? BST_CHECKED : BST_UNCHECKED);
- CheckDlgButton(hwndDlg, IDC_RESOLVEIP, settingResolveIp ? BST_CHECKED : BST_UNCHECKED);
- CheckDlgButton(hwndDlg, ID_CHK_DEFAULTACTION, settingDefaultAction ? BST_CHECKED : BST_UNCHECKED);
-
- SendDlgItemMessage(hwndDlg, IDC_BGCOLOR, CPM_SETCOLOUR, 0, (LPARAM)settingBgColor);
- SendDlgItemMessage(hwndDlg, IDC_FGCOLOR, CPM_SETCOLOUR, 0, (LPARAM)settingFgColor);
- if (!settingSetColours) {
- HWND hwnd = GetDlgItem(hwndDlg, IDC_BGCOLOR);
- CheckDlgButton(hwndDlg, IDC_SETCOLOURS, BST_UNCHECKED);
- EnableWindow(hwnd, FALSE);
- hwnd = GetDlgItem(hwndDlg, IDC_FGCOLOR);
- EnableWindow(hwnd, FALSE);
- }
- SendDlgItemMessage(hwndDlg, ID_ADD, BM_SETIMAGE, IMAGE_ICON, (LPARAM)LoadImage(g_plugin.getInst(), MAKEINTRESOURCE(IDI_ICON6), IMAGE_ICON, 16, 16, 0));
- SendDlgItemMessage(hwndDlg, ID_DELETE, BM_SETIMAGE, IMAGE_ICON, (LPARAM)LoadImage(g_plugin.getInst(), MAKEINTRESOURCE(IDI_ICON3), IMAGE_ICON, 16, 16, 0));
- SendDlgItemMessage(hwndDlg, ID_DOWN, BM_SETIMAGE, IMAGE_ICON, (LPARAM)LoadImage(g_plugin.getInst(), MAKEINTRESOURCE(IDI_ICON4), IMAGE_ICON, 16, 16, 0));
- SendDlgItemMessage(hwndDlg, ID_UP, BM_SETIMAGE, IMAGE_ICON, (LPARAM)LoadImage(g_plugin.getInst(), MAKEINTRESOURCE(IDI_ICON5), IMAGE_ICON, 16, 16, 0));
- // initialise and fill listbox
- hwndList = GetDlgItem(hwndDlg, IDC_STATUS);
- ListView_DeleteAllItems(hwndList);
- SendMessage(hwndList, LVM_SETEXTENDEDLISTVIEWSTYLE, 0, LVS_EX_FULLROWSELECT | LVS_EX_CHECKBOXES);
- // Initialize the LVCOLUMN structure.
- // The mask specifies that the format, width, text, and
- // subitem members of the structure are valid.
- lvc.mask = LVCF_FMT | LVCF_WIDTH | LVCF_TEXT | LVCF_SUBITEM;
- lvc.fmt = LVCFMT_LEFT;
- lvc.iSubItem = 0;
- lvc.pszText = TranslateT("Status");
- lvc.cx = 120; // width of column in pixels
- ListView_InsertColumn(hwndList, 0, &lvc);
- // Some code to create the list-view control.
- // Initialize LVITEM members that are common to all
- // items.
- lvI.mask = LVIF_TEXT;
- for (int i = 0; i < STATUS_COUNT; i++) {
- lvI.pszText = Clist_GetStatusModeDescription(ID_STATUS_ONLINE + i, 0);
- lvI.iItem = i;
- ListView_InsertItem(hwndList, &lvI);
- ListView_SetCheckState(hwndList, i, settingStatus[i]);
- }
-
- connExceptionsTmp = LoadSettingsConnections();
- hwndList = GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS);
- SendMessage(hwndList, LVM_SETEXTENDEDLISTVIEWSTYLE, 0, LVS_EX_FULLROWSELECT);
-
- lvc.mask = LVCF_FMT | LVCF_WIDTH | LVCF_TEXT | LVCF_SUBITEM;
- lvc.fmt = LVCFMT_LEFT;
- lvc.iSubItem = 0;
- lvc.cx = 120; // width of column in pixels
- lvc.pszText = TranslateT("Application");
- ListView_InsertColumn(hwndList, 1, &lvc);
- lvc.pszText = TranslateT("Internal socket");
- ListView_InsertColumn(hwndList, 2, &lvc);
- lvc.pszText = TranslateT("External socket");
- ListView_InsertColumn(hwndList, 3, &lvc);
- lvc.pszText = TranslateT("Action");
- lvc.cx = 50;
- ListView_InsertColumn(hwndList, 4, &lvc);
-
- //fill exceptions list
- fillExceptionsListView(hwndDlg);
- }
- break;
-
- case WM_COMMAND://user changed something, so get changes to variables
- PostMessage(GetParent(hwndDlg), PSM_CHANGED, 0, 0);
- switch (LOWORD(wParam)) {
- case IDC_INTERVAL: settingInterval = GetDlgItemInt(hwndDlg, IDC_INTERVAL, nullptr, FALSE); break;
- case IDC_INTERVAL1: settingInterval1 = GetDlgItemInt(hwndDlg, IDC_INTERVAL1, nullptr, TRUE); break;
- case IDC_RESOLVEIP: settingResolveIp = (BYTE)IsDlgButtonChecked(hwndDlg, IDC_RESOLVEIP); break;
- case ID_CHK_DEFAULTACTION: settingDefaultAction = (BYTE)IsDlgButtonChecked(hwndDlg, ID_CHK_DEFAULTACTION); break;
- case ID_ADD:
- {
- struct CONNECTION *cur = (struct CONNECTION *)mir_alloc(sizeof(struct CONNECTION));
- memset(cur, 0, sizeof(struct CONNECTION));
- cur->intExtPort = -1;
- cur->intIntPort = -1;
- cur->Pid = 0;
- cur->PName[0] = '*';
- cur->strExtIp[0] = '*';
- cur->strIntIp[0] = '*';
-
- if (DialogBoxParam(g_plugin.getInst(), MAKEINTRESOURCE(IDD_FILTER_DIALOG), hwndDlg, FilterEditProc, (LPARAM)cur) == IDCANCEL) {
- mir_free(cur);
- cur = nullptr;
- }
- else {
- cur->next = connExceptionsTmp;
- connExceptionsTmp = cur;
- }
-
- fillExceptionsListView(hwndDlg);
- ListView_SetItemState(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), 0, LVNI_FOCUSED | LVIS_SELECTED, LVNI_FOCUSED | LVIS_SELECTED);
- SetFocus(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS));
- }
- break;
-
- case ID_DELETE:
- {
- int pos, pos1;
- struct CONNECTION *cur = connExceptionsTmp, *pre = nullptr;
-
- pos = (int)ListView_GetNextItem(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), -1, LVNI_FOCUSED);
- if (pos == -1)break;
- pos1 = pos;
- while (pos--) {
- pre = cur;
- cur = cur->next;
- }
- if (pre == nullptr)
- connExceptionsTmp = connExceptionsTmp->next;
- else
- (pre)->next = cur->next;
- mir_free(cur);
- fillExceptionsListView(hwndDlg);
- ListView_SetItemState(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), pos1, LVNI_FOCUSED | LVIS_SELECTED, LVNI_FOCUSED | LVIS_SELECTED);
- SetFocus(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS));
- break;
- }
- case ID_UP:
- {
- int pos, pos1;
- struct CONNECTION *cur = nullptr, *pre = nullptr, *prepre = nullptr;
-
- cur = connExceptionsTmp;
-
- pos = (int)ListView_GetNextItem(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), -1, LVNI_FOCUSED);
- if (pos == -1)break;
- pos1 = pos;
- while (pos--) {
- prepre = pre;
- pre = cur;
- cur = cur->next;
- }
- if (prepre != nullptr) {
- pre->next = cur->next;
- cur->next = pre;
- prepre->next = cur;
- }
- else if (pre != nullptr) {
- pre->next = cur->next;
- cur->next = pre;
- connExceptionsTmp = cur;
- }
- fillExceptionsListView(hwndDlg);
- ListView_SetItemState(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), pos1 - 1, LVNI_FOCUSED | LVIS_SELECTED, LVNI_FOCUSED | LVIS_SELECTED);
- SetFocus(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS));
- break;
- }
- case ID_DOWN:
- {
- int pos, pos1;
- struct CONNECTION *cur = nullptr, *pre = nullptr;
-
- cur = connExceptionsTmp;
-
- pos = (int)ListView_GetNextItem(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), -1, LVNI_FOCUSED);
- if (pos == -1)break;
- pos1 = pos;
- while (pos--) {
- pre = cur;
- cur = cur->next;
- }
- if (cur == connExceptionsTmp&&cur->next != nullptr) {
- connExceptionsTmp = cur->next;
- cur->next = cur->next->next;
- connExceptionsTmp->next = cur;
- }
- else if (cur->next != nullptr) {
- struct CONNECTION *tmp = cur->next->next;
- pre->next = cur->next;
- cur->next->next = cur;
- cur->next = tmp;
- }
- fillExceptionsListView(hwndDlg);
- ListView_SetItemState(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), pos1 + 1, LVNI_FOCUSED | LVIS_SELECTED, LVNI_FOCUSED | LVIS_SELECTED);
- SetFocus(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS));
- break;
- }
- case IDC_SETCOLOURS:
- {
- HWND hwnd = GetDlgItem(hwndDlg, IDC_BGCOLOR);
- settingSetColours = IsDlgButtonChecked(hwndDlg, IDC_SETCOLOURS);
- EnableWindow(hwnd, settingSetColours);
- hwnd = GetDlgItem(hwndDlg, IDC_FGCOLOR);
- EnableWindow(hwnd, settingSetColours);
- break;
- }
- case IDC_BGCOLOR: settingBgColor = (COLORREF)SendDlgItemMessage(hwndDlg, IDC_BGCOLOR, CPM_GETCOLOUR, 0, 0); break;
- case IDC_FGCOLOR: settingFgColor = (COLORREF)SendDlgItemMessage(hwndDlg, IDC_FGCOLOR, CPM_GETCOLOUR, 0, 0); break;
-
- }
- break;
-
- case WM_NOTIFY://apply changes so write it to db
- switch (((LPNMHDR)lParam)->idFrom) {
- case 0:
- switch (((LPNMHDR)lParam)->code) {
- case PSN_RESET:
- LoadSettings();
- deleteConnectionsTable(connExceptionsTmp);
- connExceptionsTmp = LoadSettingsConnections();
- return TRUE;
-
- case PSN_APPLY:
- g_plugin.setDword("Interval", settingInterval);
- g_plugin.setDword("PopupInterval", settingInterval1);
- g_plugin.setByte("PopupSetColours", settingSetColours);
- g_plugin.setDword("PopupBgColor", settingBgColor);
- g_plugin.setDword("PopupFgColor", settingFgColor);
- g_plugin.setByte("ResolveIp", settingResolveIp);
- g_plugin.setByte("FilterDefaultAction", settingDefaultAction);
-
- for (int i = 0; i < STATUS_COUNT; i++) {
- char buff[128];
- mir_snprintf(buff, "Status%d", i);
- settingStatus[i] = (ListView_GetCheckState(GetDlgItem(hwndDlg, IDC_STATUS), i) ? TRUE : FALSE);
- g_plugin.setByte(buff, settingStatus[i] ? 1 : 0);
- }
- if (WAIT_OBJECT_0 == WaitForSingleObject(hExceptionsMutex, 100)) {
- deleteConnectionsTable(connExceptions);
- saveSettingsConnections(connExceptionsTmp);
- connExceptions = connExceptionsTmp;
- connExceptionsTmp = LoadSettingsConnections();
- ReleaseMutex(hExceptionsMutex);
- }
- return TRUE;
- }
- break;
- }
-
- if (GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS) == ((LPNMHDR)lParam)->hwndFrom) {
- switch (((LPNMHDR)lParam)->code) {
- case NM_DBLCLK:
- {
- int pos, pos1;
- struct CONNECTION *cur = nullptr;
-
- cur = connExceptionsTmp;
-
- pos = (int)ListView_GetNextItem(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), -1, LVNI_FOCUSED);
- if (pos == -1)break;
- pos1 = pos;
- while (pos--) {
- cur = cur->next;
- }
- DialogBoxParam(g_plugin.getInst(), MAKEINTRESOURCE(IDD_FILTER_DIALOG), hwndDlg, FilterEditProc, (LPARAM)cur);
- fillExceptionsListView(hwndDlg);
- ListView_SetItemState(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS), pos1, LVNI_FOCUSED | LVIS_SELECTED, LVNI_FOCUSED | LVIS_SELECTED);
- SetFocus(GetDlgItem(hwndDlg, IDC_LIST_EXCEPTIONS));
- break;
- }
- }
- }
-
- if (GetDlgItem(hwndDlg, IDC_STATUS) == ((LPNMHDR)lParam)->hwndFrom) {
- switch (((LPNMHDR)lParam)->code) {
- case LVN_ITEMCHANGED:
- NMLISTVIEW *nmlv = (NMLISTVIEW *)lParam;
- if ((nmlv->uNewState ^ nmlv->uOldState) & LVIS_STATEIMAGEMASK)
- SendMessage(GetParent(hwndDlg), PSM_CHANGED, 0, 0);
- break;
- }
- }
- break;
-
- case WM_DESTROY:
- bOptionsOpen = FALSE;
- deleteConnectionsTable(connExceptionsTmp);
- connExceptionsTmp = nullptr;
- return TRUE;
- }
- return 0;
-}
-
-//options page on miranda called
-int ConnectionNotifyOptInit(WPARAM wParam, LPARAM)
-{
- OPTIONSDIALOGPAGE odp = {};
- odp.pszTemplate = MAKEINTRESOURCEA(IDD_OPT_DIALOG);
- odp.szTitle.w = _A2W(PLUGINNAME);
- odp.szGroup.w = LPGENW("Plugins");
- odp.flags = ODPF_BOLDGROUPS | ODPF_UNICODE;
- odp.pfnDlgProc = DlgProcConnectionNotifyOpts;//callback function name
- g_plugin.addOptions(wParam, &odp);
- return 0;
}
-//gives protocol avainable statuses
+// gives protocol avainable statuses
INT_PTR GetCaps(WPARAM wParam, LPARAM)
{
if (wParam == PFLAGNUM_1)
@@ -600,14 +167,14 @@ INT_PTR GetCaps(WPARAM wParam, LPARAM)
return 0;
}
-//gives name to protocol module
+// gives name to protocol module
INT_PTR GetName(WPARAM wParam, LPARAM lParam)
{
mir_strncpy((char*)lParam, PLUGINNAME, wParam);
return 0;
}
-//gives icon for proto module
+// gives icon for proto module
INT_PTR TMLoadIcon(WPARAM wParam, LPARAM)
{
UINT id;
@@ -641,7 +208,7 @@ INT_PTR SetStatus(WPARAM wParam, LPARAM lParam)
else {
int retv = 0;
- if (settingStatus[wParam - ID_STATUS_ONLINE])
+ if (g_plugin.iStatus[wParam - ID_STATUS_ONLINE])
retv = SetStatus(ID_STATUS_OFFLINE, lParam);
else
retv = SetStatus(ID_STATUS_ONLINE, lParam);
@@ -676,7 +243,7 @@ static unsigned __stdcall checkthread(void *)
_OutputDebugString(L"check thread started");
#endif
while (1) {
- struct CONNECTION* conn = nullptr, *connOld = first, *cur = nullptr;
+ CONNECTION* conn = nullptr, *connOld = first, *cur = nullptr;
#ifdef _DEBUG
_OutputDebugString(L"checking connections table...");
#endif
@@ -688,7 +255,7 @@ static unsigned __stdcall checkthread(void *)
conn = GetConnectionsTable();
cur = conn;
while (cur != nullptr) {
- if (searchConnection(first, cur->strIntIp, cur->strExtIp, cur->intIntPort, cur->intExtPort, cur->state) == nullptr && (settingStatusMask & (1 << (cur->state - 1)))) {
+ if (searchConnection(first, cur->strIntIp, cur->strExtIp, cur->intIntPort, cur->intExtPort, cur->state) == nullptr && (g_plugin.iStatusMask & (1 << (cur->state - 1)))) {
#ifdef _DEBUG
wchar_t msg[1024];
@@ -709,7 +276,7 @@ static unsigned __stdcall checkthread(void *)
first = conn;
deleteConnectionsTable(connOld);
- Sleep(settingInterval);
+ Sleep(g_plugin.iInterval);
}
hConnectionCheckThread = nullptr;
return 1;
@@ -722,10 +289,10 @@ static LRESULT CALLBACK PopupDlgProc(HWND hWnd, UINT message, WPARAM wParam, LPA
case WM_COMMAND:
if (HIWORD(wParam) == STN_CLICKED)//client clicked on popup with left mouse button
{
- struct CONNECTION *conn = (struct CONNECTION*)mir_alloc(sizeof(struct CONNECTION));
- struct CONNECTION *mpd = (struct CONNECTION*) PUGetPluginData(hWnd);
+ CONNECTION *conn = (CONNECTION*)mir_alloc(sizeof(CONNECTION));
+ CONNECTION *mpd = (CONNECTION*) PUGetPluginData(hWnd);
- memcpy(conn, mpd, sizeof(struct CONNECTION));
+ memcpy(conn, mpd, sizeof(CONNECTION));
PUDeletePopup(hWnd);
PostThreadMessage(FilterOptionsThreadId, WM_ADD_FILTER, 0, (LPARAM)conn);
}
@@ -737,13 +304,13 @@ static LRESULT CALLBACK PopupDlgProc(HWND hWnd, UINT message, WPARAM wParam, LPA
case UM_INITPOPUP:
//struct CONNECTON *conn=NULL;
- //conn = (struct CONNECTION*)PUGetPluginData(hWnd,(LPARAM)conn);
+ //conn = (CONNECTION*)PUGetPluginData(hWnd,(LPARAM)conn);
//MessageBox(NULL,conn->extIp);
//PUDeletePopUp(hWnd);
break;
case UM_FREEPLUGINDATA:
- struct CONNECTION *mpd = (struct CONNECTION*)PUGetPluginData(hWnd);
+ CONNECTION *mpd = (CONNECTION*)PUGetPluginData(hWnd);
if (mpd > 0) mir_free(mpd);
return TRUE; //TRUE or FALSE is the same, it gets ignored.
}
@@ -753,12 +320,12 @@ static LRESULT CALLBACK PopupDlgProc(HWND hWnd, UINT message, WPARAM wParam, LPA
//show popup
void showMsg(wchar_t *pName, DWORD pid, wchar_t *intIp, wchar_t *extIp, int intPort, int extPort, int state)
{
- struct CONNECTION *mpd = (struct CONNECTION*)mir_alloc(sizeof(struct CONNECTION));
+ CONNECTION *mpd = (CONNECTION*)mir_alloc(sizeof(CONNECTION));
POPUPDATAW ppd;
ppd.lchContact = NULL;//(HANDLE)hContact; //Be sure to use a GOOD handle, since this will not be checked.
ppd.lchIcon = LoadIcon(g_plugin.getInst(), MAKEINTRESOURCE(IDI_ICON1));
- if (settingResolveIp) {
+ if (g_plugin.bResolveIp) {
wchar_t hostName[128];
getDnsName(extIp, hostName, _countof(hostName));
mir_snwprintf(ppd.lpwzText, L"%s:%d\n%s:%d", hostName, extPort, intIp, intPort);
@@ -767,13 +334,13 @@ void showMsg(wchar_t *pName, DWORD pid, wchar_t *intIp, wchar_t *extIp, int intP
mir_snwprintf(ppd.lpwzContactName, L"%s (%s)", pName, tcpStates[state - 1]);
- if (settingSetColours) {
- ppd.colorBack = settingBgColor;
- ppd.colorText = settingFgColor;
+ if (g_plugin.bSetColours) {
+ ppd.colorBack = g_plugin.BgColor;
+ ppd.colorText = g_plugin.FgColor;
}
ppd.PluginWindowProc = PopupDlgProc;
- ppd.iSeconds = settingInterval1;
+ ppd.iSeconds = g_plugin.iInterval1;
//Now the "additional" data.
wcsncpy_s(mpd->strIntIp, intIp, _TRUNCATE);
wcsncpy_s(mpd->strExtIp, extIp, _TRUNCATE);
@@ -813,7 +380,6 @@ static int preshutdown(WPARAM, LPARAM)
{
deleteConnectionsTable(first);
deleteConnectionsTable(connExceptions);
- deleteConnectionsTable(connExceptionsTmp);
PostThreadMessage(ConnectionCheckThreadId, WM_QUIT, 0, 0);
PostThreadMessage(FilterOptionsThreadId, WM_QUIT, 0, 0);