[OpenSIPS-Devel] [OpenSIPS-Users] [Request for Brain[storming]] New types of routes in config

Bogdan-Andrei Iancu bogdan at voice-system.ro
Tue Apr 28 14:56:45 CEST 2009


Hi Thomas,

Thomas Gelf wrote:
> Hi Bogdan,
>
> here my 2 Euro Cents, following your brainstorm request:
>
>
>   
>> 1. Init Route (new)
>>     
>
> Personally I do not have immmediate need for this feature, but as soon
> as I start digging into memcache support it will be really useful. As
> it also shouldn't be that hard to implement: please do it!
>   
yes, it is not hard to do it, and as time as it brings some added value, 
why not :)
>   
>> 2. Reply Route (change)
>>     
>
> I have encountered some issues, for example with uac_replace_from calls
> for specific branches - I'm pretty sure such an enhancement would clean
> up such scenarios / make them easier to implement.
>
> The following should IMO be possible:
>
> route[] {
>     t_on_reply(1);
> }
>
> branch_route[] {
>     if (whatever) {
>         # this will not affect other branches
>         t_on_reply(2);
>     }
> }
>
> If this is how it would work: great, I would really welcome such an
> enhancement.
>   

yes, that's my idea - if you set onreply_route from request_route -> it 
will be used for all branches; but if you set it from Branch_route -> 
only for that branch.

>
>   
>> 3. Reply Route (change) versus branch_completed Route
>>     
>
> To summarize my questions / your explainations on IRC:
>
> - branch_completed[] will be triggered when a branch is completed = when
>   a final response is received on that branch (reply >=200)
> - Calling drop() in branch_completed[] will prevent failure_route from
>   being triggered for replies >=400
> - When triggering a new branch in branch_completed[], minor branches
>   will still remain active and are not going to be CANCELed
>
> This seems very useful and would allow clean routing scripts for complex
> scenarios. I would welcome also this addition!
>   

so you are in favour of branch_complete route, instead of chaginf the 
reply_route to allow new branch creation? Actually, thinking more on 
this, these 2 approaches do not exclude one each other :D
>
>   
>> 4. Timer based route
>>     
>
> This ould be a nice feature. It's not something I have immediate need
> for - and I guess it could be tricky to implement it, probably with some
> side effects... If you want to face the challenge: feel free to do so ;)
>
> My personal favourites are 2. and 3. - 1. should not be that hard, and
> if there is enough time and interest for 4.: I'm absolutely not against
> it. Can someone provide a concrete example where this could make sense?
>   
An example was on the mailing list - asyncron parallel forking (instead 
of firing all branches in the same time, they will fired with some delays).
> And: we would also need individual timeouts for each delayed branch,
> correct?
>   
timeout per branch during parallel forking? interesting.....I guess it 
can be done....

Regards,
Bogdan



More information about the Devel mailing list