TODO 8.6 KB

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