wireshark/gtk/sctp_stat_dlg.c

661 lines
20 KiB
C

/*
* Copyright 2004, Irene Ruengeler <i.ruengeler [AT] fh-muenster.de>
*
* $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
* Copyright 1998 Gerald Combs
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
#include <gtk/gtk.h>
#include <string.h>
#include "globals.h"
#include "epan/filesystem.h"
#include "image/clist_ascend.xpm"
#include "image/clist_descend.xpm"
#include "../stat_menu.h"
#include "gui_stat_menu.h"
#include "dlg_utils.h"
#include "gui_utils.h"
#include "main.h"
#include "compat_macros.h"
#include "sctp_stat.h"
#include "gtkglobals.h"
static GtkWidget *sctp_stat_dlg=NULL;
static GtkWidget *clist = NULL;
static GList *last_list = NULL;
static gchar *filter_string = NULL;
static sctp_assoc_info_t* selected_stream=NULL; /* current selection */
static sctp_allassocs_info_t *sctp_assocs=NULL;
static guint16 n_children=0;
static GtkWidget *bt_afilter = NULL, *bt_unselect=NULL, *bt_analyse=NULL, *bt_filter=NULL;
static gboolean prevent_update = FALSE, filter_applied = FALSE;
#define NUM_COLS 9
typedef struct column_arrows {
GtkWidget *table;
GtkWidget *ascend_pm;
GtkWidget *descend_pm;
} column_arrows;
static void
dlg_destroy(void)
{
guint32 i, j;
GList *list;
struct sctp_analyse *child_data;
j=n_children;
for (i=0; i<j; i++)
{
list=g_list_last(sctp_assocs->children);
child_data=(struct sctp_analyse *)list->data;
gtk_grab_remove(GTK_WIDGET(child_data->window));
gtk_widget_destroy(GTK_WIDGET(child_data->window));
list=g_list_previous(list);
}
g_list_free(sctp_assocs->children);
sctp_assocs->children = NULL;
sctp_stat_dlg = NULL;
prevent_update = FALSE;
filter_applied = FALSE;
}
void
decrease_analyse_childcount()
{
n_children--;
}
void
increase_analyse_childcount()
{
n_children++;
}
void
set_analyse_child(struct sctp_analyse *child)
{
sctp_assocs->children=g_list_append(sctp_assocs->children, child);
}
void
remove_analyse_child(struct sctp_analyse *child)
{
sctp_assocs->children=g_list_remove(sctp_assocs->children, child);
}
static void add_to_clist(sctp_assoc_info_t* assinfo)
{
gint added_row, i;
gchar *data[NUM_COLS];
gchar field[NUM_COLS][30];
for (i=0; i<NUM_COLS; i++)
data[i]=&field[i][0];
g_snprintf(field[0], 20, "%u", assinfo->port1);
g_snprintf(field[1], 20, "%u", assinfo->port2);
g_snprintf(field[2], 20, "%u", assinfo->n_packets);
g_snprintf(field[3], 20, "%s", assinfo->checksum_type);
g_snprintf(field[4], 20, "%u", assinfo->n_checksum_errors);
g_snprintf(field[5], 20, "%u", assinfo->n_data_chunks);
g_snprintf(field[6], 20, "%u", assinfo->n_data_bytes);
g_snprintf(field[7], 20, "0x%x", assinfo->verification_tag1);
g_snprintf(field[8], 20, "0x%x", assinfo->verification_tag2);
added_row = gtk_clist_append(GTK_CLIST(clist), data);
gtk_clist_set_row_data(GTK_CLIST(clist), added_row, assinfo);
}
static void
sctp_stat_on_unselect(GtkButton *button _U_, gpointer user_data _U_)
{
if (filter_string != NULL) {
g_free(filter_string);
filter_string = NULL;
}
selected_stream = NULL;
gtk_entry_set_text(GTK_ENTRY(main_display_filter_widget), "");
main_filter_packets(&cfile, "", FALSE);
gtk_clist_unselect_all(GTK_CLIST(clist));
gtk_widget_set_sensitive(bt_unselect,FALSE);
gtk_widget_set_sensitive(bt_filter,FALSE);
gtk_widget_set_sensitive(bt_analyse,FALSE);
gtk_widget_set_sensitive(bt_afilter,FALSE);
prevent_update = FALSE;
filter_applied = FALSE;
}
void sctp_stat_dlg_update(void)
{
GList *list;
list=(sctp_stat_get_info()->assoc_info_list);
if (sctp_stat_dlg != NULL && !prevent_update)
{
gtk_clist_clear(GTK_CLIST(clist));
list = g_list_first(sctp_stat_get_info()->assoc_info_list);
while (list)
{
add_to_clist((sctp_assoc_info_t*)(list->data));
list = g_list_next(list);
}
}
last_list = list;
}
static void
sctp_stat_on_select_row(GtkCList *clist, gint row, gint column _U_,
GdkEventButton *event _U_, gpointer user_data _U_)
{
gchar *text[1];
guint16 port1, port2;
guint32 checksum, data_chunks, data_bytes, packets, vtag1, vtag2;
GList *list;
sctp_assoc_info_t* assoc;
gboolean stream_found=FALSE;
gtk_clist_get_row_data(GTK_CLIST(clist), row);
gtk_clist_get_text(GTK_CLIST(clist), row, 0, text);
port1=atoi(text[0]);
gtk_clist_get_text(GTK_CLIST(clist), row, 1, text);
port2=atoi(text[0]);
gtk_clist_get_text(GTK_CLIST(clist), row, 7, text);
sscanf(text[0],"0x%x",&vtag1);
gtk_clist_get_text(GTK_CLIST(clist), row, 8, text);
sscanf(text[0],"0x%x",&vtag2);
gtk_clist_get_text(GTK_CLIST(clist), row, 2, text);
packets=atoi(text[0]);
gtk_clist_get_text(GTK_CLIST(clist), row, 4, text);
checksum=atoi(text[0]);
gtk_clist_get_text(GTK_CLIST(clist), row, 5, text);
data_chunks=atoi(text[0]);
gtk_clist_get_text(GTK_CLIST(clist), row, 6, text);
data_bytes=atoi(text[0]);
list = g_list_first(sctp_assocs->assoc_info_list);
while (list)
{
assoc = (sctp_assoc_info_t*)(list->data);
if (assoc->port1==port1 && assoc->port2==port2
&& assoc->n_packets==packets && assoc->n_data_chunks==data_chunks && assoc->n_data_bytes==data_bytes
&& assoc->verification_tag1==vtag1 && assoc->verification_tag2==vtag2)
{
selected_stream=assoc;
stream_found=TRUE;
break;
}
list=g_list_next(list);
}
if (!stream_found)
selected_stream = NULL;
gtk_widget_set_sensitive(bt_unselect,TRUE);
gtk_widget_set_sensitive(bt_analyse,TRUE);
gtk_widget_set_sensitive(bt_filter,TRUE);
}
static void
sctp_stat_on_apply_filter (GtkButton *button _U_, gpointer user_data _U_)
{
GList *list;
sctp_assoc_info_t* assoc;
guint16 port1, port2;
guint32 checksum, data_chunks, data_bytes, packets, vtag1, vtag2;
if (filter_string != NULL)
{
port1 = selected_stream->port1;
port2 = selected_stream->port2;
checksum = selected_stream->n_checksum_errors;
data_chunks = selected_stream->n_data_chunks;
data_bytes = selected_stream->n_data_bytes;
packets = selected_stream->n_packets;
vtag1 = selected_stream->verification_tag1;
vtag2 = selected_stream->verification_tag2;
main_filter_packets(&cfile, filter_string, FALSE);
list = g_list_first(sctp_assocs->assoc_info_list);
while (list)
{
assoc = (sctp_assoc_info_t*)(list->data);
if (assoc->port1==port1 && assoc->port2==port2
&& assoc->n_packets==packets && assoc->n_data_chunks==data_chunks && assoc->n_data_bytes==data_bytes
&& assoc->verification_tag1==vtag1 && assoc->verification_tag2==vtag2)
{
selected_stream=assoc;
break;
}
list=g_list_next(list);
}
gtk_widget_set_sensitive(bt_afilter,FALSE);
prevent_update=TRUE;
filter_applied = TRUE;
}
}
static void
sctp_stat_on_filter (GtkButton *button _U_, gpointer user_data _U_)
{
gchar *f_string = NULL;
GList *srclist, *dstlist;
gchar *str=NULL;
GString *gstring=NULL;
struct sockaddr_in *infosrc=NULL;
struct sockaddr_in *infodst=NULL;
if (selected_stream==NULL) {
gtk_entry_set_text(GTK_ENTRY(main_display_filter_widget), "");
return;
}
if (selected_stream->check_address==FALSE)
{
f_string = g_strdup_printf("((sctp.srcport==%u && sctp.dstport==%u && "
"((sctp.verification_tag==0x%x && sctp.verification_tag!=0x0) || "
"(sctp.verification_tag==0x0 && sctp.initiate_tag==0x%x) || "
"(sctp.verification_tag==0x%x && (sctp.abort_t_bit==1 || "
"sctp.shutdown_complete_t_bit==1)))) ||"
"(sctp.srcport==%u && sctp.dstport==%u && ((sctp.verification_tag==0x%x "
"&& sctp.verification_tag!=0x0) || "
"(sctp.verification_tag==0x0 && sctp.initiate_tag==0x%x) ||"
"(sctp.verification_tag==0x%x && (sctp.abort_t_bit==1 ||"
" sctp.shutdown_complete_t_bit==1)))))",
selected_stream->port1,
selected_stream->port2,
selected_stream->verification_tag1,
selected_stream->initiate_tag,
selected_stream->verification_tag2,
selected_stream->port2,
selected_stream->port1,
selected_stream->verification_tag2,
selected_stream->initiate_tag,
selected_stream->verification_tag1);
filter_string = f_string;
}
else
{
srclist = g_list_first(selected_stream->addr1);
infosrc=(struct sockaddr_in *) (srclist->data);
gstring = g_string_new(g_strdup_printf("((sctp.srcport==%u && sctp.dstport==%u && (ip.src==%s",
selected_stream->port1, selected_stream->port2, ip_to_str((const guint8 *)&(infosrc->sin_addr.s_addr))));
srclist= g_list_next(srclist);
while (srclist)
{
infosrc=(struct sockaddr_in *) (srclist->data);
str =g_strdup_printf("|| ip.src==%s",ip_to_str((const guint8 *)&(infosrc->sin_addr.s_addr)));
g_string_append(gstring, str);
srclist= g_list_next(srclist);
}
dstlist = g_list_first(selected_stream->addr2);
infodst=(struct sockaddr_in *) (dstlist->data);
str = g_strdup_printf(") && (ip.dst==%s",ip_to_str((const guint8 *)&(infodst->sin_addr.s_addr)));
g_string_append(gstring, str);
dstlist= g_list_next(dstlist);
while (dstlist)
{
infodst=(struct sockaddr_in *) (dstlist->data);
str =g_strdup_printf("|| ip.dst==%s",ip_to_str((const guint8 *)&(infodst->sin_addr.s_addr)));
g_string_append(gstring, str);
dstlist= g_list_next(dstlist);
}
srclist = g_list_first(selected_stream->addr1);
infosrc=(struct sockaddr_in *) (srclist->data);
str = g_strdup_printf(")) || (sctp.dstport==%u && sctp.srcport==%u && (ip.dst==%s",
selected_stream->port1, selected_stream->port2, ip_to_str((const guint8 *)&(infosrc->sin_addr.s_addr)));
g_string_append(gstring, str);
srclist= g_list_next(srclist);
while (srclist)
{
infosrc=(struct sockaddr_in *) (srclist->data);
str =g_strdup_printf("|| ip.dst==%s",ip_to_str((const guint8 *)&(infosrc->sin_addr.s_addr)));
g_string_append(gstring, str);
srclist= g_list_next(srclist);
}
dstlist = g_list_first(selected_stream->addr2);
infodst=(struct sockaddr_in *) (dstlist->data);
str = g_strdup_printf(") && (ip.src==%s",ip_to_str((const guint8 *)&(infodst->sin_addr.s_addr)));
g_string_append(gstring, str);
dstlist= g_list_next(dstlist);
while (dstlist)
{
infodst=(struct sockaddr_in *) (dstlist->data);
str =g_strdup_printf("|| ip.src==%s",ip_to_str((const guint8 *)&(infodst->sin_addr.s_addr)));
g_string_append(gstring, str);
dstlist= g_list_next(dstlist);
}
str = g_strdup_printf(")))");
g_string_append(gstring, str);
filter_string = gstring->str;
g_string_free(gstring,FALSE);
}
if (filter_string != NULL) {
gtk_entry_set_text(GTK_ENTRY(main_display_filter_widget), filter_string);
} else {
g_assert_not_reached();
}
gtk_widget_set_sensitive(bt_afilter,TRUE);
gtk_widget_set_sensitive(bt_filter,FALSE);
prevent_update = TRUE;
filter_applied = FALSE;
}
static void
sctp_stat_on_close (GtkWidget *button _U_, gpointer user_data _U_)
{
gtk_grab_remove(sctp_stat_dlg);
gtk_widget_destroy(sctp_stat_dlg);
prevent_update = FALSE;
filter_applied = FALSE;
}
static void
sctp_stat_on_analyse (GtkButton *button _U_, gpointer user_data _U_)
{
if (selected_stream==NULL)
return;
else
assoc_analyse(selected_stream);
gtk_widget_set_sensitive(bt_analyse,FALSE);
if (!filter_applied)
gtk_widget_set_sensitive(bt_filter,TRUE);
prevent_update = TRUE;
}
static gint
clist_sort_column(GtkCList *clist, gconstpointer ptr1, gconstpointer ptr2)
{
char *text1 = NULL;
char *text2 = NULL;
int i1, i2;
GtkCListRow *row1 = (GtkCListRow *) ptr1;
GtkCListRow *row2 = (GtkCListRow *) ptr2;
prevent_update = FALSE;
text1 = GTK_CELL_TEXT (row1->cell[clist->sort_column])->text;
text2 = GTK_CELL_TEXT (row2->cell[clist->sort_column])->text;
switch(clist->sort_column){
case 0:
case 2:
return strcmp (text1, text2);
case 1:
case 3:
case 4:
case 5:
case 6:
case 7:
i1=atoi(text1);
i2=atoi(text2);
return i1-i2;
}
g_assert_not_reached();
return 0;
}
static void
clist_click_column_cb(GtkCList *list, gint column, gpointer data)
{
column_arrows *col_arrows = (column_arrows *) data;
int i;
prevent_update = FALSE;
gtk_clist_freeze(list);
for (i = 0; i < NUM_COLS; i++) {
gtk_widget_hide(col_arrows[i].ascend_pm);
gtk_widget_hide(col_arrows[i].descend_pm);
}
if (column == list->sort_column) {
if (list->sort_type == GTK_SORT_ASCENDING) {
list->sort_type = GTK_SORT_DESCENDING;
gtk_widget_show(col_arrows[column].descend_pm);
} else {
list->sort_type = GTK_SORT_ASCENDING;
gtk_widget_show(col_arrows[column].ascend_pm);
}
} else {
list->sort_type = GTK_SORT_DESCENDING;
gtk_widget_show(col_arrows[column].descend_pm);
gtk_clist_set_sort_column(list, column);
}
gtk_clist_thaw(list);
gtk_clist_sort(list);
}
static void
gtk_sctpstat_dlg(void)
{
GtkWidget *sctp_stat_dlg_w;
GtkWidget *vbox1;
GtkWidget *scrolledwindow1;
GtkWidget *hbuttonbox2;
GtkWidget *bt_close;
const gchar *titles[NUM_COLS] = {"Port 1","Port 2","No of Packets", "Checksum", "No of Errors", "Data Chunks", "Data Bytes", "VTag 1","VTag 2"};
column_arrows *col_arrows;
GdkBitmap *ascend_bm, *descend_bm;
GdkPixmap *ascend_pm, *descend_pm;
GtkStyle *win_style;
GtkWidget *column_lb;
gint i;
sctp_stat_dlg_w = window_new (GTK_WINDOW_TOPLEVEL, "Wireshark: SCTP Associations");
gtk_window_set_position (GTK_WINDOW (sctp_stat_dlg_w), GTK_WIN_POS_CENTER);
SIGNAL_CONNECT(sctp_stat_dlg_w, "destroy", dlg_destroy,NULL);
/* Container for each row of widgets */
vbox1 = gtk_vbox_new(FALSE, 2);
gtk_container_border_width(GTK_CONTAINER(vbox1), 8);
gtk_container_add(GTK_CONTAINER(sctp_stat_dlg_w), vbox1);
gtk_widget_show(vbox1);
scrolledwindow1 = scrolled_window_new (NULL, NULL);
gtk_widget_show (scrolledwindow1);
gtk_box_pack_start (GTK_BOX (vbox1), scrolledwindow1, TRUE, TRUE, 0);
clist = gtk_clist_new (NUM_COLS);
gtk_widget_show (clist);
gtk_container_add (GTK_CONTAINER (scrolledwindow1), clist);
WIDGET_SET_SIZE(clist, 650, 200);
gtk_clist_set_column_width (GTK_CLIST (clist), 0, 50);
gtk_clist_set_column_width (GTK_CLIST (clist), 1, 50);
gtk_clist_set_column_width (GTK_CLIST (clist), 2, 100);
gtk_clist_set_column_width (GTK_CLIST (clist), 3, 100);
gtk_clist_set_column_width (GTK_CLIST (clist), 4, 100);
gtk_clist_set_column_width (GTK_CLIST (clist), 5, 100);
gtk_clist_set_column_width (GTK_CLIST (clist), 6, 100);
gtk_clist_set_column_width (GTK_CLIST (clist), 7, 100);
gtk_clist_set_column_width (GTK_CLIST (clist), 8, 100);
gtk_clist_set_column_justification(GTK_CLIST(clist), 0, GTK_JUSTIFY_CENTER);
gtk_clist_set_column_justification(GTK_CLIST(clist), 1, GTK_JUSTIFY_CENTER);
gtk_clist_set_column_justification(GTK_CLIST(clist), 2, GTK_JUSTIFY_CENTER);
gtk_clist_set_column_justification(GTK_CLIST(clist), 3, GTK_JUSTIFY_CENTER);
gtk_clist_set_column_justification(GTK_CLIST(clist), 4, GTK_JUSTIFY_CENTER);
gtk_clist_set_column_justification(GTK_CLIST(clist), 5, GTK_JUSTIFY_CENTER);
gtk_clist_set_column_justification(GTK_CLIST(clist), 6, GTK_JUSTIFY_CENTER);
gtk_clist_set_column_justification(GTK_CLIST(clist), 7, GTK_JUSTIFY_CENTER);
gtk_clist_set_column_justification(GTK_CLIST(clist), 8, GTK_JUSTIFY_CENTER);
gtk_clist_column_titles_show (GTK_CLIST (clist));
gtk_clist_set_compare_func(GTK_CLIST(clist), clist_sort_column);
gtk_clist_set_sort_column(GTK_CLIST(clist), 0);
gtk_clist_set_sort_type(GTK_CLIST(clist), GTK_SORT_ASCENDING);
gtk_widget_show(sctp_stat_dlg_w);
col_arrows = (column_arrows *) g_malloc(sizeof(column_arrows) * NUM_COLS);
win_style = gtk_widget_get_style(scrolledwindow1);
ascend_pm = gdk_pixmap_create_from_xpm_d(scrolledwindow1->window,
&ascend_bm,
&win_style->bg[GTK_STATE_NORMAL],
(gchar **)clist_ascend_xpm);
descend_pm = gdk_pixmap_create_from_xpm_d(scrolledwindow1->window,
&descend_bm,
&win_style->bg[GTK_STATE_NORMAL],
(gchar **)clist_descend_xpm);
for (i=0; i<NUM_COLS; i++)
{
col_arrows[i].table = gtk_table_new(2, 2, FALSE);
gtk_table_set_col_spacings(GTK_TABLE(col_arrows[i].table), 5);
column_lb = gtk_label_new(titles[i]);
gtk_table_attach(GTK_TABLE(col_arrows[i].table), column_lb, 0, 1, 0, 2, GTK_SHRINK, GTK_SHRINK, 0, 0);
gtk_widget_show(column_lb);
col_arrows[i].ascend_pm = gtk_pixmap_new(ascend_pm, ascend_bm);
gtk_table_attach(GTK_TABLE(col_arrows[i].table), col_arrows[i].ascend_pm, 1, 2, 1, 2, GTK_SHRINK, GTK_SHRINK, 0, 0);
col_arrows[i].descend_pm = gtk_pixmap_new(descend_pm, descend_bm);
gtk_table_attach(GTK_TABLE(col_arrows[i].table), col_arrows[i].descend_pm, 1, 2, 0, 1, GTK_SHRINK, GTK_SHRINK, 0, 0);
/* make src-ip be the default sort order */
if (i == 0)
{
gtk_widget_show(col_arrows[i].ascend_pm);
}
gtk_clist_set_column_widget(GTK_CLIST(clist), i, col_arrows[i].table);
gtk_widget_show(col_arrows[i].table);
}
SIGNAL_CONNECT(clist, "click-column", clist_click_column_cb, col_arrows);
hbuttonbox2 = gtk_hbutton_box_new();
gtk_box_pack_start(GTK_BOX(vbox1), hbuttonbox2, FALSE, FALSE, 0);
gtk_container_set_border_width(GTK_CONTAINER(hbuttonbox2), 10);
gtk_button_box_set_layout(GTK_BUTTON_BOX (hbuttonbox2), GTK_BUTTONBOX_SPREAD);
gtk_button_box_set_spacing(GTK_BUTTON_BOX (hbuttonbox2), 0);
gtk_button_box_set_child_ipadding(GTK_BUTTON_BOX (hbuttonbox2), 4, 0);
gtk_widget_show(hbuttonbox2);
bt_unselect = gtk_button_new_with_label ("Unselect");
gtk_container_add (GTK_CONTAINER (hbuttonbox2), bt_unselect);
gtk_widget_show (bt_unselect);
gtk_widget_set_sensitive(bt_unselect,FALSE);
bt_filter = gtk_button_new_with_label ("Set filter");
gtk_container_add (GTK_CONTAINER (hbuttonbox2), bt_filter);
gtk_widget_show (bt_filter);
gtk_widget_set_sensitive(bt_filter,FALSE);
bt_afilter = gtk_button_new_with_label ("Apply filter");
gtk_container_add (GTK_CONTAINER (hbuttonbox2), bt_afilter);
gtk_widget_show (bt_afilter);
gtk_widget_set_sensitive(bt_afilter,FALSE);
bt_analyse = gtk_button_new_with_label ("Analyse");
gtk_container_add (GTK_CONTAINER (hbuttonbox2), bt_analyse);
gtk_widget_show (bt_analyse);
gtk_widget_set_sensitive(bt_analyse,FALSE);
bt_close = BUTTON_NEW_FROM_STOCK(GTK_STOCK_CLOSE);
gtk_container_add (GTK_CONTAINER (hbuttonbox2), bt_close);
GTK_WIDGET_SET_FLAGS(bt_close, GTK_CAN_DEFAULT);
window_set_cancel_button( sctp_stat_dlg_w, bt_close, sctp_stat_on_close);
gtk_widget_grab_focus(bt_close);
gtk_widget_show (bt_close);
SIGNAL_CONNECT(sctp_stat_dlg_w, "destroy", dlg_destroy, NULL);
SIGNAL_CONNECT(clist, "select_row", sctp_stat_on_select_row, NULL);
SIGNAL_CONNECT(bt_unselect, "clicked", sctp_stat_on_unselect, NULL);
SIGNAL_CONNECT(bt_filter, "clicked", sctp_stat_on_filter, NULL);
SIGNAL_CONNECT(bt_afilter, "clicked", sctp_stat_on_apply_filter, NULL);
SIGNAL_CONNECT(bt_analyse, "clicked", sctp_stat_on_analyse, NULL);
sctp_stat_dlg = sctp_stat_dlg_w;
cf_retap_packets(&cfile, FALSE);
}
static void sctp_stat_dlg_show(void)
{
if (sctp_stat_dlg != NULL)
{
/* There's already a dialog box; reactivate it. */
reactivate_window(sctp_stat_dlg);
/* Another list since last call? */
if ((sctp_stat_get_info()->assoc_info_list) != last_list)
sctp_stat_dlg_update();
}
else
{
/* Create and show the dialog box */
gtk_sctpstat_dlg();
sctp_stat_dlg_update();
}
}
static void sctp_stat_start(GtkWidget *w _U_, gpointer data _U_)
{
prevent_update = FALSE;
filter_applied = FALSE;
sctp_assocs = g_malloc(sizeof(sctp_allassocs_info_t));
sctp_assocs = (sctp_allassocs_info_t*)sctp_stat_get_info();
/* Register the tap listener */
if (sctp_stat_get_info()->is_registered==FALSE)
register_tap_listener_sctp_stat();
/* (redissect all packets) */
sctp_stat_scan();
/* Show the dialog box with the list of streams */
/* sctp_stat_dlg_show(sctp_stat_get_info()->assoc_info_list); */
sctp_stat_dlg_show();
}
/****************************************************************************/
void
register_tap_listener_sctp_stat_dlg(void)
{
register_stat_menu_item("SCTP/Show All Associations...", REGISTER_STAT_GROUP_TELEPHONY,
sctp_stat_start, NULL, NULL, NULL);
}
GtkWidget* get_stat_dlg(void)
{
return sctp_stat_dlg;
}