MCPcopy
hub / github.com/Runnin4ik/dpi-detector

github.com/Runnin4ik/dpi-detector @v3.3.0 sqlite

repository ↗ · DeepWiki ↗ · release v3.3.0 ↗
115 symbols 455 edges 15 files 40 documented · 35%
README

«Маяк у гаснущего горизонта свободного интернета»

Сквозь цифровые сумерки. Смотритель маяка, Runni

🔍 DPI Detector

Python 3.8+ License: MIT Docker

Инструмент для анализа цензуры трафика в России: обнаруживает и классифицирует блокировки сайтов, хостингов и CDN (TCP16-20 блокировки), а также подмену DNS-запросов провайдером.

Инструмент был полезен? Поставь ⭐ в качестве «спасибо»!

Пример результатов

🎯 Возможности

  • TCP 16-20KB блокировка — обнаруживает обрыв соединения к CDN и хостингам после передачи 14-34KB
  • Подбор белых SNI для AS хостингов/CDN
  • Проверка доступности заблокированных сайтов — тестирует TLS 1.2, TLS 1.3 и HTTP
  • Проверка DNS — выявляет перехват UDP/53, подмену IP-адресов заглушками и блокировку DoH
  • Классификация ошибок — различает TCP RST, Connection Abort, Handshake/Read Timeout, TLS MITM, SNI-блокировку и другие
  • Гибкая настройка — таймауты, потоки, свои списки доменов, DNS-серверы и IPv4-only режим

[!WARNING]
Если у вас запущены средства обхода блокировок (например, zapret или GoodbyeDPI), результаты тестов будут искажены. Чтобы узнать реальное состояние фильтров вашего провайдера, выключите их перед началом проверки или убедитесь, что они работают в режиме обработки всех пакетов (режим ALL), а не только по списку.

⚙️ Кастомизация

Следующие файлы могут быть переопределены. Инструкции ниже.

  1. domains.txt — список доменов для проверки.
  2. tcp16.json — цели для теста TCP 16-20KB.
  3. config.yml — конфигурация.
  4. whitelist_sni.txt — список белых SNI для подбора рабочих

⚙️ Запуск с параметрами (CLI)

Параметр Описание Пример использования
-t, --tests Указать номера тестов (без меню). -t 123 или -t 4
-p, --proxy Использовать прокси (переопределяет PROXY_URL). -p socks5://127.0.0.1:1080
-d, --domain Проверка отдельных доменов. Игнорирует domains.txt -d vk.com -d youtube.com
-c, --concurrency Количество конкурентных запросов (переопределяет MAX_CONCURRENT). -c 50
-o, --output Автоматически сохранить лог в указанный файл. -o report_log.txt
--batch Отключает все вопросы и паузы в консоли. --batch

🐋 Docker (Рекомендовано)

Быстрый старт

Docker проверит наличие обновлений и скачает свежую версию перед запуском

docker run --rm -it --pull=always ghcr.io/runnin4ik/dpi-detector:latest

Или запускайте с указанием определенной версии
Это избавляет от постоянных скачиваний, но нужно следить за актуальностью версий

docker run --rm -it ghcr.io/runnin4ik/dpi-detector:3.3.0

С кастомизацией

Переопределите нужные файлы: domains.txt, tcp16.json... Запустите с монтированием (можно монтировать один или несколько файлов)

# Bash (Linux / macOS)
docker run --rm -it --pull=always \
  -v $(pwd)/domains.txt:/app/domains.txt \
  -v $(pwd)/tcp16.json:/app/tcp16.json \
  -v $(pwd)/config.yml:/app/config.yml \
  -v $(pwd)/whitelist_sni.txt:/app/whitelist_sni.txt \
  ghcr.io/runnin4ik/dpi-detector:latest -t 123 -d discord.com

Команды для PowerShell и CMD

PowerShell (Windows)

