Объясните мне, непонятливому, почему происходит и как это решить?
Ситуация:
Версия ПО: Asterisk 1.8.11.0
ОС: CentOS 6.2 x64
Есть контекст в котором описывается обработка вызова на определенный номер. По окончании команды Dial() проверяется статус вызова и в зависимости от него выполняются те или иные действия.
Мы сейчас говорим о случае, когда вызываемый абонент ответил (снял трубку), т.е. статус ANSWER. При всех других состояниях всё ОК.
Происходит разговор, вот он завершается и тут два варианта:
1 - первым трубку вешает тот, КОГО ВЫЗЫВАЛИ (вызываемый).
2 - первым трубку вешает тот, КТО ВЫЗЫВАЛ (звонящий).
Если первым положил трубку вызываемый абонент, то всё ОК, диалплан обрабатывается дальше. Если же первым опустил телефон звонящий, то выполнение диалплана заканчивается на приоритете команды Dial(), а в консоли пишется:
-- Executing [3838@landline:34] Dial("SIP/5077-00154f6c", "SIP/5860,15,tTg") in new stack
== Spawn extension (landline, 3838, 34) exited non-zero on 'SIP/5077-00154f6c'
А мне надо, чтобы происходила дальнейшая обработка плана набора в данном контексте.
Вот что вы можете мне посоветовать?
Всех заранее благодарю за подсказки.
Вы мне предлагаете перечитать то, что выдаст мне астериск в ответ?
Я читал. И даже воспользовался параметром "g", который переводится как: "Когда вызываемый абонент вешает трубку, продолжить выполнение команд далее по текущему контексту".
ВЫЗЫВАЕМЫЙ. С этим как раз проблем нет. Проблема возникает, когда звонящий первым вешает трубку.
А если вам нужен вывод команды, то я, безусловно, его могу сюда вклеить.
Нужен?
[Synopsis]
Attempt to connect to another device or endpoint and bridge the call.
[Description]
This application will place calls to one or more specified channels. As soon
as one of the requested channels answers, the originating channel will be
answered, if it has not already been answered. These two channels will then
be active in a bridged call. All other channels that were requested will then
be hung up.
Unless there is a timeout specified, the Dial application will wait
indefinitely until one of the called channels answers, the user hangs up,
or if all of the called channels are busy or unavailable. Dialplan executing
will continue if no requested channels can be called, or if the timeout
expires. This application will report normal termination if the originating
channel hangs up, or if the call is bridged and either of the parties in the
bridge ends the call.
If the ${OUTBOUND_GROUP} variable is set, all peer channels created by this
application will be put into that group (as in Set(GROUP()=...). If the $
{OUTBOUND_GROUP_ONCE} variable is set, all peer channels created by this
application will be put into that group (as in Set(GROUP()=...). Unlike $
{OUTBOUND_GROUP}, however, the variable will be unset after use.
This application sets the following channel variables:
${DIALEDTIME}: This is the time from dialing a channel until when it is
disconnected.
${ANSWEREDTIME}: This is the amount of time for actual call.
${DIALSTATUS}: This is the status of the call
CHANUNAVAIL
CONGESTION
NOANSWER
BUSY
ANSWER
CANCEL
DONTCALL: For the Privacy and Screening Modes. Will be set if the
called party chooses to send the calling party to the 'Go Away' script.
TORTURE: For the Privacy and Screening Modes. Will be set if the
called party chooses to send the calling party to the 'torture' script.
INVALIDARGS
[Syntax]
Dial(Technology/Resource[&Technology2/Resource2[&...]][,timeout[,options[,URL]]])
Вот он: ########################
[Arguments]
Technology/Resource
Specification of the device(s) to dial. These must be in the format
of 'Technology/Resource', where <Technology> represents a particular
channel driver, and <Resource> represents a resource available to that
particular channel driver.
Technology2/Resource2
Optional extra devices to dial in parallel
If you need more then one enter them as Technology2/Resource2&Te
chnology3/Resourse3&.....
timeout
Specifies the number of seconds we attempt to dial the specified
devices
If not specified, this defaults to 136 years.
options
A(x):
x - The file to play to the called party
Play an announcement to the called party, where <x> is the prompt
to be played
a: Immediately answer the calling channel when the called channel
answers in all cases. Normally, the calling channel is answered when the
called channel answers, but when options such as A() and M() are used,
the calling channel is not answered until all actions on the called channel
(such as playing an announcement) are completed. This option can be used
to answer the calling channel before doing anything on the called channel.
You will rarely need to use this option, the default behavior is adequate
in most cases.
C: Reset the call detail record (CDR) for this call.
c: If the Dial() application cancels this call, always set the flag
to tell the channel driver that the call is answered elsewhere.
d: Allow the calling user to dial a 1 digit extension while waiting
for a call to be answered. Exit to that extension if it exists in the
current context, or the context defined in the ${EXITCONTEXT} variable,
if it exists.
NOTE: Many SIP and ISDN phones cannot send DTMF digits until the
call is connected. If you wish to use this option with these phones,
you can use the 'Answer' application before dialing.
D([called][:calling[:progress]]): Send the specified DTMF strings
*after* the called party has answered, but before the call gets bridged.
The <called> DTMF string is sent to the called party, and the <calling>
DTMF string is sent to the calling party. Both arguments can be used
alone. If <progress> is specified, its DTMF is sent immediately after
receiving a PROGRESS message.
e: Execute the 'h' extension for peer after the call ends
f([x]): If <x> is not provided, force the CallerID sent on a
call-forward or deflection to the dialplan extension of this Dial() using
a dialplan 'hint'. For example, some PSTNs do not allow CallerID to be
set to anything other than the numbers assigned to you. If <x> is provided,
force the CallerID sent to <x>.
F([[context^]exten^]priority): When the caller hangs up, transfer
the *called* party to the specified destination and *start* execution
at that location.
NOTE: Any channel variables you want the called channel to inherit
from the caller channel must be prefixed with one or two underbars ('_').
F: When the caller hangs up, transfer the *called* party to the next
priority of the current extension and *start* execution at that location.
NOTE: Any channel variables you want the called channel to inherit
from the caller channel must be prefixed with one or two underbars ('_').
NOTE: Using this option from a Macro() or GoSub() might not make
sense as there would be no return points.
g: Proceed with dialplan execution at the next priority in the current
extension if the destination channel hangs up.
G([[context^]exten^]priority): If the call is answered, transfer
the calling party to the specified <priority> and the called party to
the specified <priority> plus one.
NOTE: You cannot use any additional action post answer options in
conjunction with this option.
h: Allow the called party to hang up by sending the DTMF sequence
defined for disconnect in "features.conf".
H: Allow the calling party to hang up by sending the DTMF sequence
defined for disconnect in "features.conf".
NOTE: Many SIP and ISDN phones cannot send DTMF digits until the
call is connected. If you wish to allow DTMF disconnect before the dialed
party answers with these phones, you can use the 'Answer' application
before dialing.
i: Asterisk will ignore any forwarding requests it may receive on
this dial attempt.
I: Asterisk will ignore any connected line update requests or any
redirecting party update requests it may receive on this dial attempt.
k: Allow the called party to enable parking of the call by sending
the DTMF sequence defined for call parking in "features.conf".
K: Allow the calling party to enable parking of the call by sending
the DTMF sequence defined for call parking in "features.conf".
L(x[:y[:z]]):
x - Maximum call time, in milliseconds
y - Warning time, in milliseconds
z - Repeat time, in milliseconds
Limit the call to <x> milliseconds. Play a warning when <y> mill
iseconds are left. Repeat the warning every <z> milliseconds until time
expires.
This option is affected by the following variables:
${LIMIT_PLAYAUDIO_CALLER}:
yes
no
If set, this variable causes Asterisk to play the
prompts to the caller.
${LIMIT_PLAYAUDIO_CALLEE}:
yes
no
If set, this variable causes Asterisk to play the
prompts to the callee.
${LIMIT_TIMEOUT_FILE}:
filename
If specified, <filename> specifies the sound prompt
to play when the timeout is reached. If not set, the time remaining
will be announced.
${LIMIT_CONNECT_FILE}:
filename
If specified, <filename> specifies the sound prompt
to play when the call begins. If not set, the time remaining will
be announced.
${LIMIT_WARNING_FILE}:
filename
If specified, <filename> specifies the sound prompt
to play as a warning when time <x> is reached. If not set, the
time remaining will be announced.
m([class]): Provide hold music to the calling party until a requested
channel answers. A specific music on hold <class> (as defined in "mus
iconhold.conf") can be specified.
M(macro[^arg[^...]]):
macro - Name of the macro that should be executed.
arg - Macro arguments
Execute the specified <macro> for the *called* channel before
connecting to the calling channel. Arguments can be specified to the Macro
using '^' as a delimiter. The macro can set the variable ${MACRO_RESULT}
to specify the following actions after the macro is finished executing:
${MACRO_RESULT}: If set, this action will be taken after
the macro finished executing.
ABORT: Hangup both legs of the call
CONGESTION: Behave as if line congestion was
encountered
BUSY: Behave as if a busy signal was encountered
CONTINUE: Hangup the called party and allow the
calling party to continue dialplan execution at the next priority
GOTO:<context>^<exten>^<priority>: Transfer the call
to the specified destination.
NOTE: You cannot use any additional action post answer options in
conjunction with this option. Also, pbx services are not run on the peer
(called) channel, so you will not be able to set timeouts via the TIMEOUT()
function in this macro.
WARNING!!!: Be aware of the limitations that macros have, specifically
with regards to use of the 'WaitExten' application. For more information,
see the documentation for Macro()
n([delete]):
delete - With <delete> either not specified or set to '0
', the recorded introduction will not be deleted if the caller hangs
up while the remote party has not yet answered.
With <delete> set to '1', the introduction will always be
deleted.
This option is a modifier for the call screening/privacy mode. (See
the 'p' and 'P' options.) It specifies that no introductions are to be
saved in the "priv-callerintros" directory.
N: This option is a modifier for the call screening/privacy mode.
It specifies that if Caller*ID is present, do not screen the call.
o([x]): If <x> is not provided, specify that the CallerID that was
present on the *calling* channel be stored as the CallerID on the *called*
channel. This was the behavior of Asterisk 1.0 and earlier. If <x> is
provided, specify the CallerID stored on the *called* channel. Note that
o(${CALLERID(all)}) is similar to option o without the parameter.
O([mode]):
mode - With <mode> either not specified or set to '1', the
originator hanging up will cause the phone to ring back immediately.
With <mode> set to '2', when the operator flashes the trunk,
it will ring their phone back.
Enables *operator services* mode. This option only works when
bridging a DAHDI channel to another DAHDI channel only. if specified on
non-DAHDI interfaces, it will be ignored. When the destination answers
(presumably an operator services station), the originator no longer has
control of their line. They may hang up, but the switch will not release
their line until the destination party (the operator) hangs up.
p: This option enables screening mode. This is basically Privacy
mode without memory.
P([x]): Enable privacy mode. Use <x> as the family/key in the AstDB
database if it is provided. The current extension is used if a database
family/key is not specified.
r([tone]): Default: Indicate ringing to the calling party, even if
the called party isn't actually ringing. Pass no audio to the calling
party until the called channel has answered.
tone - Indicate progress to calling party. Send audio 'tone'
from indications.conf
S(x): Hang up the call <x> seconds *after* the called party has
answered the call.
s(x): Force the outgoing callerid tag parameter to be set to the
string <x>.
Works with the f option.
t: Allow the called party to transfer the calling party by sending
the DTMF sequence defined in "features.conf". This setting does not perform
policy enforcement on transfers initiated by other methods.
T: Allow the calling party to transfer the called party by sending
the DTMF sequence defined in "features.conf". This setting does not perform
policy enforcement on transfers initiated by other methods.
U(x[^arg[^...]]):
x - Name of the subroutine to execute via Gosub
arg - Arguments for the Gosub routine
Execute via Gosub the routine <x> for the *called* channel before
connecting to the calling channel. Arguments can be specified to the Gosub
using '^' as a delimiter. The Gosub routine can set the variable ${GO
SUB_RESULT} to specify the following actions after the Gosub returns.
${GOSUB_RESULT}:
ABORT: Hangup both legs of the call.
CONGESTION: Behave as if line congestion was
encountered.
BUSY: Behave as if a busy signal was encountered.
CONTINUE: Hangup the called party and allow the
calling party to continue dialplan execution at the next priority.
GOTO:<context>^<exten>^<priority>: Transfer the call
to the specified priority. Optionally, an extension, or extension
and priority can be specified.
NOTE: You cannot use any additional action post answer options in
conjunction with this option. Also, pbx services are not run on the peer
(called) channel, so you will not be able to set timeouts via the TIMEOUT()
function in this routine.
u(x):
x - Force the outgoing callerid presentation indicator
parameter to be set to one of the values passed in <x>: 'allowed_
not_screened' 'allowed_passed_screen' 'allowed_failed_screen' 'allowed'
'prohib_not_screened' 'prohib_passed_screen' 'prohib_failed_screen'
'prohib' 'unavailable'
Works with the f option.
w: Allow the called party to enable recording of the call by sending
the DTMF sequence defined for one-touch recording in "features.conf".
W: Allow the calling party to enable recording of the call by sending
the DTMF sequence defined for one-touch recording in "features.conf".
x: Allow the called party to enable recording of the call by sending
the DTMF sequence defined for one-touch automixmonitor in "features.c
onf".
X: Allow the calling party to enable recording of the call by sending
the DTMF sequence defined for one-touch automixmonitor in "features.c
onf".
z: On a call forward, cancel any dial timeout which has been set
for this call.
URL
The optional URL will be sent to the called party if the channel
driver supports it.