Ethereal-dev: [Ethereal-dev] drsuapi dissector

Note: This archive is from the project's previous web site, ethereal.com. This list is no longer active.

From: Jean-Baptiste Marchand <jbm@xxxxxx>
Date: Thu, 18 Sep 2003 16:30:06 +0200
Hello,

attached to this email is a dissector for the drsuapi MSRPC interface,
used in Active Directory domains.

The dissector only contains operations names, because, as far as I know,
stub data for operations in this interface is always encrypted.

Jean-Baptiste Marchand
-- 
Jean-Baptiste.Marchand@xxxxxx
HSC - http://www.hsc.fr/
/* packet-dcerpc-drsuapi.c
 * Routines for the drsuapi (Directory Replication Service) MSRPC interface 
 * Copyright 2003 Jean-Baptiste Marchand <jbm@xxxxxx>
 *
 * $Id$
 *
 * Ethereal - Network traffic analyzer
 * By Gerald Combs <gerald@xxxxxxxxxxxx>
 * 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 <glib.h>
#include <epan/packet.h>
#include "packet-dcerpc.h"
#include "packet-dcerpc-drsuapi.h"

static int proto_dcerpc_drsuapi = -1;

static int hf_drsuapi_opnum = 0;

static gint ett_dcerpc_drsuapi = -1;

/* 
IDL [ uuid(e3514235-4b06-11d1-ab04-00c04fc2dcd2),
IDL  version(4.0),
IDL  implicit_handle(handle_t rpc_binding)
IDL ] interface drsuapi
*/

static e_uuid_t uuid_dcerpc_drsuapi = {
	0xe3514235, 0x4b06, 0x11d1,
	{ 0xab, 0x04, 0x00, 0xc0, 0x4f, 0xc2, 0xdc, 0xd2 }
};

static guint16 ver_dcerpc_drsuapi = 4; 


static dcerpc_sub_dissector dcerpc_drsuapi_dissectors[] = {
	{ DRSUAPI_BIND, "DRSBind", NULL, NULL},
	{ DRSUAPI_UNBIND, "DRSUnbind", NULL, NULL},
	{ DRSUAPI_REPLICA_SYNC, "DRSReplicaSync", NULL, NULL},
	{ DRSUAPI_GET_NC_CHANGES, "DRSGetNCChanges", NULL, NULL},
	{ DRSUAPI_UPDATE_REFS, "DRSUpdateRefs", NULL, NULL},
	{ DRSUAPI_REPLICA_ADD, "DRSReplicaAdd", NULL, NULL},
	{ DRSUAPI_REPLICA_DEL, "DRSReplicaDel", NULL, NULL},
	{ DRSUAPI_REPLICA_MODIFY, "DRSReplicaModify", NULL, NULL},
	{ DRSUAPI_VERIFY_NAMES, "DRSVerifyNames", NULL, NULL},
	{ DRSUAPI_GET_MEMBERSHIPS, "DRSGetMemberships", NULL, NULL},
	{ DRSUAPI_INTER_DOMAIN_MOVE, "DRSInterDomainMove", NULL, NULL},
	{ DRSUAPI_GET_NT4_CHANGELOG, "DRSGetNT4ChangeLog", NULL, NULL},
	{ DRSUAPI_CRACKNAMES, "DRSCrackNames", NULL, NULL},	
	{ DRSUAPI_WRITE_SPN, "DRSWriteSPN", NULL, NULL},
	{ DRSUAPI_REMOVE_DS_SERVER, "DRSRemoveDsServer", NULL, NULL},
	{ DRSUAPI_REMOVE_DS_DOMAIN, "DRSRemoveDsDomain", NULL, NULL},
	{ DRSUAPI_DOMAIN_CONTROLLER_INFO, "DRSDomainControllerInfo", NULL, NULL},
	{ DRSUAPI_ADD_ENTRY, "DRSAddEntry", NULL, NULL},
	{ DRSUAPI_EXECUTE_KCC, "DRSExecuteKCC", NULL, NULL},
	{ DRSUAPI_GET_REPL_INFO, "DRSGetReplInfo", NULL, NULL},
	{ DRSUAPI_ADD_SID_HISTORY, "DRSAddSidHistory", NULL, NULL},
	{ DRSUAPI_GET_MEMBERSHIPS2, "DRSGetMemberships2", NULL, NULL},
	{ DRSUAPI_REPLICA_VERIFY_OBJECTS, "DRSReplicaVerifyObjects", NULL, NULL},
	{ DRSUAPI_GET_OBJECT_EXISTENCE, "DRSGetObjectExistence", NULL, NULL},
	{ DRSUAPI_QUERY_SITES_BY_COST, "DRSQuerySitesByCost", NULL, NULL},
        { 0, NULL, NULL,  NULL }
};


