OPNsense dvtws (zapret)

Network OPNSense

Обсуждение тут

Ставим git (он вроде доступен без подключения репозиториев, но я уже не помню)

pkg update && pkg install git

Клонируем zapret из github

mkdir /opt && git clone https://github.com/bol-van/zapret.git /opt/zapret

Копируем бинарник

cp /opt/zapret/binaries/freebsd-x64/dvtws /usr/local/sbin && chmod +x /usr/local/sbin/dvtws

Создаём скрипты для запуска

edit /etc/rc.conf.d/dvtws

пишем

dvtws_enable="YES"

далее

edit /usr/local/etc/rc.d/dvtws && chmod +x /usr/local/etc/rc.d/dvtws

пишем (не факт что будет работать с представленными параметрами dpi-desync, их нужно подбирать самостоятельно через blockcheck или ручками). Всё о подборе параметров, их описание и для чего нужны файлы hostlist читаем тут.

#!/bin/sh
SERVICE_NAME="dvtws"
SERVICE_CMD="/usr/local/sbin/dvtws"
pidfile="/var/run/dvtws.pid"
is_service_running() {
  pgrep -f "${SERVICE_CMD}" > ${pidfile} && return 0 || return 1
}

mng_service() {
  if [ "" = "start" ]; then
    kldload ipfw
    kldload ipdivert
#pppoe это мой интерфейс наружу, у вас может быть свой
    ipfw add 100 divert 989 tcp from any to any 80,443 out not diverted xmit pppoe0
    ipfw add 100 divert 989 udp from any to table\(discord\) 50000-50030 out not diverted xmit pppoe0
#тут мы заполняем ipset для таблицы discord, либо создайте список с сетями, либо удалите
    ipfw table discord flush
    cat /usr/local/etc/dvtws/dvtws_discord | while read line;do
    ipfw table discord add $line 1
    done
#этот кусок

    pfctl -d ; pfctl -e
    ${SERVICE_CMD} \
    --debug=0 \
    --pidfile=/var/run/dvtws.pid \
    --port=989 \
#порты и правила discord
    --filter-udp=50000-50030 \
    --dpi-desync=fake \
    --dpi-desync-repeats=6 \
    --dpi-desync-any-protocol \
    --dpi-desync-cutoff=n2 \
    --new \
#порт 80(хз зачем, но пусть будет)
    --filter-tcp=80 \
    --dpi-desync=split2 \
    --dpi-desync-split-seqovl=1 \
    --hostlist-auto=/usr/local/etc/dvtws/dvtws_auto \
    --hostlist-auto-fail-threshold=3 \
    --hostlist-auto-fail-time=60 \
    --hostlist-auto-retrans-threshold=3 \
    --hostlist-auto-debug=/usr/local/etc/dvtws/dvtws_debug \
    --hostlist=/usr/local/etc/dvtws/dvtws_auto \
    --hostlist=/usr/local/etc/dvtws/dvtws_host \
    --hostlist-exclude=/usr/local/etc/dvtws/dvtws_exclude \
    --new \
#порт 443 это весь наш https трафик
    --filter-tcp=443 \
    --dpi-desync=split2 \
    --dpi-desync-split-seqovl=1 \
    --hostlist-auto=/usr/local/etc/dvtws/dvtws_auto \
    --hostlist-auto-fail-threshold=3 \
    --hostlist-auto-fail-time=60 \
    --hostlist-auto-retrans-threshold=3 \
    --hostlist-auto-debug=/usr/local/etc/dvtws/dvtws_debug \
    --hostlist=/usr/local/etc/dvtws/dvtws_auto \
    --hostlist=/usr/local/etc/dvtws/dvtws_host \
    --hostlist-exclude=/usr/local/etc/dvtws/dvtws_exclude \
    | logger -t "${SERVICE_NAME}" >/dev/null 2>&1 &
  elif [ "" = "stop" ]; then
    ipfw delete 100
    pkill -f ${SERVICE_NAME}
  fi
}

чтобы управлять сервисом из web’a делаем

edit /usr/local/opnsense/service/conf/actions.d/actions_dvtws.conf

пишем

[start]
command:/usr/local/etc/rc.d/dvtws start
parameters:
type:script
message:starting dvtws
[stop]
command:/usr/local/etc/rc.d/dvtws stop
parameters:
type:script
message:stopping dvtws
[restart]
command:/usr/local/etc/rc.d/dvtws restart
parameters:
type:script
message:restarting dvtws
[status]
command:/usr/local/etc/rc.d/dvtws status; exit 0
parameters:
type:script_output
message:request dvtws status

перезапускаем configd

service configd restart

создаём сервис

edit /usr/local/etc/inc/plugins.inc.d/dvtws.inc

пишем плагин для web’a

<?php

/*
 * Copyright (C) 2017 EURO-LOG AG
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice,
 *    this list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 * AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
 * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

/**
 * register service
 * @return array
 */
function dvtws_services()
{
    global $config;

    $services = array();
    $services[] = array(
        'description' => gettext('Anti-DPI server'),
        'configd' => array(
            'restart' => array('dvtws restart'),
            'start' => array('dvtws start'),
            'stop' => array('dvtws stop'),
        ),
        'name' => 'dvtws',
        'pidfile' => '/var/run/dvtws.pid'
    );
    return $services;
}

function dvtws_syslog()
{
    $logfacilities = array();
    $logfacilities['dvtws'] = array(
        'facility' => array('dvtws'),
    );
    return $logfacilities;

ну и напоследок сделаем запуск при старте

edit /usr/local/etc/rc.syshook.d/start/99-dvtws

пишем

#!/bin/sh
#Start dvtws service
/usr/local/etc/rc.d/dvtws start

проверяем что плагин регистрируется

pluginctl -s

в появившемся списке должен присутствовать dvtws. А в system-diagnoctics-services web интерфейса строка

Готово, dvtws установлен, настроен и настроено управление через web. Осталось наполнить hostlist для своих хотелок и перезагрузиться

edit /usr/local/etc/dvtws/dvtws_host

или же оставить всё на усмотрение самого dvtws, который будет наполнять

/usr/local/etc/dvtws/dvtws_auto

за наполение этого файла отвечают параметры

    --hostlist-auto-fail-threshold=3 \
    --hostlist-auto-fail-time=60 \
    --hostlist-auto-retrans-threshold=3 \

а файл

/usr/local/etc/dvtws/dvtws_debug 

будет объяснять почему в файле появляется та или иная запись