diff options
author | Michael Mann <mmann78@netscape.net> | 2016-12-26 09:34:13 -0500 |
---|---|---|
committer | Michael Mann <mmann78@netscape.net> | 2016-12-27 01:59:55 +0000 |
commit | fc29f28cb0c72dc93398ef3cae2f9091c2205bec (patch) | |
tree | 4a41df81c87b5cbc00bcd03baf14ec35c6a532fb /epan/dissectors/packet-aim-generic.c | |
parent | 6427edb18d84a812cd3f9de95f657953f4026589 (diff) |
Merge AIM files into single dissector file.
These are probably obsolete dissectors anyway, but they are a
bunch of very small files causing unnecessary file pollution.
Change-Id: I03976484996b4bf987d6743ed379534456809c2c
Reviewed-on: https://code.wireshark.org/review/19437
Reviewed-by: Michael Mann <mmann78@netscape.net>
Diffstat (limited to 'epan/dissectors/packet-aim-generic.c')
-rw-r--r-- | epan/dissectors/packet-aim-generic.c | 612 |
1 files changed, 0 insertions, 612 deletions
diff --git a/epan/dissectors/packet-aim-generic.c b/epan/dissectors/packet-aim-generic.c deleted file mode 100644 index db9c2f8ec9..0000000000 --- a/epan/dissectors/packet-aim-generic.c +++ /dev/null @@ -1,612 +0,0 @@ -/* packet-aim-generic.c - * Routines for AIM Instant Messenger (OSCAR) dissection, SNAC Family Generic - * Copyright 2004, Jelmer Vernooij <jelmer@samba.org> - * - * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. - */ - -#include "config.h" - -#include <epan/packet.h> - -#include "packet-aim.h" - -void proto_register_aim_generic(void); -void proto_reg_handoff_aim_generic(void); - -#define STRIP_TAGS 1 - -/* SNAC families */ -#define FAMILY_GENERIC 0x0001 - - -#define FAMILY_GENERIC_MOTD_MOTDTYPE_MDT_UPGRADE 0x0001 -#define FAMILY_GENERIC_MOTD_MOTDTYPE_ADV_UPGRADE 0x0002 -#define FAMILY_GENERIC_MOTD_MOTDTYPE_SYS_BULLETIN 0x0003 -#define FAMILY_GENERIC_MOTD_MOTDTYPE_NORMAL 0x0004 -#define FAMILY_GENERIC_MOTD_MOTDTYPE_NEWS 0x0006 - -static const value_string aim_snac_generic_motd_motdtypes[] = { - { FAMILY_GENERIC_MOTD_MOTDTYPE_MDT_UPGRADE, "Mandatory Upgrade Needed Notice" }, - { FAMILY_GENERIC_MOTD_MOTDTYPE_ADV_UPGRADE, "Advisable Upgrade Notice" }, - { FAMILY_GENERIC_MOTD_MOTDTYPE_SYS_BULLETIN, "AIM/ICQ Service System Announcements" }, - { FAMILY_GENERIC_MOTD_MOTDTYPE_NORMAL, "Standard Notice" }, - { FAMILY_GENERIC_MOTD_MOTDTYPE_NEWS, "News from AOL service" }, - { 0, NULL } -}; - -#define RATEINFO_STATE_LIMITED 0x01 -#define RATEINFO_STATE_ALERT 0x02 -#define RATEINFO_STATE_CLEAR 0x03 - -static const value_string rateinfo_states[] = { - { RATEINFO_STATE_LIMITED, "Limited" }, - { RATEINFO_STATE_ALERT, "Alert" }, - { RATEINFO_STATE_CLEAR, "Clear" }, - { 0, NULL } -}; - -#define RATECHANGE_MSG_LIMIT_PARAMS_CHANGED 0x0001 -#define RATECHANGE_MSG_LIMIT_WARN 0x0002 -#define RATECHANGE_MSG_LIMIT_HIT 0x0003 -#define RATECHANGE_MSG_LIMIT_CLEAR 0x0004 - -static const value_string ratechange_msgs[] = { - { RATECHANGE_MSG_LIMIT_PARAMS_CHANGED, "Rate limits parameters changed" }, - { RATECHANGE_MSG_LIMIT_WARN, "Rate limits warning (current level < alert level)" }, - { RATECHANGE_MSG_LIMIT_HIT, "Rate limit hit (current level < limit level)" }, - { RATECHANGE_MSG_LIMIT_CLEAR, "Rate limit clear (current level now > clear level)" }, - { 0, NULL }, -}; - -#define EXT_STATUS_TYPE_BUDDY_ICON_0 0 -#define EXT_STATUS_TYPE_BUDDY_ICON_1 1 -#define EXT_STATUS_TYPE_AVAIL_MSG 2 -#define EXT_STATUS_TYPE_UNKNOWN 6 - -static const value_string ext_status_types[] = { - { EXT_STATUS_TYPE_BUDDY_ICON_0, "Request to send buddy icon" }, - { EXT_STATUS_TYPE_BUDDY_ICON_1, "Request to send buddy icon" }, - { EXT_STATUS_TYPE_AVAIL_MSG, "Extended Status Update" }, - { 0, NULL }, -}; - -#define EXT_STATUS_FLAG_INITIAL_SEND 0x41 -#define EXT_STATUS_FLAG_RESEND 0x81 - -static const value_string ext_status_flags[] = { - { EXT_STATUS_FLAG_INITIAL_SEND, "First Send Request" }, - { EXT_STATUS_FLAG_RESEND, "Request To Re-Send" }, - { 0, NULL }, -}; - -/* Initialize the protocol and registered fields */ -static int proto_aim_generic = -1; -static int hf_generic_motd_motdtype = -1; -static int hf_generic_family = -1; -static int hf_generic_version = -1; -static int hf_generic_dll_version = -1; -static int hf_generic_servicereq_service = -1; -static int hf_generic_rateinfo_numclasses = -1; -static int hf_generic_rateinfo_windowsize = -1; -static int hf_generic_rateinfo_clearlevel = -1; -static int hf_generic_rateinfo_alertlevel = -1; -static int hf_generic_rateinfo_limitlevel = -1; -static int hf_generic_rateinfo_disconnectlevel = -1; -static int hf_generic_rateinfo_currentlevel = -1; -static int hf_generic_rateinfo_maxlevel = -1; -static int hf_generic_rateinfo_lasttime = -1; -static int hf_generic_rateinfo_curstate = -1; -static int hf_generic_rateinfo_classid = -1; -static int hf_generic_rateinfo_numpairs = -1; -static int hf_generic_rateinfoack_group = -1; -static int hf_generic_ratechange_msg = -1; -static int hf_generic_migration_numfams = -1; -static int hf_generic_priv_flags = -1; -static int hf_generic_allow_idle_see = -1; -static int hf_generic_allow_member_see = -1; -static int hf_generic_selfinfo_warninglevel = -1; -static int hf_generic_evil_new_warn_level = -1; -static int hf_generic_idle_time = -1; -static int hf_generic_client_ver_req_offset = -1; -static int hf_generic_client_ver_req_length = -1; -static int hf_generic_client_ver_req_hash = -1; -static int hf_generic_ext_status_type = -1; -static int hf_generic_ext_status_length = -1; -static int hf_generic_ext_status_flags = -1; -static int hf_generic_ext_status_data = -1; - -/* Initialize the subtree pointers */ -static gint ett_generic_clientready = -1; -static gint ett_generic_migratefamilies = -1; -static gint ett_generic_clientready_item = -1; -static gint ett_generic_serverready = -1; -static gint ett_generic = -1; -static gint ett_generic_priv_flags = -1; -static gint ett_generic_rateinfo_class = -1; -static gint ett_generic_rateinfo_classes = -1; -static gint ett_generic_rateinfo_groups = -1; -static gint ett_generic_rateinfo_group = -1; - -static int dissect_rate_class(tvbuff_t *tvb, packet_info *pinfo _U_, int offset, proto_tree *class_tree) -{ - proto_tree_add_item(class_tree, hf_generic_rateinfo_classid, tvb, offset, 2, ENC_BIG_ENDIAN);offset+=2; - proto_tree_add_item(class_tree, hf_generic_rateinfo_windowsize, tvb, offset, 4, ENC_BIG_ENDIAN);offset+=4; - proto_tree_add_item(class_tree, hf_generic_rateinfo_clearlevel, tvb, offset, 4, ENC_BIG_ENDIAN);offset+=4; - proto_tree_add_item(class_tree, hf_generic_rateinfo_alertlevel, tvb, offset, 4, ENC_BIG_ENDIAN);offset+=4; - proto_tree_add_item(class_tree, hf_generic_rateinfo_limitlevel, tvb, offset, 4, ENC_BIG_ENDIAN);offset+=4; - proto_tree_add_item(class_tree, hf_generic_rateinfo_disconnectlevel, tvb, offset, 4, ENC_BIG_ENDIAN);offset+=4; - proto_tree_add_item(class_tree, hf_generic_rateinfo_currentlevel, tvb, offset, 4, ENC_BIG_ENDIAN);offset+=4; - proto_tree_add_item(class_tree, hf_generic_rateinfo_maxlevel, tvb, offset, 4, ENC_BIG_ENDIAN);offset+=4; - proto_tree_add_item(class_tree, hf_generic_rateinfo_lasttime, tvb, offset, 4, ENC_BIG_ENDIAN);offset+=4; - proto_tree_add_item(class_tree, hf_generic_rateinfo_curstate, tvb, offset, 1, ENC_BIG_ENDIAN);offset+=1; - return offset; -} - -static int dissect_generic_rateinfo(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) -{ - int offset = 0; - guint16 i; - guint16 numclasses = tvb_get_ntohs(tvb, 0); - proto_tree *classes_tree = NULL, *groups_tree, *group_tree; - proto_tree_add_uint(tree, hf_generic_rateinfo_numclasses, tvb, 0, 2, numclasses ); - offset+=2; - - if(tree) { - /* sizeof(rate_class_struct) = 35 ! */ - classes_tree = proto_tree_add_subtree(tree, tvb, offset, 35 * numclasses, - ett_generic_rateinfo_classes, NULL, "Available Rate Classes"); - } - - for(i = 0; i < numclasses; i++) { - guint16 myid = tvb_get_ntohs(tvb, offset); - proto_tree *class_tree = proto_tree_add_subtree_format(classes_tree, tvb, offset, 35, - ett_generic_rateinfo_class, NULL, "Rate Class 0x%02x", myid); - offset = dissect_rate_class(tvb, pinfo, offset, class_tree); - } - - groups_tree = proto_tree_add_subtree(tree, tvb, offset, -1, ett_generic_rateinfo_groups, NULL, "Rate Groups"); - - for(i = 0; i < numclasses; i++) { - guint16 j; - guint16 myid = tvb_get_ntohs(tvb, offset); - guint16 numpairs = tvb_get_ntohs(tvb, offset + 2); - /* - * sizeof(rate_group) = sizeof(class_id) + sizeof(numpairs) + numpairs * 2 * sizeof(uint16_t) - * = 2 + 2 + numpairs * 4 - */ - group_tree = proto_tree_add_subtree_format(groups_tree, tvb, offset, 4 + 4 * numpairs, - ett_generic_rateinfo_group, NULL, "Rate Group 0x%02x", myid); - proto_tree_add_uint(group_tree, hf_generic_rateinfo_classid, tvb, offset, 2, myid);offset+=2; - proto_tree_add_uint(group_tree, hf_generic_rateinfo_numpairs, tvb, offset, 2, numpairs); offset+=2; - for(j = 0; j < numpairs; j++) { - guint16 family_id; - guint16 subtype_id; - const aim_family *family; - const aim_subtype *subtype; - family_id = tvb_get_ntohs(tvb, offset); - subtype_id = tvb_get_ntohs(tvb, offset+2); - - family = aim_get_family(family_id); - subtype = aim_get_subtype(family_id, subtype_id); - - proto_tree_add_uint_format_value(group_tree, hf_generic_family, tvb, offset, 4, family_id, - "%s (0x%04x), Subtype: %s (0x%04x)", family?family->name:"Unknown", family_id, subtype?subtype->name:"Unknown", subtype_id); - offset+=4; - } - } - - return offset; -} - -static int dissect_aim_generic_clientready(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - int offset = 0; - proto_tree *entry = proto_tree_add_subtree(gen_tree, tvb, 0, -1, ett_generic_clientready, NULL, "Supported services"); - - while(tvb_reported_length_remaining(tvb, offset) > 0) { - proto_item *ti; - proto_tree *subtree; - - ti = proto_tree_add_item(entry, hf_generic_family, tvb, offset, 2, ENC_BIG_ENDIAN); - subtree = proto_item_add_subtree(ti, ett_generic_clientready_item); - offset+=2; - - proto_tree_add_item(subtree, hf_generic_version, tvb, offset, 2, ENC_BIG_ENDIAN); - offset += 2; - proto_tree_add_item(subtree, hf_generic_dll_version, tvb, offset, 3, ENC_BIG_ENDIAN); - /* Padding byte? */ - offset += 4; - proto_item_set_len(ti, 8); - } - return offset; -} - - -static int dissect_aim_generic_serverready(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - int offset = 0; - proto_tree *entry = proto_tree_add_subtree(gen_tree, tvb, offset, -1, ett_generic_clientready, NULL, "Supported services"); - - while(tvb_reported_length_remaining(tvb, offset) > 0) { - proto_tree_add_item(entry, hf_generic_family, tvb, offset, 2, ENC_BIG_ENDIAN); - offset+=2; - } - return offset; -} - - -static int dissect_aim_generic_service_req(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - int offset = 0; - const aim_family *family = aim_get_family( tvb_get_ntohs(tvb, offset) ); - - proto_tree_add_uint_format(gen_tree, hf_generic_servicereq_service, tvb, offset, 2, tvb_get_ntohs(tvb, offset), "%s (0x%04x)", family?family->name:"Unknown", tvb_get_ntohs(tvb, offset) ); - offset+=2; - return offset; -} - -static int dissect_aim_generic_redirect(tvbuff_t *tvb, packet_info *pinfo, proto_tree *gen_tree) -{ - return dissect_aim_tlv_sequence(tvb, pinfo, 0, gen_tree, aim_client_tlvs); -} - -static int dissect_aim_generic_capabilities(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - int offset = 0; - proto_tree *entry = proto_tree_add_subtree(gen_tree, tvb, offset, -1, ett_generic_clientready, NULL, "Requested services"); - - while(tvb_reported_length_remaining(tvb, offset) > 0) { - proto_tree_add_item(entry, hf_generic_family, tvb, offset, 2, ENC_BIG_ENDIAN); - offset+=2; - proto_tree_add_item(entry, hf_generic_version, tvb, offset, 2, ENC_BIG_ENDIAN); - offset+=2; - } - return offset; -} - -static int dissect_aim_generic_capack(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - int offset = 0; - proto_tree *entry = proto_tree_add_subtree(gen_tree, tvb, offset, -1, ett_generic_clientready, NULL, "Accepted requested services"); - - while(tvb_reported_length_remaining(tvb, offset) > 0) { - proto_tree_add_item(entry, hf_generic_family, tvb, offset, 2, ENC_BIG_ENDIAN); - offset+=2; - proto_tree_add_item(entry, hf_generic_version, tvb, offset, 2, ENC_BIG_ENDIAN); - offset+=2; - } - return offset; -} - -static int dissect_aim_generic_motd(tvbuff_t *tvb, packet_info *pinfo, proto_tree *gen_tree) -{ - int offset = 0; - proto_tree_add_item(gen_tree, hf_generic_motd_motdtype, tvb, offset, - 2, tvb_get_ntohs(tvb, offset)); - offset+=2; - return dissect_aim_tlv_sequence(tvb, pinfo, offset, gen_tree, aim_motd_tlvs); -} - -static int dissect_aim_generic_rateinfoack(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - int offset = 0; - while(tvb_reported_length_remaining(tvb, offset) > 0) { - proto_tree_add_uint(gen_tree, hf_generic_rateinfoack_group, tvb, offset, 2, tvb_get_ntohs(tvb, offset)); - offset+=2; - } - return offset; -} - -static int dissect_aim_generic_ratechange(tvbuff_t *tvb, packet_info *pinfo, proto_tree *gen_tree) -{ - int offset = 0; - proto_tree_add_uint(gen_tree, hf_generic_ratechange_msg, tvb, offset, 2, tvb_get_ntohs(tvb, offset)); - offset+=2; - offset = dissect_rate_class(tvb, pinfo, offset, gen_tree); - return offset; -} - - -static int dissect_aim_generic_clientpauseack(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - int offset = 0; - while(tvb_reported_length_remaining(tvb, offset) > 0) { - proto_tree_add_item(gen_tree, hf_generic_family, tvb, offset, 2, ENC_BIG_ENDIAN); - offset += 2; - } - return offset; -} - -static int dissect_aim_generic_migration_req(tvbuff_t *tvb, packet_info *pinfo, proto_tree *gen_tree) -{ - int offset = 0; - guint32 n, i; - proto_tree *entry; - - n = tvb_get_ntohs(tvb, offset);offset+=2; - proto_tree_add_uint(gen_tree, hf_generic_migration_numfams, tvb, offset, 2, n); - entry = proto_tree_add_subtree(gen_tree, tvb, offset, 2 * n, - ett_generic_migratefamilies, NULL, "Families to migrate"); - for(i = 0; i < n; i++) { - proto_tree_add_item(entry, hf_generic_family, tvb, offset, 2, ENC_BIG_ENDIAN); - offset += 2; - } - - return dissect_aim_tlv_sequence(tvb, pinfo, offset, gen_tree, aim_client_tlvs); -} - -static int dissect_aim_generic_setprivflags(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - static const int * flags[] = { - &hf_generic_allow_idle_see, - &hf_generic_allow_member_see, - NULL - }; - - proto_tree_add_bitmask(gen_tree, tvb, 0, hf_generic_priv_flags, ett_generic_priv_flags, flags, ENC_BIG_ENDIAN); - return 4; -} - -static int dissect_aim_generic_selfinfo_repl(tvbuff_t *tvb, packet_info *pinfo, proto_tree *gen_tree) -{ - int offset = dissect_aim_buddyname(tvb, pinfo, 0, gen_tree); - proto_tree_add_item(gen_tree, hf_generic_selfinfo_warninglevel, tvb, offset, 2, ENC_BIG_ENDIAN); - offset += 2; - return dissect_aim_tlv_list(tvb, pinfo, offset, gen_tree, aim_onlinebuddy_tlvs); -} - -static int dissect_aim_generic_evil(tvbuff_t *tvb, packet_info *pinfo, proto_tree *gen_tree) -{ - int offset = 0; - proto_tree_add_item(gen_tree, hf_generic_evil_new_warn_level, tvb, offset, 2, ENC_BIG_ENDIAN); - while(tvb_reported_length_remaining(tvb, offset) > 0) { - offset = dissect_aim_userinfo(tvb, pinfo, offset, gen_tree); - } - return offset; -} - -static int dissect_aim_generic_setidle(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - proto_tree_add_item(gen_tree, hf_generic_idle_time, tvb, 0, 2, ENC_BIG_ENDIAN); - return 2; -} - -static int dissect_aim_generic_ext_status_req(tvbuff_t *tvb, packet_info *pinfo, proto_tree *gen_tree) -{ - return dissect_aim_tlv_sequence(tvb, pinfo, 0, gen_tree, aim_onlinebuddy_tlvs); -} - -static int dissect_aim_generic_clientver_req(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - int offset = 0; - proto_tree_add_item(gen_tree, hf_generic_client_ver_req_offset, tvb, offset, 4, ENC_BIG_ENDIAN); - offset+=4; - proto_tree_add_item(gen_tree, hf_generic_client_ver_req_length, tvb, offset, 4, ENC_BIG_ENDIAN); - return offset+4; -} - -static int dissect_aim_generic_clientver_repl(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - proto_tree_add_item(gen_tree, hf_generic_client_ver_req_hash, tvb, 0, 16, ENC_NA); - return 16; -} - -static int dissect_aim_generic_ext_status_repl(tvbuff_t *tvb, packet_info *pinfo _U_, proto_tree *gen_tree) -{ - guint8 length; - int offset = 0; - proto_tree_add_item(gen_tree, hf_generic_ext_status_type, tvb, offset, 2, ENC_BIG_ENDIAN); offset += 2; - proto_tree_add_item(gen_tree, hf_generic_ext_status_flags, tvb, offset, 1, ENC_BIG_ENDIAN); offset += 1; - proto_tree_add_item(gen_tree, hf_generic_ext_status_length, tvb, offset, 1, ENC_BIG_ENDIAN); length = tvb_get_guint8(tvb, offset); offset += 1; - proto_tree_add_item(gen_tree, hf_generic_ext_status_data, tvb, offset, length, ENC_NA); offset += 1; - return offset; -} - -static void -aim_generic_family( gchar *result, guint32 famnum ) -{ - const aim_family *family = aim_get_family(famnum); - - g_snprintf( result, ITEM_LABEL_LENGTH, "%s (0x%x)", family?family->name:"Unknown", famnum); -} - -static const aim_subtype aim_fnac_family_generic[] = { - { 0x0001, "Error", dissect_aim_snac_error }, - { 0x0002, "Client Ready", dissect_aim_generic_clientready }, - { 0x0003, "Server Ready", dissect_aim_generic_serverready }, - { 0x0004, "Service Request", dissect_aim_generic_service_req }, - { 0x0005, "Redirect", dissect_aim_generic_redirect }, - { 0x0006, "Rate Info Request", NULL}, - { 0x0007, "Rate Info", dissect_generic_rateinfo }, - { 0x0008, "Rate Info Ack", dissect_aim_generic_rateinfoack }, - { 0x000a, "Rate Change", dissect_aim_generic_ratechange }, - { 0x000b, "Server Pause", NULL }, - { 0x000c, "Client Pause Ack", dissect_aim_generic_clientpauseack }, - { 0x000d, "Server Resume", NULL }, - { 0x000e, "Self Info Request", NULL }, - { 0x000f, "Self Info Reply", dissect_aim_generic_selfinfo_repl }, - { 0x0010, "Evil", dissect_aim_generic_evil }, - { 0x0011, "Set Idle", dissect_aim_generic_setidle }, - { 0x0012, "Migration Request", dissect_aim_generic_migration_req }, - { 0x0013, "Message Of The Day", dissect_aim_generic_motd }, - { 0x0014, "Set Privilege Flags", dissect_aim_generic_setprivflags }, - { 0x0015, "Well Known URL", NULL }, /* FIXME */ - { 0x0016, "noop", NULL }, - { 0x0017, "Capabilities", dissect_aim_generic_capabilities }, - { 0x0018, "Capabilities Ack", dissect_aim_generic_capack }, - { 0x001e, "Set Extended Status Request", dissect_aim_generic_ext_status_req }, - { 0x001f, "Client Verification Request", dissect_aim_generic_clientver_req }, - { 0x0020, "Client Verification Reply", dissect_aim_generic_clientver_repl }, - { 0x0021, "Set Extended Status Reply", dissect_aim_generic_ext_status_repl }, - { 0, NULL, NULL } -}; - - -/* Register the protocol with Wireshark */ -void -proto_register_aim_generic(void) -{ - - /* Setup list of header fields */ - static hf_register_info hf[] = { - { &hf_generic_servicereq_service, - { "Requested Service", "aim_generic.servicereq.service", FT_UINT16, - BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_motd_motdtype, - { "MOTD Type", "aim_generic.motd.motdtype", FT_UINT16, - BASE_HEX, VALS(aim_snac_generic_motd_motdtypes), 0x0, NULL, HFILL }, - }, - { &hf_generic_family, - { "Family", "aim_generic.family", FT_UINT16, BASE_CUSTOM, CF_FUNC(aim_generic_family), 0x0, NULL, HFILL }, - }, - { &hf_generic_version, - { "Version", "aim_generic.version", FT_UINT16, BASE_DEC, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_dll_version, - { "DLL Version", "aim_generic.dll_version", FT_UINT24, BASE_DEC, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_numclasses, - { "Number of Rateinfo Classes", "aim_generic.rateinfo.numclasses", FT_UINT16, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_windowsize, - { "Window Size", "aim_generic.rateinfo.class.window_size", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_clearlevel, - { "Clear Level", "aim_generic.rateinfo.class.clearlevel", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_alertlevel, - { "Alert Level", "aim_generic.rateinfo.class.alertlevel", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_limitlevel, - { "Limit Level", "aim_generic.rateinfo.class.limitlevel", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_disconnectlevel, - { "Disconnect Level", "aim_generic.rateinfo.class.disconnectlevel", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_currentlevel, - { "Current Level", "aim_generic.rateinfo.class.currentlevel", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_maxlevel, - { "Max Level", "aim_generic.rateinfo.class.maxlevel", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_lasttime, - { "Last Time", "aim_generic.rateinfo.class.lasttime", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_curstate, - { "Current State", "aim_generic.rateinfo.class.curstate", FT_UINT8, BASE_HEX, VALS(rateinfo_states), 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_classid, - { "Class ID", "aim_generic.rateinfo.class.id", FT_UINT16, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfo_numpairs, - { "Number of Family/Subtype pairs", "aim_generic.rateinfo.class.numpairs", FT_UINT16, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_rateinfoack_group, - { "Acknowledged Rate Class", "aim_generic.rateinfoack.class", FT_UINT16, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_ratechange_msg, - { "Rate Change Message", "aim_generic.ratechange.msg", FT_UINT16, BASE_HEX, VALS(ratechange_msgs), 0x0, NULL, HFILL }, - }, - { &hf_generic_migration_numfams, - { "Number of families to migrate", "aim_generic.migrate.numfams", FT_UINT16, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_priv_flags, - { "Privilege flags", "aim_generic.privilege_flags", FT_UINT32, BASE_HEX, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_allow_idle_see, - { "Allow other users to see idle time", "aim_generic.privilege_flags.allow_idle", FT_BOOLEAN, 32, TFS(&tfs_set_notset), 0x0001, NULL, HFILL }, - }, - { &hf_generic_allow_member_see, - { "Allow other users to see how long account has been a member", "aim_generic.privilege_flags.allow_member", FT_BOOLEAN, 32, TFS(&tfs_set_notset), 0x0002, NULL, HFILL }, - }, - { &hf_generic_selfinfo_warninglevel, - { "Warning level", "aim_generic.selfinfo.warn_level", FT_UINT16, BASE_DEC, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_evil_new_warn_level, - { "New warning level", "aim_generic.evil.new_warn_level", FT_UINT16, BASE_DEC, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_idle_time, - { "Idle time (seconds)", "aim_generic.idle_time", FT_UINT32, BASE_DEC, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_client_ver_req_offset, - { "Client Verification Request Offset", "aim_generic.client_verification.offset", FT_UINT32, BASE_DEC, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_client_ver_req_length, - { "Client Verification Request Length", "aim_generic.client_verification.length", FT_UINT32, BASE_DEC, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_client_ver_req_hash, - { "Client Verification MD5 Hash", "aim_generic.client_verification.hash", FT_BYTES, BASE_NONE, NULL, 0x0, NULL, HFILL }, - }, - { &hf_generic_ext_status_type, - { "Extended Status Type", "aim_generic.ext_status.type", FT_UINT16, BASE_DEC, VALS(ext_status_types), 0x0, NULL, HFILL }, - }, - { &hf_generic_ext_status_flags, - { "Extended Status Flags", "aim_generic.ext_status.flags", FT_UINT8, BASE_HEX, VALS(ext_status_flags), 0x0, NULL, HFILL }, - }, - { &hf_generic_ext_status_length, - { "Extended Status Length", "aim_generic.ext_status.length", FT_UINT8, BASE_HEX, NULL, 0x0, NULL , HFILL }, - }, - { &hf_generic_ext_status_data, - { "Extended Status Data", "aim_generic.ext_status.data", FT_BYTES, BASE_NONE, NULL, 0x0, NULL , HFILL }, - }, - - }; - -/* Setup protocol subtree array */ - static gint *ett[] = { - &ett_generic, - &ett_generic_migratefamilies, - &ett_generic_rateinfo_class, - &ett_generic_rateinfo_group, - &ett_generic_rateinfo_groups, - &ett_generic_rateinfo_classes, - &ett_generic_clientready, - &ett_generic_clientready_item, - &ett_generic_serverready, - &ett_generic_priv_flags, - }; - -/* Register the protocol name and description */ - proto_aim_generic = proto_register_protocol("AIM Generic Service", "AIM Generic", "aim_generic"); - -/* Required function calls to register the header fields and subtrees used */ - proto_register_field_array(proto_aim_generic, hf, array_length(hf)); - proto_register_subtree_array(ett, array_length(ett)); -} - -void -proto_reg_handoff_aim_generic(void) -{ - aim_init_family(proto_aim_generic, ett_generic, FAMILY_GENERIC, aim_fnac_family_generic); -} - -/* - * Editor modelines - http://www.wireshark.org/tools/modelines.html - * - * Local variables: - * c-basic-offset: 4 - * tab-width: 8 - * indent-tabs-mode: nil - * End: - * - * vi: set shiftwidth=4 tabstop=8 expandtab: - * :indentSize=4:tabSize=8:noTabs=true: - */ |