void
proto_register_dcerpc_drsuapi(void)
{

        static hf_register_info hf[] = {

		{ &hf_drsuapi_opnum, 
		  { "Operation", "drsuapi.opnum", FT_UINT16, BASE_DEC,
		   NULL, 0x0, "Operation", HFILL }},	
	};


        static gint *ett[] = {
                &ett_dcerpc_drsuapi,
        };


	proto_dcerpc_drsuapi = proto_register_protocol(
		"Microsoft Directory Replication Service", "DRSUAPI", "drsuapi");

	proto_register_field_array(proto_dcerpc_drsuapi, hf, array_length(hf));

        proto_register_subtree_array(ett, array_length(ett));

}


void
proto_reg_handoff_dcerpc_drsuapi(void)
{
	/* register protocol as dcerpc */

	dcerpc_init_uuid(
		proto_dcerpc_drsuapi, ett_dcerpc_drsuapi, &uuid_dcerpc_drsuapi,
		ver_dcerpc_drsuapi, dcerpc_drsuapi_dissectors, hf_drsuapi_opnum);
}
/* packet-dcerpc-drsuapi.h
 * Routines for the drsuapi (Directory Replication Service) MSRPC interface 
 * Copyright 2003 Jean-Baptiste Marchand <jbm@xxxxxx>
 *
 * $Id$
 *
 * Ethereal - Network traffic analyzer
 * By Gerald Combs <gerald@xxxxxxxxxxxx>
 * 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.
 */

#ifndef __PACKET_DCERPC_DRSUAPI_H
#define __PACKET_DCERPC_DRSUAPI_H

/* MSRPC functions available in the drsuapi interface */

#define DRSUAPI_BIND 			0x00
#define DRSUAPI_UNBIND			0x01
#define DRSUAPI_REPLICA_SYNC		0x02
#define DRSUAPI_GET_NC_CHANGES		0x03
#define DRSUAPI_UPDATE_REFS 		0x04
#define DRSUAPI_REPLICA_ADD		0x05	
#define DRSUAPI_REPLICA_DEL		0x06
#define DRSUAPI_REPLICA_MODIFY		0x07
#define DRSUAPI_VERIFY_NAMES		0x08
#define DRSUAPI_GET_MEMBERSHIPS		0x09
#define DRSUAPI_INTER_DOMAIN_MOVE	0x0a
#define DRSUAPI_GET_NT4_CHANGELOG	0x0b
#define DRSUAPI_CRACKNAMES		0x0c
#define DRSUAPI_WRITE_SPN		0x0d
#define DRSUAPI_REMOVE_DS_SERVER	0x0e
#define DRSUAPI_REMOVE_DS_DOMAIN	0x0f
#define DRSUAPI_DOMAIN_CONTROLLER_INFO	0x10
#define DRSUAPI_ADD_ENTRY		0x11
#define DRSUAPI_EXECUTE_KCC		0x12
#define DRSUAPI_GET_REPL_INFO		0x13
#define DRSUAPI_ADD_SID_HISTORY		0x14
#define DRSUAPI_GET_MEMBERSHIPS2	0x15
#define DRSUAPI_REPLICA_VERIFY_OBJECTS	0x16
#define DRSUAPI_GET_OBJECT_EXISTENCE	0x17
#define DRSUAPI_QUERY_SITES_BY_COST	0x18

#endif /* packet-dcerpc-drsuapi.h */