Пожалуйста, войдите здесь. Часто задаваемые вопросы О нас
Задайте Ваш вопрос

просит дать ему новый синтакс для ExecIf

0

Система ubuntu 10.10, установил *1.8, подключаю конфиги astpbx из архива.

При звонке на внутренний номер начинает ругаться.

- root@PBXSU:/usr/src/asterisk-1.8# asterisk -rvvv
- Verbosity is at least 3
-   == Using UDPTL TOS bits 184
-   == Using UDPTL CoS mark 5
-   == Using SIP RTP TOS bits 184
-   == Using SIP RTP CoS mark 5
-     -- Executing [701@numberplan-main:1] Macro("SIP/717-00000000", "stdexten,SIP,701") in new stack
-     -- Executing [s@macro-stdexten:1] Set("SIP/717-00000000", "__BLINDTRANSFER=") in new stack
-     -- Executing [s@macro-stdexten:2] Set("SIP/717-00000000", "CF_TYPE=uncond") in new stack
-     -- Executing [s@macro-stdexten:3] ExecIf("SIP/717-00000000", "1,Gosub,activate-user,717,1") in new stack
- [Jan 28 15:05:30] WARNING[9540]: app_exec.c:228 execif_exec: Deprecated syntax found.  Please upgrade to using ExecIf(<expr>?Gosub(activate-user,717,1))
-   == Channel 'SIP/717-00000000' jumping out of macro 'stdexten'
-     -- Executing [717@activate-user:1] ExecIf("SIP/717-00000000", "0,Macro,cf-status,717,uncond,deactivate") in new stack
- [Jan 28 15:05:30] WARNING[9540]: app_exec.c:228 execif_exec: Deprecated syntax found.  Please upgrade to using ExecIf(<expr>?Macro(cf-status,717,uncond,deactivate))
-     -- Executing [717@activate-user:2] Return("SIP/717-00000000", "") in new stack
-     -- Executing [s@macro-stdexten:4] Gosub("SIP/717-00000000", "check-meetme,,1") in new stack
- [Jan 28 15:05:30] ERROR[9540]: app_stack.c:419 gosub_exec: Attempt to reach a non-existent destination for gosub: (Context:check-meetme, Extension:s, Priority:1)
-   == Spawn extension (macro-stdexten, s, 5) exited non-zero on 'SIP/717-00000000'
-     -- Registered SIP '717' at 192.168.1.218:15846
- PBXSU*CLI>

Как обновился синтакс у execif?

