Первая вкладка содержит возможность управления функциями скрипта поведения, написанными на BGBS.
Данная подсистема оставлена для совместимости с ранними версиями биллинга. Предпочтительно использовать динамический Java код.
Получение имени класса события по Ctrl + i.
Редактор скриптов обладает подсветкой синтаксиса, индикацией строки и позиции и следующими горячими клавишами:
- Ctrl+X - вырезать
- Ctrl+C - копировать
- Ctrl+V - вставить
- Ctrl+Z - отменить
- Ctrl+R - повторить
- Ctrl+L - переход к строке
При редактировании скриптов нет необходимости перезагрузки запускающих их приложений, достаточно поправить и сохранить нужный скрипт. Перед сохранением скрипта производится его синтаксический анализ с выявлением ошибок, если они есть.
Если во время редактирования скрипт был изменен другим пользователем, то при сохранении выводится сообщение об этом с указанием имени и логина пользователя, внесшего изменения.
Программирование в BeanShell в целом идентично Java, но есть некоторые исключения:
- print( "test" ) - вывод строки (будет видна в логе обработки) вместо System.out.println( "" ).
- error( "error" ) - вывод ошибки вместо System.err.println( "" ).
При обработке события в скрипт передаются следующие переменные:
- con - объект типа java.sql.Connection - соединение с базой биллинга;
- conSlave - объект типа java.sql.Connection - соединение с Slave базой биллинга, либо Master, если ее нет;
- setup - объект класса ru.bitel.bgbilling.server.util.DefaultServerSetup - конфигурация сервера биллинга;
- event - объект, расширяющий bitel.billing.server.script.bean.event.Event - содержит класс-описание события.
Тело скрипта может выглядеть, например, следующим образом. Приведен пример обработки абстрактного события. Это оптимальная по производительности схема скрипта, когда главная функция onEvent интерпретируется один раз и далее запускается многократно.
import bitel.billing.server.contract.bean.*; import bitel.billing.server.util.*; import java.sql.*; import java.util.*; import bitel.billing.server.contract.bean.*; includeBGBS( "bgbs://ru.bitel.bgbilling.kernel.script.common.bean.ScriptLibrary/default" ); public void onEvent( event, setup, con, conSlave ) { if( event.getActionId() != 3333 ) { return; } gets(event); event.addReport(doSomething("vvv")); }
Вот эта же функция, переписанная по-старому (работает медленнее в 8-10 раз):
import bitel.billing.server.contract.bean.*; import bitel.billing.server.util.*; import java.sql.*; import java.util.*; import bitel.billing.server.contract.bean.*; includeBGBS( "bgbs://ru.bitel.bgbilling.kernel.script.common.bean.ScriptLibrary/default" ); if( event.getActionId() != 3333 ) { return; } gets(event); event.addReport(doSomething("vvv"));
Обратите внимание на инструкцию включения библиотеки:
includeBGBS( "bgbs://ru.bitel.bgbilling.kernel.script.common.bean.ScriptLibrary/default" );
Сами библиотеки скриптов определяются в меню Сервис=>Автоматизация=>Библиотеки скриптов. Для каждой библиотеки должно быть определено уникальное имя. Библиотека представляет из себя функции, которые становятся доступными после включения в скрипте инструкции includeBGBS. На снимке ниже представлен код библиотеки default, использованной в скрипте выше.
Библиотеку можно включить из другой библиотеки, но данный подход не рекомендуется, т.к. по неосторожности можно создать зацикливание включения библиотек.