forked from osmocom/wireshark
8cd389e161
The first is deprecated, as per https://spdx.org/licenses/. Change-Id: I8e21e1d32d09b8b94b93a2dc9fbdde5ffeba6bed Reviewed-on: https://code.wireshark.org/review/25661 Petri-Dish: Anders Broman <a.broman58@gmail.com> Petri-Dish: Dario Lombardo <lomato@gmail.com> Reviewed-by: Anders Broman <a.broman58@gmail.com>
104 lines
2.4 KiB
C
104 lines
2.4 KiB
C
/* tap-smbsids.c
|
|
* smbstat 2003 Ronnie Sahlberg
|
|
*
|
|
* Wireshark - Network traffic analyzer
|
|
* By Gerald Combs <gerald@wireshark.org>
|
|
* Copyright 1998 Gerald Combs
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later*/
|
|
|
|
#include "config.h"
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
#include <glib.h>
|
|
|
|
#include <epan/packet_info.h>
|
|
#include <epan/dissectors/packet-smb-sidsnooping.h>
|
|
#include <epan/tap.h>
|
|
#include <epan/stat_tap_ui.h>
|
|
#include <epan/value_string.h>
|
|
#include <epan/dissectors/packet-smb.h>
|
|
|
|
void register_tap_listener_smbsids(void);
|
|
|
|
static int
|
|
smbsids_packet(void *pss _U_, packet_info *pinfo _U_, epan_dissect_t *edt _U_, const void *psi _U_)
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
static void
|
|
enum_sids(gpointer key, gpointer value, gpointer userdata _U_)
|
|
{
|
|
const char *sid = (const char *)key;
|
|
const char *name = (const char *)value;
|
|
|
|
printf("%-60s %s\n", sid, name);
|
|
}
|
|
|
|
static void
|
|
smbsids_draw(void *pss _U_)
|
|
{
|
|
printf("\n");
|
|
printf("===================================================================\n");
|
|
printf("SMB SID List:\n");
|
|
g_hash_table_foreach(sid_name_table, enum_sids, NULL);
|
|
printf("===================================================================\n");
|
|
}
|
|
|
|
|
|
static void
|
|
smbsids_init(const char *opt_arg _U_, void *userdata _U_)
|
|
{
|
|
GString *error_string;
|
|
|
|
if (!sid_name_snooping) {
|
|
fprintf(stderr, "The -z smb,sids function needs SMB/SID-Snooping to be enabled.\n");
|
|
fprintf(stderr, "Either enable Edit/Preferences/Protocols/SMB/Snoop SID name mappings in wireshark\n");
|
|
fprintf(stderr, "or override the preference file by specifying\n");
|
|
fprintf(stderr, " -o \"smb.sid_name_snooping=TRUE\"\n");
|
|
fprintf(stderr, "on the tshark command line.\n");
|
|
exit(1);
|
|
}
|
|
|
|
|
|
error_string = register_tap_listener("smb", NULL, NULL, 0, NULL, smbsids_packet, smbsids_draw);
|
|
if (error_string) {
|
|
fprintf(stderr, "tshark: Couldn't register smb,sids tap:%s\n",
|
|
error_string->str);
|
|
g_string_free(error_string, TRUE);
|
|
exit(1);
|
|
}
|
|
}
|
|
|
|
static stat_tap_ui smbsids_ui = {
|
|
REGISTER_STAT_GROUP_GENERIC,
|
|
NULL,
|
|
"smb,sids",
|
|
smbsids_init,
|
|
0,
|
|
NULL
|
|
};
|
|
|
|
void
|
|
register_tap_listener_smbsids(void)
|
|
{
|
|
register_stat_tap_ui(&smbsids_ui, NULL);
|
|
}
|
|
|
|
/*
|
|
* Editor modelines - http://www.wireshark.org/tools/modelines.html
|
|
*
|
|
* Local variables:
|
|
* c-basic-offset: 8
|
|
* tab-width: 8
|
|
* indent-tabs-mode: t
|
|
* End:
|
|
*
|
|
* vi: set shiftwidth=8 tabstop=8 noexpandtab:
|
|
* :indentSize=8:tabSize=8:noTabs=false:
|
|
*/
|