I have and automated call-in dispatch system where hundreds of people call in
daily for 2-3 minutes each. The extension is set up to get their information,
then text-to-speech the dispatch information (via odbc). It then loops 5 times
then ends the call. These calls are being handled by an 8 port analog digium
card.
Sometimes though, I see calls via 'core show channel dahdi/1-1' that
have a time of > 16 hours. I'm not sure if this is a result of dahdi
missing the hangup, ODBC timing out, or TTS failing for some reason. When a
channel gets in this state, the call doesn't seem to progress through the
dialplan, they always display the TTS line. Doing a 'dahdi destroy channel
1-1' doesn't seem to be effective - the only way I've been able to
clear the calls is to do a 'dahdi restart' and/or restart the asterisk
service.
For TTS I'm using cepstral with the Swift wrapper.
Here is a snippet of my dialplan:
[AAA_27_EMP]
exten => s,1,Answer
same => n,Set(CDR(accountcode)=27_EMP)
same => n,Set(comp_num=27)
same => n,Set(readprompt=AAA/enter_employee_number)
same => n,Set(truck_text=employee number)
same => n,Set(validate_func=AAA_VALIDATE_EMP_NUM)
same => n,Set(get_param1=27)
same => n,Set(get_param2=E)
same => n,Set(read_length=7)
same => n,Goto(DB_LOOKUP,s,1)
[DB_LOOKUP]
exten => s,1,NoOp()
same => n(getid),Read(account_id,${readprompt},${read_length},,3,5)
same => n,Gotoif($[ "${LEN(${account_id})}" <=
"0"]?timeout_hangup)
same => n(validateid),Verbose(validating id ${account_id})
same => n,Set(CDR(userfield)=${account_id})
same =>
n,GotoIf($["${account_id}"=="*"]?AAACompMenu,s,1)
same =>
n,Set(ID_VALIDATED=${validate_func}(${get_param1},${account_id}))
same => n,GotoIf($[${ID_VALIDATED}==0]?badid)
same => n(goodid),Verbose(getting schedule for id ${account_id}
AAA_GET_SCHEDULE(${get_param1},${get_param2},${account_id})))
same =>
n,Set(ODBC_ID=${AAA_GET_SCHEDULE(${get_param1},${get_param2},${account_id})})
same => n,GotoIf($[${ODBCROWS} < 1]?no_schedule)
same => n,Verbose(odbcrows count: ${ODBCROWS})
same => n,Set(COUNTER=1)
same => n,Set(AAA_OUTPUT="Schedule for ${truck_text}
${account_id}: ")
same => n,While($[${COUNTER} <= ${ODBCROWS}])
same => n,Set(ARRAY(id,data)=${ODBC_FETCH(${ODBC_ID})})
same => n,Set(AAA_OUTPUT=${AAA_OUTPUT}${data}. )
;same => n,Swift("${data}")
same => n,Set(COUNTER=$[${COUNTER} + 1])
same => n,EndWhile()
same => n,ODBCFinish()
same => n,NoOp("${get_param2}")
same => n,Set(AAA_CHECKED_IN()="${comp_num}",
"${get_param2}", "${account_id}", "${AAA_OUTPUT}",
"S", "${CALLERID(num)}", "${CALLERID(all)}",
"${UNIQUEID}")
same => n,Set(MAX_REPEAT=5)
same => n(readschedule),Swift("${AAA_OUTPUT}")
same => n,Set(MAX_REPEAT=$[${MAX_REPEAT}-1])
same => n,Gotoif($[${MAX_REPEAT} <= 0]?timeout_hangup)
same => n,Read(return_id,AAA/end_of_schedule,${read_length},,,2)
same => n,Gotoif($[ "${LEN(${return_id})}" <=
"0"]?readschedule)
same => n,Set(account_id=${return_id})
same => n,Goto(validateid)
same => n(timeout_hangup),Swift("No ${truck_text} entered.
Goodbye")
same => n,Hangup()
same => n(badid),Set(AAA_OUTPUT="Invalid ${truck_text}
${account_id}")
same => n,Set(AAA_CHECKED_IN()="${comp_num}",
"${get_param2}", "${account_id}", "${AAA_OUTPUT}",
"I", "${CALLERID(num)}", "${CALLERID(all)}",
"${UNIQUEID}")
same => n,Swift("${AAA_OUTPUT}")
same => n,Goto(getid)
same => n(no_schedule),Set(AAA_OUTPUT="No schedule found for
${truck_text} ${account_id}")
same => n,Set(AAA_CHECKED_IN()="${comp_num}",
"${get_param2}", "${account_id}", "${AAA_OUTPUT}",
"N", "${CALLERID(num)}", "${CALLERID(all)}",
"${UNIQUEID}")
same => n,Swift("${AAA_OUTPUT}")
same => n,Goto(getid)
Thanks in advance
-Justin
-------------- next part --------------
An HTML attachment was scrubbed...
URL:
<http://lists.digium.com/pipermail/asterisk-users/attachments/20120518/7ab058d4/attachment.htm>