6c4feb69397f95b58a94ee760b38bd73c876e800
[olsrd.git] / src / olsr_ip_acl.c
1
2 /*
3  * The olsr.org Optimized Link-State Routing daemon(olsrd)
4  * Copyright (c) 2004-2009, the olsr.org team - see HISTORY file
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * * Redistributions of source code must retain the above copyright
12  *   notice, this list of conditions and the following disclaimer.
13  * * Redistributions in binary form must reproduce the above copyright
14  *   notice, this list of conditions and the following disclaimer in
15  *   the documentation and/or other materials provided with the
16  *   distribution.
17  * * Neither the name of olsr.org, olsrd nor the names of its
18  *   contributors may be used to endorse or promote products derived
19  *   from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  *
34  * Visit http://www.olsr.org for more information.
35  *
36  * If you find this software useful feel free to make a donation
37  * to the project. For more information see the website or contact
38  * the copyright holders.
39  *
40  */
41
42 #include "ipcalc.h"
43 #include "olsr_ip_prefix_list.h"
44 #include "olsr_ip_acl.h"
45
46 void
47 ip_acl_init(struct ip_acl *acl)
48 {
49   list_init_head(&acl->accept);
50   list_init_head(&acl->reject);
51   acl->default_accept = false;
52   acl->first_accept = false;
53 }
54
55 void
56 ip_acl_flush(struct ip_acl *acl)
57 {
58   ip_prefix_list_flush(&acl->accept);
59   ip_prefix_list_flush(&acl->reject);
60 }
61
62 void
63 ip_acl_add(struct ip_acl *acl, const union olsr_ip_addr *net, uint8_t prefix_len, bool reject)
64 {
65   ip_prefix_list_add(reject ? &acl->reject : &acl->accept, net, prefix_len);
66 }
67
68 void
69 ip_acl_remove(struct ip_acl *acl, const union olsr_ip_addr *net, uint8_t prefix_len, bool reject, int ip_version)
70 {
71   ip_prefix_list_remove(reject ? &acl->reject : &acl->accept, net, prefix_len, ip_version);
72 }
73
74 bool
75 ip_acl_acceptable(struct ip_acl *acl, const union olsr_ip_addr *ip, int ip_version)
76 {
77   struct list_entity *first, *second;
78   struct ip_prefix_entry *entry;
79   struct list_iterator iterator;
80
81   first = acl->first_accept ? &acl->accept : &acl->reject;
82   second = acl->first_accept ? &acl->reject : &acl->accept;
83
84   /* first run */
85   OLSR_FOR_ALL_IPPREFIX_ENTRIES(first, entry, iterator) {
86     if (ip_in_net(ip, &entry->net, ip_version)) {
87       return acl->first_accept;
88     }
89   }
90
91   /* second run */
92   OLSR_FOR_ALL_IPPREFIX_ENTRIES(second, entry, iterator) {
93     if (ip_in_net(ip, &entry->net, ip_version)) {
94       return !acl->first_accept;
95     }
96   }
97
98   /* just use default */
99   return acl->default_accept;
100 }
101
102 /*
103  * Local Variables:
104  * mode: c
105  * style: linux
106  * c-basic-offset: 4
107  * indent-tabs-mode: nil
108  * End:
109  */