<p>George Joseph <strong>submitted</strong> this change.</p><p><a href="https://gerrit.asterisk.org/c/asterisk/+/19746">View Change</a></p><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span></span><br></pre><div style="white-space:pre-wrap">Approvals:
  Joshua Colp: Looks good to me, but someone else must approve
  George Joseph: Looks good to me, approved; Approved for Submit

</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">app_cdr: Remove deprecated application and option.<br><br>This removes the deprecated NoCDR application, which<br>was deprecated in Asterisk 12, having long been fully<br>superseded by the CDR_PROP function.<br><br>The deprecated e option to ResetCDR is also removed<br>for the same reason.<br><br>ASTERISK-30371 #close<br><br>Change-Id: Id9ed094d8e4baf98bcbc610035c2295bfafe9ec0<br>---<br>M apps/app_cdr.c<br>M apps/app_forkcdr.c<br>A doc/UPGRADE-staging/app_cdr.txt<br>3 files changed, 27 insertions(+), 76 deletions(-)<br><br></pre>
<pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/apps/app_cdr.c b/apps/app_cdr.c</span><br><span>index 3e52302..6929088 100644</span><br><span>--- a/apps/app_cdr.c</span><br><span>+++ b/apps/app_cdr.c</span><br><span>@@ -38,26 +38,6 @@</span><br><span> #include "asterisk/stasis_message_router.h"</span><br><span> </span><br><span> /*** DOCUMENTATION</span><br><span style="color: hsl(0, 100%, 40%);">-    <application name="NoCDR" language="en_US"></span><br><span style="color: hsl(0, 100%, 40%);">-           <synopsis></span><br><span style="color: hsl(0, 100%, 40%);">-                        Tell Asterisk to not maintain a CDR for this channel.</span><br><span style="color: hsl(0, 100%, 40%);">-           </synopsis></span><br><span style="color: hsl(0, 100%, 40%);">-               <syntax /></span><br><span style="color: hsl(0, 100%, 40%);">-                <description></span><br><span style="color: hsl(0, 100%, 40%);">-                     <para>This application will tell Asterisk not to maintain a CDR for</span><br><span style="color: hsl(0, 100%, 40%);">-                       the current channel. This does <emphasis>NOT</emphasis> mean that</span><br><span style="color: hsl(0, 100%, 40%);">-                   information is not tracked; rather, if the channel is hung up no</span><br><span style="color: hsl(0, 100%, 40%);">-                        CDRs will be created for that channel.</para></span><br><span style="color: hsl(0, 100%, 40%);">-                     <para>If a subsequent call to ResetCDR occurs, all non-finalized</span><br><span style="color: hsl(0, 100%, 40%);">-                  CDRs created for the channel will be enabled.</para></span><br><span style="color: hsl(0, 100%, 40%);">-                      <note><para>This application is deprecated. Please use the CDR_PROP</span><br><span style="color: hsl(0, 100%, 40%);">-                 function to disable CDRs on a channel.</para></note></span><br><span style="color: hsl(0, 100%, 40%);">-                </description></span><br><span style="color: hsl(0, 100%, 40%);">-            <see-also></span><br><span style="color: hsl(0, 100%, 40%);">-                        <ref type="application">ResetCDR</ref></span><br><span style="color: hsl(0, 100%, 40%);">-                    <ref type="function">CDR_PROP</ref></span><br><span style="color: hsl(0, 100%, 40%);">-               </see-also></span><br><span style="color: hsl(0, 100%, 40%);">-       </application></span><br><span>         <application name="ResetCDR" language="en_US"></span><br><span>             <synopsis></span><br><span>                     Resets the Call Data Record.</span><br><span>@@ -68,10 +48,6 @@</span><br><span>                                    <option name="v"></span><br><span>                                            <para>Save the CDR variables during the reset.</para></span><br><span>                                    </option></span><br><span style="color: hsl(0, 100%, 40%);">-                                 <option name="e"></span><br><span style="color: hsl(0, 100%, 40%);">-                                               <para>Enable the CDRs for this channel only (negate</span><br><span style="color: hsl(0, 100%, 40%);">-                                               effects of NoCDR).</para></span><br><span style="color: hsl(0, 100%, 40%);">-                                 </option></span><br><span>                              </optionlist></span><br><span>                  </parameter></span><br><span>           </syntax></span><br><span>@@ -84,21 +60,14 @@</span><br><span>                        current time.</para></span><br><span>                   <para>3. All variables are wiped from the CDR. Note that this step</span><br><span>                     can be prevented with the <literal>v</literal> option.</para></span><br><span style="color: hsl(0, 100%, 40%);">-                 <para>On the other hand, if the <literal>e</literal> option is</span><br><span style="color: hsl(0, 100%, 40%);">-                        specified, the effects of the NoCDR application will be lifted. CDRs</span><br><span style="color: hsl(0, 100%, 40%);">-                    will be re-enabled for this channel.</para></span><br><span style="color: hsl(0, 100%, 40%);">-                       <note><para>The <literal>e</literal> option is deprecated. Please</span><br><span style="color: hsl(0, 100%, 40%);">-                       use the CDR_PROP function instead.</para></note></span><br><span>                 </description></span><br><span>                 <see-also></span><br><span>                     <ref type="application">ForkCDR</ref></span><br><span style="color: hsl(0, 100%, 40%);">-                     <ref type="application">NoCDR</ref></span><br><span>                    <ref type="function">CDR_PROP</ref></span><br><span>            </see-also></span><br><span>    </application></span><br><span>  ***/</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-static const char nocdr_app[] = "NoCDR";</span><br><span> static const char resetcdr_app[] = "ResetCDR";</span><br><span> </span><br><span> enum reset_cdr_options {</span><br><span>@@ -109,7 +78,6 @@</span><br><span> </span><br><span> AST_APP_OPTIONS(resetcdr_opts, {</span><br><span>         AST_APP_OPTION('v', AST_CDR_FLAG_KEEP_VARS),</span><br><span style="color: hsl(0, 100%, 40%);">-    AST_APP_OPTION('e', AST_CDR_FLAG_DISABLE_ALL),</span><br><span> });</span><br><span> </span><br><span> STASIS_MESSAGE_TYPE_DEFN_LOCAL(appcdr_message_type);</span><br><span>@@ -118,10 +86,6 @@</span><br><span> struct app_cdr_message_payload {</span><br><span>  /*! The name of the channel to be manipulated */</span><br><span>     const char *channel_name;</span><br><span style="color: hsl(0, 100%, 40%);">-       /*! Disable the CDR for this channel */</span><br><span style="color: hsl(0, 100%, 40%);">- unsigned int disable:1;</span><br><span style="color: hsl(0, 100%, 40%);">- /*! Re-enable the CDR for this channel */</span><br><span style="color: hsl(0, 100%, 40%);">-       unsigned int reenable:1;</span><br><span>     /*! Reset the CDR */</span><br><span>         unsigned int reset:1;</span><br><span>        /*! If reseting the CDR, keep the variables */</span><br><span>@@ -141,24 +105,9 @@</span><br><span>                return;</span><br><span>      }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-   if (payload->disable) {</span><br><span style="color: hsl(0, 100%, 40%);">-              if (ast_cdr_set_property(payload->channel_name, AST_CDR_FLAG_DISABLE_ALL)) {</span><br><span style="color: hsl(0, 100%, 40%);">-                 ast_log(AST_LOG_WARNING, "Failed to disable CDRs on channel %s\n",</span><br><span style="color: hsl(0, 100%, 40%);">-                            payload->channel_name);</span><br><span style="color: hsl(0, 100%, 40%);">-              }</span><br><span style="color: hsl(0, 100%, 40%);">-       }</span><br><span style="color: hsl(0, 100%, 40%);">-</span><br><span style="color: hsl(0, 100%, 40%);">-       if (payload->reenable) {</span><br><span style="color: hsl(0, 100%, 40%);">-             if (ast_cdr_clear_property(payload->channel_name, AST_CDR_FLAG_DISABLE_ALL)) {</span><br><span style="color: hsl(0, 100%, 40%);">-                       ast_log(AST_LOG_WARNING, "Failed to enable CDRs on channel %s\n",</span><br><span style="color: hsl(0, 100%, 40%);">-                             payload->channel_name);</span><br><span style="color: hsl(0, 100%, 40%);">-              }</span><br><span style="color: hsl(0, 100%, 40%);">-       }</span><br><span style="color: hsl(0, 100%, 40%);">-</span><br><span>    if (payload->reset) {</span><br><span>             if (ast_cdr_reset(payload->channel_name, payload->keep_variables)) {</span><br><span style="color: hsl(0, 100%, 40%);">-                      ast_log(AST_LOG_WARNING, "Failed to reset CDRs on channel %s\n",</span><br><span style="color: hsl(0, 100%, 40%);">-                              payload->channel_name);</span><br><span style="color: hsl(120, 100%, 40%);">+                    ast_log(AST_LOG_WARNING, "Failed to reset CDRs on channel %s\n", payload->channel_name);</span><br><span>                }</span><br><span>    }</span><br><span> }</span><br><span>@@ -204,10 +153,6 @@</span><br><span>        payload->channel_name = ast_channel_name(chan);</span><br><span>   payload->reset = 1;</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-      if (ast_test_flag(&flags, AST_CDR_FLAG_DISABLE_ALL)) {</span><br><span style="color: hsl(0, 100%, 40%);">-              payload->reenable = 1;</span><br><span style="color: hsl(0, 100%, 40%);">-       }</span><br><span style="color: hsl(0, 100%, 40%);">-</span><br><span>    if (ast_test_flag(&flags, AST_CDR_FLAG_KEEP_VARS)) {</span><br><span>             payload->keep_variables = 1;</span><br><span>      }</span><br><span>@@ -215,21 +160,6 @@</span><br><span>     return publish_app_cdr_message(chan, payload);</span><br><span> }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-static int nocdr_exec(struct ast_channel *chan, const char *data)</span><br><span style="color: hsl(0, 100%, 40%);">-{</span><br><span style="color: hsl(0, 100%, 40%);">-       RAII_VAR(struct app_cdr_message_payload *, payload,</span><br><span style="color: hsl(0, 100%, 40%);">-             ao2_alloc(sizeof(*payload), NULL), ao2_cleanup);</span><br><span style="color: hsl(0, 100%, 40%);">-</span><br><span style="color: hsl(0, 100%, 40%);">-        if (!payload) {</span><br><span style="color: hsl(0, 100%, 40%);">-         return -1;</span><br><span style="color: hsl(0, 100%, 40%);">-      }</span><br><span style="color: hsl(0, 100%, 40%);">-</span><br><span style="color: hsl(0, 100%, 40%);">-       payload->channel_name = ast_channel_name(chan);</span><br><span style="color: hsl(0, 100%, 40%);">-      payload->disable = 1;</span><br><span style="color: hsl(0, 100%, 40%);">-</span><br><span style="color: hsl(0, 100%, 40%);">-        return publish_app_cdr_message(chan, payload);</span><br><span style="color: hsl(0, 100%, 40%);">-}</span><br><span style="color: hsl(0, 100%, 40%);">-</span><br><span> static int unload_module(void)</span><br><span> {</span><br><span>       RAII_VAR(struct stasis_message_router *, router, ast_cdr_message_router(), ao2_cleanup);</span><br><span>@@ -238,7 +168,6 @@</span><br><span>               stasis_message_router_remove(router, appcdr_message_type());</span><br><span>         }</span><br><span>    STASIS_MESSAGE_TYPE_CLEANUP(appcdr_message_type);</span><br><span style="color: hsl(0, 100%, 40%);">-       ast_unregister_application(nocdr_app);</span><br><span>       ast_unregister_application(resetcdr_app);</span><br><span>    return 0;</span><br><span> }</span><br><span>@@ -253,10 +182,8 @@</span><br><span>        }</span><br><span> </span><br><span>        res |= STASIS_MESSAGE_TYPE_INIT(appcdr_message_type);</span><br><span style="color: hsl(0, 100%, 40%);">-   res |= ast_register_application_xml(nocdr_app, nocdr_exec);</span><br><span>  res |= ast_register_application_xml(resetcdr_app, resetcdr_exec);</span><br><span style="color: hsl(0, 100%, 40%);">-       res |= stasis_message_router_add(router, appcdr_message_type(),</span><br><span style="color: hsl(0, 100%, 40%);">-                                  appcdr_callback, NULL);</span><br><span style="color: hsl(120, 100%, 40%);">+      res |= stasis_message_router_add(router, appcdr_message_type(), appcdr_callback, NULL);</span><br><span> </span><br><span>  if (res) {</span><br><span>           unload_module();</span><br><span>diff --git a/apps/app_forkcdr.c b/apps/app_forkcdr.c</span><br><span>index a906fc9..9e4c9ae 100644</span><br><span>--- a/apps/app_forkcdr.c</span><br><span>+++ b/apps/app_forkcdr.c</span><br><span>@@ -87,7 +87,7 @@</span><br><span>            </description></span><br><span>                 <see-also></span><br><span>                     <ref type="function">CDR</ref></span><br><span style="color: hsl(0, 100%, 40%);">-                    <ref type="application">NoCDR</ref></span><br><span style="color: hsl(120, 100%, 40%);">+                     <ref type="function">CDR_PROP</ref></span><br><span>                    <ref type="application">ResetCDR</ref></span><br><span>                 </see-also></span><br><span>    </application></span><br><span>diff --git a/doc/UPGRADE-staging/app_cdr.txt b/doc/UPGRADE-staging/app_cdr.txt</span><br><span>new file mode 100644</span><br><span>index 0000000..114f0ad</span><br><span>--- /dev/null</span><br><span>+++ b/doc/UPGRADE-staging/app_cdr.txt</span><br><span>@@ -0,0 +1,6 @@</span><br><span style="color: hsl(120, 100%, 40%);">+Subject: app_cdr</span><br><span style="color: hsl(120, 100%, 40%);">+Master-Only: True</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+The previously deprecated NoCDR application has been removed.</span><br><span style="color: hsl(120, 100%, 40%);">+Additionally, the previously deprecated 'e' option to the ResetCDR</span><br><span style="color: hsl(120, 100%, 40%);">+application has been removed.</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.asterisk.org/c/asterisk/+/19746">change 19746</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.asterisk.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.asterisk.org/c/asterisk/+/19746"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: asterisk </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-Change-Id: Id9ed094d8e4baf98bcbc610035c2295bfafe9ec0 </div>
<div style="display:none"> Gerrit-Change-Number: 19746 </div>
<div style="display:none"> Gerrit-PatchSet: 2 </div>
<div style="display:none"> Gerrit-Owner: N A <asterisk@phreaknet.org> </div>
<div style="display:none"> Gerrit-Reviewer: Friendly Automation </div>
<div style="display:none"> Gerrit-Reviewer: George Joseph <gjoseph@digium.com> </div>
<div style="display:none"> Gerrit-Reviewer: Joshua Colp <jcolp@sangoma.com> </div>
<div style="display:none"> Gerrit-MessageType: merged </div>