pkg/kamailio/fedora/16: Updated rel in .spec to dev2
[sip-router] / route.h
1 /*
2  * $Id$
3  *
4  * Copyright (C) 2001-2003 FhG Fokus
5  *
6  * This file is part of ser, a free SIP server.
7  *
8  * ser is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version
12  *
13  * For a license to use the ser software under conditions
14  * other than those described here, or to purchase support for this
15  * software, please contact iptel.org by e-mail at the following addresses:
16  *    info@iptel.org
17  *
18  * ser is distributed in the hope that it will be useful,
19  * but WITHOUT ANY WARRANTY; without even the implied warranty of
20  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21  * GNU General Public License for more details.
22  *
23  * You should have received a copy of the GNU General Public License 
24  * along with this program; if not, write to the Free Software 
25  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
26  */
27
28
29 #ifndef route_h
30 #define route_h
31
32 #include <sys/types.h>
33 #include <regex.h>
34 #include <netdb.h>
35
36 #include "config.h"
37 #include "error.h"
38 #include "route_struct.h"
39 #include "action.h"
40 #include "parser/msg_parser.h"
41 #include "str_hash.h"
42
43 /*#include "cfg_parser.h" */
44
45 /* Various types of route sections, make sure that the values defined in the
46  * macros below occupy disjunct bits so that they can also be used as flags
47  */
48 #define REQUEST_ROUTE (1 << 0)
49 #define FAILURE_ROUTE (1 << 1)
50 #define TM_ONREPLY_ROUTE (1 << 2)
51 #define BRANCH_ROUTE  (1 << 3)
52 #define ONSEND_ROUTE  (1 << 4)
53 #define ERROR_ROUTE   (1 << 5)
54 #define LOCAL_ROUTE   (1 << 6)
55 #define CORE_ONREPLY_ROUTE (1 << 7)
56 #define ONREPLY_ROUTE (TM_ONREPLY_ROUTE|CORE_ONREPLY_ROUTE)
57 #define EVENT_ROUTE   REQUEST_ROUTE
58 #define ANY_ROUTE     (0xFFFFFFFF)
59
60 /* The value of this variable is one of the route types defined above and it
61  * determines the type of the route being executed, module functions can use
62  * this value to determine the type of the route they are being executed in
63  */
64 extern int route_type;
65
66 #define set_route_type(type) \
67         do {                                     \
68                 route_type = (type); \
69         } while(0)
70
71 #define get_route_type()        route_type
72
73 #define is_route_type(type) (route_type & (type))
74
75 struct route_list{
76         struct action** rlist;
77         int idx; /* first empty entry */ 
78         int entries; /* total number of entries */
79         struct str_hash_table names; /* name to route index mappings */
80 };
81
82
83 /* main "script table" */
84 extern struct route_list main_rt;
85 /* main reply route table */
86 extern struct route_list onreply_rt;
87 extern struct route_list failure_rt;
88 extern struct route_list branch_rt;
89 extern struct route_list onsend_rt;
90 extern struct route_list event_rt;
91
92 /* script optimization level */
93 extern int scr_opt_lev;
94
95 int init_routes(void);
96 void destroy_routes(void);
97 int route_get(struct route_list* rt, char* name);
98 int route_lookup(struct route_list* rt, char* name);
99
100 void push(struct action* a, struct action** head);
101 int add_actions(struct action* a, struct action** head);
102 void print_rls(void);
103 int fix_rls(void);
104
105 int eval_expr(struct run_act_ctx* h, struct expr* e, struct sip_msg* msg);
106
107
108 /* fixup functions*/
109 int fix_actions(struct action* a);
110 int fix_expr(struct expr* exp);
111
112
113
114 #endif