Make config
Модуль ядра make config входит в базовую поставку и позволяет создавать конфигурационные файлы на лету. Например, с помощью make_config можно формировать:
- конфиг для dhcp-сервера
- данные пользователей, например, в cvs-файле для экспорта во внешние программы.
Результат формируется динамически - это значит, что он будет переформирован при изменении данных в биллинге.
Пример шаблона для экспорта в csv:
{% for user in users %}
{{ user.name }};{{ user.show_data._adr_street }}
{% endfor %}
Здесь user.show_data._adr_street - вывод дополнительного поля _adr_street.
Необходимо отметить, что в дополнительных данных есть тип поля "выпадающий список", при этом в самом поле может храниться код, а отображаемое значение будет находиться в таблице dictionary:
- {{ user.data._adr_street }} - вывод значения, которое хранится в поле _adr_street (т.е там может быть код улицы)
- {{ user.show_data._adr_street }} - вывод преобразованного значения (имени улицы)
Кроме самого шаблона необходим файл настроек для модуля make_config: kernel/make_config.cfg. Он может быть таким:
run => 0,
period => 60,
template => {
'users.tmpl' => {
# куда будет записан результат
file => '/tmp/users.csv',
# системная команда, которая будет выполнена перед записью результата, можно ''
cmd_before => '',
# системная команда, которая будет выполнена после записи результата, можно ''
cmd_after => '',
# удалять пустые строки
pretty => 1,
},
}
Здесь:
- users.tmpl - имя файла с шаблоном;
- /tmp/users.csv - имя файла, куда будет записан результат;
- переменная period указывает на период в секундах, с которым будет формироваться результат.
Запустим модуль make_config с выводом результата на экран:
perl /usr/local/nodeny/nokernel.pl -v -m=make_config
Если результат корректный, добавим запуск make_config в автозагрузку:
echo '/usr/bin/perl /usr/local/nodeny/nokernel.pl -m=make_config -d &' >> /etc/rc.local