[asterisk-commits] murf: trunk r142475 - in /trunk: ./ main/features.c

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Wed Sep 10 17:11:27 CDT 2008


Author: murf
Date: Wed Sep 10 17:11:27 2008
New Revision: 142475

URL: http://svn.digium.com/view/asterisk?view=rev&rev=142475
Log:
Merged revisions 142474 via svnmerge from 
https://origsvn.digium.com/svn/asterisk/branches/1.4

........
r142474 | murf | 2008-09-10 15:58:17 -0600 (Wed, 10 Sep 2008) | 30 lines

(closes issue #12318)
Reported by: krtorio

I made a small change to the code that handles local channel situations.
In that code, I copy the answer time from the peer cdr, to the bridge_cdr,
but I wasn't also copying the disposition from the peer cdr.

So, Now I copy the disposition, and I've tested against 
these cases:

1. phone 1 never answers the phone; no cdr is generated at all.
   this should show up as a manager command failure or something.

2. phone 2 never answers. CDR is generated, says NO ANSWER

3. phone 2 is busy. CDR is generated, says BUSY

4. phone 2 answers: CDR is generated, times are correct; disposition
   is ANSWERED, which is correct. The start time is the time that
   the manager dialed the first phone. The answer time is the time
   the second phone picks up.

I purposely left the cid and src fields blank; since this call really
originates from the manager, there is no 'easy' data to put in these
fields. If you feel strongly that these fields should be filled in,
re-open this bug and I'll dig further.




........

Modified:
    trunk/   (props changed)
    trunk/main/features.c

Propchange: trunk/
------------------------------------------------------------------------------
Binary property 'branch-1.4-merged' - no diff available.

Modified: trunk/main/features.c
URL: http://svn.digium.com/view/asterisk/trunk/main/features.c?view=diff&rev=142475&r1=142474&r2=142475
==============================================================================
--- trunk/main/features.c (original)
+++ trunk/main/features.c Wed Sep 10 17:11:27 2008
@@ -2162,6 +2162,8 @@
 		if (peer->cdr && !ast_tvzero(peer->cdr->answer)) {
 			bridge_cdr->answer = peer->cdr->answer;
 			chan->cdr->answer = peer->cdr->answer;
+			bridge_cdr->disposition = peer->cdr->disposition;
+			chan->cdr->disposition = peer->cdr->disposition;
 		} else {
 			ast_cdr_answer(bridge_cdr);
 			ast_cdr_answer(chan->cdr); /* for the sake of cli status checks */




More information about the asterisk-commits mailing list