all: updated FSF address in GPL text
[sip-router] / modules / permissions / rule.h
1 /*
2  * $Id$
3  *
4  * PERMISSIONS module
5  *
6  * Copyright (C) 2003 Miklós Tirpák (mtirpak@sztaki.hu)
7  *
8  * This file is part of Kamailio, a free SIP server.
9  *
10  * Kamailio is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version
14  *
15  * Kamailio is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License 
21  * along with this program; if not, write to the Free Software 
22  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
23  *
24  */
25  
26 #ifndef RULE_H
27 #define RULE_H 1
28
29 #include <regex.h>
30
31 #define EXPRESSION_LENGTH 256   /* maximum length of an expression */
32 #define LINE_LENGTH 500         /* maximum length of lines in the config file */
33
34
35 struct rule_struct;
36 typedef struct rule_struct rule;
37
38 struct expression_struct;
39 typedef struct expression_struct expression;
40         
41 rule *new_rule(void);
42 void free_rule(rule *r);
43 void print_rule(rule *r);
44 int search_rule(rule *r, char *left, char *right);
45
46 expression *new_expression(char *str);
47 void free_expression(expression *e);
48 void print_expression(expression *e);
49 int search_expression(expression *e, char *value);
50
51 /*
52  * stores an expression
53  * value represents the string, and reg_value is the compiled string to POSIX regular expression
54 */
55 struct expression_struct  {
56         char    value[EXPRESSION_LENGTH+1];
57         regex_t *reg_value;
58         struct expression_struct        *next;
59 };
60
61
62 /*
63  * stores 4 lists of expressions in the following way:
64  *
65  * a, b, c EXCEPT d, e : f, g EXCEPT h
66  * left = a, b, c
67  * left_exceptions = d, e
68  * right = f, g
69  * right_exceptions = h
70  */
71 struct rule_struct {
72         expression *left, *left_exceptions, *right, *right_exceptions;
73         struct rule_struct      *next;
74 };
75
76
77 #endif /* RULE_H */