El Jueves, 21 de Agosto de 2008, Iñaki Baz Castillo escribió:
El Jueves, 21 de Agosto de 2008, troxlinux escribió:
ok aquí va aunque es un buen trozo , lo que me tiene con duda es ese 500 error, viendo la tablita de Response codes de los rfc , lo califica como un Internal server error ..
Lo que está ocurriendo 8otra cosa es "porqué") es que OpenSer acepta el INVITE y se lo manda a Asterisk. Pero **a la vez** está respondiendo un "500" al tfno. Este 500 acaba la transacción (el tfno envía ACK).
Luego Asterisk responde con un 200 que llega a OpenSer quien lo envía al teléfono [*].
Pero ese 200 no tiene ningún sentido en el tfno puesto que ya había recibido una respuesta final (el 500) por lo que el tfno lo ignora y Asterisk lo sigue reenviando un montón de veces en espera del ACK, hasta que expira el timer correspondiente.
[*] Ese 200 es reenviado por OpenSer al tfno de forma "stateless" puesto que la transacción ya había sido destruida.
En cuanto al porqué... buff, ni idea.
- ¿Cómo haces el envío a Asterisk en el config de OpenSer?
- ¿Usas append_branch() para algo?
- ¿Usas on_branch_route[] para algo?
Ya sé cuál es tu fallo:
------------------------- route[1] { if (!t_relay()) { sl_reply_error(); }; exit; }
[...]
if (uri=~"^sip:[2-9][0-9]{7}@.*") { rewritehostport("192.168.10.1:5070"); xlog(" ---> forwarded to Asterisk ---> "); t_relay(); route(1); }; ------------------------
Estás llamando dos veces a "t_relay". La segunda vez falla **porque ya ha sido enviado** y genera un error que se envía en forma stateless (sl_reply_error), de ahí que el error sea interno (500) y con frase: "Server error occurred (19/SL)"
Quita el "t_relay" justo antes de "route(1)".
;)
-------------------------