Small outgoing OSP cleanups

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@3299 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
Mark Spencer
2004-06-25 04:27:55 +00:00
parent 42ad569376
commit 2f421a55da
2 changed files with 16 additions and 1 deletions

View File

@@ -192,7 +192,10 @@ static int ospfinished_exec(struct ast_channel *chan, void *data)
}
if (chan->cdr) {
start = chan->cdr->answer.tv_sec;
duration = time(NULL) - start;
if (start)
duration = time(NULL) - start;
else
duration = 0;
} else
ast_log(LOG_WARNING, "OSPFinish called on channel '%s' with no CDR!\n", chan->name);
LOCAL_USER_ADD(u);

View File

@@ -28,6 +28,7 @@
#include <asterisk/utils.h>
#include <asterisk/lock.h>
#include <asterisk/causes.h>
#include <asterisk/callerid.h>
#include <osp.h>
#include <openssl/err.h>
#include <stdio.h>
@@ -434,6 +435,7 @@ int ast_osp_lookup(struct ast_channel *chan, char *provider, char *extension, ch
char callednum[2048]="";
char destination[2048]="";
char token[2000];
char tmp[256]="", *l, *n;
OSPTCALLID *callid;
OSPE_DEST_PROT prot;
@@ -448,6 +450,16 @@ int ast_osp_lookup(struct ast_channel *chan, char *provider, char *extension, ch
if (!callerid)
callerid = "";
strncpy(tmp, callerid, sizeof(tmp) - 1);
ast_callerid_parse(tmp, &n, &l);
if (!l)
l = "";
else {
ast_shrink_phone_number(l);
if (!ast_isphonenumber(l))
l = "";
}
callerid = l;
if (chan) {
strncpy(uniqueid, chan->uniqueid, sizeof(uniqueid) - 1);