1
0

dlt_plugins.h 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /* $Id: dlt_plugins.h 1757 2007-03-22 05:38:56Z 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,
  54. int pktlen, tcpr_dir_t direction);
  55. /*
  56. * or you can call them sperately if you want
  57. */
  58. int tcpedit_dlt_decode(tcpeditdlt_t *ctx, const u_char *packet, const int pktlen);
  59. int tcpedit_dlt_encode(tcpeditdlt_t* ctx, u_char **packet, int pktlen, tcpr_dir_t direction);
  60. /*
  61. * After processing each packet, you can get info about L2/L3
  62. */
  63. int tcpedit_dlt_proto(tcpeditdlt_t *ctx, int dlt, const u_char *packet, const int pktlen);
  64. u_char *tcpedit_dlt_l3data(tcpeditdlt_t *ctx, int dlt, u_char *packet, const int pktlen);
  65. /* merge the L2 & L3 (possibly changed?) after calling tcpedit_dlt_l3data() */
  66. u_char *tcpedit_dlt_merge_l3data(tcpeditdlt_t *ctx, int dlt, u_char *packet, const int pktlen, u_char *l3data);
  67. int tcpedit_dlt_src(tcpeditdlt_t *ctx);
  68. int tcpedit_dlt_dst(tcpeditdlt_t *ctx);
  69. #endif