2026-04-07 18:11:26 +03:00
> [!TIP]
>
2026-04-16 17:51:41 +03:00
> ### [🎉 Поддержать меня](https://github.com/Flowseal/tg-ws-proxy/blob/main/docs/Funding.md)
2026-04-07 18:11:26 +03:00
>
2026-04-10 02:57:25 +03:00
> **USDT (TRC20)**: `TXPnKs2Ww1RD8JN6nChFUVmi5r2hqrWjuu`
> **BTC**: `bc1qr8vd6jelkyyry3m4mq6z5txdx4pl856fu6ss0w`
> **ETH**: `0x1417878fdc5047E670a77748B34819b9A49C72F1`
2026-04-11 20:52:24 +03:00
> **Другие монеты**: https://nowpayments.io/donation/flowseal
2026-04-07 18:11:26 +03:00
2026-03-15 14:17:07 +03:00
> [!CAUTION]
>
> ### Реакция антивирусов
2026-03-19 06:55:55 +03:00
>
2026-04-14 03:11:13 +03:00
> Антивирусы часто ошибочно помечают приложение как вирус из-за упаковщика.
> Если вы не можете скачать из-за блокировки антивирусом, то:
2026-03-19 06:55:55 +03:00
>
2026-04-14 03:11:13 +03:00
> 1) **Попробуйте скачать версию win7 (она ничем не отличается в плане функционала)**
2026-03-15 15:55:23 +03:00
> 2) Отключите антивирус на время скачивания, добавьте файл в исключения и включите обратно
2026-03-15 14:17:07 +03:00
>
2026-04-14 03:11:13 +03:00
> Всегда проверяйте, что скачиваете из интернета, тем более из непроверенных источников. Всегда лучше смотреть на детекты широко известных антивирусов на VirusTotal
2026-03-15 14:17:07 +03:00
2026-03-04 17:20:07 +03:00
# TG WS Proxy
2026-04-30 06:12:54 +03:00
**Локальный MTProto-прокси** для Telegram Desktop, который **ускоряет работу Telegram ** , перенаправляя трафик через WebSocket-соединения. Данные передаются в том же зашифрованном виде, а для работы не нужны сторонние серверы.
2026-03-04 17:20:07 +03:00
2026-05-06 17:31:49 +03:00
<picture>
<source srcset="https://github.com/user-attachments/assets/17f1d15e-e1c2-41ea-a452-220d13359262" media="(prefers-color-scheme: dark)">
<img src="https://github.com/user-attachments/assets/8d595468-83a1-4e4f-bac4-9ce4a07027bd">
</picture>
2026-03-04 20:14:08 +03:00
2026-03-04 17:20:07 +03:00
## Как это работает
```
2026-03-28 15:45:08 +03:00
Telegram Desktop → MTProto Proxy (127.0.0.1:1443) → WebSocket → Telegram DC
2026-03-04 17:20:07 +03:00
```
2026-03-28 15:45:08 +03:00
1. Приложение поднимает MTProto прокси на `127.0.0.1:1443`
2026-03-04 17:20:07 +03:00
2. Перехватывает подключения к IP-адресам Telegram
3. Извлекает DC ID из MTProto obfuscation init-пакета
2026-04-30 06:12:54 +03:00
4. Устанавливает WebSocket-соединение (TLS) к соответствующему DC через домены Telegram
2026-04-07 17:12:29 +03:00
5. Если WS недоступен (302 redirect) — автоматически переключается на CfProxy / прямое TCP-соединение
2026-03-04 17:20:07 +03:00
2026-04-08 02:16:35 +03:00
> [!IMPORTANT]
> ### Н е грузит фото/видео?
2026-04-11 20:52:24 +03:00
> **Удалите в настройках прокси в DC->IP всё, кроме `4:149.154.167.220`**
2026-04-30 06:12:54 +03:00
> **Если не помогло, то полностью очистите это поле**
2026-04-11 20:52:24 +03:00
> ####
2026-04-08 02:15:39 +03:00
> Подобная проблема встречается на аккаунтах без Premium
> Если вам не помогло, то настраивайте свой домен по гайду отсюда: https://github.com/Flowseal/tg-ws-proxy/blob/main/docs/CfProxy.md
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-04-30 06:12:54 +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-04-30 06:12:54 +03:00
- **Открыть в Telegram** — автоматически настроить прокси через ссылку `tg://proxy`
2026-04-11 20:52:24 +03:00
- **Скопировать ссылку** — скопировать ссылку для подключения
2026-03-04 17:20:07 +03:00
- **Перезапустить прокси** — перезапуск без выхода из приложения
2026-04-30 06:12:54 +03:00
- **Настройки...** — GUI-редактор конфигурации (версия приложения, опциональная проверка обновлений с GitHub)
2026-03-04 17:20:07 +03:00
- **Открыть логи** — открыть файл логов
- **Выход** — остановить прокси и закрыть приложение
2026-04-30 06:12:54 +03:00
При первом запуске после старта может появиться запрос о б открытии страницы релиза, если на GitHub вышла новая версия (эту проверку можно отключить в настройках).
2026-03-27 08:54:36 +03:00
2026-04-11 20:52:24 +03:00
### Настройка Telegram Desktop
### Автоматически:
ПКМ по иконке в трее → * * «Открыть в Telegram»**
Если не сработало (не открылся Telegram с подключением), то:
1. ПКМ по иконке в трее → * * «Скопировать ссылку»**
2026-04-30 06:12:54 +03:00
2. Отправьте ссылку с е б е в избранное в Telegram-клиенте и нажмите по ней ЛКМ
2026-04-11 20:52:24 +03:00
3. Подключитесь
### Вручную:
1. Telegram → **Настройки ** → **Продвинутые настройки ** → **Тип подключения ** → **Прокси **
2. Добавить прокси:
- **Тип:** MTProto
- **Сервер:** `127.0.0.1` (или переопределенный вами)
- **Порт:** `1443` (или переопределенный вами)
- **Secret:** из настроек или логов
##
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` **.
2026-04-30 06:12:54 +03:00
Для Arch и Arch-based дистрибутивов подготовлены пакеты в AUR: [tg-ws-proxy-bin ](https://aur.archlinux.org/packages/tg-ws-proxy-bin ), [tg-ws-proxy-git ](https://aur.archlinux.org/packages/tg-ws-proxy-git ), [tg-ws-proxy-cli ](https://aur.archlinux.org/packages/tg-ws-proxy-cli )
2026-03-23 10:39:29 +05:00
```shell
# Установка без AUR-helper
git clone https://aur.archlinux.org/tg-ws-proxy-bin.git
cd tg-ws-proxy-bin
makepkg -si
# При помощи AUR-helper
paru -S tg-ws-proxy-bin
2026-04-30 06:12:54 +03:00
# Если вы установили -cli пакет, то запуск осуществляется через systemctl, где 8888 - это номер порта,
2026-03-30 11:55:44 +05:00
# разделитель ":" и secret, который можно сгенерировать командой: openssl rand -hex 16
2026-04-28 17:38:37 +03:00
sudo systemctl start tg-ws-proxy@8888:3075abe65830f0325116bb0416cadf9f
2026-03-23 10:39:29 +05:00
```
2026-03-19 07:43:42 +03:00
Для остальных дистрибутивов можно использовать * * `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
2026-03-28 15:45:08 +03:00
Для запуска только proxy без tray-интерфейса достаточно базовой установки:
2026-03-18 21:54:58 +03:00
```bash
pip install -e .
tg-ws-proxy
```
2026-03-23 13:09:30 +07:00
### Windows 7/10+
2026-03-18 17:33:38 +03:00
2026-03-19 01:33:12 +07:00
```bash
2026-03-23 13:09:30 +07:00
pip install -e .
2026-03-18 21:54:58 +03:00
tg-ws-proxy-tray-win
2026-03-19 01:33:12 +07:00
```
2026-03-18 17:33:38 +03:00
2026-03-18 21:54:58 +03:00
### macOS
```bash
2026-03-23 13:09:30 +07:00
pip install -e .
2026-03-18 21:54:58 +03:00
tg-ws-proxy-tray-macos
```
2026-03-18 17:33:38 +03:00
2026-03-19 06:55:55 +03:00
### Linux
```bash
2026-03-23 13:09:30 +07:00
pip install -e .
2026-03-19 06:55:55 +03:00
tg-ws-proxy-tray-linux
```
2026-03-18 19:22:46 +03:00
### Консольный режим из исходников
2026-03-04 17:20:07 +03:00
```bash
2026-03-19 01:33:12 +07:00
tg-ws-proxy [--port PORT] [--host HOST] [--dc-ip DC:IP ...] [-v]
2026-03-04 17:20:07 +03:00
```
**Аргументы:**
| Аргумент | По умолчанию | Описание |
|---|---|---|
2026-03-28 15:45:08 +03:00
| `--port` | `1443` | Порт прокси |
| `--host` | `127.0.0.1` | Хост прокси |
2026-04-30 06:12:54 +03:00
| `--secret` | `random` | 32-значный hex-ключ для авторизации клиентов |
2026-03-04 17:20:07 +03:00
| `--dc-ip` | `2:149.154.167.220` , `4:149.154.167.220` | Целевой IP для DC (можно указать несколько раз) |
2026-04-30 06:12:54 +03:00
| `--no-cfproxy` | `false` | Отключить попытку [проксирования через Cloudflare ](https://github.com/Flowseal/tg-ws-proxy/blob/main/docs/CfProxy.md ) |
2026-04-26 18:54:02 +03:00
| `--cfproxy-domain` | | Указать свой домен для проксирования через Cloudflare. [Подробнее тут ](https://github.com/Flowseal/tg-ws-proxy/blob/main/docs/CfProxy.md ) |
2026-04-07 17:12:29 +03:00
| `--cfproxy-priority` | `true` | Пробовать проксировать через Cloudflare перед прямым TCP подключением |
2026-04-11 20:52:24 +03:00
| `--fake-tls-domain` | | Включить Fake TLS (ee-secret) маскировку с указанным SNI-доменом |
| `--proxy-protocol` | выкл. | Принимать HAProxy PROXY protocol v1 (для работы за nginx/haproxy с `proxy_protocol on` ) |
2026-04-07 17:12:29 +03:00
| `--buf-kb` | `256` | Размер буфера в КБ |
| `--pool-size` | `4` | Количество заготовленных соединений на каждый DC |
2026-04-30 06:12:54 +03:00
| `--log-file` | выкл. | Путь к файлу, в который будут сохраняться логи |
2026-04-07 17:12:29 +03:00
| `--log-max-mb` | `5` | Максимальный размер файла логов в МБ (после идёт перезапись) |
| `--log-backups` | `0` | Количество сохранений логов после перезаписи |
2026-03-04 17:20:07 +03:00
| `-v` , `--verbose` | выкл. | Подробное логирование (DEBUG) |
**Примеры:**
```bash
# Стандартный запуск
2026-03-19 01:33:12 +07:00
tg-ws-proxy
2026-03-04 17:20:07 +03:00
# Другой порт и дополнительные DC
2026-03-19 01:33:12 +07:00
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
# С подробным логированием
2026-03-19 01:33:12 +07:00
tg-ws-proxy -v
2026-04-11 20:52:24 +03:00
# Fake TLS маскировка (ee-secret)
tg-ws-proxy --fake-tls-domain example.com
2026-03-19 01:33:12 +07:00
```
2026-04-11 20:52:24 +03:00
## Fake TLS + nginx upstream
### Домен (`--fake-tls-domain`) должен указывать на тот же IP, на котором стоит прокси
2026-03-04 17:20:07 +03:00
2026-04-11 20:52:24 +03:00
**Пример `nginx.conf` (stream):**
2026-03-04 17:20:07 +03:00
2026-04-11 20:52:24 +03:00
```nginx
upstream mtproto {
server 127.0.0.1:8446;
}
2026-03-04 17:20:07 +03:00
2026-04-11 20:52:24 +03:00
map $ssl_preread_server_name $sni_name {
hostnames;
example.com mtproto;
# if you have xray with selfsni running:
# sub.example.com www;
# default xray;
}
2026-03-04 17:20:07 +03:00
2026-04-11 20:52:24 +03:00
# upstream xray {
# server 127.0.0.1:8443;
# }
#
# upstream www {
# server 127.0.0.1:7443;
# }
server {
proxy_protocol on;
set_real_ip_from unix:;
listen 443;
proxy_pass $sni_name;
ssl_preread on;
}
```
**Запуск прокси за nginx:**
```bash
python3 proxy/tg_ws_proxy.py \
--port 8446 \
--host 127.0.0.1 \
--fake-tls-domain example.com \
--proxy-protocol \
--secret <32-hex-chars>
```
2026-04-30 06:12:54 +03:00
Ссылка для подключения будет в формате `ee` -секрета:
2026-04-11 20:52:24 +03:00
```
tg://proxy?server=your.domain.com&port=443&secret=ee<secret><domain_hex>
```
2026-03-04 17:20:07 +03:00
2026-04-11 20:52:24 +03:00
## Файлы конфигурации Tray-приложения
2026-03-04 17:20:07 +03:00
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
{
2026-03-27 08:54:36 +03:00
"host": "127.0.0.1",
2026-03-28 15:45:08 +03:00
"port": 1443,
"secret": "...",
2026-03-04 17:20:07 +03:00
"dc_ip": [
"2:149.154.167.220",
"4:149.154.167.220"
],
2026-03-27 08:54:36 +03:00
"verbose": false,
"buf_kb": 256,
"pool_size": 4,
"log_max_mb": 5.0,
2026-04-11 20:52:24 +03:00
"check_updates": true,
"cfproxy": true,
"cfproxy_priority": true,
"cfproxy_user_domain": "",
"appearance": "auto"
2026-03-04 17:20:07 +03:00
}
```
2026-03-27 08:54:36 +03:00
Ключ * * `check_updates` ** — при `true` при запросе к GitHub сравнивается версия с последним релизом (только уведомление и ссылка на страницу загрузки). Н а Windows в конфиге может быть * * `autostart` ** (автозапуск при входе в систему).
2026-03-06 19:48:12 +03:00
## Автоматическая сборка
2026-03-04 17:20:07 +03:00
2026-04-16 02:29:58 +05: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`
2026-03-23 12:38:35 +07:00
- Windows 7 (x64) для `TgWsProxy_windows_7_64bit.exe`
- Windows 7 (x32) для `TgWsProxy_windows_7_32bit.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-04-14 21:56:14 +03:00
[MIT License ](https://github.com/Flowseal/tg-ws-proxy/blob/main/LICENSE )