aboutsummaryrefslogtreecommitdiffstats
path: root/packet-gnutella.c
diff options
context:
space:
mode:
Diffstat (limited to 'packet-gnutella.c')
-rw-r--r--packet-gnutella.c761
1 files changed, 0 insertions, 761 deletions
diff --git a/packet-gnutella.c b/packet-gnutella.c
deleted file mode 100644
index a88301eb5d..0000000000
--- a/packet-gnutella.c
+++ /dev/null
@@ -1,761 +0,0 @@
-/* packet-gnutella.c
- * Routines for gnutella dissection
- * Copyright 2001, B. Johannessen <bob@havoq.com>
- *
- * $Id$
- *
- * Ethereal - Network traffic analyzer
- * By Gerald Combs <gerald@ethereal.com>
- * 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 <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-
-#include <glib.h>
-
-
-#include <epan/packet.h>
-#include "packet-gnutella.h"
-
-static int proto_gnutella = -1;
-
-static int hf_gnutella_stream = -1;
-
-static int hf_gnutella_truncated = -1;
-
-static int hf_gnutella_header = -1;
-static int hf_gnutella_header_id = -1;
-static int hf_gnutella_header_payload = -1;
-static int hf_gnutella_header_ttl = -1;
-static int hf_gnutella_header_hops = -1;
-static int hf_gnutella_header_size = -1;
-
-static int hf_gnutella_pong_payload = -1;
-static int hf_gnutella_pong_port = -1;
-static int hf_gnutella_pong_ip = -1;
-static int hf_gnutella_pong_files = -1;
-static int hf_gnutella_pong_kbytes = -1;
-
-static int hf_gnutella_query_payload = -1;
-static int hf_gnutella_query_min_speed = -1;
-static int hf_gnutella_query_search = -1;
-
-static int hf_gnutella_queryhit_payload = -1;
-static int hf_gnutella_queryhit_count = -1;
-static int hf_gnutella_queryhit_port = -1;
-static int hf_gnutella_queryhit_ip = -1;
-static int hf_gnutella_queryhit_speed = -1;
-static int hf_gnutella_queryhit_extra = -1;
-static int hf_gnutella_queryhit_servent_id = -1;
-
-static int hf_gnutella_queryhit_hit = -1;
-static int hf_gnutella_queryhit_hit_index = -1;
-static int hf_gnutella_queryhit_hit_size = -1;
-static int hf_gnutella_queryhit_hit_name = -1;
-static int hf_gnutella_queryhit_hit_extra = -1;
-
-static int hf_gnutella_push_payload = -1;
-static int hf_gnutella_push_servent_id = -1;
-static int hf_gnutella_push_index = -1;
-static int hf_gnutella_push_ip = -1;
-static int hf_gnutella_push_port = -1;
-
-static gint ett_gnutella = -1;
-
-static void dissect_gnutella_pong(tvbuff_t *tvb, guint offset, proto_tree *tree, guint size) {
-
- if(offset + size > tvb_length(tvb)) {
- proto_tree_add_item(tree,
- hf_gnutella_truncated,
- tvb,
- offset,
- size,
- FALSE);
- return;
- }
-
- proto_tree_add_item(tree,
- hf_gnutella_pong_port,
- tvb,
- offset + GNUTELLA_PONG_PORT_OFFSET,
- GNUTELLA_PORT_LENGTH,
- TRUE);
-
- proto_tree_add_item(tree,
- hf_gnutella_pong_ip,
- tvb,
- offset + GNUTELLA_PONG_IP_OFFSET,
- GNUTELLA_IP_LENGTH,
- FALSE);
-
- proto_tree_add_item(tree,
- hf_gnutella_pong_files,
- tvb,
- offset + GNUTELLA_PONG_FILES_OFFSET,
- GNUTELLA_LONG_LENGTH,
- TRUE);
-
- proto_tree_add_item(tree,
- hf_gnutella_pong_kbytes,
- tvb,
- offset + GNUTELLA_PONG_KBYTES_OFFSET,
- GNUTELLA_LONG_LENGTH,
- TRUE);
-
-}
-
-static void dissect_gnutella_query(tvbuff_t *tvb, guint offset, proto_tree *tree, guint size) {
-
- if(offset + size > tvb_length(tvb)) {
- proto_tree_add_item(tree,
- hf_gnutella_truncated,
- tvb,
- offset,
- size,
- FALSE);
- return;
- }
-
- proto_tree_add_item(tree,
- hf_gnutella_query_min_speed,
- tvb,
- offset + GNUTELLA_QUERY_SPEED_OFFSET,
- GNUTELLA_SHORT_LENGTH,
- TRUE);
-
- if (size > GNUTELLA_SHORT_LENGTH) {
- proto_tree_add_item(tree,
- hf_gnutella_query_search,
- tvb,
- offset + GNUTELLA_QUERY_SEARCH_OFFSET,
- size - GNUTELLA_SHORT_LENGTH,
- FALSE);
- }
- else {
- proto_tree_add_text(tree,
- tvb,
- offset + GNUTELLA_QUERY_SEARCH_OFFSET,
- 0,
- "Missing data for Query Search.");
- }
-}
-
-static void dissect_gnutella_queryhit(tvbuff_t *tvb, guint offset, proto_tree *tree, guint size) {
-
- proto_tree *qhi, *hit_tree;
- int hit_count, i;
- int hit_offset;
- int name_length, extra_length;
- int idx_at_offset, size_at_offset;
- int servent_id_at_offset;
- int name_at_offset, extra_at_offset;
- int cur_char, remaining, used;
-
- if(offset + size > tvb_length(tvb)) {
- proto_tree_add_item(tree,
- hf_gnutella_truncated,
- tvb,
- offset,
- size,
- FALSE);
- return;
- }
-
- hit_count = tvb_get_guint8(tvb, offset + GNUTELLA_QUERYHIT_COUNT_OFFSET);
-
- proto_tree_add_uint(tree,
- hf_gnutella_queryhit_count,
- tvb,
- offset + GNUTELLA_QUERYHIT_COUNT_OFFSET,
- GNUTELLA_BYTE_LENGTH,
- hit_count);
-
- proto_tree_add_item(tree,
- hf_gnutella_queryhit_port,
- tvb,
- offset + GNUTELLA_QUERYHIT_PORT_OFFSET,
- GNUTELLA_PORT_LENGTH,
- TRUE);
-
- proto_tree_add_item(tree,
- hf_gnutella_queryhit_ip,
- tvb,
- offset + GNUTELLA_QUERYHIT_IP_OFFSET,
- GNUTELLA_IP_LENGTH,
- FALSE);
-
- proto_tree_add_item(tree,
- hf_gnutella_queryhit_speed,
- tvb,
- offset + GNUTELLA_QUERYHIT_SPEED_OFFSET,
- GNUTELLA_LONG_LENGTH,
- TRUE);
-
- hit_offset = offset + GNUTELLA_QUERYHIT_FIRST_HIT_OFFSET;
-
- for(i = 0; i < hit_count; i++) {
- idx_at_offset = hit_offset;
- size_at_offset = hit_offset + GNUTELLA_QUERYHIT_HIT_SIZE_OFFSET;
-
- hit_offset += (GNUTELLA_LONG_LENGTH * 2);
-
- name_length = 0;
- extra_length = 0;
-
- name_at_offset = hit_offset;
-
- while(hit_offset - offset < size) {
- cur_char = tvb_get_guint8(tvb, hit_offset);
- if(cur_char == '\0')
- break;
-
- hit_offset++;
- name_length++;
- }
-
- hit_offset++;
-
- extra_at_offset = hit_offset;
-
- while(hit_offset - offset < size) {
- cur_char = tvb_get_guint8(tvb, hit_offset);
- if(cur_char == '\0')
- break;
-
- hit_offset++;
- extra_length++;
- }
-
- hit_offset++;
-
- qhi = proto_tree_add_item(tree,
- hf_gnutella_queryhit_hit,
- tvb,
- idx_at_offset,
- (GNUTELLA_LONG_LENGTH * 2) +
- name_length + extra_length +
- GNUTELLA_QUERYHIT_END_OF_STRING_LENGTH,
- FALSE);
-
- hit_tree = proto_item_add_subtree(qhi, ett_gnutella);
-
- proto_tree_add_item(hit_tree,
- hf_gnutella_queryhit_hit_index,
- tvb,
- idx_at_offset,
- GNUTELLA_LONG_LENGTH,
- TRUE);
-
- proto_tree_add_item(hit_tree,
- hf_gnutella_queryhit_hit_size,
- tvb,
- size_at_offset,
- GNUTELLA_LONG_LENGTH,
- TRUE);
-
- proto_tree_add_item(hit_tree,
- hf_gnutella_queryhit_hit_name,
- tvb,
- name_at_offset,
- name_length,
- FALSE);
-
- if(extra_length) {
- proto_tree_add_item(hit_tree,
- hf_gnutella_queryhit_hit_extra,
- tvb,
- extra_at_offset,
- extra_length,
- FALSE);
- }
- }
-
- used = hit_offset - offset;
- remaining = size - used;
-
- if(remaining > GNUTELLA_SERVENT_ID_LENGTH) {
- servent_id_at_offset = hit_offset + remaining - GNUTELLA_SERVENT_ID_LENGTH;
-
- proto_tree_add_item(tree,
- hf_gnutella_queryhit_extra,
- tvb,
- hit_offset,
- servent_id_at_offset - hit_offset,
- FALSE);
- }
- else {
- servent_id_at_offset = hit_offset;
- }
-
- proto_tree_add_item(tree,
- hf_gnutella_queryhit_servent_id,
- tvb,
- servent_id_at_offset,
- GNUTELLA_SERVENT_ID_LENGTH,
- FALSE);
-
-}
-
-static void dissect_gnutella_push(tvbuff_t *tvb, guint offset, proto_tree *tree, guint size) {
-
- if(offset + size > tvb_length(tvb)) {
- proto_tree_add_item(tree,
- hf_gnutella_truncated,
- tvb,
- offset,
- size,
- FALSE);
- return;
- }
-
- proto_tree_add_item(tree,
- hf_gnutella_push_servent_id,
- tvb,
- offset + GNUTELLA_PUSH_SERVENT_ID_OFFSET,
- GNUTELLA_SERVENT_ID_LENGTH,
- FALSE);
-
- proto_tree_add_item(tree,
- hf_gnutella_push_index,
- tvb,
- offset + GNUTELLA_PUSH_INDEX_OFFSET,
- GNUTELLA_LONG_LENGTH,
- TRUE);
-
- proto_tree_add_item(tree,
- hf_gnutella_push_ip,
- tvb,
- offset + GNUTELLA_PUSH_IP_OFFSET,
- GNUTELLA_IP_LENGTH,
- FALSE);
-
- proto_tree_add_item(tree,
- hf_gnutella_push_port,
- tvb,
- offset + GNUTELLA_PUSH_PORT_OFFSET,
- GNUTELLA_PORT_LENGTH,
- TRUE);
-
-}
-
-static void dissect_gnutella(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) {
-
- proto_item *ti, *hi, *pi;
- proto_tree *gnutella_tree, *gnutella_header_tree, *gnutella_pong_tree;
- proto_tree *gnutella_queryhit_tree, *gnutella_push_tree;
- proto_tree *gnutella_query_tree;
- int snap_len, payload_descriptor, offset;
- unsigned int size;
- char *payload_descriptor_text;
-
- if (check_col(pinfo->cinfo, COL_PROTOCOL))
- col_set_str(pinfo->cinfo, COL_PROTOCOL, "Gnutella");
-
- if (check_col(pinfo->cinfo, COL_INFO))
- col_set_str(pinfo->cinfo, COL_INFO, "Gnutella");
-
- snap_len = tvb_length(tvb);
-
- if(snap_len < GNUTELLA_HEADER_LENGTH) {
- if (check_col(pinfo->cinfo, COL_INFO))
- col_append_fstr(pinfo->cinfo, COL_INFO,
- ", %i bytes [INCOMPLETE]", snap_len);
- return;
- }
- else {
- if (check_col(pinfo->cinfo, COL_INFO))
- col_append_fstr(pinfo->cinfo, COL_INFO,
- ", %i bytes", snap_len);
- }
-
- if (tree) {
- ti = proto_tree_add_item(tree,
- proto_gnutella,
- tvb,
- 0,
- -1,
- FALSE);
- gnutella_tree = proto_item_add_subtree(ti, ett_gnutella);
-
- offset = 0;
-
- size = tvb_get_letohl(
- tvb,
- offset + GNUTELLA_HEADER_SIZE_OFFSET);
- if(size > GNUTELLA_MAX_SNAP_SIZE) {
- proto_tree_add_item(gnutella_tree,
- hf_gnutella_stream,
- tvb,
- offset,
- snap_len,
- FALSE);
- return;
- }
-
- while(snap_len - offset >= GNUTELLA_HEADER_LENGTH) {
- payload_descriptor = tvb_get_guint8(
- tvb,
- offset +
- GNUTELLA_HEADER_PAYLOAD_OFFSET);
- size = tvb_get_letohl(
- tvb,
- offset + GNUTELLA_HEADER_SIZE_OFFSET);
-
- switch(payload_descriptor) {
- case GNUTELLA_PING:
- payload_descriptor_text = GNUTELLA_PING_NAME;
- break;
- case GNUTELLA_PONG:
- payload_descriptor_text = GNUTELLA_PONG_NAME;
- break;
- case GNUTELLA_PUSH:
- payload_descriptor_text = GNUTELLA_PUSH_NAME;
- break;
- case GNUTELLA_QUERY:
- payload_descriptor_text = GNUTELLA_QUERY_NAME;
- break;
- case GNUTELLA_QUERYHIT:
- payload_descriptor_text = GNUTELLA_QUERYHIT_NAME;
- break;
- default:
- payload_descriptor_text = GNUTELLA_UNKNOWN_NAME;
- break;
- }
-
- hi = proto_tree_add_item(gnutella_tree,
- hf_gnutella_header,
- tvb,
- offset,
- GNUTELLA_HEADER_LENGTH,
- FALSE);
- gnutella_header_tree = proto_item_add_subtree(hi, ett_gnutella);
-
- proto_tree_add_item(gnutella_header_tree,
- hf_gnutella_header_id,
- tvb,
- offset + GNUTELLA_HEADER_ID_OFFSET,
- GNUTELLA_SERVENT_ID_LENGTH,
- FALSE);
-
- proto_tree_add_uint_format(gnutella_header_tree,
- hf_gnutella_header_payload,
- tvb,
- offset + GNUTELLA_HEADER_PAYLOAD_OFFSET,
- GNUTELLA_BYTE_LENGTH,
- payload_descriptor,
- "Payload: %i (%s)",
- payload_descriptor,
- payload_descriptor_text);
-
- proto_tree_add_item(gnutella_header_tree,
- hf_gnutella_header_ttl,
- tvb,
- offset + GNUTELLA_HEADER_TTL_OFFSET,
- GNUTELLA_BYTE_LENGTH,
- FALSE);
-
- proto_tree_add_item(gnutella_header_tree,
- hf_gnutella_header_hops,
- tvb,
- offset + GNUTELLA_HEADER_HOPS_OFFSET,
- GNUTELLA_BYTE_LENGTH,
- FALSE);
-
- proto_tree_add_uint(gnutella_header_tree,
- hf_gnutella_header_size,
- tvb,
- offset + GNUTELLA_HEADER_SIZE_OFFSET,
- GNUTELLA_LONG_LENGTH,
- size);
-
- if (size > 0) {
-
- switch(payload_descriptor) {
- case GNUTELLA_PONG:
- pi = proto_tree_add_item(
- gnutella_header_tree,
- hf_gnutella_pong_payload,
- tvb,
- offset + GNUTELLA_HEADER_LENGTH,
- size,
- FALSE);
- gnutella_pong_tree = proto_item_add_subtree(
- pi,
- ett_gnutella);
- dissect_gnutella_pong(
- tvb,
- offset + GNUTELLA_HEADER_LENGTH,
- gnutella_pong_tree,
- size);
- break;
- case GNUTELLA_PUSH:
- pi = proto_tree_add_item(
- gnutella_header_tree,
- hf_gnutella_push_payload,
- tvb,
- offset + GNUTELLA_HEADER_LENGTH,
- size,
- FALSE);
- gnutella_push_tree = proto_item_add_subtree(
- pi,
- ett_gnutella);
- dissect_gnutella_push(
- tvb,
- offset + GNUTELLA_HEADER_LENGTH,
- gnutella_push_tree,
- size);
- break;
- case GNUTELLA_QUERY:
- pi = proto_tree_add_item(
- gnutella_header_tree,
- hf_gnutella_query_payload,
- tvb,
- offset + GNUTELLA_HEADER_LENGTH,
- size,
- FALSE);
- gnutella_query_tree = proto_item_add_subtree(
- pi,
- ett_gnutella);
- dissect_gnutella_query(
- tvb,
- offset + GNUTELLA_HEADER_LENGTH,
- gnutella_query_tree,
- size);
- break;
- case GNUTELLA_QUERYHIT:
- pi = proto_tree_add_item(
- gnutella_header_tree,
- hf_gnutella_queryhit_payload,
- tvb,
- offset + GNUTELLA_HEADER_LENGTH,
- size,
- FALSE);
- gnutella_queryhit_tree = proto_item_add_subtree(
- pi,
- ett_gnutella);
- dissect_gnutella_queryhit(
- tvb,
- offset + GNUTELLA_HEADER_LENGTH,
- gnutella_queryhit_tree,
- size);
- break;
- }
- }
-
- offset = offset + GNUTELLA_HEADER_LENGTH + size;
- }
- }
-
-}
-
-
-void proto_register_gnutella(void) {
-
- static hf_register_info hf[] = {
- { &hf_gnutella_header,
- { "Descriptor Header", "gnutella.header",
- FT_NONE, BASE_NONE, NULL, 0,
- "Gnutella Descriptor Header", HFILL }
- },
- { &hf_gnutella_pong_payload,
- { "Pong", "gnutella.pong.payload",
- FT_NONE, BASE_NONE, NULL, 0,
- "Gnutella Pong Payload", HFILL }
- },
- { &hf_gnutella_push_payload,
- { "Push", "gnutella.push.payload",
- FT_NONE, BASE_NONE, NULL, 0,
- "Gnutella Push Payload", HFILL }
- },
- { &hf_gnutella_query_payload,
- { "Query", "gnutella.query.payload",
- FT_NONE, BASE_NONE, NULL, 0,
- "Gnutella Query Payload", HFILL }
- },
- { &hf_gnutella_queryhit_payload,
- { "QueryHit", "gnutella.queryhit.payload",
- FT_NONE, BASE_NONE, NULL, 0,
- "Gnutella QueryHit Payload", HFILL }
- },
- { &hf_gnutella_truncated,
- { "Truncated Frame", "gnutella.truncated",
- FT_NONE, BASE_NONE, NULL, 0,
- "The Gnutella Frame Was Truncated", HFILL }
- },
- { &hf_gnutella_stream,
- { "Gnutella Upload / Download Stream", "gnutella.stream",
- FT_NONE, BASE_NONE, NULL, 0,
- "Gnutella Upload / Download Stream", HFILL }
- },
- { &hf_gnutella_header_id,
- { "ID", "gnutella.header.id",
- FT_BYTES, BASE_HEX, NULL, 0,
- "Gnutella Descriptor ID", HFILL }
- },
- { &hf_gnutella_header_payload,
- { "Payload", "gnutella.header.payload",
- FT_UINT8, BASE_DEC, NULL, 0,
- "Gnutella Descriptor Payload", HFILL }
- },
- { &hf_gnutella_header_ttl,
- { "TTL", "gnutella.header.ttl",
- FT_UINT8, BASE_DEC, NULL, 0,
- "Gnutella Descriptor Time To Live", HFILL }
- },
- { &hf_gnutella_header_hops,
- { "Hops", "gnutella.header.hops",
- FT_UINT8, BASE_DEC, NULL, 0,
- "Gnutella Descriptor Hop Count", HFILL }
- },
- { &hf_gnutella_header_size,
- { "Length", "gnutella.header.size",
- FT_UINT8, BASE_DEC, NULL, 0,
- "Gnutella Descriptor Payload Length", HFILL }
- },
- { &hf_gnutella_pong_port,
- { "Port", "gnutella.pong.port",
- FT_UINT16, BASE_DEC, NULL, 0,
- "Gnutella Pong TCP Port", HFILL }
- },
- { &hf_gnutella_pong_ip,
- { "IP", "gnutella.pong.ip",
- FT_IPv4, BASE_DEC, NULL, 0,
- "Gnutella Pong IP Address", HFILL }
- },
- { &hf_gnutella_pong_files,
- { "Files Shared", "gnutella.pong.files",
- FT_UINT32, BASE_DEC, NULL, 0,
- "Gnutella Pong Files Shared", HFILL }
- },
- { &hf_gnutella_pong_kbytes,
- { "KBytes Shared", "gnutella.pong.kbytes",
- FT_UINT32, BASE_DEC, NULL, 0,
- "Gnutella Pong KBytes Shared", HFILL }
- },
- { &hf_gnutella_query_min_speed,
- { "Min Speed", "gnutella.query.min_speed",
- FT_UINT32, BASE_DEC, NULL, 0,
- "Gnutella Query Minimum Speed", HFILL }
- },
- { &hf_gnutella_query_search,
- { "Search", "gnutella.query.search",
- FT_STRINGZ, BASE_NONE, NULL, 0,
- "Gnutella Query Search", HFILL }
- },
- { &hf_gnutella_queryhit_hit,
- { "Hit", "gnutella.queryhit.hit",
- FT_NONE, BASE_NONE, NULL, 0,
- "Gnutella QueryHit", HFILL }
- },
- { &hf_gnutella_queryhit_hit_index,
- { "Index", "gnutella.queryhit.hit.index",
- FT_UINT32, BASE_DEC, NULL, 0,
- "Gnutella QueryHit Index", HFILL }
- },
- { &hf_gnutella_queryhit_hit_size,
- { "Size", "gnutella.queryhit.hit.size",
- FT_UINT32, BASE_DEC, NULL, 0,
- "Gnutella QueryHit Size", HFILL }
- },
- { &hf_gnutella_queryhit_hit_name,
- { "Name", "gnutella.queryhit.hit.name",
- FT_STRING, BASE_NONE, NULL, 0,
- "Gnutella Query Name", HFILL }
- },
- { &hf_gnutella_queryhit_hit_extra,
- { "Extra", "gnutella.queryhit.hit.extra",
- FT_BYTES, BASE_HEX, NULL, 0,
- "Gnutella Query Extra", HFILL }
- },
- { &hf_gnutella_queryhit_count,
- { "Count", "gnutella.queryhit.count",
- FT_UINT8, BASE_DEC, NULL, 0,
- "Gnutella QueryHit Count", HFILL }
- },
- { &hf_gnutella_queryhit_port,
- { "Port", "gnutella.queryhit.port",
- FT_UINT16, BASE_DEC, NULL, 0,
- "Gnutella QueryHit Port", HFILL }
- },
- { &hf_gnutella_queryhit_ip,
- { "IP", "gnutella.queryhit.ip",
- FT_IPv4, BASE_DEC, NULL, 0,
- "Gnutella QueryHit IP Address", HFILL }
- },
- { &hf_gnutella_queryhit_speed,
- { "Speed", "gnutella.queryhit.speed",
- FT_UINT32, BASE_DEC, NULL, 0,
- "Gnutella QueryHit Speed", HFILL }
- },
- { &hf_gnutella_queryhit_extra,
- { "Extra", "gnutella.queryhit.extra",
- FT_BYTES, BASE_HEX, NULL, 0,
- "Gnutella QueryHit Extra", HFILL }
- },
- { &hf_gnutella_queryhit_servent_id,
- { "Servent ID", "gnutella.queryhit.servent_id",
- FT_BYTES, BASE_HEX, NULL, 0,
- "Gnutella QueryHit Servent ID", HFILL }
- },
- { &hf_gnutella_push_servent_id,
- { "Servent ID", "gnutella.push.servent_id",
- FT_BYTES, BASE_HEX, NULL, 0,
- "Gnutella Push Servent ID", HFILL }
- },
- { &hf_gnutella_push_ip,
- { "IP", "gnutella.push.ip",
- FT_IPv4, BASE_DEC, NULL, 0,
- "Gnutella Push IP Address", HFILL }
- },
- { &hf_gnutella_push_index,
- { "Index", "gnutella.push.index",
- FT_UINT32, BASE_DEC, NULL, 0,
- "Gnutella Push Index", HFILL }
- },
- { &hf_gnutella_push_port,
- { "Port", "gnutella.push.port",
- FT_UINT16, BASE_DEC, NULL, 0,
- "Gnutella Push Port", HFILL }
- },
- };
-
- static gint *ett[] = {
- &ett_gnutella,
- };
-
- proto_gnutella = proto_register_protocol("Gnutella Protocol",
- "GNUTELLA",
- "gnutella");
-
- proto_register_field_array(proto_gnutella, hf, array_length(hf));
-
- proto_register_subtree_array(ett, array_length(ett));
-}
-
-void proto_reg_handoff_gnutella(void) {
- dissector_handle_t gnutella_handle;
-
- gnutella_handle = create_dissector_handle(dissect_gnutella,
- proto_gnutella);
- dissector_add("tcp.port", GNUTELLA_TCP_PORT, gnutella_handle);
-}