Carbon Reductor позволяет блокировать разным абонентам разные ресурсы и показывать разные страницы заглушки в зависимости от списка запрещённых URL к которому принадлежит ресурс.
Поддерживаются списки URL и списки доменов.
Обобщённое устройство дополнительных списков
Для настройки дополнительных списков нужно три "компонента":
- Файл со списком заблокированных ресурсов, описывающий категорию ресурсов
- Файл со списком IP сетей, описывающий категорию абонентов
- Файл со списком сопоставлений, в котором категории ресурсов привязываются к категориям абонентов.
Ко всем этим файлам относятся те же самые требования, что и к обычным пользовательским спискам (в списках URL должны быть HTTP-URL, в списке доменов - домены, в списке IP - IPv4 адреса).
Все эти файлы располагаются в директори.
/app/reductor/cfg/userinfo/hooks
При изменении файла сопоставлений и добавлении новых URL/доменов (например при первичной настройке) требуются полная обработка списков перезапуск службы /app/reductor.
Рекомендуем проверить фильтрацию URL/доменов для абонента входящего в категорию для которой фильтрация предполагается и для абонента вне таких групп до (не должно работать) и после (должно заработать) настройки.
chroot /app/reductor/ /usr/local/Reductor/bin/update.sh /app/reductor/service restart
Настройка дополнительных списков URL
Категории URL
Создайте папку для категорий URL
mkdir -p /app/reductor/cfg/userinfo/hooks/custom_url_lists/
внутри неё создайте файл категории URL со списком URL (требования к спискам те же, что и для собственных списков провайдера).
название файла должно состоять из номера категории (без расширения), например 1, 2, 3 или 153.
Примеры
# cat /app/reductor/cfg/userinfo/hooks/custom_url_lists/1 http://bad.example.com http://category1.example.com/bad-things-in-internet.html # cat /app/reductor/cfg/userinfo/hooks/custom_url_lists/2 http://torrents.example.com http://piracy.example.com
Категории абонентов
Создайте папку для категорий абонентов
mkdir -p /app/reductor/cfg/userinfo/hooks/custom_ipsets/
внутри неё создайте файл категории абонентов со списком IP-адресов (требования к спискам те же, что и для собственных списков провайдера).
название файла должно состоять из номера категории (без расширения), например 3, 7, 15 или 163.
Примеры
# cat /app/reductor/cfg/userinfo/hooks/custom_ipsets/1 192.168.3.0/24 10.30.0.0/16 # cat /app/reductor/cfg/userinfo/hooks/custom_ipsets/2 196.168.4.0/24
Связь категорий абонентов и URL
Создайте файл
vim /app/reductor/cfg/userinfo/hooks/custom_bindings
В нём нужно описать связи между категориями абонентов и ресурсов (URL).
Формат файла для списков URL следующий:
- 1 колонка - номер категории ресурсов (URL)
- 2 колонка - номер категории абонентов
- 3 колонка - URL страницы заглушки для перенаправления
- 4 колонка - комментарий, который будет отображаться в правиле фильтрации.
Разделитель - пробел или табуляция, комментарии в файле не поддерживаются.
Номер категории ресурсов заблокированных для всех абонентов (реестр запрещённых сайтов, список МинЮста, собственные списки провайдера) - 0. Не используйте его в файле custom_bindings, это может привести к пропускам фильтрации и штрафам.
Пример
1 2 http://good.example.com block_bad_things 2 1 http://promo-tv.example.com anti_piracy_promo
Возьмём первую строчку и попробуем понять что она значит:
Категория URL №1 (см. файл custom_url_lists/1) для категории абонентов №2 (custom_ipsets/2) будет перенаправляться на страницу http://good.example.com.
В файрволе это правило можно будет найти по комментарию "block_bad_things".
Настройка дополнительных списков доменов
Категории доменов
Создайте папку для категорий доменов
mkdir -p /app/reductor/cfg/userinfo/hooks/custom_url_lists/
внутри неё создайте файл категории доменов со списком доменов (требования к спискам те же, что и для собственных списков провайдера).
название файла должно состоять из номера категории (без расширения), например 1, 2, 3 или 153.
Примеры
# cat /app/reductor/cfg/userinfo/hooks/custom_domains/1 test1.category1.example.com test2.category1.example.com # cat /app/reductor/cfg/userinfo/hooks/custom_domains/2 test3.category2.example.com test4.category2.example.com
Категории абонентов
Создайте папку для категорий абонентов
mkdir -p /app/reductor/cfg/userinfo/hooks/custom_ipsets/
внутри неё создайте файл категории абонентов со списком IP-адресов (требования к спискам те же, что и для собственных списков провайдера).
название файла должно состоять из номера категории (без расширения), например 3, 7, 15 или 163.
Примеры
# cat /app/reductor/cfg/userinfo/hooks/custom_ipsets/1 192.168.3.0/24 10.30.0.0/16 # cat /app/reductor/cfg/userinfo/hooks/custom_ipsets/2 196.168.4.0/24
Связь категорий абонентов и доменов
Создайте файл
vim /app/reductor/cfg/userinfo/hooks/custom_bindings_dns
В нём нужно описать связи между категориями абонентов и ресурсов (доменов).
Формат файла для списков доменов следующий:
- 1 колонка - номер категории ресурсов (доменов)
- 2 колонка - номер категории абонентов
- 3 колонка - IP-адрес страницы заглушки для перенаправления
- 4 колонка - режим блокировки. Имеет два варианта:
- with_subdomains - все перечисленные в категории ресурсов домены будут блокироваться "по маскам" со всеми субдоменами.
- exact - все перечисленные в категории ресурсов домены будут блокироваться точечно. Их субдомены не будут заблокированы.
- 5 колонка - тип списка. Имеет два ваианта:
- black - чёрный список, ресурсы будут блокироваться для заданной категории абонентов
- white - белый список, ресурсы будут разблокированы для заданной категории абонентов.
- 6 колонка - комментарий, который будет отображаться в правиле фильтрации.
Разделитель - пробел или табуляция, комментарии в файле не поддерживаются.
Номер категории ресурсов заблокированных для всех абонентов (реестр запрещённых сайтов, список МинЮста, собственные списки провайдера) - 0. Не используйте его в файле custom_bindings, это может привести к пропускам фильтрации и штрафам.
Пример
1 1 192.168.1.100 with_subdomains black content_filter 2 2 - exact white monitoring_services
Возьмём первую строчку и попробуем понять что она значит:
Категория доменов №1 (см. файл custom_domains/1) для категории абонентов №1 (custom_ipsets/1) будет перенаправляться на адрес 192.168.1.100. Действовать это будет для всех поддоменов.
В файрволе это правило можно будет найти по комментарию "content_filter".
Вторая строчка:
Категория доменов №2 (см. файл custom_domains/2) для категории абонентов №2 (custom_ipsets/2) не будет никуда перенаправляться, даже если содержится в других чёрных списках. Действовать это будет только для конкретных доменов - если в другом чёрном списке такой домен блокируется по маске - субдомены продолжат блокироваться.