/* oids.h * Object IDentifier Support * * (c) 2007, Luis E. Garcia Ontanon * * Wireshark - Network traffic analyzer * By Gerald Combs * Copyright 1998 Gerald Combs * * SPDX-License-Identifier: GPL-2.0-or-later */ #ifndef __OIDS_H__ #define __OIDS_H__ #include #include #include #include "ws_symbol_export.h" #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ /** *@file */ #define BER_TAG_ANY -1 struct _oid_bit_t { guint offset; int hfid; }; typedef struct _oid_bits_info_t { guint num; gint ett; struct _oid_bit_t* data; } oid_bits_info_t; typedef enum _oid_key_type_t { OID_KEY_TYPE_WRONG, OID_KEY_TYPE_INTEGER, OID_KEY_TYPE_OID, OID_KEY_TYPE_STRING, OID_KEY_TYPE_BYTES, OID_KEY_TYPE_NSAP, OID_KEY_TYPE_IPADDR, OID_KEY_TYPE_IMPLIED_OID, OID_KEY_TYPE_IMPLIED_STRING, OID_KEY_TYPE_IMPLIED_BYTES, OID_KEY_TYPE_ETHER, OID_KEY_TYPE_DATE_AND_TIME } oid_key_type_t; typedef struct _oid_value_type_t { enum ftenum ft_type; int display; gint8 ber_class; gint32 ber_tag; int min_len; int max_len; oid_key_type_t keytype; int keysize; } oid_value_type_t; typedef enum _oid_kind_t { OID_KIND_UNKNOWN = 0, OID_KIND_NODE, OID_KIND_SCALAR, OID_KIND_TABLE, OID_KIND_ROW, OID_KIND_COLUMN, OID_KIND_NOTIFICATION, OID_KIND_GROUP, OID_KIND_COMPLIANCE, OID_KIND_CAPABILITIES } oid_kind_t; typedef struct _oid_key_t { char* name; guint32 num_subids; oid_key_type_t key_type; int hfid; enum ftenum ft_type; int display; struct _oid_key_t* next; } oid_key_t; typedef struct _oid_info_t { guint32 subid; char* name; oid_kind_t kind; wmem_tree_t* children; const oid_value_type_t* value_type; int value_hfid; oid_key_t* key; oid_bits_info_t* bits; struct _oid_info_t* parent; } oid_info_t; /** init function called from prefs.c */ WS_DLL_PUBLIC void oids_init(void); extern void oid_pref_init(module_t *nameres); /** init function called from epan.h */ WS_DLL_PUBLIC void oids_cleanup(void); /* * The objects returned by all these functions are all allocated with a * packet lifetime and do not have to be freed. * However, take into account that when the packet dissection * completes, these buffers will be automatically reclaimed/freed. * If you need the buffer to remain for a longer scope than packet lifetime * you must copy the content to an wmem_file_scope() buffer. */ /* * These functions convert through the various formats: * string: is like "0.1.3.4.5.30" (not resolved) * encoded: is BER encoded (as per X.690 section 8.19) * subids: is an array of guint32s */ /* return length of encoded buffer */ WS_DLL_PUBLIC guint oid_subid2encoded(wmem_allocator_t *scope, guint len, guint32* subids, guint8** encoded_p); WS_DLL_PUBLIC guint oid_string2encoded(wmem_allocator_t *scope, const gchar *oid_str, guint8** encoded_p); /* return length of subid array */ WS_DLL_PUBLIC guint oid_encoded2subid(wmem_allocator_t *scope, const guint8 *oid, gint len, guint32** subids_p); WS_DLL_PUBLIC guint oid_encoded2subid_sub(wmem_allocator_t *scope, const guint8 *oid_bytes, gint oid_len, guint32** subids_pi, gboolean is_first); WS_DLL_PUBLIC guint oid_string2subid(wmem_allocator_t *scope, const gchar *oid_str, guint32** subids_p); WS_DLL_PUBLIC gchar* oid_encoded2string(wmem_allocator_t *scope, const guint8* encoded, guint len); WS_DLL_PUBLIC gchar* rel_oid_encoded2string(wmem_allocator_t *scope, const guint8* encoded, guint len); WS_DLL_PUBLIC gchar* oid_subid2string(wmem_allocator_t *scope, guint32 *subids, guint len); WS_DLL_PUBLIC gchar* rel_oid_subid2string(wmem_allocator_t *scope, guint32 *subids, guint len, gboolean is_absolute); /* these return a formated string as human readable as posible */ WS_DLL_PUBLIC gchar *oid_resolved(wmem_allocator_t *scope, guint len, guint32 *subids); WS_DLL_PUBLIC gchar *oid_resolved_from_encoded(wmem_allocator_t *scope, const guint8 *oid, gint len); WS_DLL_PUBLIC gchar *rel_oid_resolved_from_encoded(wmem_allocator_t *scope, const guint8 *oid, gint len); WS_DLL_PUBLIC gchar *oid_resolved_from_string(wmem_allocator_t *scope, const gchar *oid_str); /* these yield two formated strings one resolved and one numeric */ WS_DLL_PUBLIC void oid_both(wmem_allocator_t *scope, guint oid_len, guint32 *subids, gchar** resolved_p, gchar** numeric_p); WS_DLL_PUBLIC void oid_both_from_encoded(wmem_allocator_t *scope, const guint8 *oid, gint oid_len, gchar** resolved_p, gchar** numeric_p); WS_DLL_PUBLIC void oid_both_from_string(wmem_allocator_t *scope, const gchar *oid_str, gchar** resolved_p, gchar** numeric_p); /* * These return the info for the best match. * *matched_p will be set to the number of nodes used by the returned oid * *left_p will be set to the number of remaining unresolved subids */ WS_DLL_PUBLIC oid_info_t* oid_get(guint oid_len, guint32 *subids, guint* matched_p, guint* left_p); WS_DLL_PUBLIC oid_info_t* oid_get_from_encoded(wmem_allocator_t *scope, const guint8 *oid, gint oid_len, guint32 **subids, guint* matched, guint* left); WS_DLL_PUBLIC oid_info_t* oid_get_from_string(wmem_allocator_t *scope, const gchar *oid_str, guint32 **subids, guint* matched, guint* left); /* these are used to add oids to the collection */ WS_DLL_PUBLIC void oid_add(const char* name, guint oid_len, guint32 *subids); WS_DLL_PUBLIC void oid_add_from_encoded(const char* name, const guint8 *oid, gint oid_len); WS_DLL_PUBLIC void oid_add_from_string(const char* name, const gchar *oid_str); /** * Fetch the default MIB/PIB path * * @return A string containing the default MIB/PIB path. It must be * g_free()d by the caller. */ WS_DLL_PUBLIC gchar *oid_get_default_mib_path(void); /* macros for legacy oid functions */ #define subid_t guint32 #ifdef DEBUG_OIDS extern char* oid_test_a2b(guint32 num_subids, guint32* subids); extern void add_oid_debug_subtree(oid_info_t* oid_info, proto_tree *tree); #else #define add_oid_debug_subtree(a,b) ((void)0) #endif #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* __OIDS_H__ */ /* * Editor modelines * * Local Variables: * c-basic-offset: 4 * tab-width: 8 * indent-tabs-mode: nil * End: * * ex: set shiftwidth=4 tabstop=8 expandtab: * :indentSize=4:tabSize=8:noTabs=true: */