Applies a patch made a long time ago by alecdavis which adds a CDR feature for logging
calls that failed due to congestion.
(closes issue #15907)
Reported by: alecdavis
Patches:
cdr_congestion.diff.txt uploaded by alecdavis (license #5546)
Review: https://reviewboard.asterisk.org/r/454/
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@329835
65c4cc65-6c06-0410-ace0-
fbb531ad65f3
--------------------------
* The filter option in cdr_adaptive_odbc now supports negating the argument,
thus allowing records which do NOT match the specified filter.
+ * Added ability to log CONGESTION calls to CDR
CODECS
--------------------------
AST_CDR_FAILED = (1 << 1),
AST_CDR_BUSY = (1 << 2),
AST_CDR_ANSWERED = (1 << 3),
+ AST_CDR_CONGESTION = (1 << 4),
};
/*!
extern void ast_cdr_noanswer(struct ast_cdr *cdr);
/*!
+ * \brief A call was set to congestion
+ * \param cdr the cdr you wish to associate with the call
+ * Markst he channel disposition as "CONGESTION"
+ * Will skip CDR's in chain with ANS_LOCK bit set. (see
+ * forkCDR() application
+ */
+extern void ast_cdr_congestion(struct ast_cdr *cdr);
+
+/*!
* \brief Busy a call
* \param cdr the cdr you wish to associate with the call
* Marks the channel disposition as "BUSY"
}
}
+void ast_cdr_congestion(struct ast_cdr *cdr)
+{
+ char *chan;
+
+ while (cdr) {
+ if (!ast_test_flag(cdr, AST_CDR_FLAG_LOCKED)) {
+ chan = !ast_strlen_zero(cdr->channel) ? cdr->channel : "<unknown>";
+
+ if (ast_test_flag(cdr, AST_CDR_FLAG_POSTED)) {
+ ast_log(LOG_WARNING, "CDR on channel '%s' already posted\n", chan);
+ }
+
+ if (cdr->disposition < AST_CDR_CONGESTION) {
+ cdr->disposition = AST_CDR_CONGESTION;
+ }
+ }
+ cdr = cdr->next;
+ }
+}
+
/* everywhere ast_cdr_disposition is called, it will call ast_cdr_failed()
if ast_cdr_disposition returns a non-zero value */
case AST_CAUSE_NO_ANSWER:
ast_cdr_noanswer(cdr);
break;
+ case AST_CAUSE_NORMAL_CIRCUIT_CONGESTION:
+ ast_cdr_congestion(cdr);
+ break;
case AST_CAUSE_NORMAL:
break;
default:
return "BUSY";
case AST_CDR_ANSWERED:
return "ANSWERED";
+ case AST_CDR_CONGESTION:
+ return "CONGESTION";
}
return "UNKNOWN";
}
ast_indicate(chan, AST_CONTROL_CONGESTION);
/* Don't change state of an UP channel, just indicate
congestion in audio */
- if (chan->_state != AST_STATE_UP)
+ if (chan->_state != AST_STATE_UP) {
ast_setstate(chan, AST_STATE_BUSY);
+ ast_cdr_congestion(chan->cdr);
+ }
wait_for_hangup(chan, data);
return -1;
}