Обработчик активации сервисов для Mikrotik(по протоколу mikrotik api)
Материал из BiTel WiKi
Stark (Обсуждение | вклад) |
Stark (Обсуждение | вклад) |
||
Строка 34: | Строка 34: | ||
</source> | </source> | ||
+ | Она нужна в тех случаях, когда есть необходимость в использовании команды find внутри другой команды. Дело в том, что Mikrotik Api не поддерживает использования таких команд, но их можно эмулировать | ||
+ | с помощью вызова 2-х команд: | ||
+ | |||
+ | 1) вначале команда print с заданными параметрами, из нее извлекаются список найденных id через запятую(их может быть несколько в общем случае) | ||
+ | |||
+ | 2) Вызывается основная команда, куда вместо find подставляют список id, найденных на предыдущем шаге. | ||
Пример конфигурации с этим параметром. | Пример конфигурации с этим параметром. |
Версия 10:43, 21 февраля 2014
Универсальный обработчик активации сервисов Mikrotik по протоколу MikrotikApi.
На устройстве должен быть прописан host:port Mikrotik, где port - 8728(порт управления Mikrotik с помощью Mikrotik Api). Либо просто host, тогда порт может быть указан в параметре
sa.port
в конфигурации устройств.
Класс обработчика активации сервисов:
ru.bitel.bgbilling.modules.inet.dyn.device.mikrotik.MikrotikServiceActivator
Поставляется в стандартной поставке. Параметры общие описаны тут:
Пример конфигурации
#Команды включения сервиса на устройстве sa.command.serv.enable=/ip/firewall/address-list/add\n=address=$ip\n=list=ACCESS_LIST\n=comment=!!$servId!! #Команды создания сервиса на устройстве. sa.command.serv.disable=/ip/firewall/address-list/remove\n=numbers="!!$servId!!"
Так же есть специфичная переменная:
$prevIdList - результаты вызова предыдущей команды(все параметры id, через запятую).
Она нужна в тех случаях, когда есть необходимость в использовании команды find внутри другой команды. Дело в том, что Mikrotik Api не поддерживает использования таких команд, но их можно эмулировать с помощью вызова 2-х команд:
1) вначале команда print с заданными параметрами, из нее извлекаются список найденных id через запятую(их может быть несколько в общем случае)
2) Вызывается основная команда, куда вместо find подставляют список id, найденных на предыдущем шаге.
Пример конфигурации с этим параметром.
#Команды включения сервиса на устройстве sa.command.serv.enable=/ip/firewall/address-list/add\n=address=$ip\n=list=ACCESS_LIST #Команды выключения сервиса на устройстве sa.command.serv.disable.1=/ip/firewall/address-list/print\n?=address=$ip sa.command.serv.disable.2=/ip/firewall/address-list/remove\n=numbers=$prevIdList
Тут видно что в команде sa.command.serv.disable.2 удаляют те, номера, которые нашли в команде sa.command.serv.disable.1.