Page tree
Skip to end of metadata
Go to start of metadata

Модуль Voice поддерживает обработку логов CDR по мере появления их в папке. Для этого в типе устройства надо поставить - Runtime обработчик логов CDR.

Чтобы он работал нужно раскомментировать вот эту секцию в файле voice-application.xml приложения BGVoiceProcesso:

<context name="logsRuntime">    
   <bean name="logRuntimeProcessor" class="ru.bitel.bgbilling.modules.voice.accounting.mediation.runtime.LogRuntimeProcessor">                   
   </bean>
</context>

 

 

Это обработчик работает обычно в паре с обработчиком логов CDR . Runtime обработчик берет логи новые в какой-либо папке, обрабатывает и перекладывает их  в другую папку, разложенную по дням и часам.

А обычный обработчик логов CDR используется потом для обработки этих логов повторно в ручном режиме в случае каких-либо корректировок. 

Runtime обработчик периодически опрашивает папку в которой появляются логи, и частота опроса задается настройка в устройтве:

log.runtime.cronTab=0 0/2 * * * ?

Тут задается расписание в формате cron  в формате cron библиотеки Quartz. А данном примере  запускается каждую вторую минуту( 0,2,4,6...). Если не задать эту настройку на устройстве, то Runtime обработчик логов работать не будет.  

Как примеры доступны некоторые обработчики в стандартной поставке и так же можно создавать свои.

В стандартной поставке есть пример пары связанных обработчиков логов для АТС Asterisk:

ru.bitel.bgbilling.modules.voice.dyn.mediator.asterisk.AsteriskMediator - обработчик логов CDR.

ru.bitel.bgbilling.modules.voice.dyn.mediator.asterisk.AsteriskRuntimeMediator - runtime обработчик логов CDR.

Также можно создавать свои обработчики. Runtime обработчик должен реализовывать интерфейс  ru.bitel.bgbilling.modules.voice.accounting.mediation.runtime.RuntimeMediator:

/**
 * Интерфейс Runtime  обработчика  логов CDR. 
 *
 */
public interface RuntimeMediator
{
    /**
     * Метод инициализации
     * @param setup Насройки приложения
     * @param moduleId код модуля
     * @param device устройсто
     * @param deviceType тип устройства
     * @param config конфигуруция устройства
     * @return Object. Можно вернуть null
     * @throws BGException В случае каких либо ошибок
     */
    Object init( Setup setup, int moduleId, VoiceDevice device, VoiceDeviceType deviceType, ParameterMap config )
        throws BGException;

    /**
     * Map записей упрядоченный по часам.

     */
    SortedMap<Date, List<VoiceRecord> > getNewRecords()
        throws BGException;

}

 

 

  • No labels