parser: some more const-correctness for the other functions in msg_parser.[c,h]
[sip-router] / etc / sip-router-basic.cfg
1 #
2 # $Id$
3 #
4 # This a very basic config file w/ aliases and a named route but
5 # w/o authentication, accounting, database, multi-domain support etc.
6 # Please refer to sip-router.cfg for a more complete example
7 #
8 # Direct your questions about this file to: <sr-users@lists.sip-router.org>.
9 #
10 # For more information about the various parameters, functions and statements
11 # try http://sip-router.org/wiki/ .
12 #
13
14 #------------ Features -----------------------------------------------
15 # Several extra features can be enabled by adding #!define WITH_<FEATURE>
16 # statements to the config file, or by starting sr/ser with -A WITH_<FEATURE>.
17 # E.g.: ser -f /etc/ser/sip-router-basic.cfg -A WITH_TLS
18
19 # run in debug mode:
20 ##!define WITH_DEBUG
21
22 # enable tls support:
23 ##!define WITH_TLS
24
25 # started from compile directory (not installed)
26 ##!define LOCAL_TEST_RUN
27
28
29 # ----------- global configuration parameters ------------------------
30
31 #!ifdef WITH_DEBUG
32 debug=5
33 log_stderror=yes
34 fork=no
35 #!else
36 debug=2         # debug level (cmd line: -dddddddddd)
37 #!endif
38
39 #memdbg=10 # memory debug message level
40 #memlog=10 # memory statistics log level
41 #log_facility=LOG_LOCAL0 # sets the facility used for logging (see syslog(3))
42
43
44 check_via=no    # (cmd. line: -v)
45 dns=no          # (cmd. line: -r)
46 rev_dns=no      # (cmd. line: -R)
47 #port=5060
48 #children=4
49 #user=sip-router
50 #group=sip-router
51 #disable_core=yes #disables core dumping
52 #open_fd_limit=1024 # sets the open file descriptors limit
53 #mhomed=yes  # usefull for multihomed hosts, small performance penalty
54 #disable_tcp=yes
55 #tcp_accept_aliases=yes # accepts the tcp alias via option (see NEWS)
56 sip_warning=yes
57
58 #!ifdef WITH_TLS
59 enable_tls=yes
60 #!endif
61
62 #
63
64 # ------------------ module loading ----------------------------------
65
66 #!ifdef LOCAL_TEST_RUN
67 loadpath "modules:modules_s"
68 #!else
69 loadpath "/usr/lib/sip-router/modules:/usr/lib/sip-router/modules_s"
70 #!endif
71
72 loadmodule "tm"
73 loadmodule "sl"
74 loadmodule "rr"
75 loadmodule "textops"
76 loadmodule "maxfwd"
77 loadmodule "usrloc"
78 loadmodule "registrar"
79 loadmodule "ctl"
80 loadmodule "cfg_rpc"
81 #!ifdef WITH_TLS
82 loadmodule "tls"
83 #!endif
84
85 # ----------------- setting module-specific parameters ---------------
86
87 # -- usrloc params --
88
89 modparam("usrloc", "db_mode",   0)
90
91 # -- rr params --
92 # add value to ;lr param to make some broken UAs happy
93 modparam("rr", "enable_full_lr", 1)
94
95 # ctl params
96 # by default ctl listens on unixs:/tmp/sip-router_ctl if no other address is
97 # specified in modparams; this is also the default for sercmd
98 modparam("ctl", "binrpc", "unixs:/tmp/ser_ctl")
99 # listen on the "standard" fifo for backward compatibility
100 modparam("ctl", "fifo", "fifo:/tmp/ser_fifo")
101 # listen on tcp, localhost
102 modparam("ctl", "binrpc", "tcp:127.0.0.1:2046")
103
104 #!ifdef WITH_TLS
105 modparam("tls", "verify_certificate", 0)
106 #!ifdef  LOCAL_TEST_RUN
107 modparam("tls", "certificate", "./modules/tls/sip-router-selfsigned.pem")
108 modparam("tls", "private_key", "./modules/tls/sip-router-selfsigned.key")
109 #separate TLS config file
110 #modparam("tls", "config", "./modules/tls/tls.cfg")
111 #!else
112 modparam("tls", "certificate", "ser-selfsigned.pem")
113 modparam("tls", "private_key", "ser-selfsigned.key")
114 #separate TLS config file
115 #modparam("tls", "config", "tls.cfg")
116 #!endif
117 #!endif
118
119
120
121 #!endif
122
123 # -------------------------  request routing logic -------------------
124
125 # main routing logic
126
127 route{
128
129         # initial sanity checks -- messages with
130         # max_forwards==0, or excessively long requests
131         if (!mf_process_maxfwd_header("10")) {
132                 sl_reply("483","Too Many Hops");
133                 break;
134         }
135         if (msg:len >=  4096 ) {
136                 sl_reply("513", "Message too big");
137                 break;
138         }
139
140         # we record-route all messages -- to make sure that
141         # subsequent messages will go through our proxy; that's
142         # particularly good if upstream and downstream entities
143         # use different transport protocol
144         if (!method=="REGISTER") record_route();
145
146         # subsequent messages withing a dialog should take the
147         # path determined by record-routing
148         if (loose_route()) {
149                 # mark routing logic in request
150                 append_hf("P-hint: rr-enforced\r\n");
151                 route(FORWARD);
152                 break;
153         }
154
155         if (!uri==myself) {
156                 # mark routing logic in request
157                 append_hf("P-hint: outbound\r\n");
158                 route(FORWARD);
159                 break;
160         }
161
162         # if the request is for other domain use UsrLoc
163         # (in case, it does not work, use the following command
164         # with proper names and addresses in it)
165         if (uri==myself) {
166
167                 if (method=="REGISTER") {
168                         save_contacts("location");
169                         break;
170                 }
171
172                 # native SIP destinations are handled using our USRLOC DB
173                 if (!lookup_contacts("location")) {
174                         sl_reply("404", "Not Found");
175                         break;
176                 }
177                 append_hf("P-hint: usrloc applied\r\n");
178         }
179         route(FORWARD);
180 }
181
182 route[FORWARD]
183 {
184         # send it out now; use stateful forwarding as it works reliably
185         # even for UDP2TCP
186         if (!t_relay()) {
187                 sl_reply_error();
188         }
189 }
190