mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-26 06:26:41 +00:00 
			
		
		
		
	app_cdr,app_forkcdr,func_cdr: Synchronize with engine when manipulating state
When doing the rework of the CDR engine that pushed all of the logic into cdr.c and made it respond to changes in channel state over Stasis, we knew that accessing the CDR engine from the dialplan would be "slightly" non-deterministic. Dialplan threads would be accessing CDRs while Stasis threads would be updating the state of said CDRs - whereas in the past, everything happened on the dialplan threads. Tests have shown that "slightly" is in reality "very". This patch synchronizes things by making the dialplan applications/functions that manipulate CDRs do so over Stasis. ForkCDR, NoCDR, ResetCDR, CDR, and CDR_PROP now all use Stasis to send their requests over to the CDR engine, and synchronize on the channel Stasis topic via a subscription so that they return their values/control to the dialplan at the appropriate time. While going through this, the following changes were also made: * DISA, which can reset the CDR when a user successfully authenticates, now just uses the ResetCDR app to do this. This prevents having to duplicate the same Stasis synchronization logic in that application. * Answer no longer disables CDRs. It actually didn't work anyway - calling DISABLE on the channel's CDR doesn't stop the CDR from getting the Answer time - it just kills all CDRs on that channel, which isn't what the caller would intend. (closes issue ASTERISK-22884) (closes issue ASTERISK-22886) Review: https://reviewboard.asterisk.org/r/3057/ git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/12@404294 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		| @@ -431,17 +431,13 @@ int ast_cdr_clear_property(const char *channel_name, enum ast_cdr_options option | ||||
| /*! | ||||
|  * \brief Reset the detail record | ||||
|  * \param channel_name The channel that the CDR is associated with | ||||
|  * \param options Options that control what the reset operation does. | ||||
|  * | ||||
|  * Valid options are: | ||||
|  * \ref AST_CDR_FLAG_KEEP_VARS - keep the variables during the reset | ||||
|  * \ref AST_CDR_FLAG_DISABLE_ALL - when used with \ref ast_cdr_reset, re-enables | ||||
|  * the CDR | ||||
|  * \param keep_variables Keep the variables during the reset. If zero, | ||||
|  *        variables are discarded during the reset. | ||||
|  * | ||||
|  * \retval 0 on success | ||||
|  * \retval -1 on failure | ||||
|  */ | ||||
| int ast_cdr_reset(const char *channel_name, struct ast_flags *options); | ||||
| int ast_cdr_reset(const char *channel_name, int keep_variables); | ||||
|  | ||||
| /*! | ||||
|  * \brief Serializes all the data and variables for a current CDR record | ||||
|   | ||||
		Reference in New Issue
	
	Block a user