aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuy Harris <guy@alum.mit.edu>2003-04-25 21:09:37 +0000
committerGuy Harris <guy@alum.mit.edu>2003-04-25 21:09:37 +0000
commitbef46400dfc9cc8f7a9e060b86eb6a90d78d359c (patch)
treedcc77e458ae7b00575bb291eb35ff42773c551cd
parentc1b7eb399ae59968f61b4696f3c786e3215a5aa4 (diff)
From Tony Schene: initial stub Kerberos kadmin support.
svn path=/trunk/; revision=7562
-rw-r--r--AUTHORS4
-rw-r--r--Makefile.am3
-rw-r--r--Makefile.nmake3
-rw-r--r--doc/ethereal.pod.template1
-rw-r--r--packet-kadm5.c146
5 files changed, 155 insertions, 2 deletions
diff --git a/AUTHORS b/AUTHORS
index 292159a2c8..fdc699c17f 100644
--- a/AUTHORS
+++ b/AUTHORS
@@ -1678,6 +1678,10 @@ Duncan Laurie <duncan [AT] sun.com> {
IPMI-over-LAN support (IPMI, RMCP, partial ASF)
}
+Tony Schene <Schene_Tony [AT] emc.com> {
+ Initial stub Kerberos kadmin support
+}
+
And assorted fixes and enhancements by the people listed above and by:
Pavel Roskin <proski [AT] gnu.org>
diff --git a/Makefile.am b/Makefile.am
index 17cd47e87b..8a7d40c044 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -1,7 +1,7 @@
# Makefile.am
# Automake file for Ethereal
#
-# $Id: Makefile.am,v 1.576 2003/04/23 00:24:36 guy Exp $
+# $Id: Makefile.am,v 1.577 2003/04/25 21:09:34 guy Exp $
#
# Ethereal - Network traffic analyzer
# By Gerald Combs <gerald@ethereal.com>
@@ -247,6 +247,7 @@ DISSECTOR_SRC = \
packet-isl.c \
packet-isup.c \
packet-iua.c \
+ packet-kadm5.c \
packet-kerberos.c \
packet-klm.c \
packet-l2tp.c \
diff --git a/Makefile.nmake b/Makefile.nmake
index 503bdf4499..359840beef 100644
--- a/Makefile.nmake
+++ b/Makefile.nmake
@@ -1,7 +1,7 @@
## Makefile for building ethereal.exe with Microsoft C and nmake
## Use: $(MAKE) /$(MAKEFLAGS) -f makefile.nmake
#
-# $Id: Makefile.nmake,v 1.294 2003/04/23 00:24:36 guy Exp $
+# $Id: Makefile.nmake,v 1.295 2003/04/25 21:09:34 guy Exp $
include config.nmake
include <win32.mak>
@@ -189,6 +189,7 @@ DISSECTOR_SRC = \
packet-isl.c \
packet-isup.c \
packet-iua.c \
+ packet-kadm5.c \
packet-kerberos.c \
packet-klm.c \
packet-l2tp.c \
diff --git a/doc/ethereal.pod.template b/doc/ethereal.pod.template
index e832b7590e..a3c05778e9 100644
--- a/doc/ethereal.pod.template
+++ b/doc/ethereal.pod.template
@@ -1729,6 +1729,7 @@ B<http://www.ethereal.com>.
Stephen Shelley <steve.shelley [AT] attbi.com>
Erwin Rol <erwin [AT] muffin.org>
Duncan Laurie <duncan [AT] sun.com>
+ Tony Schene <Schene_Tony [AT] emc.com>
Pavel Roskin <proski [AT] gnu.org>
Georgi Guninski <guninski [AT] guninski.com>
Jason Copenhaver <jcopenha [AT] typedef.org>
diff --git a/packet-kadm5.c b/packet-kadm5.c
new file mode 100644
index 0000000000..f77dc7e3ad
--- /dev/null
+++ b/packet-kadm5.c
@@ -0,0 +1,146 @@
+/* packet-kadm5.c
+ * Routines for kadm5 dissection
+ *
+ * $Id: packet-kadm5.c,v 1.1 2003/04/25 21:09:35 guy Exp $
+ *
+ * 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.
+ */
+
+/*
+ * The kadm5 RPC protocol is used to administer Kerberos principals
+ * and policies. It is not officially documented anywhere. The
+ * information for this dissector came from the MIT kadmin source.
+ */
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include "packet-rpc.h"
+
+#define KADM5_PROGRAM 2112
+#define KADM5PROC_NULL 0
+#define KADM5PROC_CREATE_PRINCIPAL 1
+#define KADM5PROC_DELETE_PRINCIPAL 2
+#define KADM5PROC_MODIFY_PRINCIPAL 3
+#define KADM5PROC_RENAME_PRINCIPAL 4
+#define KADM5PROC_GET_PRINCIPAL 5
+#define KADM5PROC_CHPASS_PRINCIPAL 6
+#define KADM5PROC_CHRAND_PRINCIPAL 7
+#define KADM5PROC_CREATE_POLICY 8
+#define KADM5PROC_DELETE_POLICY 9
+#define KADM5PROC_MODIFY_POLICY 10
+#define KADM5PROC_GET_POLICY 11
+#define KADM5PROC_GET_PRIVS 12
+#define KADM5PROC_INIT 13
+#define KADM5PROC_GET_PRINCS 14
+#define KADM5PROC_GET_POLS 15
+#define KADM5PROC_SETKEY_PRINCIPAL 16
+#define KADM5PROC_SETV4KEY_PRINCIPAL 17
+#define KADM5PROC_CREATE_PRINCIPAL3 18
+#define KADM5PROC_CHPASS_PRINCIPAL3 19
+#define KADM5PROC_CHRAND_PRINCIPAL3 20
+#define KADM5PROC_SETKEY_PRINCIPAL3 21
+
+static int proto_kadm5 = -1;
+static int hf_kadm5_procedure_v2 = -1;
+static gint ett_kadm5 = -1;
+
+/* proc number, "proc name", dissect_request, dissect_reply */
+/* NULL as function pointer means: type of arguments is "void". */
+static const vsff kadm5_v2_proc[] = {
+ { KADM5PROC_NULL, "NULL", NULL, NULL },
+ { KADM5PROC_CREATE_PRINCIPAL, "CREATE_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_DELETE_PRINCIPAL, "DELETE_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_MODIFY_PRINCIPAL, "MODIFY_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_RENAME_PRINCIPAL, "RENAME_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_GET_PRINCIPAL, "GET_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_CHPASS_PRINCIPAL, "CHPASS_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_CHRAND_PRINCIPAL, "CHRAND_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_CREATE_POLICY, "CREATE_POLICY", NULL, NULL },
+ { KADM5PROC_DELETE_POLICY, "DELETE_POLICY", NULL, NULL },
+ { KADM5PROC_MODIFY_POLICY, "MODIFY_POLICY", NULL, NULL },
+ { KADM5PROC_GET_POLICY, "GET_POLICY", NULL, NULL },
+ { KADM5PROC_GET_PRIVS, "GET_PRIVS", NULL, NULL },
+ { KADM5PROC_INIT, "INIT", NULL, NULL },
+ { KADM5PROC_GET_PRINCS, "GET_PRINCS", NULL, NULL },
+ { KADM5PROC_GET_POLS, "GET_POLS", NULL, NULL },
+ { KADM5PROC_SETKEY_PRINCIPAL, "SETKEY_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_SETV4KEY_PRINCIPAL, "SETV4KEY_PRINCIPAL", NULL, NULL },
+ { KADM5PROC_CREATE_PRINCIPAL3, "CREATE_PRINCIPAL3", NULL, NULL },
+ { KADM5PROC_CHPASS_PRINCIPAL3, "CHPASS_PRINCIPAL3", NULL, NULL },
+ { KADM5PROC_CHRAND_PRINCIPAL3, "CHRAND_PRINCIPAL3", NULL, NULL },
+ { KADM5PROC_SETKEY_PRINCIPAL3, "SETKEY_PRINCIPAL3", NULL, NULL },
+ { 0, NULL, NULL, NULL }
+};
+
+static const value_string kadm5_v2_proc_vals[] = {
+ { KADM5PROC_NULL, "NULL" },
+ { KADM5PROC_CREATE_PRINCIPAL, "CREATE_PRINCIPAL" },
+ { KADM5PROC_DELETE_PRINCIPAL, "DELETE_PRINCIPAL" },
+ { KADM5PROC_MODIFY_PRINCIPAL, "MODIFY_PRINCIPAL" },
+ { KADM5PROC_RENAME_PRINCIPAL, "RENAME_PRINCIPAL" },
+ { KADM5PROC_GET_PRINCIPAL, "GET_PRINCIPAL" },
+ { KADM5PROC_CHPASS_PRINCIPAL, "CHPASS_PRINCIPAL" },
+ { KADM5PROC_CHRAND_PRINCIPAL, "CHRAND_PRINCIPAL" },
+ { KADM5PROC_CREATE_POLICY, "CREATE_POLICY" },
+ { KADM5PROC_DELETE_POLICY, "DELETE_POLICY" },
+ { KADM5PROC_MODIFY_POLICY, "MODIFY_POLICY" },
+ { KADM5PROC_GET_POLICY, "GET_POLICY" },
+ { KADM5PROC_GET_PRIVS, "GET_PRIVS" },
+ { KADM5PROC_INIT, "INIT" },
+ { KADM5PROC_GET_PRINCS, "GET_PRINCS" },
+ { KADM5PROC_GET_POLS, "GET_POLS" },
+ { KADM5PROC_SETKEY_PRINCIPAL, "SETKEY_PRINCIPAL" },
+ { KADM5PROC_SETV4KEY_PRINCIPAL, "SETV4KEY_PRINCIPAL" },
+ { KADM5PROC_CREATE_PRINCIPAL3, "CREATE_PRINCIPAL3" },
+ { KADM5PROC_CHPASS_PRINCIPAL3, "CHPASS_PRINCIPAL3" },
+ { KADM5PROC_CHRAND_PRINCIPAL3, "CHRAND_PRINCIPAL3" },
+ { KADM5PROC_SETKEY_PRINCIPAL3, "SETKEY_PRINCIPAL3" },
+ { 0, NULL }
+};
+
+void
+proto_register_kadm5(void)
+{
+ static hf_register_info hf[] = {
+ { &hf_kadm5_procedure_v2, {
+ "V2 Procedure", "kadm5.procedure_v2", FT_UINT32, BASE_DEC,
+ VALS(kadm5_v2_proc_vals), 0, "V2 Procedure", HFILL }},
+ };
+
+ static gint *ett[] = {
+ &ett_kadm5,
+ };
+
+ proto_kadm5 = proto_register_protocol("Kerberos Administration",
+ "KADM5", "kadm5");
+ proto_register_field_array(proto_kadm5, hf, array_length(hf));
+ proto_register_subtree_array(ett, array_length(ett));
+}
+
+void
+proto_reg_handoff_kadm5(void)
+{
+ /* Register the protocol as RPC */
+ rpc_init_prog(proto_kadm5, KADM5_PROGRAM, ett_kadm5);
+ /* Register the procedure tables */
+ rpc_init_proc_table(KADM5_PROGRAM, 2, kadm5_v2_proc,
+ hf_kadm5_procedure_v2);
+}