2 * Routines for DDTP (Dynamic DNS Tools Protocol) packet disassembly
3 * see http://ddt.sourceforge.net/
4 * Olivier Abad <oabad@cybercable.fr>
6 * $Id: packet-ddtp.c,v 1.16 2001/06/18 02:17:45 guy Exp $
8 * Ethereal - Network traffic analyzer
9 * By Gerald Combs <gerald@zing.org>
13 * This program is free software; you can redistribute it and/or
14 * modify it under the terms of the GNU General Public License
15 * as published by the Free Software Foundation; either version 2
16 * of the License, or (at your option) any later version.
18 * This program is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU General Public License for more details.
23 * You should have received a copy of the GNU General Public License
24 * along with this program; if not, write to the Free Software
25 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
33 #ifdef HAVE_SYS_TYPES_H
34 #include <sys/types.h>
42 #ifdef HAVE_NETINET_IN_H
43 # include <netinet/in.h>
46 #include "packet-ddtp.h"
48 static int proto_ddtp = -1;
49 static int hf_ddtp_version = -1;
50 static int hf_ddtp_encrypt = -1;
51 static int hf_ddtp_hostid = -1;
52 static int hf_ddtp_msgtype = -1;
53 static int hf_ddtp_opcode = -1;
54 static int hf_ddtp_ipaddr = -1;
55 static int hf_ddtp_status = -1;
57 static int ett_ddtp = -1;
59 #define UDP_PORT_DDTP 1052
61 static const value_string vals_ddtp_version[] = {
62 { DDTP_VERSION_ERROR, "Protocol Error" },
63 { DDTP_VERSION_4, "4" },
64 { DDTP_VERSION_5, "5" },
68 static const value_string vals_ddtp_encrypt[] = {
69 { DDTP_ENCRYPT_ERROR, "Encryption Error" },
70 { DDTP_ENCRYPT_PLAINTEXT, "Plain text" },
71 { DDTP_ENCRYPT_BLOWFISH, "Blowfish" },
75 static const value_string vals_ddtp_msgtype[] = {
76 { DDTP_MESSAGE_ERROR, "Message Error" },
77 { DDTP_UPDATE_QUERY, "Update Query" },
78 { DDTP_UPDATE_REPLY, "Update Reply" },
79 { DDTP_ALIVE_QUERY, "Alive Query" },
80 { DDTP_ALIVE_REPLY, "Alive Reply" },
84 static const value_string vals_ddtp_opcode[] = {
85 { DDTP_MARK_ONLINE, "Mark online" },
86 { DDTP_MARK_OFFLINE, "Mark offline" },
90 static const value_string vals_ddtp_status[] = {
91 { DDTP_UPDATE_SUCCEEDED, "Update succeeded" },
92 { DDTP_UPDATE_FAILED, "Update failed" },
93 { DDTP_INVALID_PASSWORD, "Invalid password" },
94 { DDTP_INVALID_ACCOUNT, "Invalid account" },
95 { DDTP_INVALID_OPCODE, "Invalid opcode" },
100 dissect_ddtp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
102 proto_tree *ddtp_tree = NULL;
105 if (check_col(pinfo->fd, COL_PROTOCOL)) {
106 /* Indicate what kind of message this is. */
107 col_set_str (pinfo->fd, COL_PROTOCOL, "DDTP");
109 if (check_col(pinfo->fd, COL_INFO)) {
110 /* In case we throw an exception below. */
111 col_clear (pinfo->fd, COL_INFO);
114 ti = proto_tree_add_item(tree, proto_ddtp, tvb, 0,
115 tvb_length(tvb), FALSE);
116 ddtp_tree = proto_item_add_subtree(ti, ett_ddtp);
118 proto_tree_add_item(ddtp_tree, hf_ddtp_version, tvb, 0, 4, FALSE);
119 proto_tree_add_item(ddtp_tree, hf_ddtp_encrypt, tvb, 4, 4, FALSE);
120 proto_tree_add_item(ddtp_tree, hf_ddtp_hostid, tvb, 8, 4, FALSE);
122 if (tvb_get_ntohl(tvb, 4) == DDTP_ENCRYPT_PLAINTEXT) {
124 proto_tree_add_item(ddtp_tree, hf_ddtp_msgtype, tvb, 12, 4, FALSE);
125 switch (tvb_get_ntohl(tvb, 12)) {
126 case DDTP_MESSAGE_ERROR :
127 if (check_col(pinfo->fd, COL_INFO))
128 col_set_str (pinfo->fd, COL_INFO, "Message Error");
130 case DDTP_UPDATE_QUERY :
131 if (check_col(pinfo->fd, COL_INFO))
132 col_set_str (pinfo->fd, COL_INFO, "Update Query");
134 proto_tree_add_item(ddtp_tree, hf_ddtp_opcode, tvb, 16, 4,
136 proto_tree_add_item(ddtp_tree, hf_ddtp_ipaddr, tvb, 20, 4,
140 case DDTP_UPDATE_REPLY :
141 if (check_col(pinfo->fd, COL_INFO))
142 col_set_str (pinfo->fd, COL_INFO, "Update Reply");
144 proto_tree_add_item(ddtp_tree, hf_ddtp_status, tvb, 16, 4,
148 case DDTP_ALIVE_QUERY :
149 if (check_col(pinfo->fd, COL_INFO))
150 col_set_str (pinfo->fd, COL_INFO, "Alive Query");
152 proto_tree_add_text(ddtp_tree, tvb, 16, 4, "Dummy : %u",
153 tvb_get_ntohl(tvb, 16));
156 case DDTP_ALIVE_REPLY :
157 if (check_col(pinfo->fd, COL_INFO))
158 col_set_str (pinfo->fd, COL_INFO, "Alive Reply");
160 proto_tree_add_text(ddtp_tree, tvb, 16, 4, "Dummy : %u",
161 tvb_get_ntohl(tvb, 16));
165 if (check_col(pinfo->fd, COL_INFO))
166 col_set_str (pinfo->fd, COL_INFO, "Unknown type");
168 proto_tree_add_text(ddtp_tree, tvb, 12, 4, "Unknown type : %u",
169 tvb_get_ntohl(tvb, 12));
173 if (check_col(pinfo->fd, COL_INFO))
174 col_set_str (pinfo->fd, COL_INFO, "Encrypted payload");
179 proto_register_ddtp(void)
181 static hf_register_info hf_ddtp[] = {
183 { "Version", "ddtp.version", FT_UINT32, BASE_DEC, VALS(vals_ddtp_version), 0x0,
186 { "Encryption", "ddtp.encrypt", FT_UINT32, BASE_DEC, VALS(vals_ddtp_encrypt), 0x0,
187 "Encryption type", HFILL }},
189 { "Hostid", "ddtp.hostid", FT_UINT32, BASE_DEC, NULL, 0x0,
192 { "Message type", "ddtp.msgtype", FT_UINT32, BASE_DEC, VALS(vals_ddtp_msgtype), 0x0,
193 "Message Type", HFILL }},
195 { "Opcode", "ddtp.opcode", FT_UINT32, BASE_DEC, VALS(vals_ddtp_opcode), 0x0,
196 "Update query opcode", HFILL }},
198 { "IP address", "ddtp.ipaddr", FT_IPv4, BASE_NONE, NULL, 0x0,
199 "IP address", HFILL }},
201 { "Status", "ddtp.status", FT_UINT32, BASE_DEC, VALS(vals_ddtp_status), 0x0,
202 "Update reply status", HFILL }}
205 static gint *ett[] = { &ett_ddtp };
207 proto_ddtp = proto_register_protocol("Dynamic DNS Tools Protocol",
209 proto_register_field_array(proto_ddtp, hf_ddtp, array_length(hf_ddtp));
210 proto_register_subtree_array(ett, array_length(ett));
214 proto_reg_handoff_ddtp(void)
216 dissector_add("udp.port", UDP_PORT_DDTP, dissect_ddtp, proto_ddtp);