mirror of
https://github.com/openlibrecommunity/olcrtc.git
synced 2026-06-01 22:18:52 +02:00
doc: add YAML configuration support
This commit is contained in:
+254
-114
@@ -30,44 +30,54 @@
|
||||
|
||||
---
|
||||
|
||||
## Обязательные флаги
|
||||
## Обязательные поля YAML конфига
|
||||
|
||||
| Флаг | Что вводить |
|
||||
|------|-------------|
|
||||
| `-mode` | `srv` на сервере, `cnc` на клиенте, `gen` для генерации Room ID |
|
||||
| `-carrier` | `telemost`, `jazz` или `wbstream` |
|
||||
| `-transport` | `datachannel`, `vp8channel`, `seichannel` или `videochannel` |
|
||||
| `-id` | Room ID |
|
||||
| `-client-id` | Общий идентификатор клиента. Должен совпадать на сервере и клиенте. Один client-id может держать бесконечное количество соединений, но SFU ограничивает полосу на участника - оптимально 1 client-id = 1 пользователь (не обязательно) |
|
||||
| `-key` | Ключ шифрования hex 64 символа. Генерация: `openssl rand -hex 32` |
|
||||
| `-link` | Всегда `direct` |
|
||||
| `-data` | Всегда `data` |
|
||||
| `-dns` | DNS-сервер, например `1.1.1.1:53` |
|
||||
| YAML поле | Что вводить |
|
||||
|-----------|-------------|
|
||||
| `mode` | `srv` на сервере, `cnc` на клиенте, `gen` для генерации Room ID |
|
||||
| `auth.provider` | `telemost`, `jazz` или `wbstream` |
|
||||
| `net.transport` | `datachannel`, `vp8channel`, `seichannel` или `videochannel` |
|
||||
| `room.id` | Room ID |
|
||||
| `crypto.key` | Ключ шифрования hex 64 символа. Генерация: `openssl rand -hex 32` |
|
||||
| `link` | Всегда `direct` |
|
||||
| `data` | Всегда `data` |
|
||||
| `net.dns` | DNS-сервер, например `1.1.1.1:53` |
|
||||
|
||||
---
|
||||
|
||||
## Необязательные флаги
|
||||
## Необязательные поля
|
||||
|
||||
| Флаг | Описание |
|
||||
|------|----------|
|
||||
| `--debug` | Подробные логи соединений |
|
||||
| YAML поле | Описание |
|
||||
|-----------|----------|
|
||||
| `debug` | `true` для подробных логов соединений |
|
||||
|
||||
---
|
||||
|
||||
## -mode gen
|
||||
## mode: gen
|
||||
|
||||
Генерирует Room ID заранее, не запуская сервер. Поддерживается только для `jazz`. Для `wbstream` создавай руму вручную через [stream.wb.ru](https://stream.wb.ru) (автогенерация отключена со стороны WB).
|
||||
|
||||
**Обязательные флаги:**
|
||||
**Обязательные поля:**
|
||||
|
||||
| Флаг | Описание |
|
||||
|------|----------|
|
||||
| `-carrier` | `jazz` |
|
||||
| `-dns` | DNS-сервер |
|
||||
| `-amount` | Количество комнат |
|
||||
| YAML поле | Описание |
|
||||
|-----------|----------|
|
||||
| `auth.provider` | `jazz` |
|
||||
| `net.dns` | DNS-сервер |
|
||||
| `gen.amount` | Количество комнат |
|
||||
|
||||
```yaml
|
||||
# gen.yaml
|
||||
mode: gen
|
||||
auth:
|
||||
provider: jazz
|
||||
net:
|
||||
dns: "1.1.1.1:53"
|
||||
gen:
|
||||
amount: 3
|
||||
```
|
||||
|
||||
```sh
|
||||
./olcrtc -mode gen -carrier jazz -dns 1.1.1.1:53 -amount 3
|
||||
./olcrtc gen.yaml
|
||||
# room-id-1
|
||||
# room-id-2
|
||||
# room-id-3
|
||||
@@ -75,163 +85,293 @@
|
||||
|
||||
---
|
||||
|
||||
## Флаги только для сервера (`-mode srv`)
|
||||
## Поля только для сервера (`mode: srv`)
|
||||
|
||||
| Флаг | Описание |
|
||||
|------|----------|
|
||||
| `-socks-proxy` | Адрес SOCKS5-прокси для исходящего трафика сервера |
|
||||
| `-socks-proxy-port` | Порт этого прокси |
|
||||
| YAML поле | Описание |
|
||||
|-----------|----------|
|
||||
| `socks.proxy_addr` | Адрес SOCKS5-прокси для исходящего трафика сервера |
|
||||
| `socks.proxy_port` | Порт этого прокси |
|
||||
|
||||
---
|
||||
|
||||
## Флаги только для клиента (`-mode cnc`)
|
||||
## Поля только для клиента (`mode: cnc`)
|
||||
|
||||
| Флаг | Описание | По умолчанию |
|
||||
|------|----------|:------------:|
|
||||
| `-socks-host` | На каком адресе поднять SOCKS5 | `127.0.0.1` |
|
||||
| `-socks-port` | На каком порту поднять SOCKS5 | `1080` |
|
||||
| `-socks-user` | Логин для входящих SOCKS5-подключений (необязательно) | - |
|
||||
| `-socks-pass` | Пароль для входящих SOCKS5-подключений (необязательно) | - |
|
||||
| YAML поле | Описание | По умолчанию |
|
||||
|-----------|----------|:------------:|
|
||||
| `socks.host` | На каком адресе поднять SOCKS5 | `127.0.0.1` |
|
||||
| `socks.port` | На каком порту поднять SOCKS5 | `1080` |
|
||||
| `socks.user` | Логин для входящих SOCKS5-подключений (необязательно) | - |
|
||||
| `socks.pass` | Пароль для входящих SOCKS5-подключений (необязательно) | - |
|
||||
|
||||
Если `-socks-user` не задан - аутентификация отключена (любой локальный клиент может подключиться).
|
||||
Если `socks.user` не задан - аутентификация отключена (любой локальный клиент может подключиться).
|
||||
Если задан - клиент принимает только подключения с правильным логином и паролем (RFC 1929).
|
||||
|
||||
---
|
||||
|
||||
## datachannel
|
||||
|
||||
Дополнительных флагов нет - всё по умолчанию.
|
||||
Дополнительных полей нет - всё по умолчанию.
|
||||
|
||||
---
|
||||
|
||||
## vp8channel
|
||||
|
||||
**Рекомендуется: `-vp8-fps 60 -vp8-batch 64`** (числа лучше чётные, больший batch = выше скорость)
|
||||
**Рекомендуется: `fps: 60`, `batch_size: 64`** (числа лучше чётные, больший batch = выше скорость)
|
||||
|
||||
| Флаг | Описание | По умолчанию |
|
||||
|------|----------|:------------:|
|
||||
| `-vp8-fps` | FPS VP8 потока | `25` |
|
||||
| `-vp8-batch` | Кадров за тик | `1` |
|
||||
| YAML поле | Описание | По умолчанию |
|
||||
|-----------|----------|:------------:|
|
||||
| `vp8.fps` | FPS VP8 потока | `25` |
|
||||
| `vp8.batch_size` | Кадров за тик | `1` |
|
||||
|
||||
---
|
||||
|
||||
## seichannel
|
||||
|
||||
**Рекомендуется: `-fps 60 -batch 64 -frag 900 -ack-ms 2000`**
|
||||
**Рекомендуется: `fps: 60`, `batch_size: 64`, `fragment_size: 900`, `ack_timeout_ms: 2000`**
|
||||
|
||||
| Флаг | Описание | По умолчанию |
|
||||
|------|----------|:------------:|
|
||||
| `-fps` | FPS H264 потока | `60` |
|
||||
| `-batch` | Кадров за тик | `64` |
|
||||
| `-frag` | Размер фрагмента в байтах | `900` |
|
||||
| `-ack-ms` | Таймаут ACK в миллисекундах | `2000` |
|
||||
| YAML поле | Описание | По умолчанию |
|
||||
|-----------|----------|:------------:|
|
||||
| `sei.fps` | FPS H264 потока | `60` |
|
||||
| `sei.batch_size` | Кадров за тик | `64` |
|
||||
| `sei.fragment_size` | Размер фрагмента в байтах | `900` |
|
||||
| `sei.ack_timeout_ms` | Таймаут ACK в миллисекундах | `2000` |
|
||||
|
||||
---
|
||||
|
||||
## videochannel
|
||||
|
||||
**Рекомендуется: `-video-codec qrcode -video-w 1080 -video-h 1080 -video-fps 60 -video-bitrate 5000k -video-hw none`**
|
||||
**Рекомендуется: `codec: qrcode`, `width: 1080`, `height: 1080`, `fps: 60`, `bitrate: "5000k"`, `hw: none`**
|
||||
|
||||
| Флаг | Описание | По умолчанию |
|
||||
|------|----------|:------------:|
|
||||
| `-video-codec` | `qrcode` или `tile` | `qrcode` |
|
||||
| `-video-w` | Ширина в пикселях | `1920` |
|
||||
| `-video-h` | Высота в пикселях | `1080` |
|
||||
| `-video-fps` | FPS | `30` |
|
||||
| `-video-bitrate` | Битрейт, например `2M` или `5000k` | `2M` |
|
||||
| `-video-hw` | Аппаратное ускорение: `none` или `nvenc` | `none` |
|
||||
| `-video-qr-recovery` | Коррекция ошибок QR: `low` / `medium` / `high` / `highest` | `low` |
|
||||
| `-video-qr-size` | Размер фрагмента QR в байтах, `0` = авто | `0` |
|
||||
| `-video-tile-module` | Размер тайла в пикселях 1..270 (только `tile`) | `4` |
|
||||
| `-video-tile-rs` | Reed-Solomon паритет % 0..200 (только `tile`) | `20` |
|
||||
| `-ffmpeg` | Путь к исполняемому файлу ffmpeg | `ffmpeg` |
|
||||
| YAML поле | Описание | По умолчанию |
|
||||
|-----------|----------|:------------:|
|
||||
| `video.codec` | `qrcode` или `tile` | `qrcode` |
|
||||
| `video.width` | Ширина в пикселях | `1920` |
|
||||
| `video.height` | Высота в пикселях | `1080` |
|
||||
| `video.fps` | FPS | `30` |
|
||||
| `video.bitrate` | Битрейт, например `"2M"` или `"5000k"` | `"2M"` |
|
||||
| `video.hw` | Аппаратное ускорение: `none` или `nvenc` | `none` |
|
||||
| `video.qr_recovery` | Коррекция ошибок QR: `low` / `medium` / `high` / `highest` | `low` |
|
||||
| `video.qr_size` | Размер фрагмента QR в байтах, `0` = авто | `0` |
|
||||
| `video.tile_module` | Размер тайла в пикселях 1..270 (только `tile`) | `4` |
|
||||
| `video.tile_rs` | Reed-Solomon паритет % 0..200 (только `tile`) | `20` |
|
||||
| `ffmpeg` | Путь к исполняемому файлу ffmpeg | `ffmpeg` |
|
||||
|
||||
Для codec `tile` нужно точно `1080x1080`.
|
||||
|
||||
---
|
||||
|
||||
## Готовые команды
|
||||
## Готовые конфиги
|
||||
|
||||
### wbstream + datachannel (рекомендуется - максимальная скорость, без бана)
|
||||
|
||||
```sh
|
||||
```yaml
|
||||
# room ID нужно создать вручную через https://stream.wb.ru
|
||||
ROOM_ID="<room-id-со-stream.wb.ru>"
|
||||
|
||||
# сервер
|
||||
./olcrtc -mode srv -carrier wbstream -transport datachannel \
|
||||
-id "$ROOM_ID" -client-id <client-id> -key <hex-key> -link direct -data data -dns 1.1.1.1:53
|
||||
# server.yaml
|
||||
mode: srv
|
||||
link: direct
|
||||
auth:
|
||||
provider: wbstream
|
||||
room:
|
||||
id: "<room-id-со-stream.wb.ru>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: datachannel
|
||||
dns: "1.1.1.1:53"
|
||||
data: data
|
||||
```
|
||||
|
||||
# клиент
|
||||
./olcrtc -mode cnc -carrier wbstream -transport datachannel \
|
||||
-id "$ROOM_ID" -client-id <client-id> -key <hex-key> -link direct -data data -dns 1.1.1.1:53 \
|
||||
-socks-host 127.0.0.1 -socks-port 1080
|
||||
```yaml
|
||||
# client.yaml
|
||||
mode: cnc
|
||||
link: direct
|
||||
auth:
|
||||
provider: wbstream
|
||||
room:
|
||||
id: "<room-id-со-stream.wb.ru>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: datachannel
|
||||
dns: "1.1.1.1:53"
|
||||
socks:
|
||||
host: "127.0.0.1"
|
||||
port: 8808
|
||||
data: data
|
||||
```
|
||||
|
||||
### wbstream + datachannel + SOCKS5 аутентификация
|
||||
|
||||
```sh
|
||||
# клиент с логином и паролем на прокси
|
||||
./olcrtc -mode cnc -carrier wbstream -transport datachannel \
|
||||
-id "$ROOM_ID" -client-id <client-id> -key <hex-key> -link direct -data data -dns 1.1.1.1:53 \
|
||||
-socks-host 127.0.0.1 -socks-port 1080 \
|
||||
-socks-user myuser -socks-pass mypass
|
||||
```yaml
|
||||
# client.yaml с логином и паролем на прокси
|
||||
mode: cnc
|
||||
link: direct
|
||||
auth:
|
||||
provider: wbstream
|
||||
room:
|
||||
id: "<room-id>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: datachannel
|
||||
dns: "1.1.1.1:53"
|
||||
socks:
|
||||
host: "127.0.0.1"
|
||||
port: 8808
|
||||
user: myuser
|
||||
pass: mypass
|
||||
data: data
|
||||
```
|
||||
|
||||
Использование:
|
||||
```sh
|
||||
curl --socks5-hostname myuser:mypass@127.0.0.1:1080 https://icanhazip.com
|
||||
curl --socks5-hostname myuser:mypass@127.0.0.1:8808 https://icanhazip.com
|
||||
# или
|
||||
export all_proxy=socks5h://myuser:mypass@127.0.0.1:1080
|
||||
export all_proxy=socks5h://myuser:mypass@127.0.0.1:8808
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
### telemost + vp8channel
|
||||
|
||||
```sh
|
||||
# сервер
|
||||
./olcrtc -mode srv -carrier telemost -transport vp8channel \
|
||||
-id <room-id> -client-id <client-id> -key <hex-key> -link direct -data data \
|
||||
-vp8-fps 60 -vp8-batch 64
|
||||
```yaml
|
||||
# server.yaml
|
||||
mode: srv
|
||||
link: direct
|
||||
auth:
|
||||
provider: telemost
|
||||
room:
|
||||
id: "<room-id>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: vp8channel
|
||||
dns: "1.1.1.1:53"
|
||||
vp8:
|
||||
fps: 60
|
||||
batch_size: 64
|
||||
data: data
|
||||
```
|
||||
|
||||
# клиент
|
||||
./olcrtc -mode cnc -carrier telemost -transport vp8channel \
|
||||
-id <room-id> -client-id <client-id> -key <hex-key> -link direct -data data \
|
||||
-socks-host 127.0.0.1 -socks-port 1080 \
|
||||
-vp8-fps 60 -vp8-batch 64
|
||||
```yaml
|
||||
# client.yaml
|
||||
mode: cnc
|
||||
link: direct
|
||||
auth:
|
||||
provider: telemost
|
||||
room:
|
||||
id: "<room-id>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: vp8channel
|
||||
dns: "1.1.1.1:53"
|
||||
socks:
|
||||
host: "127.0.0.1"
|
||||
port: 8808
|
||||
vp8:
|
||||
fps: 60
|
||||
batch_size: 64
|
||||
data: data
|
||||
```
|
||||
|
||||
### telemost + seichannel
|
||||
|
||||
```sh
|
||||
# сервер
|
||||
./olcrtc -mode srv -carrier telemost -transport seichannel \
|
||||
-id <room-id> -client-id <client-id> -key <hex-key> -link direct -data data \
|
||||
-fps 60 -batch 64 -frag 900 -ack-ms 2000
|
||||
```yaml
|
||||
# server.yaml
|
||||
mode: srv
|
||||
link: direct
|
||||
auth:
|
||||
provider: telemost
|
||||
room:
|
||||
id: "<room-id>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: seichannel
|
||||
dns: "1.1.1.1:53"
|
||||
sei:
|
||||
fps: 60
|
||||
batch_size: 64
|
||||
fragment_size: 900
|
||||
ack_timeout_ms: 2000
|
||||
data: data
|
||||
```
|
||||
|
||||
# клиент
|
||||
./olcrtc -mode cnc -carrier telemost -transport seichannel \
|
||||
-id <room-id> -client-id <client-id> -key <hex-key> -link direct -data data \
|
||||
-socks-host 127.0.0.1 -socks-port 1080 \
|
||||
-fps 60 -batch 64 -frag 900 -ack-ms 2000
|
||||
```yaml
|
||||
# client.yaml
|
||||
mode: cnc
|
||||
link: direct
|
||||
auth:
|
||||
provider: telemost
|
||||
room:
|
||||
id: "<room-id>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: seichannel
|
||||
dns: "1.1.1.1:53"
|
||||
socks:
|
||||
host: "127.0.0.1"
|
||||
port: 8808
|
||||
sei:
|
||||
fps: 60
|
||||
batch_size: 64
|
||||
fragment_size: 900
|
||||
ack_timeout_ms: 2000
|
||||
data: data
|
||||
```
|
||||
|
||||
### telemost + videochannel (крайний случай)
|
||||
|
||||
```sh
|
||||
# сервер
|
||||
./olcrtc -mode srv -carrier telemost -transport videochannel \
|
||||
-id <room-id> -client-id <client-id> -key <hex-key> -link direct -data data \
|
||||
-video-codec qrcode -video-w 1080 -video-h 1080 \
|
||||
-video-fps 60 -video-bitrate 5000k -video-hw none
|
||||
```yaml
|
||||
# server.yaml
|
||||
mode: srv
|
||||
link: direct
|
||||
auth:
|
||||
provider: telemost
|
||||
room:
|
||||
id: "<room-id>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: videochannel
|
||||
dns: "1.1.1.1:53"
|
||||
video:
|
||||
codec: qrcode
|
||||
width: 1080
|
||||
height: 1080
|
||||
fps: 60
|
||||
bitrate: "5000k"
|
||||
hw: none
|
||||
data: data
|
||||
```
|
||||
|
||||
# клиент
|
||||
./olcrtc -mode cnc -carrier telemost -transport videochannel \
|
||||
-id <room-id> -client-id <client-id> -key <hex-key> -link direct -data data \
|
||||
-socks-host 127.0.0.1 -socks-port 1080 \
|
||||
-video-codec qrcode -video-w 1080 -video-h 1080 \
|
||||
-video-fps 60 -video-bitrate 5000k -video-hw none
|
||||
```yaml
|
||||
# client.yaml
|
||||
mode: cnc
|
||||
link: direct
|
||||
auth:
|
||||
provider: telemost
|
||||
room:
|
||||
id: "<room-id>"
|
||||
crypto:
|
||||
key: "<hex-key>"
|
||||
net:
|
||||
transport: videochannel
|
||||
dns: "1.1.1.1:53"
|
||||
socks:
|
||||
host: "127.0.0.1"
|
||||
port: 8808
|
||||
video:
|
||||
codec: qrcode
|
||||
width: 1080
|
||||
height: 1080
|
||||
fps: 60
|
||||
bitrate: "5000k"
|
||||
hw: none
|
||||
data: data
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
Reference in New Issue
Block a user