Wireshark 4.7.0
The Wireshark network protocol analyzer
Loading...
Searching...
No Matches
addr_resolv.h
Go to the documentation of this file.
1
12/* The buffers returned by these functions are all allocated with a
13 * packet lifetime and does not have to be freed.
14 * However, take into account that when the packet dissection
15 * completes, these buffers will be automatically reclaimed/freed.
16 * If you need the buffer to remain for a longer scope than packet lifetime
17 * you must copy the content to an wmem_file_scope() buffer.
18 */
19
20#ifndef __RESOLV_H__
21#define __RESOLV_H__
22
23#include <epan/address.h>
24#include <epan/tvbuff.h>
25#include <wsutil/inet_cidr.h>
26#include <epan/to_str.h>
27#include <wiretap/wtap.h>
28#include "ws_symbol_export.h"
29
30#ifdef __cplusplus
31extern "C" {
32#endif /* __cplusplus */
33
34#ifndef MAXNAMELEN
35#define MAXNAMELEN 64 /* max name length (most names: DNS labels, services, eth) */
36#endif
37
38#ifndef MAXVLANNAMELEN
39#define MAXVLANNAMELEN 128 /* max vlan name length */
40#endif
41
42#ifndef MAXDNSNAMELEN
43#define MAXDNSNAMELEN 256 /* max total length of a domain name in the DNS */
44#endif
45
46#define BASE_ENTERPRISES BASE_CUSTOM
47#define STRINGS_ENTERPRISES CF_FUNC(enterprises_base_custom)
48
63
64#define ADDR_RESOLV_MACADDR(at) \
65 (((at)->type == AT_ETHER) || ((at)->type == AT_EUI64))
66
67#define ADDR_RESOLV_NETADDR(at) \
68 (((at)->type == AT_IPv4) || ((at)->type == AT_IPv6) || ((at)->type == AT_IPX))
69
70struct hashether;
71typedef struct hashether hashether_t;
72
73struct hasheui64;
74typedef struct hasheui64 hasheui64_t;
75
76struct hashwka;
77typedef struct hashwka hashwka_t;
78
79struct hashmanuf;
80typedef struct hashmanuf hashmanuf_t;
81
82typedef struct _serv_port_key {
83 uint16_t port;
84 port_type type;
86
87/* Used for manually edited DNS resolved names */
88typedef struct _resolved_name {
89 char name[MAXDNSNAMELEN];
91
92/*
93 * Flags for various resolved name hash table entries.
94 */
95#define TRIED_RESOLVE_ADDRESS (1U<<0) /* name resolution is being/has been tried */
96#define NAME_RESOLVED (1U<<1) /* the name field contains a host name, not a printable address */
97#define RESOLVED_ADDRESS_USED (1U<<2) /* a get_hostname* call returned the host name */
98#define STATIC_HOSTNAME (1U<<3) /* do not update entries from hosts file with DNS responses */
99#define NAME_RESOLVED_PREFIX (1U<<4) /* name was generated from a prefix (e.g., OUI) instead of the entire address */
100
101#define TRIED_OR_RESOLVED_MASK (TRIED_RESOLVE_ADDRESS | NAME_RESOLVED)
102#define USED_AND_RESOLVED_MASK (NAME_RESOLVED | RESOLVED_ADDRESS_USED)
103
104/*
105 * Flag controlling what names to resolve.
106 */
107WS_DLL_PUBLIC e_addr_resolve gbl_resolv_flags;
108
109/* global variables */
110
111extern char *g_ethers_path;
112extern char *g_ipxnets_path;
113extern char *g_pethers_path;
114extern char *g_pipxnets_path;
115
116/* Functions in addr_resolv.c */
117
128WS_DLL_PUBLIC hashipv4_t * new_ipv4(const unsigned addr);
129
142WS_DLL_PUBLIC bool fill_dummy_ip4(const unsigned addr, hashipv4_t* volatile tp);
143
155WS_DLL_PUBLIC char *udp_port_to_display(wmem_allocator_t *allocator, unsigned port);
156
157
169WS_DLL_PUBLIC char *tcp_port_to_display(wmem_allocator_t *allocator, unsigned port);
170
182extern char *dccp_port_to_display(wmem_allocator_t *allocator, unsigned port);
183
195WS_DLL_PUBLIC char *sctp_port_to_display(wmem_allocator_t *allocator, unsigned port);
196
209WS_DLL_PUBLIC const char *serv_name_lookup(port_type proto, unsigned port);
210
225WS_DLL_PUBLIC const char *enterprises_lookup(uint32_t value, const char *unknown_str);
226
237WS_DLL_PUBLIC const char *try_enterprises_lookup(uint32_t value);
238
249WS_DLL_PUBLIC void enterprises_base_custom(char *buf, uint32_t value);
250
262WS_DLL_PUBLIC const char *try_serv_name_lookup(port_type proto, unsigned port);
263
277WS_DLL_PUBLIC char *port_with_resolution_to_str(wmem_allocator_t *scope,
278 port_type proto, unsigned port);
279
298WS_DLL_PUBLIC int port_with_resolution_to_str_buf(char *buf, unsigned long buf_size,
299 port_type proto, unsigned port);
300
301/*
302 * Asynchronous host name lookup initialization, processing, and cleanup
303 */
304
305/* Setup name resolution preferences */
306struct pref_module;
307extern void addr_resolve_pref_init(struct pref_module *nameres);
308extern void addr_resolve_pref_apply(void);
309
318WS_DLL_PUBLIC void disable_name_resolution(void);
319
331WS_DLL_PUBLIC bool host_name_lookup_process(void);
332
349WS_DLL_PUBLIC const char *get_hostname(const unsigned addr);
350
366WS_DLL_PUBLIC char *get_hostname_wmem(wmem_allocator_t *allocator, const unsigned addr);
367
368/* get_hostname6 returns the host name, or numeric addr if not found.
369 * The string does not have to be freed; it will be freed when the
370 * address hashtables are emptied (e.g., when preferences change or
371 * upon redissection.) However, this increases persistent memory usage
372 * even when host name lookups are off.
373 *
374 * This might get deprecated in the future for get_hostname6_wmem.
375 */
376WS_DLL_PUBLIC const char *get_hostname6(const ws_in6_addr *ad);
377
378/* get_hostname6 returns the host name, or numeric addr if not found.
379 * The returned string is allocated according to the wmem scope allocator. */
380WS_DLL_PUBLIC char *get_hostname6_wmem(wmem_allocator_t *allocator, const ws_in6_addr *ad);
381
382/* get_ether_name returns the logical name if found in ethers files else
383 "<vendor>_%02x:%02x:%02x" if the vendor code is known else
384 "%02x:%02x:%02x:%02x:%02x:%02x" */
385WS_DLL_PUBLIC const char *get_ether_name(const uint8_t *addr);
386
387/* get_hostname_ss7pc returns the logical name if found in ss7pcs file else
388 '\0' on the first call or the unresolved Point Code in the subsequent calls */
389const char *get_hostname_ss7pc(const uint8_t ni, const uint32_t pc);
390
391/* fill_unresolved_ss7pc initializes the unresolved Point Code Address string in the hashtable */
392void fill_unresolved_ss7pc(const char * pc_addr, const uint8_t ni, const uint32_t pc);
393
394
395/* Same as get_ether_name with tvb support */
396WS_DLL_PUBLIC const char *tvb_get_ether_name(tvbuff_t *tvb, int offset);
397
398/* get_ether_name_if_known returns the logical name if an exact match is
399 * found (in ethers files or from ARP) else NULL.
400 * @note: It returns NULL for addresses if only a prefix can be resolved
401 * into a manufacturer name.
402 */
403const char *get_ether_name_if_known(const uint8_t *addr);
404
405/*
406 * Given a sequence of 3 octets containing an OID, get_manuf_name()
407 * returns an abbreviated form of the vendor name, or "%02x:%02x:%02x"
408 * if not known. (The short form of the name is roughly similar in length
409 * to the hexstring, so that they may be used in similar places.)
410 * @note: This only looks up entries in the 24-bit OUI table (and the
411 * CID table), not the MA-M and MA-S tables. The hex byte string is
412 * returned for sequences registered to the IEEE Registration Authority
413 * for the purposes of being subdivided into MA-M and MA-S.
414 */
415extern const char *get_manuf_name(const uint8_t *addr, size_t size);
416
417/*
418 * Given a sequence of 3 or more octets containing an OUI,
419 * get_manuf_name_if_known() returns the vendor name, or NULL if not known.
420 * @note Unlike get_manuf_name() above, this returns the full vendor name.
421 * @note If size is 6 or larger, vendor names will be looked up in the MA-M
422 * and MA-S tables as well (but note that the length of the sequence is
423 * not returned.) If size is less than 6, only the 24 bit tables are searched,
424 * and NULL is returned for sequences registered to the IEEE Registration
425 * Authority for purposes of being subdivided into MA-M and MA-S.
426 */
427WS_DLL_PUBLIC const char *get_manuf_name_if_known(const uint8_t *addr, size_t size);
428
429/*
430 * Given an integer containing a 24-bit OUI (or CID),
431 * uint_get_manuf_name_if_known() returns the vendor name, or NULL if not known.
432 * @note NULL is returned for sequences registered to the IEEE Registration
433 * Authority for purposes of being subdivided into MA-M and MA-S.
434 */
435extern const char *uint_get_manuf_name_if_known(const uint32_t oid);
436
437/*
438 * Given a tvbuff and an offset in that tvbuff for a 3-octet OID,
439 * tvb_get_manuf_name() returns an abbreviated vendor name, or "%02x:%02x:%02x"
440 * if not known.
441 * @note: This only looks up entries in the 24-bit OUI table (and the
442 * CID table), not the MA-M and MA-S tables. The hex byte string is
443 * returned for sequences registered to the IEEE Registration Authority
444 * for the purposes of being subdivided into MA-M and MA-S.
445 */
446WS_DLL_PUBLIC const char *tvb_get_manuf_name(tvbuff_t *tvb, int offset);
447
448/*
449 * Given a tvbuff and an offset in that tvbuff for a 3-octet OID,
450 * tvb_get_manuf_name_if_known() returns the full vendor name, or NULL
451 * if not known.
452 * @note NULL is returned for sequences registered to the IEEE Registration
453 * Authority for purposes of being subdivided into MA-M and MA-S.
454 */
455WS_DLL_PUBLIC const char *tvb_get_manuf_name_if_known(tvbuff_t *tvb, int offset);
456
457/* get_eui64_name returns the logical name if found in ethers files else
458 * "<vendor>_%02x:%02x:%02x:%02x:%02x:%02x" if the vendor code is known
459 * (or as appropriate for MA-M and MA-S), and if not,
460 * "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x"
461*/
462extern const char *get_eui64_name(const uint8_t *addr);
463
464/* eui64_to_display returns "<vendor>_%02x:%02x:%02x:%02x:%02x:%02x" if the
465 * vendor code is known (or as appropriate for MA-M and MA-S), and if not,
466 * "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x". Gives the same results
467 * as address_to_display, but for when the EUI-64 address is a host endian
468 * uint64_t instead of bytes / an AT_EUI64 address.
469*/
470extern char *eui64_to_display(wmem_allocator_t *allocator, const uint64_t addr);
471
472/* get_ipxnet_name returns the logical name if found in an ipxnets file,
473 * or a string formatted with "%X" if not */
474extern char *get_ipxnet_name(wmem_allocator_t *allocator, const uint32_t addr);
475
476/* get_vlan_name returns the logical name if found in a vlans file,
477 * or the VLAN ID itself as a string if not found*/
478extern char *get_vlan_name(wmem_allocator_t *allocator, const uint16_t id);
479
480WS_DLL_PUBLIC unsigned get_hash_ether_status(hashether_t* ether);
481WS_DLL_PUBLIC bool get_hash_ether_used(hashether_t* ether);
482WS_DLL_PUBLIC char* get_hash_ether_hexaddr(hashether_t* ether);
483WS_DLL_PUBLIC char* get_hash_ether_resolved_name(hashether_t* ether);
484
485WS_DLL_PUBLIC bool get_hash_manuf_used(hashmanuf_t* manuf);
486WS_DLL_PUBLIC char* get_hash_manuf_resolved_name(hashmanuf_t* manuf);
487
488WS_DLL_PUBLIC bool get_hash_wka_used(hashwka_t* wka);
489WS_DLL_PUBLIC char* get_hash_wka_resolved_name(hashwka_t* wka);
490
491/* adds a hostname/IPv4 in the hash table */
492WS_DLL_PUBLIC void add_ipv4_name(const unsigned addr, const char *name, const bool static_entry);
493
494/* adds a hostname/IPv6 in the hash table */
495WS_DLL_PUBLIC void add_ipv6_name(const ws_in6_addr *addr, const char *name, const bool static_entry);
496
506WS_DLL_PUBLIC bool add_hosts_file (const char *hosts_file);
507
508/* adds a hostname in the hash table */
509WS_DLL_PUBLIC bool add_ip_name_from_string (const char *addr, const char *name);
510
511/* Get the user defined name, for a given address */
512WS_DLL_PUBLIC resolved_name_t* get_edited_resolved_name(const char* addr);
513
514
521WS_DLL_PUBLIC addrinfo_lists_t *get_addrinfo_list(void);
522
523/* add ethernet address / name corresponding to IP address */
524extern void add_ether_byip(const unsigned ip, const uint8_t *eth);
525
537WS_DLL_PUBLIC
538bool get_host_ipaddr(const char *host, uint32_t *addrp);
539
551WS_DLL_PUBLIC
552bool get_host_ipaddr6(const char *host, ws_in6_addr *addrp);
553
554WS_DLL_PUBLIC
555wmem_map_t *get_manuf_hashtable(void);
556
557WS_DLL_PUBLIC
558wmem_map_t *get_wka_hashtable(void);
559
560WS_DLL_PUBLIC
561wmem_map_t *get_eth_hashtable(void);
562
563WS_DLL_PUBLIC
564wmem_map_t *get_serv_port_hashtable(void);
565
566WS_DLL_PUBLIC
567wmem_map_t *get_ipxnet_hash_table(void);
568
569WS_DLL_PUBLIC
570wmem_map_t *get_vlan_hash_table(void);
571
572WS_DLL_PUBLIC
573wmem_map_t *get_ipv4_hash_table(void);
574
575WS_DLL_PUBLIC
576wmem_map_t *get_ipv6_hash_table(void);
577
578/*
579 * XXX - if we ever have per-session host name etc. information, we
580 * should probably have the "resolve synchronously or asynchronously"
581 * flag be per-session, set with an epan API.
582 */
583WS_DLL_PUBLIC
584void set_resolution_synchrony(bool synchronous);
585
586/*
587 * private functions (should only be called by epan directly)
588 */
589
590WS_DLL_LOCAL
591void name_resolver_init(void);
592
593/* Reinitialize hostname resolution subsystem */
594WS_DLL_LOCAL
595void host_name_lookup_reset(void);
596
597WS_DLL_LOCAL
598void addr_resolv_init(void);
599
600WS_DLL_LOCAL
601void addr_resolv_cleanup(void);
602
603WS_DLL_PUBLIC
604bool str_to_ip(const char *str, void *dst);
605
606WS_DLL_PUBLIC
607bool str_to_ip6(const char *str, void *dst);
608
609WS_DLL_LOCAL
610bool str_to_eth(const char *str, char *eth_bytes);
611
612WS_DLL_LOCAL
613unsigned ipv6_oat_hash(const void *key);
614
615WS_DLL_LOCAL
616gboolean ipv6_equal(const void *v1, const void *v2);
617
618#ifdef __cplusplus
619}
620#endif /* __cplusplus */
621
622#endif /* __RESOLV_H__ */
WS_DLL_PUBLIC bool host_name_lookup_process(void)
Process outstanding asynchronous host name lookups via c-ares.
Definition addr_resolv.c:3465
WS_DLL_PUBLIC const char * get_hostname(const unsigned addr)
Resolve an IPv4 address to its host name.
Definition addr_resolv.c:3512
char * dccp_port_to_display(wmem_allocator_t *allocator, unsigned port)
Resolve a DCCP port number to its display name.
Definition addr_resolv.c:3789
WS_DLL_PUBLIC char * tcp_port_to_display(wmem_allocator_t *allocator, unsigned port)
Resolve a TCP port number to its display name.
Definition addr_resolv.c:3801
WS_DLL_PUBLIC void enterprises_base_custom(char *buf, uint32_t value)
Format a private enterprise code as "name (decimal)" into a buffer.
Definition addr_resolv.c:1141
WS_DLL_PUBLIC const char * try_enterprises_lookup(uint32_t value)
Attempt to resolve a private enterprise code to its registered name.
Definition addr_resolv.c:1115
WS_DLL_PUBLIC const char * serv_name_lookup(port_type proto, unsigned port)
Resolve a port number to its well-known service name.
Definition addr_resolv.c:982
WS_DLL_PUBLIC bool get_host_ipaddr6(const char *host, ws_in6_addr *addrp)
Definition addr_resolv.c:4132
WS_DLL_PUBLIC hashipv4_t * new_ipv4(const unsigned addr)
Construct a new IPv4 object from a 32-bit address.
Definition addr_resolv.c:1268
WS_DLL_PUBLIC char * udp_port_to_display(wmem_allocator_t *allocator, unsigned port)
Resolve a UDP port number to its display name.
Definition addr_resolv.c:3777
WS_DLL_PUBLIC const char * try_serv_name_lookup(port_type proto, unsigned port)
Attempt to resolve a port number to its well-known service name.
Definition addr_resolv.c:976
WS_DLL_PUBLIC bool get_host_ipaddr(const char *host, uint32_t *addrp)
Definition addr_resolv.c:4067
WS_DLL_PUBLIC const char * enterprises_lookup(uint32_t value, const char *unknown_str)
Resolve a private enterprise code to its registered name.
Definition addr_resolv.c:1128
WS_DLL_PUBLIC addrinfo_lists_t * get_addrinfo_list(void)
Definition addr_resolv.c:2987
WS_DLL_PUBLIC char * sctp_port_to_display(wmem_allocator_t *allocator, unsigned port)
Resolve an SCTP port number to its display name.
Definition addr_resolv.c:3813
WS_DLL_PUBLIC bool fill_dummy_ip4(const unsigned addr, hashipv4_t *volatile tp)
Populate a dummy IPv4 object with the specified address.
Definition addr_resolv.c:1166
WS_DLL_PUBLIC char * get_hostname_wmem(wmem_allocator_t *allocator, const unsigned addr)
Resolve an IPv4 address to its host name using scoped memory allocation.
Definition addr_resolv.c:3539
WS_DLL_PUBLIC bool add_hosts_file(const char *hosts_file)
Definition addr_resolv.c:2863
struct _e_addr_resolve e_addr_resolve
Flags to control name resolution.
WS_DLL_PUBLIC void disable_name_resolution(void)
Disable all forms of name resolution.
Definition addr_resolv.c:3452
WS_DLL_PUBLIC int port_with_resolution_to_str_buf(char *buf, unsigned long buf_size, port_type proto, unsigned port)
Format a port number with its resolved service name into a buffer.
Definition addr_resolv.c:3839
WS_DLL_PUBLIC char * port_with_resolution_to_str(wmem_allocator_t *scope, port_type proto, unsigned port)
Format a port number with its resolved service name.
Definition addr_resolv.c:3825
Flags to control name resolution.
Definition addr_resolv.h:52
bool dns_pkt_addr_resolution
Definition addr_resolv.h:56
bool maxmind_geoip
Definition addr_resolv.h:61
bool ss7pc_name
Definition addr_resolv.h:60
bool use_external_net_name_resolver
Definition addr_resolv.h:58
bool handshake_sni_addr_resolution
Definition addr_resolv.h:57
bool transport_name
Definition addr_resolv.h:55
bool mac_name
Definition addr_resolv.h:53
bool network_name
Definition addr_resolv.h:54
bool vlan_name
Definition addr_resolv.h:59
Definition addr_resolv.h:88
Definition addr_resolv.h:82
Definition wmem_allocator.h:27
Definition wmem_map.c:60
Definition wtap.h:1539
Definition inet_addr.h:27
Definition addr_resolv.c:162
Definition addr_resolv.c:169
Definition wtap.h:1521
Definition addr_resolv.c:181
Definition addr_resolv.c:176
Definition prefs-int.h:27
const char * name
Definition prefs-int.h:28
Definition tvbuff-int.h:35