Module: sip-router
Branch: master
Commit: a3fe154263bd4c94e53c55ea7af42cf6e1952cd5
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=a3fe154…
Author: Miklos Tirpak <miklos(a)iptel.org>
Committer: Miklos Tirpak <miklos(a)iptel.org>
Date: Fri Jul 10 15:58:17 2009 +0200
tm: check whether or not 100 response has already been sent
- Do not send the 100 Trying response when it has already been sent
The script writer can do it for example before t_relay().
---
modules/tm/t_funcs.c | 5 +++--
modules/tm/t_suspend.c | 4 +++-
2 files changed, 6 insertions(+), 3 deletions(-)
diff --git a/modules/tm/t_funcs.c b/modules/tm/t_funcs.c
index aa7d1f4..33d141d 100644
--- a/modules/tm/t_funcs.c
+++ b/modules/tm/t_funcs.c
@@ -342,8 +342,9 @@ int t_relay_to( struct sip_msg *p_msg , struct proxy_l *proxy, int proto,
/* INVITE processing might take long, particularly because of DNS
look-ups -- let upstream know we're working on it */
- if (p_msg->REQ_METHOD==METHOD_INVITE && (t->flags&T_AUTO_INV_100))
- {
+ if (p_msg->REQ_METHOD==METHOD_INVITE && (t->flags&T_AUTO_INV_100)
+ && (t->uas.status < 100)
+ ) {
DBG( "SER: new INVITE\n");
if (!t_reply( t, p_msg , 100 ,
cfg_get(tm, tm_cfg, tm_auto_inv_100_r)))
diff --git a/modules/tm/t_suspend.c b/modules/tm/t_suspend.c
index f05e7eb..c8527a5 100644
--- a/modules/tm/t_suspend.c
+++ b/modules/tm/t_suspend.c
@@ -65,7 +65,9 @@ int t_suspend(struct sip_msg *msg,
/* send a 100 Trying reply, because the INVITE processing
will probably take a long time */
- if (msg->REQ_METHOD==METHOD_INVITE && (t->flags&T_AUTO_INV_100)) {
+ if (msg->REQ_METHOD==METHOD_INVITE && (t->flags&T_AUTO_INV_100)
+ && (t->uas.status < 100)
+ ) {
if (!t_reply( t, msg , 100 ,
"trying -- your call is important to us"))
DBG("SER: ERROR: t_suspend (100)\n");
Bugs item #2819457, was opened at 2009-07-10 10:47
Message generated for change (Comment added) made by baron76
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: modules
Group: ver 1.5.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Alexandr Dubovikov (baron76)
Assigned to: Nobody/Anonymous (nobody)
Summary: dialog module. BYE with bad Cseq.
Initial Comment:
the dialog module in timeout BYE request send thru tm_module Cseq number from INVITE.
dlg_req_within.c:
function:
dlg_t * build_dlg_t(struct dlg_cell * cell, int dir){
line:
td->loc_seq.value = loc_seq;
if before final 200 OK, we will recieve PRACK/200 (new Cseq) , the dialog module will send bad Cseq number (loc_seq + 1);
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3) -
---------- timeout ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
Quickly Solution:
td->loc_seq.value = loc_seq + 100;
----------------------------------------------------------------------
>Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 16:02
Message:
should but didn't.
because dlg_onroute check record-route param. If the param is not present,
than ignored this message.
if ( seq_match_mode!=SEQ_MATCH_NO_ID ) {
if( d_rrb.get_route_param( req, &rr_param, &val)!=0) {
LM_DBG("Route param '%.*s' not found\n",
rr_param.len,rr_param.s);
if (seq_match_mode==SEQ_MATCH_STRICT_ID )
return;
}
default value for dlg_match_mode is 0;
so. should works only in dlg_match_mode 2
2 - DID_NONE - the match is done exclusively based on SIP elements; no DID
information is added in RR.
.
so fix should be anyway. Or default value set to 2, or loc_cseq +100 or a
notice in the README: "in 100rel mode, use only dlg_match_mode 2.
Daniel. you should decide. :-)
----------------------------------------------------------------------
Comment By: Nobody/Anonymous (nobody)
Date: 2009-07-10 15:22
Message:
CSeq should be increased in dialog module also for PRACKs.
What's the original problem? Is dialog module not able to detect the PRACK
as belonging to the dialog?
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 15:19
Message:
ok, in this case we couldn't remove Require, but can use this solution:
http://www.faqs.org/rfcs/rfc3261.html
8.2.2.3 Require
UAC->UAS: INVITE sip:watson@bell-telephone.com SIP/2.0
Require: 100rel
UAS->UAC: SIP/2.0 420 Bad Extension
Unsupported: 100rel
This behavior ensures that the client-server interaction will
proceed without delay when all options are understood by both
sides, and only slow down if options are not understood (as in the
example above). For a well-matched client-server pair, the
interaction proceeds quickly, saving a round-trip often required
by negotiation mechanisms. In addition, it also removes ambiguity
when the client requires features that the server does not
understand. Some features, such as call handling fields, are only
of interest to end systems.
anyway, all ways are posible. But as I told before, just make loc_seq
+=100;
it will be enougth.
Wbr,
Alexandr
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 14:37
Message:
Imagine that the UAC uses "Require: 100rel" instead of "Supported". The
header cannot be removed or the call won't take place.
A proxy shouldn't play to be god :)
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:56
Message:
> and PRACK/200 ok in the dialog. But I think, the best solution, set
and PRACK/200 are not ok in the dialog. But I think, the best solution,
set
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:55
Message:
Hi miconda,
much better remove_hf("Supported:") from INVITE request; :-)
and PRACK/200 ok in the dialog. But I think, the best solution, set
loc_seq +100.
P.S. don't forget about UPDATE method.
----------------------------------------------------------------------
Comment By: Daniel-Constantin Mierla (miconda)
Date: 2009-07-10 13:48
Message:
quick fix: reply pracks on server, with sl_send_reply() as they just get
into config?!?!
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 12:59
Message:
This is a good example of why a proxy shouldn't try to behave as a B2BUA
XD
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 10:50
Message:
oops:
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3 PRACK) -
<---- 200 OK ( Cseq: 1 INVITE) -
---------- timeout dialog ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Bugs item #2819457, was opened at 2009-07-10 08:47
Message generated for change (Comment added) made by nobody
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: modules
Group: ver 1.5.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Alexandr Dubovikov (baron76)
Assigned to: Nobody/Anonymous (nobody)
Summary: dialog module. BYE with bad Cseq.
Initial Comment:
the dialog module in timeout BYE request send thru tm_module Cseq number from INVITE.
dlg_req_within.c:
function:
dlg_t * build_dlg_t(struct dlg_cell * cell, int dir){
line:
td->loc_seq.value = loc_seq;
if before final 200 OK, we will recieve PRACK/200 (new Cseq) , the dialog module will send bad Cseq number (loc_seq + 1);
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3) -
---------- timeout ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
Quickly Solution:
td->loc_seq.value = loc_seq + 100;
----------------------------------------------------------------------
Comment By: Nobody/Anonymous (nobody)
Date: 2009-07-10 13:22
Message:
CSeq should be increased in dialog module also for PRACKs.
What's the original problem? Is dialog module not able to detect the PRACK
as belonging to the dialog?
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:19
Message:
ok, in this case we couldn't remove Require, but can use this solution:
http://www.faqs.org/rfcs/rfc3261.html
8.2.2.3 Require
UAC->UAS: INVITE sip:watson@bell-telephone.com SIP/2.0
Require: 100rel
UAS->UAC: SIP/2.0 420 Bad Extension
Unsupported: 100rel
This behavior ensures that the client-server interaction will
proceed without delay when all options are understood by both
sides, and only slow down if options are not understood (as in the
example above). For a well-matched client-server pair, the
interaction proceeds quickly, saving a round-trip often required
by negotiation mechanisms. In addition, it also removes ambiguity
when the client requires features that the server does not
understand. Some features, such as call handling fields, are only
of interest to end systems.
anyway, all ways are posible. But as I told before, just make loc_seq
+=100;
it will be enougth.
Wbr,
Alexandr
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 12:37
Message:
Imagine that the UAC uses "Require: 100rel" instead of "Supported". The
header cannot be removed or the call won't take place.
A proxy shouldn't play to be god :)
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 11:56
Message:
> and PRACK/200 ok in the dialog. But I think, the best solution, set
and PRACK/200 are not ok in the dialog. But I think, the best solution,
set
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 11:55
Message:
Hi miconda,
much better remove_hf("Supported:") from INVITE request; :-)
and PRACK/200 ok in the dialog. But I think, the best solution, set
loc_seq +100.
P.S. don't forget about UPDATE method.
----------------------------------------------------------------------
Comment By: Daniel-Constantin Mierla (miconda)
Date: 2009-07-10 11:48
Message:
quick fix: reply pracks on server, with sl_send_reply() as they just get
into config?!?!
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 10:59
Message:
This is a good example of why a proxy shouldn't try to behave as a B2BUA
XD
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 08:50
Message:
oops:
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3 PRACK) -
<---- 200 OK ( Cseq: 1 INVITE) -
---------- timeout dialog ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Bugs item #2819457, was opened at 2009-07-10 10:47
Message generated for change (Comment added) made by baron76
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: modules
Group: ver 1.5.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Alexandr Dubovikov (baron76)
Assigned to: Nobody/Anonymous (nobody)
Summary: dialog module. BYE with bad Cseq.
Initial Comment:
the dialog module in timeout BYE request send thru tm_module Cseq number from INVITE.
dlg_req_within.c:
function:
dlg_t * build_dlg_t(struct dlg_cell * cell, int dir){
line:
td->loc_seq.value = loc_seq;
if before final 200 OK, we will recieve PRACK/200 (new Cseq) , the dialog module will send bad Cseq number (loc_seq + 1);
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3) -
---------- timeout ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
Quickly Solution:
td->loc_seq.value = loc_seq + 100;
----------------------------------------------------------------------
>Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 15:19
Message:
ok, in this case we couldn't remove Require, but can use this solution:
http://www.faqs.org/rfcs/rfc3261.html
8.2.2.3 Require
UAC->UAS: INVITE sip:watson@bell-telephone.com SIP/2.0
Require: 100rel
UAS->UAC: SIP/2.0 420 Bad Extension
Unsupported: 100rel
This behavior ensures that the client-server interaction will
proceed without delay when all options are understood by both
sides, and only slow down if options are not understood (as in the
example above). For a well-matched client-server pair, the
interaction proceeds quickly, saving a round-trip often required
by negotiation mechanisms. In addition, it also removes ambiguity
when the client requires features that the server does not
understand. Some features, such as call handling fields, are only
of interest to end systems.
anyway, all ways are posible. But as I told before, just make loc_seq
+=100;
it will be enougth.
Wbr,
Alexandr
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 14:37
Message:
Imagine that the UAC uses "Require: 100rel" instead of "Supported". The
header cannot be removed or the call won't take place.
A proxy shouldn't play to be god :)
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:56
Message:
> and PRACK/200 ok in the dialog. But I think, the best solution, set
and PRACK/200 are not ok in the dialog. But I think, the best solution,
set
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:55
Message:
Hi miconda,
much better remove_hf("Supported:") from INVITE request; :-)
and PRACK/200 ok in the dialog. But I think, the best solution, set
loc_seq +100.
P.S. don't forget about UPDATE method.
----------------------------------------------------------------------
Comment By: Daniel-Constantin Mierla (miconda)
Date: 2009-07-10 13:48
Message:
quick fix: reply pracks on server, with sl_send_reply() as they just get
into config?!?!
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 12:59
Message:
This is a good example of why a proxy shouldn't try to behave as a B2BUA
XD
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 10:50
Message:
oops:
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3 PRACK) -
<---- 200 OK ( Cseq: 1 INVITE) -
---------- timeout dialog ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Bugs item #2819457, was opened at 2009-07-10 10:47
Message generated for change (Comment added) made by ibc_sf
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: modules
Group: ver 1.5.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Alexandr Dubovikov (baron76)
Assigned to: Nobody/Anonymous (nobody)
Summary: dialog module. BYE with bad Cseq.
Initial Comment:
the dialog module in timeout BYE request send thru tm_module Cseq number from INVITE.
dlg_req_within.c:
function:
dlg_t * build_dlg_t(struct dlg_cell * cell, int dir){
line:
td->loc_seq.value = loc_seq;
if before final 200 OK, we will recieve PRACK/200 (new Cseq) , the dialog module will send bad Cseq number (loc_seq + 1);
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3) -
---------- timeout ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
Quickly Solution:
td->loc_seq.value = loc_seq + 100;
----------------------------------------------------------------------
>Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 14:37
Message:
Imagine that the UAC uses "Require: 100rel" instead of "Supported". The
header cannot be removed or the call won't take place.
A proxy shouldn't play to be god :)
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:56
Message:
> and PRACK/200 ok in the dialog. But I think, the best solution, set
and PRACK/200 are not ok in the dialog. But I think, the best solution,
set
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:55
Message:
Hi miconda,
much better remove_hf("Supported:") from INVITE request; :-)
and PRACK/200 ok in the dialog. But I think, the best solution, set
loc_seq +100.
P.S. don't forget about UPDATE method.
----------------------------------------------------------------------
Comment By: Daniel-Constantin Mierla (miconda)
Date: 2009-07-10 13:48
Message:
quick fix: reply pracks on server, with sl_send_reply() as they just get
into config?!?!
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 12:59
Message:
This is a good example of why a proxy shouldn't try to behave as a B2BUA
XD
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 10:50
Message:
oops:
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3 PRACK) -
<---- 200 OK ( Cseq: 1 INVITE) -
---------- timeout dialog ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Bugs item #2819457, was opened at 2009-07-10 10:47
Message generated for change (Comment added) made by baron76
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: modules
Group: ver 1.5.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Alexandr Dubovikov (baron76)
Assigned to: Nobody/Anonymous (nobody)
Summary: dialog module. BYE with bad Cseq.
Initial Comment:
the dialog module in timeout BYE request send thru tm_module Cseq number from INVITE.
dlg_req_within.c:
function:
dlg_t * build_dlg_t(struct dlg_cell * cell, int dir){
line:
td->loc_seq.value = loc_seq;
if before final 200 OK, we will recieve PRACK/200 (new Cseq) , the dialog module will send bad Cseq number (loc_seq + 1);
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3) -
---------- timeout ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
Quickly Solution:
td->loc_seq.value = loc_seq + 100;
----------------------------------------------------------------------
>Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:56
Message:
> and PRACK/200 ok in the dialog. But I think, the best solution, set
and PRACK/200 are not ok in the dialog. But I think, the best solution,
set
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:55
Message:
Hi miconda,
much better remove_hf("Supported:") from INVITE request; :-)
and PRACK/200 ok in the dialog. But I think, the best solution, set
loc_seq +100.
P.S. don't forget about UPDATE method.
----------------------------------------------------------------------
Comment By: Daniel-Constantin Mierla (miconda)
Date: 2009-07-10 13:48
Message:
quick fix: reply pracks on server, with sl_send_reply() as they just get
into config?!?!
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 12:59
Message:
This is a good example of why a proxy shouldn't try to behave as a B2BUA
XD
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 10:50
Message:
oops:
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3 PRACK) -
<---- 200 OK ( Cseq: 1 INVITE) -
---------- timeout dialog ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Bugs item #2819457, was opened at 2009-07-10 10:47
Message generated for change (Comment added) made by baron76
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: modules
Group: ver 1.5.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Alexandr Dubovikov (baron76)
Assigned to: Nobody/Anonymous (nobody)
Summary: dialog module. BYE with bad Cseq.
Initial Comment:
the dialog module in timeout BYE request send thru tm_module Cseq number from INVITE.
dlg_req_within.c:
function:
dlg_t * build_dlg_t(struct dlg_cell * cell, int dir){
line:
td->loc_seq.value = loc_seq;
if before final 200 OK, we will recieve PRACK/200 (new Cseq) , the dialog module will send bad Cseq number (loc_seq + 1);
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3) -
---------- timeout ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
Quickly Solution:
td->loc_seq.value = loc_seq + 100;
----------------------------------------------------------------------
>Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 13:55
Message:
Hi miconda,
much better remove_hf("Supported:") from INVITE request; :-)
and PRACK/200 ok in the dialog. But I think, the best solution, set
loc_seq +100.
P.S. don't forget about UPDATE method.
----------------------------------------------------------------------
Comment By: Daniel-Constantin Mierla (miconda)
Date: 2009-07-10 13:48
Message:
quick fix: reply pracks on server, with sl_send_reply() as they just get
into config?!?!
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 12:59
Message:
This is a good example of why a proxy shouldn't try to behave as a B2BUA
XD
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 10:50
Message:
oops:
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3 PRACK) -
<---- 200 OK ( Cseq: 1 INVITE) -
---------- timeout dialog ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Bugs item #2819457, was opened at 2009-07-10 11:47
Message generated for change (Comment added) made by miconda
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: modules
Group: ver 1.5.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Alexandr Dubovikov (baron76)
Assigned to: Nobody/Anonymous (nobody)
Summary: dialog module. BYE with bad Cseq.
Initial Comment:
the dialog module in timeout BYE request send thru tm_module Cseq number from INVITE.
dlg_req_within.c:
function:
dlg_t * build_dlg_t(struct dlg_cell * cell, int dir){
line:
td->loc_seq.value = loc_seq;
if before final 200 OK, we will recieve PRACK/200 (new Cseq) , the dialog module will send bad Cseq number (loc_seq + 1);
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3) -
---------- timeout ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
Quickly Solution:
td->loc_seq.value = loc_seq + 100;
----------------------------------------------------------------------
>Comment By: Daniel-Constantin Mierla (miconda)
Date: 2009-07-10 14:48
Message:
quick fix: reply pracks on server, with sl_send_reply() as they just get
into config?!?!
----------------------------------------------------------------------
Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 13:59
Message:
This is a good example of why a proxy shouldn't try to behave as a B2BUA
XD
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 11:50
Message:
oops:
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3 PRACK) -
<---- 200 OK ( Cseq: 1 INVITE) -
---------- timeout dialog ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Bugs item #2819457, was opened at 2009-07-10 10:47
Message generated for change (Comment added) made by ibc_sf
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…
Please note that this message will contain a full copy of the comment thread,
including the initial issue submission, for this request,
not just the latest update.
Category: modules
Group: ver 1.5.x
Status: Open
Resolution: None
Priority: 5
Private: No
Submitted By: Alexandr Dubovikov (baron76)
Assigned to: Nobody/Anonymous (nobody)
Summary: dialog module. BYE with bad Cseq.
Initial Comment:
the dialog module in timeout BYE request send thru tm_module Cseq number from INVITE.
dlg_req_within.c:
function:
dlg_t * build_dlg_t(struct dlg_cell * cell, int dir){
line:
td->loc_seq.value = loc_seq;
if before final 200 OK, we will recieve PRACK/200 (new Cseq) , the dialog module will send bad Cseq number (loc_seq + 1);
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3) -
---------- timeout ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
Quickly Solution:
td->loc_seq.value = loc_seq + 100;
----------------------------------------------------------------------
>Comment By: Iñaki Baz Castillo (ibc_sf)
Date: 2009-07-10 12:59
Message:
This is a good example of why a proxy shouldn't try to behave as a B2BUA
XD
----------------------------------------------------------------------
Comment By: Alexandr Dubovikov (baron76)
Date: 2009-07-10 10:50
Message:
oops:
Scenario:
----INVITE ( Cseq: 1) ->
<--- 183 ( Cseq: 1) ----
---- PRACK ( Cseq: 3) ->
<---- 200 OK ( Cseq: 3 PRACK) -
<---- 200 OK ( Cseq: 1 INVITE) -
---------- timeout dialog ---->
---- BYE ( Cseq: 2) ->
<------ 503 (Bad CSeq number) -------
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=743020&aid=2819457&group_…