From a86c5f7cae7ec9a3398300555a0b644689d946a1 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Thu, 19 Sep 2024 06:14:53 +0200 Subject: Merging upstream version 4.4.0. Signed-off-by: Daniel Baumann --- epan/dissectors/packet-tacacs.c | 308 ++++++++++++++++++++-------------------- 1 file changed, 154 insertions(+), 154 deletions(-) (limited to 'epan/dissectors/packet-tacacs.c') diff --git a/epan/dissectors/packet-tacacs.c b/epan/dissectors/packet-tacacs.c index 386773d2..ef3c9ab6 100644 --- a/epan/dissectors/packet-tacacs.c +++ b/epan/dissectors/packet-tacacs.c @@ -40,32 +40,32 @@ void proto_reg_handoff_tacplus(void); void proto_register_tacplus(void); static dissector_handle_t tacplus_handle; -static void md5_xor( guint8 *data, const char *key, int data_len, guint8 *session_id, guint8 version, guint8 seq_no ); +static void md5_xor( uint8_t *data, const char *key, int data_len, uint8_t *session_id, uint8_t version, uint8_t seq_no ); static int dissect_tacplus_message(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data); -static int proto_tacacs = -1; -static int hf_tacacs_version = -1; -static int hf_tacacs_type = -1; -static int hf_tacacs_nonce = -1; -static int hf_tacacs_userlen = -1; -static int hf_tacacs_passlen = -1; -static int hf_tacacs_response = -1; -static int hf_tacacs_reason = -1; -static int hf_tacacs_result1 = -1; -static int hf_tacacs_destaddr = -1; -static int hf_tacacs_destport = -1; -static int hf_tacacs_line = -1; -static int hf_tacacs_result2 = -1; -static int hf_tacacs_result3 = -1; -static int hf_tacacs_username = -1; -static int hf_tacacs_password = -1; - -static gint ett_tacacs = -1; - -static gboolean tacplus_preference_desegment = TRUE; +static int proto_tacacs; +static int hf_tacacs_version; +static int hf_tacacs_type; +static int hf_tacacs_nonce; +static int hf_tacacs_userlen; +static int hf_tacacs_passlen; +static int hf_tacacs_response; +static int hf_tacacs_reason; +static int hf_tacacs_result1; +static int hf_tacacs_destaddr; +static int hf_tacacs_destport; +static int hf_tacacs_line; +static int hf_tacacs_result2; +static int hf_tacacs_result3; +static int hf_tacacs_username; +static int hf_tacacs_password; + +static int ett_tacacs; + +static bool tacplus_preference_desegment = true; static const char *tacplus_opt_key; -static GSList *tacplus_keys = NULL; +static GSList *tacplus_keys; #define ADDR_INVLD "invalid" @@ -130,17 +130,17 @@ dissect_tacacs(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data _ { proto_tree *tacacs_tree; proto_item *ti; - guint32 version,type,userlen,passlen; + uint32_t version,type,userlen,passlen; col_set_str(pinfo->cinfo, COL_PROTOCOL, "TACACS"); col_clear(pinfo->cinfo, COL_INFO); - version = tvb_get_guint8(tvb,0); + version = tvb_get_uint8(tvb,0); if (version != 0) { col_set_str(pinfo->cinfo, COL_PROTOCOL, "XTACACS"); } - type = tvb_get_guint8(tvb,1); + type = tvb_get_uint8(tvb,1); col_add_str(pinfo->cinfo, COL_INFO, val_to_str(type, tacacs_type_vals, "Unknown (0x%02x)")); @@ -257,7 +257,7 @@ proto_register_tacacs(void) NULL, HFILL }}, }; - static gint *ett[] = { + static int *ett[] = { &ett_tacacs, }; proto_tacacs = proto_register_protocol("TACACS", "TACACS", "tacacs"); @@ -272,85 +272,85 @@ proto_reg_handoff_tacacs(void) dissector_add_uint_with_preference("udp.port", UDP_PORT_TACACS, tacacs_handle); } -static int proto_tacplus = -1; -static int hf_tacplus_response = -1; -static int hf_tacplus_request = -1; -static int hf_tacplus_majvers = -1; -static int hf_tacplus_minvers = -1; -static int hf_tacplus_type = -1; -static int hf_tacplus_seqno = -1; -static int hf_tacplus_flags = -1; -static int hf_tacplus_flags_payload_type = -1; -static int hf_tacplus_flags_connection_type = -1; -static int hf_tacplus_acct_flags = -1; -static int hf_tacplus_acct_flags_more = -1; -static int hf_tacplus_acct_flags_start = -1; -static int hf_tacplus_acct_flags_stop = -1; -static int hf_tacplus_acct_flags_watchdog = -1; -static int hf_tacplus_session_id = -1; -static int hf_tacplus_packet_len = -1; -static int hf_tacplus_auth_password = -1; -static int hf_tacplus_port = -1; -static int hf_tacplus_remote_address = -1; -static int hf_tacplus_chap_challenge = -1; -static int hf_tacplus_chap_response = -1; -static int hf_tacplus_mschap_challenge = -1; -static int hf_tacplus_mschap_response = -1; -static int hf_tacplus_arap_nas_challenge = -1; -static int hf_tacplus_arap_remote_challenge = -1; -static int hf_tacplus_arap_remote_response = -1; -static int hf_tacplus_privilege_level = -1; -static int hf_tacplus_authentication_type = -1; -static int hf_tacplus_service = -1; -static int hf_tacplus_user_len = -1; -static int hf_tacplus_user = -1; -static int hf_tacplus_port_len = -1; -static int hf_tacplus_remote_address_len = -1; -static int hf_tacplus_arg_length = -1; -static int hf_tacplus_arg_value = -1; -static int hf_tacplus_chap_id = -1; -static int hf_tacplus_mschap_id = -1; -static int hf_tacplus_authen_action = -1; -static int hf_tacplus_body_authen_req_cont_flags = -1; -static int hf_tacplus_body_authen_req_cont_user_length = -1; -static int hf_tacplus_body_authen_req_cont_user = -1; -static int hf_tacplus_body_authen_req_cont_data_length = -1; -static int hf_tacplus_body_authen_rep_status = -1; -static int hf_tacplus_body_authen_rep_flags = -1; -static int hf_tacplus_body_authen_rep_server_msg_len = -1; -static int hf_tacplus_body_authen_rep_server_msg = -1; -static int hf_tacplus_body_authen_rep_server_data_len = -1; -static int hf_tacplus_body_author_req_auth_method = -1; -static int hf_tacplus_body_author_req_arg_count = -1; -static int hf_tacplus_body_author_rep_auth_status = -1; -static int hf_tacplus_body_author_rep_server_msg_len = -1; -static int hf_tacplus_body_author_rep_server_data_len = -1; -static int hf_tacplus_body_author_rep_arg_count = -1; -static int hf_tacplus_acct_authen_method = -1; -static int hf_tacplus_acct_arg_count = -1; -static int hf_tacplus_body_acct_status = -1; -static int hf_tacplus_body_acct_server_msg_len = -1; -static int hf_tacplus_body_acct_server_msg = -1; -static int hf_tacplus_body_acct_data_len = -1; -static int hf_tacplus_body_acct_data = -1; -static int hf_tacplus_data = -1; +static int proto_tacplus; +static int hf_tacplus_response; +static int hf_tacplus_request; +static int hf_tacplus_majvers; +static int hf_tacplus_minvers; +static int hf_tacplus_type; +static int hf_tacplus_seqno; +static int hf_tacplus_flags; +static int hf_tacplus_flags_payload_type; +static int hf_tacplus_flags_connection_type; +static int hf_tacplus_acct_flags; +static int hf_tacplus_acct_flags_more; +static int hf_tacplus_acct_flags_start; +static int hf_tacplus_acct_flags_stop; +static int hf_tacplus_acct_flags_watchdog; +static int hf_tacplus_session_id; +static int hf_tacplus_packet_len; +static int hf_tacplus_auth_password; +static int hf_tacplus_port; +static int hf_tacplus_remote_address; +static int hf_tacplus_chap_challenge; +static int hf_tacplus_chap_response; +static int hf_tacplus_mschap_challenge; +static int hf_tacplus_mschap_response; +static int hf_tacplus_arap_nas_challenge; +static int hf_tacplus_arap_remote_challenge; +static int hf_tacplus_arap_remote_response; +static int hf_tacplus_privilege_level; +static int hf_tacplus_authentication_type; +static int hf_tacplus_service; +static int hf_tacplus_user_len; +static int hf_tacplus_user; +static int hf_tacplus_port_len; +static int hf_tacplus_remote_address_len; +static int hf_tacplus_arg_length; +static int hf_tacplus_arg_value; +static int hf_tacplus_chap_id; +static int hf_tacplus_mschap_id; +static int hf_tacplus_authen_action; +static int hf_tacplus_body_authen_req_cont_flags; +static int hf_tacplus_body_authen_req_cont_user_length; +static int hf_tacplus_body_authen_req_cont_user; +static int hf_tacplus_body_authen_req_cont_data_length; +static int hf_tacplus_body_authen_rep_status; +static int hf_tacplus_body_authen_rep_flags; +static int hf_tacplus_body_authen_rep_server_msg_len; +static int hf_tacplus_body_authen_rep_server_msg; +static int hf_tacplus_body_authen_rep_server_data_len; +static int hf_tacplus_body_author_req_auth_method; +static int hf_tacplus_body_author_req_arg_count; +static int hf_tacplus_body_author_rep_auth_status; +static int hf_tacplus_body_author_rep_server_msg_len; +static int hf_tacplus_body_author_rep_server_data_len; +static int hf_tacplus_body_author_rep_arg_count; +static int hf_tacplus_acct_authen_method; +static int hf_tacplus_acct_arg_count; +static int hf_tacplus_body_acct_status; +static int hf_tacplus_body_acct_server_msg_len; +static int hf_tacplus_body_acct_server_msg; +static int hf_tacplus_body_acct_data_len; +static int hf_tacplus_body_acct_data; +static int hf_tacplus_data; /* Generated from convert_proto_tree_add_text.pl */ -static int hf_tacplus_ascii_length = -1; -static int hf_tacplus_arap_data_length = -1; -static int hf_tacplus_mschap_data_length = -1; -static int hf_tacplus_chap_data_length = -1; -static int hf_tacplus_password_length = -1; -static int hf_tacplus_data_length = -1; - -static gint ett_tacplus = -1; -static gint ett_tacplus_body = -1; -static gint ett_tacplus_body_chap = -1; -static gint ett_tacplus_flags = -1; -static gint ett_tacplus_acct_flags = -1; - -static expert_field ei_tacplus_packet_len_invalid = EI_INIT; -static expert_field ei_tacplus_unencrypted = EI_INIT; -static expert_field ei_tacplus_bogus_data = EI_INIT; +static int hf_tacplus_ascii_length; +static int hf_tacplus_arap_data_length; +static int hf_tacplus_mschap_data_length; +static int hf_tacplus_chap_data_length; +static int hf_tacplus_password_length; +static int hf_tacplus_data_length; + +static int ett_tacplus; +static int ett_tacplus_body; +static int ett_tacplus_body_chap; +static int ett_tacplus_flags; +static int ett_tacplus_acct_flags; + +static expert_field ei_tacplus_packet_len_invalid; +static expert_field ei_tacplus_unencrypted; +static expert_field ei_tacplus_bogus_data; typedef struct _tacplus_key_entry { address *s; /* Server address */ @@ -358,21 +358,21 @@ typedef struct _tacplus_key_entry { char *k; /* Key */ } tacplus_key_entry; -static gint -tacplus_decrypted_tvb_setup( tvbuff_t *tvb, tvbuff_t **dst_tvb, packet_info *pinfo, guint32 len, guint8 version, const char *key ) +static int +tacplus_decrypted_tvb_setup( tvbuff_t *tvb, tvbuff_t **dst_tvb, packet_info *pinfo, uint32_t len, uint8_t version, const char *key ) { - guint8 *buff; - guint8 session_id[4]; + uint8_t *buff; + uint8_t session_id[4]; /* TODO Check the possibility to use pinfo->decrypted_data */ /* session_id is in NETWORK Byte Order, and is used as byte array in the md5_xor */ tvb_memcpy(tvb, session_id, 4,4); - buff = (guint8 *)tvb_memdup(pinfo->pool, tvb, TAC_PLUS_HDR_SIZE, len); + buff = (uint8_t *)tvb_memdup(pinfo->pool, tvb, TAC_PLUS_HDR_SIZE, len); - md5_xor( buff, key, len, session_id,version, tvb_get_guint8(tvb,2) ); + md5_xor( buff, key, len, session_id,version, tvb_get_uint8(tvb,2) ); /* Allocate a new tvbuff, referring to the decrypted data. */ *dst_tvb = tvb_new_child_real_data(tvb, buff, len, len ); @@ -387,9 +387,9 @@ dissect_tacplus_args_list( tvbuff_t *tvb, proto_tree *tree, int data_off, int le { int i; int len; - guint8 *value; + uint8_t *value; for(i=0;is ); c_str = address_to_str( NULL, tacplus_data->c ); @@ -746,11 +746,11 @@ tacplus_print_key_entry( gpointer data, gpointer user_data ) } #endif static int -cmp_conv_address( gconstpointer p1, gconstpointer p2 ) +cmp_conv_address( const void *p1, const void *p2 ) { const tacplus_key_entry *a1=(const tacplus_key_entry *)p1; const tacplus_key_entry *a2=(const tacplus_key_entry *)p2; - gint32 ret; + int32_t ret; /* ws_debug_printf("p1=>"); tacplus_print_key_entry( p1, NULL ); @@ -778,8 +778,8 @@ find_key( address *srv, address *cln ) data.s=srv; data.c=cln; /* ws_debug_printf("Looking for: "); - tacplus_print_key_entry( (gconstpointer)&data, NULL ); */ - match=g_slist_find_custom( tacplus_keys, (gpointer)&data, cmp_conv_address ); + tacplus_print_key_entry( (const void *)&data, NULL ); */ + match=g_slist_find_custom( tacplus_keys, (void *)&data, cmp_conv_address ); /* ws_debug_printf("Finished (%p)\n", match); */ if( match ) return ((tacplus_key_entry*)match->data)->k; @@ -862,10 +862,10 @@ parse_tacplus_keys( const char *keys_from_option ) #endif } -static guint +static unsigned get_tacplus_message_len(packet_info *pinfo _U_, tvbuff_t *tvb, int offset, void *data _U_) { - return (guint)tvb_get_ntohl(tvb, offset+H_LENGTH_OFF) + TAC_PLUS_HDR_SIZE; + return (unsigned)tvb_get_ntohl(tvb, offset+H_LENGTH_OFF) + TAC_PLUS_HDR_SIZE; } static int @@ -881,12 +881,12 @@ dissect_tacplus_message(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, voi tvbuff_t *new_tvb=NULL; proto_tree *tacplus_tree, *body_tree; proto_item *ti, *hidden_item; - guint8 version,flags; + uint8_t version,flags; proto_tree *flags_tree; proto_item *tf; proto_item *tmp_pi; - guint32 len; - gboolean request=( pinfo->destport == TCP_PORT_TACACS ); + uint32_t len; + bool request=( pinfo->destport == TCP_PORT_TACACS ); const char *key=NULL; len = tvb_get_ntohl(tvb, 8); @@ -900,7 +900,7 @@ dissect_tacplus_message(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, voi col_add_fstr( pinfo->cinfo, COL_INFO, "%s: %s", request ? "Q" : "R", - val_to_str(tvb_get_guint8(tvb,1), tacplus_type_vals, "Unknown (0x%02x)")); + val_to_str(tvb_get_uint8(tvb,1), tacplus_type_vals, "Unknown (0x%02x)")); /* if (tree) */ { @@ -910,16 +910,16 @@ dissect_tacplus_message(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, voi if (pinfo->match_uint == pinfo->destport) { hidden_item = proto_tree_add_boolean(tacplus_tree, - hf_tacplus_request, tvb, 0, 0, TRUE); + hf_tacplus_request, tvb, 0, 0, true); } else { hidden_item = proto_tree_add_boolean(tacplus_tree, - hf_tacplus_response, tvb, 0, 0, TRUE); + hf_tacplus_response, tvb, 0, 0, true); } proto_item_set_hidden(hidden_item); - version = tvb_get_guint8(tvb,0); + version = tvb_get_uint8(tvb,0); proto_tree_add_uint_format_value(tacplus_tree, hf_tacplus_majvers, tvb, 0, 1, version, "%s", @@ -930,7 +930,7 @@ dissect_tacplus_message(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, voi ENC_BIG_ENDIAN); proto_tree_add_item(tacplus_tree, hf_tacplus_seqno, tvb, 2, 1, ENC_BIG_ENDIAN); - flags = tvb_get_guint8(tvb,3); + flags = tvb_get_uint8(tvb,3); tf = proto_tree_add_uint_format_value(tacplus_tree, hf_tacplus_flags, tvb, 3, 1, flags, "0x%02x (%s payload, %s)", flags, @@ -948,7 +948,7 @@ dissect_tacplus_message(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, voi ENC_BIG_ENDIAN); tmp_pi = proto_tree_add_uint(tacplus_tree, hf_tacplus_packet_len, tvb, 8, 4, len); - if ((gint)len < 1) { + if ((int)len < 1) { expert_add_info_format(pinfo, tmp_pi, &ei_tacplus_packet_len_invalid, "Invalid length: %u", len); } @@ -988,11 +988,11 @@ proto_register_tacplus(void) { &hf_tacplus_response, { "Response", "tacplus.response", FT_BOOLEAN, BASE_NONE, NULL, 0x0, - "TRUE if TACACS+ response", HFILL }}, + "true if TACACS+ response", HFILL }}, { &hf_tacplus_request, { "Request", "tacplus.request", FT_BOOLEAN, BASE_NONE, NULL, 0x0, - "TRUE if TACACS+ request", HFILL }}, + "true if TACACS+ request", HFILL }}, { &hf_tacplus_majvers, { "Major version", "tacplus.majvers", FT_UINT8, BASE_DEC, NULL, 0x0, @@ -1239,7 +1239,7 @@ proto_register_tacplus(void) { &hf_tacplus_data_length, { "Data", "tacplus.data_length", FT_UINT8, BASE_DEC, NULL, 0x0, NULL, HFILL }}, }; - static gint *ett[] = { + static int *ett[] = { &ett_tacplus, &ett_tacplus_flags, &ett_tacplus_acct_flags, @@ -1277,18 +1277,18 @@ proto_reg_handoff_tacplus(void) } static void -md5_xor( guint8 *data, const char *key, int data_len, guint8 *session_id, guint8 version, guint8 seq_no ) +md5_xor( uint8_t *data, const char *key, int data_len, uint8_t *session_id, uint8_t version, uint8_t seq_no ) { int i,j; size_t md5_len; - guint8 *md5_buff; - guint8 hash[HASH_MD5_LENGTH]; /* the md5 hash */ - guint8 *mdp; + uint8_t *md5_buff; + uint8_t hash[HASH_MD5_LENGTH]; /* the md5 hash */ + uint8_t *mdp; md5_len = 4 /* sizeof(session_id) */ + strlen(key) + sizeof(version) + sizeof(seq_no); - md5_buff = (guint8*)wmem_alloc(wmem_packet_scope(), md5_len + HASH_MD5_LENGTH); + md5_buff = (uint8_t*)wmem_alloc(wmem_packet_scope(), md5_len + HASH_MD5_LENGTH); mdp = md5_buff; -- cgit v1.2.3