tree.h 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /* $Id: tree.h 1757 2007-03-22 05:38:56Z aturner $ */
  2. /*
  3. * Copyright (c) 2001-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. #ifndef __TREE_H__
  32. #define __TREE_H__
  33. #include "lib/tree.h"
  34. #define TREEPRINTBUFFLEN 2048
  35. struct tcpr_tree_s {
  36. RB_ENTRY(tcpr_tree_s) node;
  37. unsigned long ip; /* ip/network address in network byte order */
  38. u_char mac[ETHER_ADDR_LEN]; /* mac address of system */
  39. int masklen; /* CIDR network mask length */
  40. int server_cnt; /* count # of times this entry was flagged server */
  41. int client_cnt; /* flagged client */
  42. int type; /* 1 = server, 0 = client, -1 = undefined */
  43. };
  44. typedef struct tcpr_tree_s tcpr_tree_t;
  45. /*
  46. * replacement for RB_HEAD() which doesn't actually declare the root
  47. */
  48. struct tcpr_data_tree_s {
  49. tcpr_tree_t *rbh_root;
  50. };
  51. typedef struct tcpr_data_tree_s tcpr_data_tree_t;
  52. struct tcpr_buildcidr_s {
  53. int type; /* SERVER|CLIENT|UNKNOWN|ANY */
  54. int masklen; /* mask size to use to build the CIDR */
  55. };
  56. typedef struct tcpr_buildcidr_s tcpr_buildcidr_t;
  57. #define DNS_QUERY_FLAG 0x8000
  58. void add_tree(const unsigned long, const u_char *); /* done */
  59. tcpr_dir_t check_ip_tree(const int, const unsigned long);
  60. int process_tree();
  61. void tree_calculate(tcpr_data_tree_t *);
  62. int tree_comp(tcpr_tree_t *, tcpr_tree_t *);
  63. #endif
  64. /*
  65. Local Variables:
  66. mode:c
  67. indent-tabs-mode:nil
  68. c-basic-offset:4
  69. End:
  70. */