dlt_plugins.h 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /* $Id: dlt_plugins.h 1841 2007-04-26 03:43:14Z aturner $ */
  2. /*
  3. * Copyright (c) 2006-2007 Aaron Turner.
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. *
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. Neither the names of the copyright owners nor the names of its
  16. * contributors may be used to endorse or promote products derived from
  17. * this software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
  20. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  21. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  22. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
  23. * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  24. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
  25. * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  26. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
  27. * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
  28. * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  29. * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  30. */
  31. /*
  32. * Main DLT Plugin Header. You should only include this file outside
  33. * of the plugin API. dlt_plugin-int.h is used internal to the plugin ONLY.
  34. */
  35. #include "tcpedit.h"
  36. #ifndef _DLT_PLUGINS_H_
  37. #define _DLT_PLUGINS_H_
  38. /* forward declare our context, so we can use it in the plugin struct */
  39. typedef struct tcpeditdlt_s tcpeditdlt_t;
  40. /*
  41. * initialize the DLT plugin backend, and return a new context var.
  42. * call this once per pcap to be processed
  43. */
  44. tcpeditdlt_t *tcpedit_dlt_init(tcpedit_t *tcpedit, int srcdlt);
  45. /* cleans up after ourselves. Called for each initalized plugin */
  46. void tcpedit_dlt_cleanup(tcpeditdlt_t *ctx);
  47. /* What is the output DLT type? */
  48. int tcpedit_dlt_output_dlt(tcpeditdlt_t *ctx);
  49. int tcpedit_dlt_l2len(tcpeditdlt_t *ctx, int dlt, const u_char *packet, const int pktlen);
  50. /*
  51. * process the given packet, by calling decode & encode
  52. */
  53. int tcpedit_dlt_process(tcpeditdlt_t *ctx, u_char *packet, int pktlen, tcpr_dir_t direction);
  54. /*
  55. * or you can call them sperately if you want
  56. */
  57. int tcpedit_dlt_decode(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen);
  58. int tcpedit_dlt_encode(tcpeditdlt_t* ctx, u_char **packet, int pktlen, tcpr_dir_t direction);
  59. /*
  60. * After processing each packet, you can get info about L2/L3
  61. */
  62. int tcpedit_dlt_proto(tcpeditdlt_t *ctx, int dlt, const u_char *packet, const int pktlen);
  63. u_char *tcpedit_dlt_l3data(tcpeditdlt_t *ctx, int dlt, u_char *packet, const int pktlen);
  64. /* merge the L2 & L3 (possibly changed?) after calling tcpedit_dlt_l3data() */
  65. u_char *tcpedit_dlt_merge_l3data(tcpeditdlt_t *ctx, int dlt, u_char *packet, const int pktlen, u_char *l3data);
  66. int tcpedit_dlt_src(tcpeditdlt_t *ctx);
  67. int tcpedit_dlt_dst(tcpeditdlt_t *ctx);
  68. #endif