Hello

I have a question.  I hope that someone could clarify this to me.

I have the next situation.

I’m using a t_on_failure route along with the LCR module. So I have something like this :

 

failure_route[1] {

        if (t_was_cancelled()) {

                xlog("L_INFO", "[$ci] $rm:$ru t_was_cancelled in failure_route\n");

                exit;

        }

 

        if ( t_check_status("486") ) {

                xlog("L_INFO","[$ci] 486 Received\n");

                        

  }

 

        if (t_check_status("603")) {

                xlog("L_INFO","[$ci] 603 Received\n");

                if (!next_gw()) {

                        t_reply("503", "Service not available, no more gateways");

                        xlog("L_INFO", "[$ci] No hay mas gateways para $rm:$ou\n");

                        exit;

                } else  {

                        xlog("L_INFO", "[$ci] $rm cambiando $ou por $ru en failure_route");

                }

                t_on_failure("1");

        }

        t_relay();

}

 

Maybe I’m misunderstanding how the failure_route works but with this configuration I was expecting that If I have a 603 from the callee I will do the “next_gateway” configuration.  And If I have a 486 I will put a line in the log and then continue with the t_relay. So.. the 486 will be passed to the caller, but with the final answer from the caller ( ACK ) to the 486.. and I’m getting this error…

 

Sep  2 16:43:41 ERROR:tm:t_forward_nonack: no branch for forwarding

Sep  2 16:43:41 ERROR:tm:w_t_relay: t_forward_nonack failed

 

So it seems that tries to forward the ACK with t_relay?

 

Caller     Proxy   Callee

  ------>

       INVITE

               ----->

                    INVITE

              <------

                     486

             ------->

                     ACK

 <------

  486

  ----->  (error?)

       ACK

 

But…

When I modified the next lines in the failure_route

 

        if ( t_check_status("486") ) {

                xlog("L_INFO","[$ci] 486 Received\n");

                 exit;                        

  }

 

And add the “exit” parameter, i don’t have the above error and the “486” is passed back to the caller as “expected”.

 

Can someone explain me this?

 

Thanks in advance..

Regards

 

Ricardo Martinez.-