WebRTTY allows you to share a terminal session from your machine using WebRTC. You can pair with a friend without setting up a proxy server, debug servers behind NATs, and more. WebRTTY also works in-browser. You can connect to a WebRTTY session from this static page: https://maxmcd.github.io/webrtty/
There are a handful of bugs to fix, but everything works pretty well at the moment. Please open an issue if you find a bug.
go get -u github.com/maxmcd/webrtty
WebRTTY uses the wonderful pions/webrtc for WebRTC communication. It currently requires OpenSSL to build. More here: https://github.com/pions/webrtc#install
> webrtty -h
Usage of webrtty:
-cmd
The command to run. Default is "bash -l"
Because this flag consumes the remainder of the command line,
all other args (if present) must appear before this flag.
eg: webrtty -o -v -ni -cmd docker run -it --rm alpine:latest sh
-ni
Set host to non-interactive
-non-interactive
Set host to non-interactive
-o One-way connection with no response needed.
-v Verbose logging
# On the host computer
> webrtty
Setting up a WebRTTY connection.
Connection ready. Here is your connection data:
25FrtDEjh7yuGdWMk7R9PhzPmphst7FdsotL11iXa4r9xyTM4koAauQYivKViWYBskf8habEc5vHf3DZge5VivuAT79uSCvzc6aL2M11kcUn9rzb4DX4...
Paste it in the terminal after the webrtty command
Or in a browser: https://maxmcd.github.io/webrtty/
When you have the answer, paste it below and hit enter:
# On the client computer
webrtty 25FrtDEjh7yuGdWMk7R9PhzPmphst7FdsotL11iXa4r9xyTM4koAauQYivKViWYBskf8habEc5vHf3DZge5VivuAT79uSCvzc6aL2M11kcUn9rzb4DX4...
By default WebRTTY forces the size of the client terminal. This means the host size can frequently render incorrectly. One way you can fix this is by using tmux:
tmux new-session -s shared
# in another terminal
webrtty -ni -cmd tmux attach-session -t shared
Tmux will now resize the session to the smallest terminal viewport.
One-way connections can be enabled with the -o
flag. A typical webrtc connection requires an SDP exchange between both parties. By default, WebRTTY will create an SDP offer and wait for you to enter the SDP answer. With the -o
flag the initial offer is sent along with a public url that the receiver is expected to post their response to. This uses my service 10kb.site. The host then polls the url continually until it gets an answer.
I think this somewhat violates the spirit of this tool because it relies on a third party service. However, one-way connections allow you to do very cool things. Eg: I can have a build server output a WebRTTY connection string on error and allow anyone to attach to the session.
SDP descriptions are encrypted when uploaded and encryption keys are shared with the connection data to decrypt. So presumably the service being compromised is not problematic.
Very open to any ideas on how to enable trusted one-way connections. Please open an issue or reach out if you have thoughts. For now, the -o
flag will print a warning and link to this explanation.