Files
tg-ws-proxy/README.md

198 lines
7.7 KiB
Markdown
Raw Normal View History

2026-03-15 14:17:07 +03:00
> [!CAUTION]
>
> ### Реакция антивирусов
2026-03-19 06:55:55 +03:00
>
2026-03-15 14:17:07 +03:00
> Windows Defender часто ошибочно помечает приложение как **Wacatac**.
> Если вы не можете скачать из-за блокировки, то:
2026-03-19 06:55:55 +03:00
>
2026-03-15 14:17:07 +03:00
> 1) Попробуйте скачать версию win7 (она ничем не отличается в плане функционала)
2026-03-15 15:55:23 +03:00
> 2) Отключите антивирус на время скачивания, добавьте файл в исключения и включите обратно
2026-03-15 14:17:07 +03:00
>
> **Всегда проверяйте, что скачиваете из интернета, тем более из непроверенных источников. Всегда лучше смотреть на детекты широко известных антивирусов на VirusTotal**
2026-03-04 17:20:07 +03:00
# TG WS Proxy
2026-03-18 19:22:46 +03:00
**Локальный SOCKS5-прокси** для Telegram Desktop, который **ускоряет работу Telegram**, перенаправляя трафик через WebSocket-соединения. Данные передаются в том же зашифрованном виде, а для работы не нужны сторонние сервера.
2026-03-04 17:20:07 +03:00
2026-03-04 20:14:08 +03:00
<img width="529" height="487" alt="image" src="https://github.com/user-attachments/assets/6a4cf683-0df8-43af-86c1-0e8f08682b62" />
2026-03-04 17:20:07 +03:00
## Как это работает
```
2026-03-18 19:22:46 +03:00
Telegram Desktop → SOCKS5 (127.0.0.1:1080) → TG WS Proxy → WSS → Telegram DC
2026-03-04 17:20:07 +03:00
```
1. Приложение поднимает локальный SOCKS5-прокси на `127.0.0.1:1080`
2. Перехватывает подключения к IP-адресам Telegram
3. Извлекает DC ID из MTProto obfuscation init-пакета
2026-03-18 19:22:46 +03:00
4. Устанавливает WebSocket (TLS) соединение к соответствующему DC через домены Telegram
2026-03-04 17:20:07 +03:00
5. Если WS недоступен (302 redirect) — автоматически переключается на прямое TCP-соединение
2026-03-06 19:48:12 +03:00
## 🚀 Быстрый старт
2026-03-04 17:20:07 +03:00
2026-03-06 19:48:12 +03:00
### Windows
2026-03-19 06:55:55 +03:00
2026-03-19 07:43:42 +03:00
Перейдите на [страницу релизов](https://github.com/Flowseal/tg-ws-proxy/releases) и скачайте **`TgWsProxy_windows.exe`**. Он собирается автоматически через [Github Actions](https://github.com/Flowseal/tg-ws-proxy/actions) из открытого исходного кода.
2026-03-04 17:20:07 +03:00
При первом запуске откроется окно с инструкцией по подключению Telegram Desktop. Приложение сворачивается в системный трей.
**Меню трея:**
2026-03-19 06:55:55 +03:00
2026-03-04 17:20:07 +03:00
- **Открыть в Telegram** — автоматически настроить прокси через `tg://socks` ссылку
- **Перезапустить прокси** — перезапуск без выхода из приложения
- **Настройки...** — GUI-редактор конфигурации
- **Открыть логи** — открыть файл логов
- **Выход** — остановить прокси и закрыть приложение
2026-03-18 21:54:58 +03:00
### macOS
2026-03-19 06:55:55 +03:00
2026-03-19 07:43:42 +03:00
Перейдите на [страницу релизов](https://github.com/Flowseal/tg-ws-proxy/releases) и скачайте **`TgWsProxy_macos_universal.dmg`** — универсальная сборка для Apple Silicon и Intel.
2026-03-18 21:54:58 +03:00
1. Открыть образ
2. Перенести **TG WS Proxy.app** в папку **Applications**
3. При первом запуске macOS может попросить подтвердить открытие: **Системные настройки → Конфиденциальность и безопасность → Всё равно открыть**
2026-03-19 06:55:55 +03:00
### Linux
2026-03-19 07:43:42 +03:00
Для Debian/Ubuntu скачайте со [страницы релизов](https://github.com/Flowseal/tg-ws-proxy/releases) пакет **`TgWsProxy_linux_amd64.deb`**.
Для остальных дистрибутивов можно использовать **`TgWsProxy_linux_amd64`** (бинарный файл для x86_64).
2026-03-19 06:55:55 +03:00
```bash
2026-03-19 07:43:42 +03:00
chmod +x TgWsProxy_linux_amd64
./TgWsProxy_linux_amd64
2026-03-19 06:55:55 +03:00
```
При первом запуске откроется окно с инструкцией. Приложение работает в системном трее (требуется AppIndicator).
2026-03-18 21:54:58 +03:00
## Установка из исходников
### Консольный proxy
Для запуска только SOCKS5/WebSocket proxy без tray-интерфейса достаточно базовой установки:
```bash
pip install -e .
tg-ws-proxy
```
### Windows 10+
2026-03-18 17:33:38 +03:00
```bash
pip install -e ".[win10]"
2026-03-18 21:54:58 +03:00
tg-ws-proxy-tray-win
```
### Windows 7
```bash
pip install -e ".[win7]"
2026-03-18 21:54:58 +03:00
tg-ws-proxy-tray-win
```
2026-03-18 17:33:38 +03:00
2026-03-18 21:54:58 +03:00
### macOS
```bash
pip install -e ".[macos]"
tg-ws-proxy-tray-macos
```
2026-03-18 17:33:38 +03:00
2026-03-19 06:55:55 +03:00
### Linux
```bash
pip install -e ".[linux]"
tg-ws-proxy-tray-linux
```
2026-03-18 19:22:46 +03:00
### Консольный режим из исходников
2026-03-04 17:20:07 +03:00
```bash
tg-ws-proxy [--port PORT] [--host HOST] [--dc-ip DC:IP ...] [-v]
2026-03-04 17:20:07 +03:00
```
**Аргументы:**
| Аргумент | По умолчанию | Описание |
|---|---|---|
| `--port` | `1080` | Порт SOCKS5-прокси |
| `--host` | `127.0.0.1` | Хост SOCKS5-прокси |
2026-03-04 17:20:07 +03:00
| `--dc-ip` | `2:149.154.167.220`, `4:149.154.167.220` | Целевой IP для DC (можно указать несколько раз) |
| `-v`, `--verbose` | выкл. | Подробное логирование (DEBUG) |
**Примеры:**
```bash
# Стандартный запуск
tg-ws-proxy
2026-03-04 17:20:07 +03:00
# Другой порт и дополнительные DC
tg-ws-proxy --port 9050 --dc-ip 1:149.154.175.205 --dc-ip 2:149.154.167.220
2026-03-04 17:20:07 +03:00
# С подробным логированием
tg-ws-proxy -v
```
## CLI-скрипты (pyproject.toml)
CLI команды объявляются в `pyproject.toml` в секции `[project.scripts]` и должны указывать на `module:function`.
Пример:
```toml
[project.scripts]
tg-ws-proxy = "proxy.tg_ws_proxy:main"
2026-03-18 21:54:58 +03:00
tg-ws-proxy-tray-win = "windows:main"
tg-ws-proxy-tray-macos = "macos:main"
2026-03-19 06:55:55 +03:00
tg-ws-proxy-tray-linux = "linux:main"
2026-03-04 17:20:07 +03:00
```
## Настройка Telegram Desktop
### Автоматически
ПКМ по иконке в трее → **«Открыть в Telegram»**
### Вручную
1. Telegram → **Настройки****Продвинутые настройки****Тип подключения****Прокси**
2. Добавить прокси:
- **Тип:** SOCKS5
- **Сервер:** `127.0.0.1`
- **Порт:** `1080`
- **Логин/Пароль:** оставить пустыми
## Конфигурация
2026-03-19 06:55:55 +03:00
Tray-приложение хранит данные в:
- **Windows:** `%APPDATA%/TgWsProxy`
- **macOS:** `~/Library/Application Support/TgWsProxy`
- **Linux:** `~/.config/TgWsProxy` (или `$XDG_CONFIG_HOME/TgWsProxy`)
2026-03-04 17:20:07 +03:00
```json
{
"port": 1080,
"dc_ip": [
"2:149.154.167.220",
"4:149.154.167.220"
],
"verbose": false
}
```
2026-03-06 19:48:12 +03:00
## Автоматическая сборка
2026-03-04 17:20:07 +03:00
2026-03-19 06:55:55 +03:00
Проект содержит спецификации PyInstaller ([`packaging/windows.spec`](packaging/windows.spec), [`packaging/macos.spec`](packaging/macos.spec), [`packaging/linux.spec`](packaging/linux.spec)) и GitHub Actions workflow ([`.github/workflows/build.yml`](.github/workflows/build.yml)) для автоматической сборки.
2026-03-18 17:33:38 +03:00
2026-03-18 21:54:58 +03:00
Минимально поддерживаемые версии ОС для текущих бинарных сборок:
2026-03-19 06:55:55 +03:00
2026-03-19 07:43:42 +03:00
- Windows 10+ для `TgWsProxy_windows.exe`
- Windows 7 для `TgWsProxy_windows_7.exe`
2026-03-18 21:54:58 +03:00
- Intel macOS 10.15+
- Apple Silicon macOS 11.0+
2026-03-19 06:55:55 +03:00
- Linux x86_64 (требуется AppIndicator для системного трея)
2026-03-18 21:54:58 +03:00
2026-03-04 17:20:07 +03:00
## Лицензия
2026-03-04 20:14:08 +03:00
[MIT License](LICENSE)