rtctunnel

build network tunnels over WebRTC

Github星跟蹤圖

RTCTunnel

RTCTunnel builds network tunnels over WebRTC.

WARNING: this is a proof of concept and should not be used in production. Things like disconnects and invalid data are not handled gracefully and will result in the program crashing.

An overview of the application and how and why it was built is available here: RTCTunnel: Building a WebRTC Proxy with Go.

Installation

RTCTunnel can be installed via go get:

go get github.com/rtctunnel/rtctunnel/cmd/rtctunnel

Or downloaded from the releases page (for linux).

Usage

RTCTunnel creates a network tunnel over WebRTC between two peers. Those peers are identified by a public key.

To use RTCTunnel first create a config with:

rtctunnel init

You can see info with:

rtctunnel info

Once you've done that on both peers, copy the two public keys and add a route. A route has four components: a local peer, a local port, a remote peer and a remote port. All network connections and data sent to the local port will be forwarded to the remote peer. For example:

export CLIENT_KEY=
export SERVER_KEY=
rtctunnel add-route \
    --local-peer=$CLIENT_KEY \
    --local-port=6379 \
    --remote-peer=$SERVER_KEY \
    --remote-port=6379

The route must be added on both peers and the CLIENT_KEY and SERVER_KEY should be set to the peer keys.

Once the routes are added you can run rtctunnel with:

rtctunnel run

Typically it would be run in the background.

A docker-compose example is available in examples/redis.

Configuration

Configuration is stored in a yaml file based on github.com/kirsle/configdir:

Linux:   $XDG_CONFIG_HOME or "$HOME/.config"
Windows: %APPDATA% or "C:\\Users\\%USER%\\AppData\\Roaming"
macOS:   $HOME/Library/Application Support

You can see the path by running rtctunnel help.

Signal Channel

In addition to the key pair and routes you can set the signal channel in the config:

keypair:
  public: xxx
  private: xxx
routes: []
signalchannel: operator://localhost:8000

The default signal channel is apprtc:// which uses a websocket server for appr.tc.

主要指標

概覽
名稱與所有者scivision/PyLivestream
主編程語言Python
編程語言Go (語言數: 2)
平台
許可證Apache License 2.0
所有者活动
創建於2017-05-14 02:26:40
推送於2025-03-06 18:01:17
最后一次提交
發布數46
最新版本名稱v2.1.1 (發布於 )
第一版名稱v1.0.0 (發布於 )
用户参与
星數736
關注者數26
派生數162
提交數362
已啟用問題?
問題數86
打開的問題數5
拉請求數4
打開的拉請求數0
關閉的拉請求數4
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?