- macro-stdexten];
- exten => s,1,Set(__BLINDTRANSFER=${BLINDTRANSFER})
- exten => s,n,Set(CF_TYPE=uncond)
- exten => s,n,ExecIf($["${FROM_OUTSIDE}" != "1"],Gosub,activate-user,${CALLERID(num)},1) ;
- exten => s,n,Gosub(check-meetme,${MACRO_EXTEN},1)
- exten => s,n,Gosub(check-cf,${MACRO_EXTEN},1)
- exten => s,n,Gosub(check-dnd,${MACRO_EXTEN},1)
- exten => s,n,Gosub(call-record,${MACRO_EXTEN},1)
- exten => s,n,Gosub(check-simult,${MACRO_EXTEN},1)
- exten => s,n,ExecIf($[ "${FROM_OUTSIDE}" != - "1"],Set,INDIAL_OPTS=${INDIAL_OPTS}${OUTDIAL_OPTS}); combine opts for internal calls
- exten => s,n,ExecIf($[ "${FROM_OUTSIDE}" = "1"],Playback,razgovor-mozhet-byt-zapisan)
- exten => s,n,Set(DIAL_TIMEOUT=${DB(dial_timeout/${MACRO_EXTEN})})
- exten => s,n,ExecIf($[ "${DIAL_TIMEOUT}" = "" ],Set,DIAL_TIMEOUT=${INDIAL_TIMEOUT})
- exten => s,n,Dial(${ARG1}/${ARG2},${INDIAL_TIMEOUT},${INDIAL_OPTS})
- exten => s,n,ExecIf($["${BLINDTRANSFER}" != ""],Dial,${CUT(BLINDTRANSFER,-,1)},${INDIAL_TIMEOUT},${INDIAL_OPTS})
- exten => s,n,Goto(s-${DIALSTATUS},1)
- exten => s-NOANSWER,1,Set(CF_TYPE=onunavail)
- exten => s-NOANSWER,2,Gosub(check-cf,${MACRO_EXTEN},1)
- exten => s-NOANSWER,3,Voicemail(${ARG2},ju)
- exten => s-NOANSWER,104,Answer
- exten => s-NOANSWER,105,Wait(${AFTER_ANSWER_PAUSE})
- exten => s-NOANSWER,106,Playback(abonent)
- exten => s-NOANSWER,107,Playback(ne-otvechaet)
- exten => s-NOANSWER,108,Hangup
- exten => s-BUSY,1,Set(CF_TYPE=onbusy)
- exten => s-BUSY,2,Gosub(check-cf,${MACRO_EXTEN},1)
- exten => s-BUSY,3,Voicemail(${ARG2},bj)
- exten => s-BUSY,104,Answer
- exten => s-BUSY,105,Playtones(busy)
- exten => s-BUSY,106,Wait(5)
- exten => s-BUSY,107,Hangup
- exten => s-CHANUNAVAIL,1,Set(CF_TYPE=onunavail)
- exten => s-CHANUNAVAIL,n,Gosub(check-cf,${MACRO_EXTEN},1)
- exten => s-CHANUNAVAIL,n,Gosub(menu-user-unavail,s-${MACRO_EXTEN},1) - personal menu for user, disabled by default
- exten => s-CHANUNAVAIL,n,Answer
- exten => s-CHANUNAVAIL,n,Wait(${AFTER_ANSWER_PAUSE})
- exten => s-CHANUNAVAIL,n(vm),Voicemail(${ARG2},ju)
- exten => s-CHANUNAVAIL,n,Return
- exten => s-CHANUNAVAIL,vm+101,Playback(abonent)
- exten => s-CHANUNAVAIL,vm+102,Playback(ne-podkljuchen)
- exten => s-CHANUNAVAIL,vm+103,Return
- exten => _s-.,1,Goto(s-NOANSWER,1)
удалить закрыть спам изменить тег редактировать

спросил 2011-01-28 13:26:27 +0400

n978143 Gravatar n978143
1 1 2
http://konceptcom.ru/

обновил 2011-01-30 15:18:37 +0400

litnimax Gravatar litnimax
1453 11 8 29
http://www.pbxware.ru/

3 Ответа

0

раньше было с запятыми, теперь закрываеться скобками Gosub,activate-user, поправить на Gosub(activate-user

ну и вконце строки скобку закрыть

ссылка удалить спам редактировать

ответил 2011-01-30 21:34:22 +0400

meral Gravatar meral flag of Ukraine
23347 24 20 177
http://pro-sip.net/
0

а можно мне помочь с пониманием этого макроса macro-stdexten, обяснить его.

ссылка удалить спам редактировать

ответил 2011-01-30 13:39:42 +0400

n978143 Gravatar n978143
1 1 2
http://konceptcom.ru/
0

Если я правильно понял твой вопрос новый синтаксис такой:

Version 1.6 
 ExecIf(expression?appiftrue(args)[:appiffalse(args)])

voip-info.org в помощь.

ссылка удалить спам редактировать

ответил 2011-01-28 14:22:18 +0400

kasper Gravatar kasper
305 3 10

обновил 2011-01-28 14:22:57 +0400

Ваш ответ

Please start posting your answer anonymously - your answer will be saved within the current session and published after you log in or create a new account. Please try to give a substantial answer, for discussions, please use comments and please do remember to vote (after you log in)!
[скрыть предварительный просмотр]

Закладки и информация

Добавить закладку

подписаться на rss ленту новостей

Статистика

Задан: 2011-01-28 13:26:27 +0400

Просмотрен: 2,835 раз

Обновлен: Jan 30 '11

Проект компании "АТС Дизайн"
Asterisk® и Digium® являются зарегистрированными торговыми марками компании Digium, Inc., США.
IP АТС Asterisk распространяется под лицензией GNU GPL.