[asterisk-bugs] [JIRA] (ASTERISK-22886) CDRs: Applications that manipulate CDRs are out of step with engine, creating unpredictable results
Matt Jordan (JIRA)
noreply at issues.asterisk.org
Thu Nov 21 17:26:03 CST 2013
Matt Jordan created ASTERISK-22886:
--------------------------------------
Summary: CDRs: Applications that manipulate CDRs are out of step with engine, creating unpredictable results
Key: ASTERISK-22886
URL: https://issues.asterisk.org/jira/browse/ASTERISK-22886
Project: Asterisk
Issue Type: Bug
Components: CDR/General
Affects Versions: 12.0.0-beta1
Reporter: Matt Jordan
CDRs are now generated by consuming messages from the Stasis message bus. This has had the advantage of decoupling CDR code from the Asterisk core, making CDRs more predictable and maintainable.
One downside however has been that the channels producing state for the CDRs are now operating on different threads than the actual maintenance of the CDR records. This means that dialplan applications that manipulate CDRs, such as ForkCDR, ResetCDR, and NoCDR (as well CDR_PROPSET) manipulate CDR data that may be 'stale', in that updates to the records are currently in flight.
>From a testing perspective, this has made verifying ForkCDR in particular problematic. From a longer term perspective, the potential exists for the wrong CDR record to get disabled, enabled, forked, etc.
In general, these applications should not be directly manipulating the CDRs. They should instead be raising a message on the Stasis message bus that the CDR engine interprets when the message is serviced.
More strangely, we could actually use the act of entering into the dialplan application as a mechanism to trigger the application. That is, the entry point of app_forkcdr is a NoOp that simply returns success, but the module itself has registered a Stasis message handler that looks at all channel messages and, if it sees an application message that matches ForkCDR, it handles it and directly manipulates the CDR engine.
That would be odd, but would work as well as generating an additional message for the bus.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.asterisk.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the asterisk-bugs
mailing list