[OpenSER-Devel] NEW FEATURE: local route for internally generated requests

Bogdan-Andrei Iancu bogdan at voice-system.ro
Fri Jun 6 14:33:56 CEST 2008


Hi,

OpenSER has a new type of route: local route. This route is to be 
executed when a brand new request is internally generated (openser being 
the UAC) ; such requests are result of :
    - t_uac_dlg MI command
    - msilo, sms, presence, cpl-c, dialog (and others) modules


Purpose
========

This need route was added to meet the need to do dynamic manipulation 
(do some checking, adding headers, logging, etc) of the internally 
generated requests; without this new route, these requests were totally 
transparent for the openser script.

Some strong cases there were debated for a long time on the lists:

   - adding new headers into internally generated requests - so far all 
kind of hacks were used to do it (like defining module parameters with 
predefined headers to be added in the request - see presence modules)

   - logging (log or xlog) information about the outgoing requests - see 
the discussion about the presence internal logging

   - accounting - there was no way to account these requests (as 
accounting can be triggered only from script) - see the discussion 
around the dialog module for how to account the BYEs generated by this 
module



How to use
===========

there is a single instance of this route allowed in the configuration:
    local_route {
       ......
    }

Note that not all the functions are allowed to be called from this route 
(better check the docs before)

Example:

    local_route {
       ....
       if (is_method("NOTIFY")) {
          xlog("new $rm sent out for $ru via $du\n");
       }
       ....
       if (is_method("BYE")) {
          acc_log_request("internal bye");
          append_hf("X-note: terminated by dialog module");
       }
       ....
    }



Limitations
============

- you can access RURI and destination uri ($ru and $du), but any change 
of these value will be discarded - you cannot change the destination of 
the request

- there is no transaction persistence (yet) - you cannot set onreply or 
failure routes, flags are not pushed into transaction ; this will be 
probably available in the next version.

- accounting via flags do not work - as this requires transaction 
persistence (see above)



Regards,
Bogdan







More information about the Devel mailing list