docker run --rm -it --pull=always `
  -v ${PWD}/domains.txt:/app/domains.txt `
  -v ${PWD}/tcp16.json:/app/tcp16.json `
  -v ${PWD}/config.yml:/app/config.yml `
  -v ${PWD}/whitelist_sni.txt:/app/whitelist_sni.txt `
  ghcr.io/runnin4ik/dpi-detector:latest

CMD (Windows)

docker run --rm -it --pull=always ^
  -v %cd%/domains.txt:/app/domains.txt ^
  -v %cd%/tcp16.json:/app/tcp16.json ^
  -v %cd%/config.yml:/app/config.yml ^
  -v %cd%/whitelist_sni.txt:/app/whitelist_sni.txt ^
  ghcr.io/runnin4ik/dpi-detector:latest

🐍 Python 3.8+

Требования: httpx[socks,http2]>=0.28.1, rich>=14.3.2, PyYAML>=6.0.3

Установка:

# скачайте и распакуйте архив руками, или:
git clone https://github.com/Runnin4ik/dpi-detector.git
cd dpi-detector
python -m pip install -r requirements.txt

Запуск:

python dpi_detector.py
# или с параметрами
python dpi_detector.py -t 2 -d discord.com -p socks5://127.0.0.1:1080

🪟 Windows (Готовые сборки)

Для использования программы не обязательно устанавливать Python. Скачайте подходящий .exe файл в разделе Releases -> Assets:

С кастомизацией

Переопределите нужные файлы: domains.txt, tcp16.json, config.yml, whitelist_sni.txt И положите их в папку рядом с .exe файлом.

🤝 Вклад в проект

Приветствуются Issue и Pull Request'ы и предложения функционала!

📜 Лицензия

MIT License — свободное использование, модификация и распространение.

⚠️ Дисклеймер

Этот инструмент предназначен исключительно для образовательных и диагностических целей. Автор не несет ответственности за использование данного ПО.

🙏 Благодарности

👀Похожие проекты

Советуем также взглянуть: - hyperion-cs/dpi-chDPI comprehensive checker (go)

💖 Поддержка проекта

Картой или по СБП

Валюта Сеть Адрес
USDT TRC20 TGtcb4JMT5F3KiEL16oZnj9ijB2Pag1jCX
USDT ERC20 0x97413028546b5da4cbba4d9838c9d635a5333ab1
USDT TON UQApgV57_p0hQGBV9oxrDi7SvKqgN3pigw5YEA28VShrZ7X_
TON UQApgV57_p0hQGBV9oxrDi7SvKqgN3pigw5YEA28VShrZ7X_
BNB BEP-20 0x97413028546b5da4cbba4d9838c9d635a5333ab1
SOL 9obMiD8hYfs4D8XskQjHPPtAKYPq9CaEZTbBMxtCjQ3k
BTC bc1q7579xpmxcrz34lzmrxfupkpcczvemeqk2e9f4h
ETH 0x97413028546b5da4cbba4d9838c9d635a5333ab1

Star History

Star History Chart

Core symbols most depended-on inside this repo

find_cause
called by 10
utils/error_classifier.py
update
called by 10
core/telegram_scanner.py
_fmt_speed
called by 8
core/telegram_scanner.py
_build_dns_query
called by 6
core/dns_scanner.py
wait_and_exit
called by 5
utils/files.py
_parse_dns_response
called by 5
core/dns_scanner.py
get_fake_ip_type
called by 4
utils/network.py
clean_detail
called by 4
utils/error_classifier.py

Shape

Function 100
Method 12
Class 3

Languages

Python100%

Modules by API surface

core/dns_scanner.py40 symbols
core/telegram_scanner.py19 symbols
cli/runners.py15 symbols
dpi_detector.py10 symbols
utils/error_classifier.py8 symbols
utils/files.py6 symbols
core/tls_scanner.py6 symbols
core/tcp16_scanner.py4 symbols
cli/ui.py4 symbols
utils/network.py2 symbols
utils/config.py1 symbols

Dependencies from manifests, versioned

PyYAML6.0.3 · 1×
rich14.3.2 · 1×

For agents

$ claude mcp add dpi-detector \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact