Add support for the GeoIP library. Using different database files,
[obnox/wireshark/wip.git] / gtk / hostlist_table.h
1 /* hostlist_table.h   2004 Ian Schorr
2  * modified from endpoint_talkers_table   2003 Ronnie Sahlberg
3  * Helper routines common to all host talkers taps.
4  *
5  * $Id$
6  *
7  * Wireshark - Network traffic analyzer
8  * By Gerald Combs <gerald@wireshark.org>
9  * Copyright 1998 Gerald Combs
10  *
11  * This program is free software; you can redistribute it and/or
12  * modify it under the terms of the GNU General Public License
13  * as published by the Free Software Foundation; either version 2
14  * of the License, or (at your option) any later version.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program; if not, write to the Free Software
23  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
24  */
25
26 #include "sat.h"
27
28 /** @file
29  *  Hostlist definitions.
30  */
31
32 /** Hostlist information */
33 typedef struct _hostlist_talker_t {
34         address address;        /**< address */
35         SAT_E   sat;            /**< address type */
36         guint32 port_type;      /**< port_type (e.g. PT_TCP) */
37         guint32 port;           /**< port */
38
39         guint64 rx_frames;      /**< number of received packets */
40         guint64 tx_frames;      /**< number of transmitted packets */
41         guint64 rx_bytes;       /**< number of received bytes */
42         guint64 tx_bytes;       /**< number of transmitted bytes */
43 } hostlist_talker_t;
44
45 #define NUM_BUILTIN_COLS 8
46 #ifdef HAVE_GEOIP
47 # define NUM_GEOIP_COLS 8
48 #else
49 # define NUM_GEOIP_COLS 0
50 #endif
51 #define NUM_HOSTLIST_COLS (NUM_BUILTIN_COLS + NUM_GEOIP_COLS)
52
53 /** Hostlist widget */
54 typedef struct _hostlist_table {
55         const char          *name;              /**< the name of the table */
56         const char          *filter;            /**< the filter used */
57         gboolean             use_dfilter;       /**< use display filter */
58         GtkWidget           *win;               /**< GTK window */
59         GtkWidget           *page_lb;           /**< page label */
60         GtkWidget           *name_lb;           /**< name label */
61         GtkWidget           *scrolled_window;   /**< the scrolled window */
62         GtkCList            *table;             /**< the GTK table */
63         guint32             num_columns;        /**< number of columns in the above table */
64         const char          *default_titles[NUM_HOSTLIST_COLS]; /**< Column headers */
65         GtkWidget           *menu;              /**< context menu */
66         gboolean            has_ports;          /**< table has ports */
67         guint32             num_hosts;          /**< number of hosts (0 or 1) */
68         hostlist_talker_t   *hosts;             /**< array of host values */
69         gboolean            resolve_names;      /**< resolve address names? */
70 } hostlist_table;
71
72 /** Register the hostlist table for the multiple hostlist window.
73  *
74  * @param hide_ports hide the port columns
75  * @param table_name the table name to be displayed
76  * @param tap_name the registered tap name
77  * @param filter the optional filter name or NULL
78  * @param packet_func the function to be called for each incoming packet
79  */
80 extern void register_hostlist_table(gboolean hide_ports, const char *table_name, const char *tap_name, const char *filter, tap_packet_cb packet_func);
81
82 /** Init the hostlist table for the single hostlist window.
83  *
84  * @param hide_ports hide the port columns
85  * @param table_name the table name to be displayed
86  * @param tap_name the registered tap name
87  * @param filter the optional filter name or NULL
88  * @param packet_func the function to be called for each incoming packet
89  */
90 extern void init_hostlist_table(gboolean hide_ports, const char *table_name, const char *tap_name, const char *filter, tap_packet_cb packet_func);
91
92 /** Callback for "Endpoints" statistics item.
93  *
94  * @param w unused
95  * @param d unused
96  */
97 extern void init_hostlist_notebook_cb(GtkWidget *w, gpointer d);
98
99 /** Add some data to the table.
100  *
101  * @param hl the table to add the data to
102  * @param addr address
103  * @param port port
104  * @param sender TRUE, if this is a sender
105  * @param num_frames number of packets
106  * @param num_bytes number of bytes
107  * @param sat address type
108  * @param port_type the port type (e.g. PT_TCP)
109  */
110 void add_hostlist_table_data(hostlist_table *hl, const address *addr,
111                              guint32 port, gboolean sender, int num_frames, int num_bytes, SAT_E sat, int port_type);