simul-call-limit-reached при схеме USER/Device
Добавлено: 23 дек 2015, 11:36
День добрый. Подскажите, кто сталкивался с подобным багом.
Опишу ситуацию.
Стоит FreePBX 6.12.65-30 (Asterisk 13.5.0). Используется схема работы User/Device, когда сотрудники КоллЦентра логинятся на девайсы в начале смены.
Соответственно в базе /DEVICE/1111/user и /AMPUSER/1111/device могут иметь имеют разные значения. У каждого пользователя свой девайс и у каждого девайса свой пользователь.
Сразу оговорюсь, что нумерация пользователей и девайсов пересекается. И возможно это не самый лучший вариант, но уж так сложилось.
Проблема.
Обнаружилось, что при звонках на RingGroup с несколькими внешними номерами пользователи получают Playback(beep&im-sorry&your&simul-call-limit-reached&goodbye).
Поиск дал следующее. Playback идет из [macro-user-callerid]. Получается по причине проверки в 6ой строчке: exten => s,n,GotoIf($["${AMPUSER}" = "none"]?limit)
А "none" ставит 5ая строчка: exten => s,n,Set(AMPUSER=${DB(DEVICE/${REALCALLERIDNUM}/user)}).
И вот к ней у меня как раз и вопрос. Т.е. она берет номер пользователя совершающего звонок (например, REALCALLERIDNUM = 1111, а /AMPUSER/1111/device = 1112), ставит его в номер девайса (Device/1111) и уже у девайса берет пользователя (Device/1111/user = none). У девайса 1111 на данный момент может и не быть пользователя.
Это же в корне не верно. А главное почему так?
Даже если бы у меня нумерации девайсов и пользователей не пересекались, то я получал бы в 5ой строчке AMPUSER=${DB(DEVICE/${REALCALLERIDNUM}/user = "". Т.к. номер пользователя приводил бы к несуществующему номеру девайса. И только за счёт этого проверка 6ой строчки не вываливалась с ошибкой. Везение, но тоже работает не верно.
Этот кусок макроса работает верно только в одном случае, когда пользователи однозначно закреплены за девайсами, словами FreePBX схема работы c Extensions.
Может я что-то не понимаю? Может есть какой патч? Или как самому исправить ситуацию?
ЗЫ. Смена нумерации, чтобы не было пересечений, исправит ситуацию, но работать будет всё равно не верно.
Переписать данный макрос самому и заблокировать проверку можно, но к чему это может привести.
Есть ли ещё варианты.
Спасибо.
Опишу ситуацию.
Стоит FreePBX 6.12.65-30 (Asterisk 13.5.0). Используется схема работы User/Device, когда сотрудники КоллЦентра логинятся на девайсы в начале смены.
Соответственно в базе /DEVICE/1111/user и /AMPUSER/1111/device могут иметь имеют разные значения. У каждого пользователя свой девайс и у каждого девайса свой пользователь.
Сразу оговорюсь, что нумерация пользователей и девайсов пересекается. И возможно это не самый лучший вариант, но уж так сложилось.
Проблема.
Обнаружилось, что при звонках на RingGroup с несколькими внешними номерами пользователи получают Playback(beep&im-sorry&your&simul-call-limit-reached&goodbye).
Поиск дал следующее. Playback идет из [macro-user-callerid]. Получается по причине проверки в 6ой строчке: exten => s,n,GotoIf($["${AMPUSER}" = "none"]?limit)
А "none" ставит 5ая строчка: exten => s,n,Set(AMPUSER=${DB(DEVICE/${REALCALLERIDNUM}/user)}).
И вот к ней у меня как раз и вопрос. Т.е. она берет номер пользователя совершающего звонок (например, REALCALLERIDNUM = 1111, а /AMPUSER/1111/device = 1112), ставит его в номер девайса (Device/1111) и уже у девайса берет пользователя (Device/1111/user = none). У девайса 1111 на данный момент может и не быть пользователя.
Это же в корне не верно. А главное почему так?
Даже если бы у меня нумерации девайсов и пользователей не пересекались, то я получал бы в 5ой строчке AMPUSER=${DB(DEVICE/${REALCALLERIDNUM}/user = "". Т.к. номер пользователя приводил бы к несуществующему номеру девайса. И только за счёт этого проверка 6ой строчки не вываливалась с ошибкой. Везение, но тоже работает не верно.
Этот кусок макроса работает верно только в одном случае, когда пользователи однозначно закреплены за девайсами, словами FreePBX схема работы c Extensions.
Может я что-то не понимаю? Может есть какой патч? Или как самому исправить ситуацию?
ЗЫ. Смена нумерации, чтобы не было пересечений, исправит ситуацию, но работать будет всё равно не верно.
Переписать данный макрос самому и заблокировать проверку можно, но к чему это может привести.
Есть ли ещё варианты.
Спасибо.