summaryrefslogtreecommitdiffstats
path: root/epan/epan.h
diff options
context:
space:
mode:
Diffstat (limited to 'epan/epan.h')
-rw-r--r--epan/epan.h290
1 files changed, 290 insertions, 0 deletions
diff --git a/epan/epan.h b/epan/epan.h
new file mode 100644
index 00000000..c822e805
--- /dev/null
+++ b/epan/epan.h
@@ -0,0 +1,290 @@
+/** @file
+ *
+ * Wireshark Protocol Analyzer Library
+ *
+ * Copyright (c) 2001 by Gerald Combs <gerald@wireshark.org>
+ *
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ */
+
+#ifndef __EPAN_H__
+#define __EPAN_H__
+
+#include <wireshark.h>
+
+#include <wsutil/feature_list.h>
+#include <epan/tvbuff.h>
+#include <epan/prefs.h>
+#include <epan/frame_data.h>
+#include <epan/register.h>
+#include <wiretap/wtap_opttypes.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+/** Global variable holding the content of the corresponding environment variable
+ * to save fetching it repeatedly.
+ */
+extern gboolean wireshark_abort_on_dissector_bug;
+extern gboolean wireshark_abort_on_too_many_items;
+
+typedef struct epan_dissect epan_dissect_t;
+
+struct epan_dfilter;
+struct epan_column_info;
+
+/**
+ * Opaque structure provided when an epan_t is created; it contains
+ * information needed to allow the user of libwireshark to provide
+ * time stamps, comments, and other information outside the packet
+ * data itself.
+ */
+struct packet_provider_data;
+
+/**
+ * Structure containing pointers to functions supplied by the user
+ * of libwireshark.
+ */
+struct packet_provider_funcs {
+ const nstime_t *(*get_frame_ts)(struct packet_provider_data *prov, guint32 frame_num);
+ const char *(*get_interface_name)(struct packet_provider_data *prov, guint32 interface_id);
+ const char *(*get_interface_description)(struct packet_provider_data *prov, guint32 interface_id);
+ wtap_block_t (*get_modified_block)(struct packet_provider_data *prov, const frame_data *fd);
+};
+
+/**
+ @section Epan The Enhanced Packet ANalyzer
+
+ XXX
+
+ @b Sections:
+*/
+/*
+Ref 1
+Epan
+Enhanced Packet ANalyzer, aka the packet analyzing engine. Source code can be found in the epan directory.
+
+Protocol-Tree - Keep data of the capture file protocol information.
+
+Dissectors - The various protocol dissectors in epan/dissectors.
+
+Plugins - Some of the protocol dissectors are implemented as plugins. Source code can be found at plugins.
+
+Display-Filters - the display filter engine at epan/dfilter
+
+
+
+Ref2 for further edits - delete when done
+ \section Introduction
+
+ This document describes the data structures and the functions exported by the CACE Technologies AirPcap library.
+ The AirPcap library provides low-level access to the AirPcap driver including advanced capabilities such as channel setting,
+ link type control and WEP configuration.<br>
+ This manual includes the following sections:
+
+ \note throughout this documentation, \e device refers to a physical USB AirPcap device, while \e adapter is an open API
+ instance. Most of the AirPcap API operations are adapter-specific but some of them, like setting the channel, are
+ per-device and will be reflected on all the open adapters. These functions will have "Device" in their name, e.g.
+ AirpcapSetDeviceChannel().
+
+ \b Sections:
+
+ - \ref airpcapfuncs
+ - \ref airpcapdefs
+ - \ref radiotap
+*/
+
+/**
+ * Init the whole epan module.
+ *
+ * Must be called only once in a program.
+ *
+ * Returns TRUE on success, FALSE on failure.
+ */
+WS_DLL_PUBLIC
+gboolean epan_init(register_cb cb, void *client_data, gboolean load_plugins);
+
+/**
+ * Load all settings, from the current profile, that affect epan.
+ */
+WS_DLL_PUBLIC
+e_prefs *epan_load_settings(void);
+
+/** cleanup the whole epan module, this is used to be called only once in a program */
+WS_DLL_PUBLIC
+void epan_cleanup(void);
+
+typedef struct {
+ void (*init)(void); /* Called before proto_init() */
+ void (*post_init)(void); /* Called at the end of epan_init() */
+ void (*dissect_init)(epan_dissect_t *);
+ void (*dissect_cleanup)(epan_dissect_t *);
+ void (*cleanup)(void);
+ void (*register_all_protocols)(register_cb, gpointer);
+ void (*register_all_handoffs)(register_cb, gpointer);
+ void (*register_all_tap_listeners)(void);
+} epan_plugin;
+
+WS_DLL_PUBLIC void epan_register_plugin(const epan_plugin *plugin);
+
+/** Returns_
+ * 0 if plugins can be loaded for all of libwireshark (tap, dissector, epan).
+ * 1 if plugins are not supported by the platform.
+ * -1 if plugins were disabled in the build configuration.
+ */
+WS_DLL_PUBLIC int epan_plugins_supported(void);
+
+/**
+ * Initialize the table of conversations. Conversations are identified by
+ * their endpoints; they are used for protocols such as IP, TCP, and UDP,
+ * where packets contain endpoint information but don't contain a single
+ * value indicating to which flow the packet belongs.
+ */
+void epan_conversation_init(void);
+
+/** A client will create one epan_t for an entire dissection session.
+ * A single epan_t will be used to analyze the entire sequence of packets,
+ * sequentially, in a single session. A session corresponds to a single
+ * packet trace file. The reasons epan_t exists is that some packets in
+ * some protocols cannot be decoded without knowledge of previous packets.
+ * This inter-packet "state" is stored in the epan_t.
+ */
+typedef struct epan_session epan_t;
+
+WS_DLL_PUBLIC epan_t *epan_new(struct packet_provider_data *prov,
+ const struct packet_provider_funcs *funcs);
+
+WS_DLL_PUBLIC wtap_block_t epan_get_modified_block(const epan_t *session, const frame_data *fd);
+
+WS_DLL_PUBLIC const char *epan_get_interface_name(const epan_t *session, guint32 interface_id);
+
+WS_DLL_PUBLIC const char *epan_get_interface_description(const epan_t *session, guint32 interface_id);
+
+const nstime_t *epan_get_frame_ts(const epan_t *session, guint32 frame_num);
+
+WS_DLL_PUBLIC void epan_free(epan_t *session);
+
+WS_DLL_PUBLIC const gchar*
+epan_get_version(void);
+
+WS_DLL_PUBLIC void epan_get_version_number(int *major, int *minor, int *micro);
+
+/**
+ * Set/unset the tree to always be visible when epan_dissect_init() is called.
+ * This state change sticks until cleared, rather than being done per function call.
+ * This is currently used when Lua scripts request all fields be generated.
+ * By default it only becomes visible if epan_dissect_init() makes it so, usually
+ * only when a packet is selected.
+ * Setting this overrides that so it's always visible, although it will still not be
+ * created if create_proto_tree is false in the call to epan_dissect_init().
+ * Clearing this reverts the decision to epan_dissect_init() and proto_tree_visible.
+ */
+WS_DLL_PUBLIC
+void epan_set_always_visible(gboolean force);
+
+/** initialize an existing single packet dissection */
+WS_DLL_PUBLIC
+void
+epan_dissect_init(epan_dissect_t *edt, epan_t *session, const gboolean create_proto_tree, const gboolean proto_tree_visible);
+
+/** get a new single packet dissection
+ * should be freed using epan_dissect_free() after packet dissection completed
+ */
+WS_DLL_PUBLIC
+epan_dissect_t*
+epan_dissect_new(epan_t *session, const gboolean create_proto_tree, const gboolean proto_tree_visible);
+
+WS_DLL_PUBLIC
+void
+epan_dissect_reset(epan_dissect_t *edt);
+
+/** Indicate whether we should fake protocols or not */
+WS_DLL_PUBLIC
+void
+epan_dissect_fake_protocols(epan_dissect_t *edt, const gboolean fake_protocols);
+
+/** run a single packet dissection */
+WS_DLL_PUBLIC
+void
+epan_dissect_run(epan_dissect_t *edt, int file_type_subtype,
+ wtap_rec *rec, tvbuff_t *tvb, frame_data *fd,
+ struct epan_column_info *cinfo);
+
+WS_DLL_PUBLIC
+void
+epan_dissect_run_with_taps(epan_dissect_t *edt, int file_type_subtype,
+ wtap_rec *rec, tvbuff_t *tvb, frame_data *fd,
+ struct epan_column_info *cinfo);
+
+/** run a single file packet dissection */
+WS_DLL_PUBLIC
+void
+epan_dissect_file_run(epan_dissect_t *edt, wtap_rec *rec,
+ tvbuff_t *tvb, frame_data *fd, struct epan_column_info *cinfo);
+
+WS_DLL_PUBLIC
+void
+epan_dissect_file_run_with_taps(epan_dissect_t *edt, wtap_rec *rec,
+ tvbuff_t *tvb, frame_data *fd, struct epan_column_info *cinfo);
+
+/** Prime an epan_dissect_t's proto_tree using the fields/protocols used in a dfilter. */
+WS_DLL_PUBLIC
+void
+epan_dissect_prime_with_dfilter(epan_dissect_t *edt, const struct epan_dfilter *dfcode);
+
+/** Prime an epan_dissect_t's proto_tree with a field/protocol specified by its hfid */
+WS_DLL_PUBLIC
+void
+epan_dissect_prime_with_hfid(epan_dissect_t *edt, int hfid);
+
+/** Prime an epan_dissect_t's proto_tree with a set of fields/protocols specified by their hfids in a GArray */
+WS_DLL_PUBLIC
+void
+epan_dissect_prime_with_hfid_array(epan_dissect_t *edt, GArray *hfids);
+
+/** fill the dissect run output into the packet list columns */
+WS_DLL_PUBLIC
+void
+epan_dissect_fill_in_columns(epan_dissect_t *edt, const gboolean fill_col_exprs, const gboolean fill_fd_colums);
+
+/** Check whether a dissected packet contains a given named field */
+WS_DLL_PUBLIC
+gboolean
+epan_dissect_packet_contains_field(epan_dissect_t* edt,
+ const char *field_name);
+
+/** releases resources attached to the packet dissection. DOES NOT free the actual pointer */
+WS_DLL_PUBLIC
+void
+epan_dissect_cleanup(epan_dissect_t* edt);
+
+/** free a single packet dissection */
+WS_DLL_PUBLIC
+void
+epan_dissect_free(epan_dissect_t* edt);
+
+/** Sets custom column */
+const gchar *
+epan_custom_set(epan_dissect_t *edt, GSList *ids, gint occurrence,
+ gchar *result, gchar *expr, const int size);
+
+/**
+ * Get compile-time information for libraries used by libwireshark.
+ */
+WS_DLL_PUBLIC
+void
+epan_gather_compile_info(feature_list l);
+
+/**
+ * Get runtime information for libraries used by libwireshark.
+ */
+WS_DLL_PUBLIC
+void
+epan_gather_runtime_info(feature_list l);
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif /* __EPAN_H__ */