1999-10-14 01:29:07 +00:00
|
|
|
/* packet-yhoo.c
|
|
|
|
* Routines for yahoo messenger packet dissection
|
|
|
|
* Copyright 1999, Nathan Neulinger <nneul@umr.edu>
|
|
|
|
*
|
2002-08-28 21:04:11 +00:00
|
|
|
* $Id: packet-yhoo.c,v 1.25 2002/08/28 21:00:40 jmayer Exp $
|
1999-10-14 01:29:07 +00:00
|
|
|
*
|
|
|
|
* Ethereal - Network traffic analyzer
|
2001-07-03 04:56:46 +00:00
|
|
|
* By Gerald Combs <gerald@ethereal.com>
|
1999-10-14 01:29:07 +00:00
|
|
|
* Copyright 1998 Gerald Combs
|
|
|
|
*
|
|
|
|
* Copied from packet-tftp.c
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
1999-10-14 01:29:07 +00:00
|
|
|
* 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.
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
1999-10-14 01:29:07 +00:00
|
|
|
* 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.
|
2002-08-28 21:04:11 +00:00
|
|
|
*
|
1999-10-14 01:29:07 +00:00
|
|
|
* 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 <stdio.h>
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include <glib.h>
|
2002-01-21 07:37:49 +00:00
|
|
|
#include <epan/packet.h>
|
1999-10-14 01:29:07 +00:00
|
|
|
#include "packet-yhoo.h"
|
|
|
|
|
|
|
|
static int proto_yhoo = -1;
|
1999-10-14 03:12:32 +00:00
|
|
|
static int hf_yhoo_version = -1;
|
|
|
|
static int hf_yhoo_len = -1;
|
|
|
|
static int hf_yhoo_service = -1;
|
|
|
|
static int hf_yhoo_connection_id = -1;
|
|
|
|
static int hf_yhoo_magic_id = -1;
|
|
|
|
static int hf_yhoo_unknown1 = -1;
|
|
|
|
static int hf_yhoo_msgtype = -1;
|
|
|
|
static int hf_yhoo_nick1 = -1;
|
|
|
|
static int hf_yhoo_nick2 = -1;
|
|
|
|
static int hf_yhoo_content = -1;
|
|
|
|
|
1999-11-16 11:44:20 +00:00
|
|
|
static gint ett_yhoo = -1;
|
|
|
|
|
Add routines to:
register lists of "heuristic" dissectors, which are handed a
frame that may or may contain a payload for the protocol they
dissect, and that return FALSE if it's not or dissect the packet
and return TRUE if it is;
add a dissector to such a list;
go through such a list, calling each dissector until either a
dissector returns TRUE, in which case the routine returns TRUE,
or it runs out of entries in the list, in which case the routine
returns FALSE.
Have lists of heuristic dissectors for TCP and for COTP when used with
the Inactive Subset of CLNP, and add the GIOP and Yahoo Messenger
dissectors to the first list and the Sinec H1 dissector to the second
list.
Make the dissector name argument to "dissector_add()" and
"dissector_delete()" a "const char *" rarther than just a "char *".
Add "heur_dissector_add()", the routine to add a heuristic dissector to
a list of heuristic dissectors, to the set of routines we can export to
plugins through a table on platforms where dynamically-loaded code can't
call stuff in the main program, and initialize the element in the table
in question for "dissector_add()" (which we'd forgotten to do).
svn path=/trunk/; revision=1909
2000-05-05 09:32:36 +00:00
|
|
|
#define TCP_PORT_YHOO 5050
|
|
|
|
|
1999-10-14 03:12:32 +00:00
|
|
|
static const value_string yhoo_service_vals[] = {
|
|
|
|
{YAHOO_SERVICE_LOGON, "Pager Logon"},
|
|
|
|
{YAHOO_SERVICE_LOGOFF, "Pager Logoff"},
|
|
|
|
{YAHOO_SERVICE_ISAWAY, "Is Away"},
|
|
|
|
{YAHOO_SERVICE_ISBACK, "Is Back"},
|
|
|
|
{YAHOO_SERVICE_IDLE, "Idle"},
|
|
|
|
{YAHOO_SERVICE_MESSAGE, "Message"},
|
|
|
|
{YAHOO_SERVICE_IDACT, "Activate Identity"},
|
|
|
|
{YAHOO_SERVICE_IDDEACT, "Deactivate Identity"},
|
|
|
|
{YAHOO_SERVICE_MAILSTAT, "Mail Status"},
|
|
|
|
{YAHOO_SERVICE_USERSTAT, "User Status"},
|
|
|
|
{YAHOO_SERVICE_NEWMAIL, "New Mail"},
|
|
|
|
{YAHOO_SERVICE_CHATINVITE, "Chat Invitation"},
|
|
|
|
{YAHOO_SERVICE_CALENDAR, "Calendar Reminder"},
|
|
|
|
{YAHOO_SERVICE_NEWPERSONALMAIL, "New Personals Mail"},
|
|
|
|
{YAHOO_SERVICE_NEWCONTACT, "New Friend"},
|
|
|
|
{YAHOO_SERVICE_GROUPRENAME, "Group Renamed"},
|
|
|
|
{YAHOO_SERVICE_ADDIDENT, "Add Identity"},
|
|
|
|
{YAHOO_SERVICE_ADDIGNORE, "Add Ignore"},
|
|
|
|
{YAHOO_SERVICE_PING, "Ping"},
|
|
|
|
{YAHOO_SERVICE_SYSMESSAGE, "System Message"},
|
|
|
|
{YAHOO_SERVICE_CONFINVITE, "Conference Invitation"},
|
|
|
|
{YAHOO_SERVICE_CONFLOGON, "Conference Logon"},
|
|
|
|
{YAHOO_SERVICE_CONFDECLINE, "Conference Decline"},
|
|
|
|
{YAHOO_SERVICE_CONFLOGOFF, "Conference Logoff"},
|
|
|
|
{YAHOO_SERVICE_CONFMSG, "Conference Message"},
|
1999-10-20 16:36:08 +00:00
|
|
|
{YAHOO_SERVICE_CONFADDINVITE, "Conference Additional Invitation"},
|
1999-10-14 03:12:32 +00:00
|
|
|
{YAHOO_SERVICE_CHATLOGON, "Chat Logon"},
|
|
|
|
{YAHOO_SERVICE_CHATLOGOFF, "Chat Logoff"},
|
|
|
|
{YAHOO_SERVICE_CHATMSG, "Chat Message"},
|
|
|
|
{YAHOO_SERVICE_FILETRANSFER, "File Transfer"},
|
1999-10-20 16:36:08 +00:00
|
|
|
{YAHOO_SERVICE_PASSTHROUGH2, "Passthrough 2"},
|
1999-10-14 03:12:32 +00:00
|
|
|
{0, NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static const value_string yhoo_msgtype_vals[] = {
|
|
|
|
{YAHOO_MSGTYPE_NONE, "None"},
|
|
|
|
{YAHOO_MSGTYPE_NORMAL, "Normal"},
|
|
|
|
{YAHOO_MSGTYPE_BOUNCE, "Bounce"},
|
|
|
|
{YAHOO_MSGTYPE_STATUS, "Status Update"},
|
|
|
|
{YAHOO_MSGTYPE_OFFLINE, "Request Offline"},
|
|
|
|
{0, NULL}
|
|
|
|
};
|
1999-10-14 01:29:07 +00:00
|
|
|
|
Add routines to:
register lists of "heuristic" dissectors, which are handed a
frame that may or may contain a payload for the protocol they
dissect, and that return FALSE if it's not or dissect the packet
and return TRUE if it is;
add a dissector to such a list;
go through such a list, calling each dissector until either a
dissector returns TRUE, in which case the routine returns TRUE,
or it runs out of entries in the list, in which case the routine
returns FALSE.
Have lists of heuristic dissectors for TCP and for COTP when used with
the Inactive Subset of CLNP, and add the GIOP and Yahoo Messenger
dissectors to the first list and the Sinec H1 dissector to the second
list.
Make the dissector name argument to "dissector_add()" and
"dissector_delete()" a "const char *" rarther than just a "char *".
Add "heur_dissector_add()", the routine to add a heuristic dissector to
a list of heuristic dissectors, to the set of routines we can export to
plugins through a table on platforms where dynamically-loaded code can't
call stuff in the main program, and initialize the element in the table
in question for "dissector_add()" (which we'd forgotten to do).
svn path=/trunk/; revision=1909
2000-05-05 09:32:36 +00:00
|
|
|
static gboolean
|
2001-04-18 00:21:01 +00:00
|
|
|
dissect_yhoo(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
|
1999-10-14 01:29:07 +00:00
|
|
|
{
|
|
|
|
proto_tree *yhoo_tree, *ti;
|
2001-04-18 00:21:01 +00:00
|
|
|
int offset = 0;
|
1999-10-14 01:29:07 +00:00
|
|
|
|
2001-07-03 04:56:46 +00:00
|
|
|
if (pinfo->srcport != TCP_PORT_YHOO && pinfo->destport != TCP_PORT_YHOO) {
|
Add routines to:
register lists of "heuristic" dissectors, which are handed a
frame that may or may contain a payload for the protocol they
dissect, and that return FALSE if it's not or dissect the packet
and return TRUE if it is;
add a dissector to such a list;
go through such a list, calling each dissector until either a
dissector returns TRUE, in which case the routine returns TRUE,
or it runs out of entries in the list, in which case the routine
returns FALSE.
Have lists of heuristic dissectors for TCP and for COTP when used with
the Inactive Subset of CLNP, and add the GIOP and Yahoo Messenger
dissectors to the first list and the Sinec H1 dissector to the second
list.
Make the dissector name argument to "dissector_add()" and
"dissector_delete()" a "const char *" rarther than just a "char *".
Add "heur_dissector_add()", the routine to add a heuristic dissector to
a list of heuristic dissectors, to the set of routines we can export to
plugins through a table on platforms where dynamically-loaded code can't
call stuff in the main program, and initialize the element in the table
in question for "dissector_add()" (which we'd forgotten to do).
svn path=/trunk/; revision=1909
2000-05-05 09:32:36 +00:00
|
|
|
/* Not the Yahoo port - not a Yahoo Messenger packet. */
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
1999-10-14 01:29:07 +00:00
|
|
|
/* get at least a full packet structure */
|
2001-04-18 00:21:01 +00:00
|
|
|
if ( !tvb_bytes_exist(tvb, 0, sizeof(struct yahoo_rawpacket)) ) {
|
Add routines to:
register lists of "heuristic" dissectors, which are handed a
frame that may or may contain a payload for the protocol they
dissect, and that return FALSE if it's not or dissect the packet
and return TRUE if it is;
add a dissector to such a list;
go through such a list, calling each dissector until either a
dissector returns TRUE, in which case the routine returns TRUE,
or it runs out of entries in the list, in which case the routine
returns FALSE.
Have lists of heuristic dissectors for TCP and for COTP when used with
the Inactive Subset of CLNP, and add the GIOP and Yahoo Messenger
dissectors to the first list and the Sinec H1 dissector to the second
list.
Make the dissector name argument to "dissector_add()" and
"dissector_delete()" a "const char *" rarther than just a "char *".
Add "heur_dissector_add()", the routine to add a heuristic dissector to
a list of heuristic dissectors, to the set of routines we can export to
plugins through a table on platforms where dynamically-loaded code can't
call stuff in the main program, and initialize the element in the table
in question for "dissector_add()" (which we'd forgotten to do).
svn path=/trunk/; revision=1909
2000-05-05 09:32:36 +00:00
|
|
|
/* Not enough data captured; maybe it is a Yahoo
|
|
|
|
Messenger packet, but it contains too little data to
|
|
|
|
tell. */
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2001-04-18 00:21:01 +00:00
|
|
|
if (memcmp(tvb_get_ptr(tvb, offset, 4), "YPNS", 4) != 0 &&
|
|
|
|
memcmp(tvb_get_ptr(tvb, offset, 4), "YHOO", 4) != 0) {
|
Add routines to:
register lists of "heuristic" dissectors, which are handed a
frame that may or may contain a payload for the protocol they
dissect, and that return FALSE if it's not or dissect the packet
and return TRUE if it is;
add a dissector to such a list;
go through such a list, calling each dissector until either a
dissector returns TRUE, in which case the routine returns TRUE,
or it runs out of entries in the list, in which case the routine
returns FALSE.
Have lists of heuristic dissectors for TCP and for COTP when used with
the Inactive Subset of CLNP, and add the GIOP and Yahoo Messenger
dissectors to the first list and the Sinec H1 dissector to the second
list.
Make the dissector name argument to "dissector_add()" and
"dissector_delete()" a "const char *" rarther than just a "char *".
Add "heur_dissector_add()", the routine to add a heuristic dissector to
a list of heuristic dissectors, to the set of routines we can export to
plugins through a table on platforms where dynamically-loaded code can't
call stuff in the main program, and initialize the element in the table
in question for "dissector_add()" (which we'd forgotten to do).
svn path=/trunk/; revision=1909
2000-05-05 09:32:36 +00:00
|
|
|
/* Not a Yahoo Messenger packet. */
|
|
|
|
return FALSE;
|
|
|
|
}
|
1999-10-14 01:29:07 +00:00
|
|
|
|
2001-12-10 00:26:21 +00:00
|
|
|
if (check_col(pinfo->cinfo, COL_PROTOCOL))
|
|
|
|
col_set_str(pinfo->cinfo, COL_PROTOCOL, "YHOO");
|
1999-10-14 01:29:07 +00:00
|
|
|
|
2001-04-18 00:21:01 +00:00
|
|
|
offset = 0;
|
2001-12-10 00:26:21 +00:00
|
|
|
if (check_col(pinfo->cinfo, COL_INFO)) {
|
2002-08-28 21:04:11 +00:00
|
|
|
col_add_fstr(pinfo->cinfo, COL_INFO,
|
|
|
|
"%s: %s",
|
2001-04-18 00:21:01 +00:00
|
|
|
( strncmp(tvb_get_ptr(tvb, offset + 0, 4), "YPNS", 4) == 0 ) ? "Request" : "Response",
|
|
|
|
val_to_str(tvb_get_letohl(tvb, offset + 12),
|
1999-10-14 03:12:32 +00:00
|
|
|
yhoo_service_vals, "Unknown Service: %u")
|
|
|
|
);
|
2001-04-18 00:21:01 +00:00
|
|
|
}
|
1999-10-14 01:29:07 +00:00
|
|
|
|
|
|
|
if (tree) {
|
2002-01-24 09:20:54 +00:00
|
|
|
ti = proto_tree_add_item(tree, proto_yhoo, tvb, offset, -1,
|
|
|
|
FALSE);
|
1999-11-16 11:44:20 +00:00
|
|
|
yhoo_tree = proto_item_add_subtree(ti, ett_yhoo);
|
1999-10-14 01:29:07 +00:00
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_version, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 8, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 8;
|
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_len, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 4, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 4;
|
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_service, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 4, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 4;
|
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_connection_id, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 4, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 4;
|
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_magic_id, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 4, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 4;
|
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_unknown1, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 4, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 4;
|
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_msgtype, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 4, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 4;
|
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_nick1, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 36, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 36;
|
|
|
|
|
2002-08-28 21:04:11 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_nick2, tvb,
|
2001-07-16 06:09:02 +00:00
|
|
|
offset, 36, TRUE);
|
2001-04-18 00:21:01 +00:00
|
|
|
offset += 36;
|
|
|
|
|
2002-02-01 07:12:53 +00:00
|
|
|
proto_tree_add_item(yhoo_tree, hf_yhoo_content, tvb, -1,
|
|
|
|
offset, TRUE);
|
1999-10-14 01:29:07 +00:00
|
|
|
}
|
Add routines to:
register lists of "heuristic" dissectors, which are handed a
frame that may or may contain a payload for the protocol they
dissect, and that return FALSE if it's not or dissect the packet
and return TRUE if it is;
add a dissector to such a list;
go through such a list, calling each dissector until either a
dissector returns TRUE, in which case the routine returns TRUE,
or it runs out of entries in the list, in which case the routine
returns FALSE.
Have lists of heuristic dissectors for TCP and for COTP when used with
the Inactive Subset of CLNP, and add the GIOP and Yahoo Messenger
dissectors to the first list and the Sinec H1 dissector to the second
list.
Make the dissector name argument to "dissector_add()" and
"dissector_delete()" a "const char *" rarther than just a "char *".
Add "heur_dissector_add()", the routine to add a heuristic dissector to
a list of heuristic dissectors, to the set of routines we can export to
plugins through a table on platforms where dynamically-loaded code can't
call stuff in the main program, and initialize the element in the table
in question for "dissector_add()" (which we'd forgotten to do).
svn path=/trunk/; revision=1909
2000-05-05 09:32:36 +00:00
|
|
|
|
|
|
|
return TRUE;
|
1999-10-14 01:29:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
proto_register_yhoo(void)
|
|
|
|
{
|
1999-10-14 03:12:32 +00:00
|
|
|
static hf_register_info hf[] = {
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_service, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Service Type", "yhoo.service", FT_UINT32, BASE_DEC,
|
2001-06-18 02:18:27 +00:00
|
|
|
VALS(yhoo_service_vals), 0, "Service Type", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_msgtype, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Message Type", "yhoo.msgtype", FT_UINT32, BASE_DEC,
|
2001-06-18 02:18:27 +00:00
|
|
|
VALS(yhoo_msgtype_vals), 0, "Message Type Flags", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_connection_id, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Connection ID", "yhoo.connection_id", FT_UINT32, BASE_HEX,
|
2001-06-18 02:18:27 +00:00
|
|
|
NULL, 0, "Connection ID", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_magic_id, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Magic ID", "yhoo.magic_id", FT_UINT32, BASE_HEX,
|
2001-06-18 02:18:27 +00:00
|
|
|
NULL, 0, "Magic ID", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_unknown1, {
|
1999-10-20 16:36:08 +00:00
|
|
|
"Unknown 1", "yhoo.unknown1", FT_UINT32, BASE_HEX,
|
2001-06-18 02:18:27 +00:00
|
|
|
NULL, 0, "Unknown 1", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_len, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Packet Length", "yhoo.len", FT_UINT32, BASE_DEC,
|
2001-06-18 02:18:27 +00:00
|
|
|
NULL, 0, "Packet Length", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_nick1, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Real Nick (nick1)", "yhoo.nick1", FT_STRING, 0,
|
2001-06-18 02:18:27 +00:00
|
|
|
NULL, 0, "Real Nick (nick1)", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_nick2, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Active Nick (nick2)", "yhoo.nick2", FT_STRING, 0,
|
2001-06-18 02:18:27 +00:00
|
|
|
NULL, 0, "Active Nick (nick2)", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_content, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Content", "yhoo.content", FT_STRING, 0,
|
2001-06-18 02:18:27 +00:00
|
|
|
NULL, 0, "Data portion of the packet", HFILL }},
|
2002-08-28 21:04:11 +00:00
|
|
|
{ &hf_yhoo_version, {
|
1999-10-14 03:12:32 +00:00
|
|
|
"Version", "yhoo.version", FT_STRING, 0,
|
2001-06-18 02:18:27 +00:00
|
|
|
NULL, 0, "Packet version identifier", HFILL }},
|
1999-10-14 03:12:32 +00:00
|
|
|
};
|
1999-11-16 11:44:20 +00:00
|
|
|
static gint *ett[] = {
|
|
|
|
&ett_yhoo,
|
|
|
|
};
|
1999-10-14 03:12:32 +00:00
|
|
|
|
2001-01-03 06:56:03 +00:00
|
|
|
proto_yhoo = proto_register_protocol("Yahoo Messenger Protocol",
|
|
|
|
"YHOO", "yhoo");
|
1999-10-14 03:12:32 +00:00
|
|
|
|
|
|
|
proto_register_field_array(proto_yhoo, hf, array_length(hf));
|
1999-11-16 11:44:20 +00:00
|
|
|
|
|
|
|
proto_register_subtree_array(ett, array_length(ett));
|
1999-10-14 01:29:07 +00:00
|
|
|
}
|
Add routines to:
register lists of "heuristic" dissectors, which are handed a
frame that may or may contain a payload for the protocol they
dissect, and that return FALSE if it's not or dissect the packet
and return TRUE if it is;
add a dissector to such a list;
go through such a list, calling each dissector until either a
dissector returns TRUE, in which case the routine returns TRUE,
or it runs out of entries in the list, in which case the routine
returns FALSE.
Have lists of heuristic dissectors for TCP and for COTP when used with
the Inactive Subset of CLNP, and add the GIOP and Yahoo Messenger
dissectors to the first list and the Sinec H1 dissector to the second
list.
Make the dissector name argument to "dissector_add()" and
"dissector_delete()" a "const char *" rarther than just a "char *".
Add "heur_dissector_add()", the routine to add a heuristic dissector to
a list of heuristic dissectors, to the set of routines we can export to
plugins through a table on platforms where dynamically-loaded code can't
call stuff in the main program, and initialize the element in the table
in question for "dissector_add()" (which we'd forgotten to do).
svn path=/trunk/; revision=1909
2000-05-05 09:32:36 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
proto_reg_handoff_yhoo(void)
|
|
|
|
{
|
2001-04-18 00:21:01 +00:00
|
|
|
heur_dissector_add("tcp", dissect_yhoo, proto_yhoo);
|
Add routines to:
register lists of "heuristic" dissectors, which are handed a
frame that may or may contain a payload for the protocol they
dissect, and that return FALSE if it's not or dissect the packet
and return TRUE if it is;
add a dissector to such a list;
go through such a list, calling each dissector until either a
dissector returns TRUE, in which case the routine returns TRUE,
or it runs out of entries in the list, in which case the routine
returns FALSE.
Have lists of heuristic dissectors for TCP and for COTP when used with
the Inactive Subset of CLNP, and add the GIOP and Yahoo Messenger
dissectors to the first list and the Sinec H1 dissector to the second
list.
Make the dissector name argument to "dissector_add()" and
"dissector_delete()" a "const char *" rarther than just a "char *".
Add "heur_dissector_add()", the routine to add a heuristic dissector to
a list of heuristic dissectors, to the set of routines we can export to
plugins through a table on platforms where dynamically-loaded code can't
call stuff in the main program, and initialize the element in the table
in question for "dissector_add()" (which we'd forgotten to do).
svn path=/trunk/; revision=1909
2000-05-05 09:32:36 +00:00
|
|
|
}
|