use CDR API calls instead of re-implementing them (bug #4726)

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@6213 65c4cc65-6c06-0410-ace0-fbb531ad65f3
1.2-netsec
Kevin P. Fleming 20 years ago
parent 307566933f
commit f358db3d43

@ -40,30 +40,23 @@ STANDARD_LOCAL_USER;
LOCAL_USER_DECL; LOCAL_USER_DECL;
static void ast_cdr_fork(struct ast_channel *chan)
static void ast_cdr_clone(struct ast_cdr *cdr)
{ {
struct ast_cdr *newcdr = ast_cdr_alloc(); struct ast_cdr *cdr;
memcpy(newcdr,cdr,sizeof(struct ast_cdr)); struct ast_cdr *newcdr;
if (!chan || !(cdr = chan->cdr))
return;
while (cdr->next)
cdr = cdr->next;
if (!(newcdr = ast_cdr_dup(cdr)))
return;
ast_cdr_append(cdr, newcdr); ast_cdr_append(cdr, newcdr);
newcdr->start = ast_tvnow(); ast_cdr_reset(newcdr, AST_CDR_FLAG_KEEP_VARS);
memset(&newcdr->answer, 0, sizeof(newcdr->answer)); if (!ast_test_flag(cdr, AST_CDR_FLAG_KEEP_VARS))
memset(&newcdr->varshead, 0, sizeof(newcdr->varshead));
ast_cdr_copy_vars(newcdr, cdr);
if (!ast_test_flag(cdr, AST_CDR_FLAG_KEEP_VARS)) {
ast_cdr_free_vars(cdr, 0); ast_cdr_free_vars(cdr, 0);
}
newcdr->disposition = AST_CDR_NOANSWER;
ast_set_flag(cdr, AST_CDR_FLAG_CHILD | AST_CDR_FLAG_LOCKED); ast_set_flag(cdr, AST_CDR_FLAG_CHILD | AST_CDR_FLAG_LOCKED);
} }
static void ast_cdr_fork(struct ast_channel *chan)
{
if(chan && chan->cdr) {
ast_cdr_clone(chan->cdr);
}
}
static int forkcdr_exec(struct ast_channel *chan, void *data) static int forkcdr_exec(struct ast_channel *chan, void *data)
{ {
int res=0; int res=0;

@ -147,7 +147,7 @@ void ast_cdr_unregister(char *name)
AST_LIST_UNLOCK(&be_list); AST_LIST_UNLOCK(&be_list);
} }
static struct ast_cdr *cdr_dup(struct ast_cdr *cdr) struct ast_cdr *ast_cdr_dup(struct ast_cdr *cdr)
{ {
struct ast_cdr *newcdr; struct ast_cdr *newcdr;
@ -809,7 +809,7 @@ void ast_cdr_reset(struct ast_cdr *cdr, int flags)
if (ast_test_flag(&tmp, AST_CDR_FLAG_LOCKED) || !ast_test_flag(cdr, AST_CDR_FLAG_LOCKED)) { if (ast_test_flag(&tmp, AST_CDR_FLAG_LOCKED) || !ast_test_flag(cdr, AST_CDR_FLAG_LOCKED)) {
if (ast_test_flag(&tmp, AST_CDR_FLAG_POSTED)) { if (ast_test_flag(&tmp, AST_CDR_FLAG_POSTED)) {
ast_cdr_end(cdr); ast_cdr_end(cdr);
if ((dup = cdr_dup(cdr))) { if ((dup = ast_cdr_dup(cdr))) {
ast_cdr_detach(dup); ast_cdr_detach(dup);
} }
ast_set_flag(cdr, AST_CDR_FLAG_POSTED); ast_set_flag(cdr, AST_CDR_FLAG_POSTED);

@ -104,6 +104,12 @@ typedef int (*ast_cdrbe)(struct ast_cdr *cdr);
*/ */
extern struct ast_cdr *ast_cdr_alloc(void); extern struct ast_cdr *ast_cdr_alloc(void);
/*! Duplicate a record */
/*!
* Returns a malloc'd ast_cdr structure, returns NULL on error (malloc failure)
*/
extern struct ast_cdr *ast_cdr_dup(struct ast_cdr *cdr);
/*! Free a record */ /*! Free a record */
/* \param cdr ast_cdr structure to free /* \param cdr ast_cdr structure to free
* Returns nothing important * Returns nothing important

Loading…
Cancel
Save