Preparations for dropping the old plugin api.
[obnox/wireshark/wip.git] / plugins / pcli / packet-pcli.c
1 /* packet-pcli.c
2  * Routines for Packet Cable Lawful Intercept packet disassembly
3  * Packet Cable Lawful Intercept is detailed at
4  * http://www.packetcable.com/downloads/specs/pkt-sp-esp-I01-991229.pdf
5  * Chapter 4 ( Call Content Connection Interface )
6  *
7  * $Id$
8  *
9  * Copyright (c) 2000 by Ed Warnicke <hagbard@physics.rutgers.edu>
10  *
11  * Ethereal - Network traffic analyzer
12  * By Gerald Combs <gerald@ethereal.com>
13  * Copyright 1999 Gerald Combs
14  *
15  * This program is free software; you can redistribute it and/or
16  * modify it under the terms of the GNU General Public License
17  * as published by the Free Software Foundation; either version 2
18  * of the License, or (at your option) any later version.
19  *
20  * This program is distributed in the hope that it will be useful,
21  * but WITHOUT ANY WARRANTY; without even the implied warranty of
22  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23  * GNU General Public License for more details.
24  *
25  * You should have received a copy of the GNU General Public License
26  * along with this program; if not, write to the Free Software
27  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
28  */
29
30 /* Include files */
31
32 #ifdef HAVE_CONFIG_H
33 #include "config.h"
34 #endif
35 #include "moduleinfo.h"
36
37 #include <stdio.h>
38 #include <stdlib.h>
39 #include <gmodule.h>
40 #include <ctype.h>
41 #include <time.h>
42 #include <string.h>
43 #include <epan/packet.h>
44 #include <epan/addr_resolv.h>
45 #include <epan/prefs.h>
46 #include <epan/strutil.h>
47
48 /* Define version if we are not building ethereal statically */
49
50 #ifndef ENABLE_STATIC
51 G_MODULE_EXPORT const gchar version[] = VERSION;
52 #endif
53
54 /* Define udp_port for lawful intercept */
55
56 #define UDP_PORT_PCLI 9000
57
58 void proto_reg_handoff_pcli(void);
59
60 /* Define the pcli proto */
61
62 static int proto_pcli = -1;
63
64 /* Define headers for pcli */
65
66 static int hf_pcli_cccid = -1;
67
68 /* Define the tree for pcli */
69
70 static int ett_pcli = -1;
71
72 /* 
73  * Here are the global variables associated with the preferences
74  * for pcli
75  */
76
77 static guint global_udp_port_pcli = UDP_PORT_PCLI;
78 static guint udp_port_pcli = UDP_PORT_PCLI;
79
80 /* A static handle for the ip dissector */
81 static dissector_handle_t ip_handle;
82
83 static void 
84 dissect_pcli(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) {
85   
86   guint32 cccid;
87   proto_tree *ti,*pcli_tree;
88   tvbuff_t * next_tvb;
89
90   /* Set the protocol column */
91   if(check_col(pinfo->cinfo,COL_PROTOCOL)){
92     col_add_str(pinfo->cinfo,COL_PROTOCOL,"PCLI");
93   }
94
95   /* Get the CCCID */
96   cccid = tvb_get_ntohl(tvb,0);
97
98   /* Set the info column */
99   if(check_col(pinfo->cinfo,COL_INFO)){
100     col_add_fstr(pinfo->cinfo, COL_INFO, "CCCID: %u",cccid);
101   }
102
103   /* 
104    *If we have a non-null tree (ie we are building the proto_tree
105    * instead of just filling out the columns ), then add a PLCI
106    * tree node and put a CCCID header element under it.
107    */
108   if(tree) {
109     ti = proto_tree_add_item(tree,proto_pcli,tvb,0,0,FALSE);
110     pcli_tree = proto_item_add_subtree(ti,ett_pcli);
111     proto_tree_add_uint(pcli_tree,hf_pcli_cccid,tvb,
112                         0,4,cccid);
113   }
114
115   /*
116    * Hand off to the IP dissector.
117    */
118   next_tvb = tvb_new_subset(tvb,4,-1,-1);
119   call_dissector(ip_handle,next_tvb,pinfo,tree);
120 }
121
122 void 
123 proto_register_pcli(void) {
124   static hf_register_info hf[] = {
125     { &hf_pcli_cccid,
126       { "CCCID", "pcli.cccid", FT_UINT32, BASE_DEC, NULL, 0x0,
127         "Call Content Connection Identifier", HFILL }},
128   };
129
130   static gint *ett[] = {
131     &ett_pcli,
132   };
133
134   module_t *pcli_module;
135
136   proto_pcli = proto_register_protocol("Packet Cable Lawful Intercept",
137                                        "PCLI","pcli");
138   proto_register_field_array(proto_pcli,hf,array_length(hf));
139   proto_register_subtree_array(ett,array_length(ett));
140
141   pcli_module = prefs_register_protocol(proto_pcli,
142                                         proto_reg_handoff_pcli);
143   prefs_register_uint_preference(pcli_module, "udp_port",
144                                  "PCLI UDP Port",
145                                  "The UDP port on which "
146                                  "Packet Cable Lawful Intercept "
147                                  "packets will be sent",
148                                  10,&global_udp_port_pcli);
149
150 }
151
152 /* The registration hand-off routing */
153
154 void
155 proto_reg_handoff_pcli(void) {
156   static int pcli_initialized = FALSE;
157   static dissector_handle_t pcli_handle;
158
159   ip_handle = find_dissector("ip");
160
161   if(!pcli_initialized) {
162     pcli_handle = create_dissector_handle(dissect_pcli,proto_pcli);
163     pcli_initialized = TRUE;
164   } else {
165     dissector_delete("udp.port",udp_port_pcli,pcli_handle);
166   }
167
168   udp_port_pcli = global_udp_port_pcli;
169   
170   dissector_add("udp.port",global_udp_port_pcli,pcli_handle);
171 }
172
173 /* Start the functions we need for the plugin stuff */
174
175 #ifndef ENABLE_STATIC
176
177 G_MODULE_EXPORT void
178 plugin_reg_handoff(void){
179   proto_reg_handoff_pcli();
180 }
181
182 G_MODULE_EXPORT void
183 new_plugin_init(void)
184 {
185   /* register the new protocol, protocol fields, and subtrees */
186   if (proto_pcli == -1) { /* execute protocol initialization only once */
187     proto_register_pcli();
188   }
189 }
190
191 #endif
192
193 /* End the functions we need for plugin stuff */
194