pkg/kamailio/fedora/16: Updated rel in .spec to dev2
[sip-router] / TODO
1 $Id$
2
3 ( - todo, x - done)
4 x change subst_run/str to return error (different from not found)
5 x change subst_user as on serdev
6 x tm : fake_env: fake also bind_address (else the default will be used
7  in the failure route)
8 - [core] parse_uri support for new uri params
9 x [core] on sig_child, kill the processes if they don't exit in a 
10   reasonable time
11 - [doc] document force_rport()
12 - [fifo] fix fgets error handling (it does not set errno always,
13    , right now kills all ser if interrupted by a signal on ?solaris?)
14 - [mem] make shm_realloc be fragmentation friendly: call shm_compact_frags
15    for the small frags?, don't produce smaller frags -- be wastefull?
16 - [mem] qm_compact_frags (compacts frags if possible), keep a 
17         fragment count/bucket and if too much mem. is blocked in one bucket
18         de-frag.
19 x [mem] investigate: don't produce frag if frag size < request
20       (should reduce the unrequested fragments number)
21 x [mem] investigate: keep an used/unused flag per fragment, on free
22       check if neighboring frags were not used and if so defragment
23 - [timer] multiple timers? at least ticks should no be affected by the amount
24    of work done in the timer handlers
25 - [tcp] ser intiated tcp connections use INADDR_ANY (they should be bound first
26   to some ip/port ?function of the dest?)
27 - [tcp] need to confirm fd receipt after send_fd, before closing it (this might
28  happen in tcp_send new conn.) (see FreeBSD send BUGS for more info)
29 x [tcp] make send_all, send  non-blocking ready ?
30 x [tcp] tcp_send w/ timeout (to avoid waiting forever to send DOS)
31
32 - forward port fixes from testing
33 - [udp] use recvmsg to get the dst ip address in udp_rcv_loop
34  (it won't work on solaris, but...)
35 x nathelper: extract_body broken-> uses content_length value form the 
36  message instead of recalculating it + duplicate code for get_body()
37 - fix check_sel_op -- add proto for uri proto checks
38 - [tcp] add setting for infinite tcp conn life?
39
40 - fix 2 different fixups for diff. no of parameter
41  (add no of params to struct action?) -- linked to var. no. of params
42 x alias support fot tcp/tls port numbers
43 - warning builder set_advertised address support
44 - grep parse_uri & replace with parse_sip_msg_uri (e.g do_action!)
45 x update AUTHORS, debian/copyright, ser.8, ser.cfg.5 from stable
46 x update Makefile*  from stable
47 x update all package specs from stable
48 - [tcp] add BUG checks for  fd > 0 && fd <= maxfd to all selects?
49 - [tcp] switch to poll if HAVE_POLL defined (it's unifix so  everybody 
50    should have it, but it would be slower on systems emulating it, like
51    older linuxes)
52 - [tcp] switch to epoll if HAVE_EPOLL defined (linux 2.6.*)
53 - [tcp] switch to SIGIO if no epoll (linux only, better than poll)
54 x tcp_main_loop: BUG cases should "conitnue;"
55 x change len_gt into and expr (e.g msg:len).
56 x sipit: uri == myself doesn't match tls port = 5061 
57   -- updated: new socket_info list code should fix it
58 x sipit: fix check_self & *_alias to work with tcp & tls
59   -- updated: new socket_info list code should fix it
60 x sipit: fix ipv6 references in check_self
61 x regex subst on uris?
62 x port receive.c pre_script_cb fix from stable
63 x extend alias to include port numbers :
64     something like alias= foo1.bar:5080 foo2.bar foo3.bar:*
65 x extend listen and alias to include port numbers and protocol:
66        tcp foo.bar:5063, udp foo.bar:5062, foo2.bar
67 x added set_advertised_{address,port} -- was: add force_via, force_srcip a.s.o
68 (the advertised addresses should be overwritable from the script).
69 x ? add force_outbound_socket(ip)? (choose an apropriate socket from the
70  listen list for sending the msg; works on udp only)
71
72 release:
73 - unlink_timer_lists -- unsafe ???
74 x print_cseq_num max. size fix.
75 x backport: tcp conn id fix to stable + destroy_tcp 
76 x backport: acc mem. leak fixes
77 x backport: dns mem. leak fixes (resolve.[ch])
78 x backport: id_builder receive_msg mem. leak (msg_translator.c)
79 x backport: check_self ipv6/case fixes (forward.c)
80 x change tcp timeouts to 2 or 3 min?
81 x check via ipv6 fixes and backport to stable
82 x fix kill(0, SIGTERM) on startup error (will kill also the launching shell
83  if non-interactive)
84 - fix modules destroy (some modules will try to free uninitialized resources
85    if modules_init was not called first)
86 x fix CC_VER bug in newer Makefile (move DEFS after CC?)
87 x openbsd 3.2 packages -> doc in share/doc (and not in doc)
88 - openbsd 3.2 -> add jabber and mysql to the package
89 x fix modules makefiles (so that cd modules/foo; make will also link the proper
90    libs)
91 x fix -march=..., or compile w/ i386 for the release
92 x resolver should resolve [ipv6]
93 x remove parse_uri debugging info
94 - fix DBG("<%.*s>", len, _null_)
95 x add -t, -w, -u -g equivalents to the config file
96 x force add rport : force_rport()
97 - kill all the fprintf
98 see also tcp & tm
99
100
101
102 not so critical:
103 x replace  remaining mallocs/frees at least in msg_translator.c
104 - add $(INCLUDES) to the Makefiles
105 x make ser suncc ready
106 - fix parse_cseq!!! (it doesnt parse 1234\n INVITE a.s.o)
107 x fix 0 parameter module f. call
108 x better Via parsing (handle ' ' in uri, eg: foo.bar : 1234 ; received=) and
109  ipv6 addresses ([fec0:aa::01]).
110 - fix format string vulnerability in log()
111 - fix alignment access problems (warning on Sun)
112 x (different way) add request header bitmap field for the modules
113 - introduce variables & function in the script language (cfg. file)
114 - ? variable number of params functions in script (no longer limited to 2)?
115 - kill bind_idx
116 x fix bind_address for tcp (in some  way)
117 x add conflict in debs/rpms/etc (conflict w/ older ser-mysql, ser-jabber)
118 x new packages ser-radius etc
119 x tcp_destroy (called on ser exit)
120 - BUG:?? ipv6 only and try to send to ipv4 => getsendsocket=>0 (send_ipv6=0)
121   the reverse is also true
122 - SUBST lumps for replies (involves setting the send_socket in forward_reply, 
123   before build_res_from_res, & adding it to buid_res_from_res).
124
125
126 High priority:
127 x- parse_uri should not copy anymore the uri members (and it should not 0
128  terminate them anylonger).
129 x fix/replace T_REF/T_UNREF
130 x review all the tm locking
131 x if () {} else {}
132 x plugin interface
133 x ipv6 support
134 x reply ("response line")
135 x drop ACKs for our replies
136 x add To-tag (for the replies)
137 x add User-Agent (for the replies)
138
139 Low priority:
140 - icmp error handling
141 x fix via address someday
142 - fix listen=0.0.0.0 case (see [udp] use recvmsg...)
143 x forward to received= if present
144 - make it easier to register a statically linkable module.
145 x add support for -u user and -g group (not only -u uid, -g uid)
146 x change uid/gid after opening the sockets
147 - exec improvments (add format strings to it)
148 x command line switch for checking the config file syntax
149 - config file version (a la sendmail)
150 0 loop detection
151 - cfg. file reload
152 - flags for using names or ip adresses in Via ?
153 - escape char injection/printing fix (verify all log/printed messages
154  for terminal escapes and remove them)
155
156 x handle SIGCHLD, SIGHUP
157 - use a  standard lex compatible .lex format (instead of flex)
158 x try & use native compiler & ld if possible
159
160 x make install
161 x init.d scripts (and rc.local? for *BSD or Slackware)
162 x man page
163 - autoconf scripts
164 x Debian package build files
165 x the same for rpm
166 x the same for *BSD
167
168
169 x jku: branch hash computation over canonical values
170 0 jku: loop checking
171 - jku: try CRC as opposed to MD5
172
173
174 x freopen stdin, stdout, stderr to /dev/null
175 - add a section on building ser & configuring it for maximum performance
176  (-DF_MALLOC, -DNO_DBG, ... sip_warning=0, a.s.o)
177 x add src_port, dst_port, proto to cfg.{y,lex}
178 x generic locking lib
179 x convert tm to use new locking lib
180
181 optimizations:
182 - better timer interface with hashes (a la openbsd)
183 - change lumps (flags for malloc type, recursive? see COND lumps )
184 - atomic ops?
185 - assembly for some very common used function
186 - getsock* cache
187 - fd cache for tcp_send
188 - dns cache? (see DNS)
189 - make option to use openssl MD5 (HMAC_Init(hmac_ctx, (void*)key, 16, md5_md))
190  [ 0.9.7 version is really fast ]
191
192
193 tcp stuff:
194 x timeout on long sends
195 x tcp disable nagle 
196 x set TOS to minimize delay
197 x tcp locking/atomic ops review
198 - tcp fix simultaneous connects (ser process is blocked until connect timeouts
199  => possible DOS)
200
201 tm optimizations:
202
203 - inline/macro/drop for: get_tm_table, set_kr, lock_hash, unlock_hash,
204   set_t, get_t
205 - replace snprintfs int build_uac_request, *_dlg
206 - fix the huge param no. in this functions (use structs if neccessary):
207   build_uac_request, build_uac_request_dlg, t_uac, t_uac_dlg
208 - uri2proxy - t_uac_dlg => extra malloc/free (no ├╝roxy needed here)
209   
210 dns stuff:
211  - dns cache
212  - support for NAPTR (naptr(domain, pref_proto)=> srv_rec + proto => srv(srv_rec, proto) => A or AAAA => A/AAAA(name))
213  - support for fallback (inside the same A/AAAA record, other ip; if fails => other SRV ; if it fails too other NAPTR
214 [see rfc3263]