telebit.js/README.md

545 lines
14 KiB
Markdown
Raw Normal View History

2018-05-27 01:59:43 -06:00
# Telebit™ Remote
2018-04-24 01:54:21 +00:00
2018-05-27 01:58:37 -06:00
Because friends don't let friends localhost™
2016-09-30 12:33:38 -04:00
2018-05-27 01:58:37 -06:00
| Sponsored by [ppl](https://ppl.family)
| **Telebit Remote**
| [Telebit Relay](https://git.coolaj86.com/coolaj86/telebit-relay.js)
2018-05-27 01:58:37 -06:00
|
2016-09-30 12:33:38 -04:00
2018-05-27 01:58:37 -06:00
Break out of localhost.
2018-05-27 01:59:43 -06:00
=======
2016-10-06 15:01:58 -06:00
2018-05-27 01:58:37 -06:00
If you need to get bits from here to there, Telebit gets the job done.
2016-09-30 12:33:38 -04:00
2018-05-27 01:58:37 -06:00
Install Telebit Remote on any device - your laptop, raspberry pi, whatever -
and now you can access that device from anywhere, even securely in a web browser.
2016-09-30 12:33:38 -04:00
2018-05-27 01:58:37 -06:00
How does it work?
It's a net server that uses a relay to allow multiplexed incoming connections
on any external port.
Features
--------
* [x] Show your mom the web app you're working on
* [x] Access your Raspberry Pi from behind a firewall
* [x] Watch Netflix without region restrictions while traveling
* [x] SSH over HTTPS on networks with restricted ports or protocols
* [x] Access your wife's laptop while she's on a flight
2018-06-02 02:58:42 -06:00
Examples
========
2018-06-08 09:58:44 -06:00
As a user service
```bash
2018-06-11 14:52:01 -06:00
telebitd --config ~/.config/telebit/telebitd.yml &
2018-06-04 18:32:18 -06:00
```
2018-06-08 09:58:44 -06:00
As a system service
```bash
2018-06-11 14:52:01 -06:00
sudo telebitd --config ~/.config/telebit/telebitd.yml
2018-06-04 18:32:18 -06:00
```
2018-06-08 09:58:44 -06:00
Example output:
2018-06-04 18:32:18 -06:00
```
Connect to your device by any of the following means:
SSH+HTTPS
ssh+https://lucky-duck-37.telebit.cloud:443
ex: ssh -o ProxyCommand='openssl s_client -connect %h:%p -servername %h -quiet' lucky-duck-37.telebit.cloud -p 443
2018-06-04 18:32:18 -06:00
SSH
ssh://ssh.telebit.cloud:32852
ex: ssh ssh.telebit.cloud -p 32852
TCP
tcp://tcp.telebit.cloud:32852
ex: netcat tcp.telebit.cloud 32852
HTTPS
https://lucky-duck-37.telebit.cloud
ex: curl https://lucky-duck-37.telebit.cloud
2018-06-04 18:32:18 -06:00
```
2018-06-08 09:58:44 -06:00
```bash
# Forward all https traffic to port 3000
2018-06-02 02:58:42 -06:00
telebit http 3000
2018-06-08 09:58:44 -06:00
# Forward all tcp traffic to port 5050
telebit tcp 5050
# List all rules
telebit list
2018-06-02 02:58:42 -06:00
```
2018-05-27 01:58:37 -06:00
Install
=======
Mac & Linux
-----------
Open Terminal and run this install script:
2018-06-04 23:23:59 -06:00
```
2018-06-04 23:50:02 -06:00
curl -fsSL https://get.telebit.cloud | bash
2018-06-04 23:23:59 -06:00
```
<!--
2018-05-27 01:58:37 -06:00
```
2018-06-04 23:50:02 -06:00
bash <( curl -fsSL https://get.telebit.cloud )
2018-05-27 01:58:37 -06:00
```
2018-06-05 04:50:39 +00:00
<small>
Note: **fish**, **zsh**, and other **non-bash** users should do this
```
curl -fsSL https://get.telebit.cloud/ > get.sh; bash get.sh
```
</small>
2018-06-04 23:23:59 -06:00
-->
2018-06-05 04:50:39 +00:00
2018-06-11 14:52:01 -06:00
What does the installer do?
* install Telebit Remote to `/opt/telebit`
* symlink the executables to `/usr/local/bin` for convenience
* `/usr/local/bin/telebitd => /opt/telebit/bin/telebitd`
* `/usr/local/bin/telebit => /opt/telebit/bin/telebit`
* create the appropriate system launcher file
* `/etc/systemd/system/telebit.service`
* `/Library/LaunchDaemons/cloud.telebit.remote.plist`
2018-06-11 14:52:01 -06:00
* create local user config
* `~/.config/telebit/telebit.yml`
* `~/.local/share/telebit`
Of course, feel free to inspect it before you run it: `curl -fsSL https://get.telebit.cloud`
2018-05-27 01:58:37 -06:00
2018-06-04 18:32:18 -06:00
**You can customize the installation**:
2016-09-30 12:33:38 -04:00
2017-04-05 16:36:01 -06:00
```bash
2018-05-27 01:58:37 -06:00
export NODEJS_VER=v10.2
export TELEBIT_PATH=/opt/telebit
export TELEBIT_VERSION=v1 # git tag or branch to install from
2018-05-27 01:58:37 -06:00
curl -fsSL https://get.telebit.cloud/
2017-04-05 16:36:01 -06:00
```
2018-05-27 01:58:37 -06:00
That will change the bundled version of node.js is bundled with Telebit Relay
and the path to which Telebit Relay installs.
You can get rid of the tos + email and server domain name prompts by providing them right away:
2017-04-05 16:36:01 -06:00
2016-09-30 12:33:38 -04:00
```bash
2018-05-27 01:58:37 -06:00
curl -fsSL https://get.telebit.cloud/ | bash -- jon@example.com example.com telebit.example.com xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
2016-09-30 12:33:38 -04:00
```
2018-05-27 01:58:37 -06:00
Windows & Node.js
-----------------
2017-03-28 15:31:45 -06:00
2018-05-27 01:58:37 -06:00
1. Install [node.js](https://nodejs.org)
2. Open _Node.js_
2. Run the command `npm install -g telebit`
2018-06-11 14:52:01 -06:00
2. Copy the example daemon conifg to your user folder `.config/telebit/telebitd.yml` (such as `/Users/John/.config/telebit/telebitd.yml`)
2. Copy the example remote conifg to your user folder `.config/telebit/telebit.yml` (such as `/Users/John/.config/telebit/telebit.yml`)
2. Change the email address
2. Run `telebitd`
2. Run `telebit list`
2017-03-28 15:31:45 -06:00
2018-05-27 01:58:37 -06:00
**Note**: Use node.js v8.x or v10.x
There is [a bug](https://github.com/nodejs/node/issues/20241) in node v9.x that causes telebit to crash.
2018-06-08 03:01:59 -06:00
Remote Usage
============
```
# commands
telebit <command>
# domain and port control
telebit <service> <handler> [servername] [options ...]
```
Examples:
```
telebit status # whether enabled or disabled
telebit enable # disallow incoming connections
telebit disable # allow incoming connections
telebit restart # kill daemon and allow system launcher to restart it
telebit list # list rules for servernames and ports
################
# HTTP #
################
telebit http <handler> [servername] [opts]
telebit http none # remove all https handlers
telebit http 3000 # forward all https traffic to port 3000
telebit http /module/path # load a node module to handle all https traffic
telebit http none example.com # remove https handler from example.com
telebit http 3001 example.com # forward https traffic for example.com to port 3001
telebit http /module/path example.com # forward https traffic for example.com to port 3001
################
# TCP #
################
telebit tcp <handler> [servername] [opts]
telebit tcp none # remove all tcp handlers
telebit tcp 5050 # forward all tcp to port 5050
telebit tcp /module/path # handle all tcp with a node module
telebit tcp none 6565 # remove tcp handler from external port 6565
telebit tcp 5050 6565 # forward external port 6565 to local 5050
telebit tcp /module/path 6565 # handle external port 6565 with a node module
telebit ssh disable # disable ssh access
telebit ssh 22 # port-forward all ssh connections to port 22
telebit save # save http and tcp configuration changes
2018-06-08 03:01:59 -06:00
```
### Using SSH
SSH over HTTPS
```
ssh -o ProxyCommand='openssl s_client -connect %h:443 -servername %h -quiet' lucky-duck-42.telebit.cloud
2018-06-08 03:01:59 -06:00
```
SSH over non-standard port
```
ssh lucky-duck-42.telebit.cloud -p 3031
2018-06-08 03:01:59 -06:00
```
Daemon Usage
============
2017-03-28 15:31:45 -06:00
```bash
2018-06-11 14:52:01 -06:00
telebitd --config /opt/telebit/etc/telebitd.yml
2018-05-27 01:58:37 -06:00
```
Options
2018-06-11 14:52:01 -06:00
`/opt/telebit/etc/telebitd.yml:`
2018-05-27 01:58:37 -06:00
```
email: 'jon@example.com' # must be valid (for certificate recovery and security alerts)
agree_tos: true # agree to the Telebit, Greenlock, and Let's Encrypt TOSes
2018-06-04 18:32:18 -06:00
relay: wss://telebit.cloud # a Telebit Relay instance
2018-05-27 01:58:37 -06:00
community_member: true # receive infrequent relevant but non-critical updates
telemetry: true # contribute to project telemetric data
2018-05-27 04:26:34 -06:00
secret: '' # Secret with which to sign Tokens for authorization
2018-06-04 18:32:18 -06:00
#token: '' # A signed Token for authorization
ssh_auto: 22 # forward ssh-looking packets, from any connection, to port 22
2018-05-27 01:58:37 -06:00
servernames: # servernames that will be forwarded here
2018-06-02 02:58:42 -06:00
example.com: {}
2017-03-28 15:31:45 -06:00
```
2018-06-04 23:50:02 -06:00
Choosing A Relay
================
You can create a free or paid account at https://telebit.cloud
or you can run [Telebit Relay](https://git.coolaj86.com/coolaj86/telebitd.js)
open source on a VPS (Vultr, Digital Ocean)
or your Raspberry Pi at home (with port-forwarding).
Only connect to Telebit Relays that you trust.
2018-06-04 18:32:18 -06:00
<!--
2018-06-02 02:58:42 -06:00
## Important Defaults
The default behaviors work great for newbies,
but can be confusing or annoying to experienced networking veterans.
See the **Advanced Configuration** section below for more details.
2018-05-27 01:58:37 -06:00
```
redirect:
example.com/foo: /bar
'*': whatever.com/
vhost: # securely serve local sites from this path (or false)
example.com: /srv/example.com # (uses template string, i.e. /var/www/:hostname/public)
'*': /srv/www/:hostname
reverse_proxy: /srv/
example.com: 3000
'*': 3000
2018-06-02 02:58:42 -06:00
terminate_tls:
2018-05-27 01:58:37 -06:00
'example.com': 3000
'*': 3000
2018-06-02 02:58:42 -06:00
tls:
2018-05-27 01:58:37 -06:00
'example.com': 8443
'*': 8443
port_forward:
2020: 2020
'*': 4040
greenlock:
store: le-store-certbot # certificate storage plugin
config_dir: /etc/acme # directory for ssl certificates
```
Using Telebit with node.js
--------------------------
Telebit has two parts:
* the local server
* the relay service
This repository is for the local server, which you run on the computer or device that you would like to access.
This is the portion that runs on your computer
You will need both Telebit (this, telebit.js) and a Telebit Relay
(such as [telebitd.js](https://git.coolaj86.com/coolaj86/telebitd.js)).
You can **integrate telebit.js into your existing codebase** or use the **standalone CLI**.
* CLI
* Node.js Library
* Browser Library
Telebit CLI
-----------
2018-05-27 04:26:34 -06:00
Installs Telebit Remote as `telebit`
(for those that regularly use `telebit` but still like commandline completion).
2018-05-27 01:58:37 -06:00
### Install
2017-03-28 15:31:45 -06:00
```bash
2018-05-27 01:58:37 -06:00
npm install -g telebit
```
```bash
2018-05-27 04:26:34 -06:00
npm install -g 'https://git.coolaj86.com/coolaj86/telebit.js.git#v1'
2017-03-28 15:31:45 -06:00
```
2018-05-27 01:58:37 -06:00
Or if you want to bow down to the kings of the centralized dictator-net:
2016-09-30 12:33:38 -04:00
2018-05-27 04:26:34 -06:00
How to use Telebit Remote with your own instance of Telebit Relay:
2016-09-30 12:33:38 -04:00
2017-03-26 01:37:26 -06:00
```bash
2018-05-27 04:26:34 -06:00
telebit \
2017-03-26 01:37:26 -06:00
--locals <<external domain name>> \
2018-05-27 04:26:34 -06:00
--relay wss://<<tunnel domain>>:<<tunnel port>> \
2017-03-26 01:37:26 -06:00
--secret <<128-bit hex key>>
```
2016-09-30 12:33:38 -04:00
```bash
2018-05-27 04:26:34 -06:00
telebit --locals john.example.com --relay wss://tunnel.example.com:443 --secret abc123
2016-10-06 15:16:21 -06:00
```
2017-03-26 01:37:26 -06:00
```bash
2018-05-27 04:26:34 -06:00
telebit \
2017-03-26 01:37:26 -06:00
--locals <<protocol>>:<<external domain name>>:<<local port>> \
2018-05-27 04:26:34 -06:00
--relay wss://<<tunnel domain>>:<<tunnel port>> \
2017-03-26 01:37:26 -06:00
--secret <<128-bit hex key>>
```
2016-10-06 15:16:21 -06:00
```bash
2018-05-27 04:26:34 -06:00
telebit \
2016-10-06 15:16:21 -06:00
--locals http:john.example.com:3000,https:john.example.com \
2018-05-27 04:26:34 -06:00
--relay wss://tunnel.example.com:443 \
2016-10-06 15:16:21 -06:00
--secret abc123
2016-09-30 12:33:38 -04:00
```
```
2018-05-27 04:26:34 -06:00
--secret the same secret used by the Telebit Relay (for authentication)
2016-09-30 12:33:38 -04:00
--locals comma separated list of <proto>:<servername>:<port> to which
incoming http and https should be forwarded
2018-05-27 04:26:34 -06:00
--relay the domain or ip address at which you are running Telebit Relay
-k, --insecure ignore invalid ssl certificates from relay
2016-09-30 12:33:38 -04:00
```
2018-05-27 01:58:37 -06:00
Node.js Library
2016-10-06 15:01:58 -06:00
=======
### Example
```javascript
2018-05-27 04:26:34 -06:00
var Telebit = require('telebit');
2016-10-06 15:01:58 -06:00
2018-05-27 04:26:34 -06:00
Telebit.connect({
relay: 'wss://tunnel.example.com'
2016-10-06 15:01:58 -06:00
, token: '...'
, locals: [
// defaults to sending http to local port 80 and https to local port 443
{ hostname: 'doe.net' }
// sends both http and https to local port 3000 (httpolyglot)
, { protocol: 'https', hostname: 'john.doe.net', port: 3000 }
// send http to local port 4080 and https to local port 8443
, { protocol: 'https', hostname: 'jane.doe.net', port: 4080 }
, { protocol: 'https', hostname: 'jane.doe.net', port: 8443 }
]
, net: require('net')
, insecure: false
});
```
2016-10-11 15:39:06 -06:00
* You can get sneaky with `net` and provide a `createConnection` that returns a `stream.Duplex`.
2016-10-06 15:01:58 -06:00
### Token
```javascript
var tokenData = { domains: [ 'doe.net', 'john.doe.net', 'jane.doe.net' ] }
var secret = 'shhhhh';
var token = jwt.sign(tokenData, secret);
```
### net
Let's say you want to handle http requests in-process
or decrypt https before passing it to the local http handler.
2016-10-11 14:49:52 -06:00
You'll need to create a pair of streams to connect between the
local handler and the tunnel handler.
2016-10-06 15:01:58 -06:00
You could do a little magic like this:
2016-12-19 09:31:35 -07:00
```js
2018-05-27 04:26:34 -06:00
Telebit.connect({
2016-10-06 15:01:58 -06:00
// ...
, net: {
createConnection: function (info, cb) {
// data is the hello packet / first chunk
// info = { data, servername, port, host, remoteAddress: { family, address, port } }
var streamPair = require('stream-pair');
2018-02-14 23:27:15 -07:00
// here "reader" means the socket that looks like the connection being accepted
var writer = streamPair.create();
// here "writer" means the remote-looking part of the socket that driving the connection
var reader = writer.other;
2016-10-11 14:49:52 -06:00
// duplex = { write, push, end, events: [ 'readable', 'data', 'error', 'end' ] };
reader.remoteFamily = info.remoteFamily;
reader.remoteAddress = info.remoteAddress;
reader.remotePort = info.remotePort;
2016-10-06 15:01:58 -06:00
// socket.local{Family,Address,Port}
reader.localFamily = 'IPv4';
reader.localAddress = '127.0.01';
reader.localPort = info.port;
2016-10-06 15:01:58 -06:00
httpsServer.emit('connection', reader);
2016-10-06 15:01:58 -06:00
2016-10-11 13:57:21 -06:00
if (cb) {
2016-10-11 15:43:09 -06:00
process.nextTick(cb);
2016-10-11 13:57:21 -06:00
}
return writer;
2016-10-06 15:01:58 -06:00
}
});
```
2018-05-27 01:58:37 -06:00
2018-06-02 02:58:42 -06:00
Advanced Configuration
======================
There is no configuration for these yet,
but we believe it is important to add them.
### http to https
By default http connections are redirected to https.
If for some reason you need raw access to unencrypted http
you'll need to set it manually.
Proposed configuration:
```
insecure_http:
proxy: true # add X-Forward-* headers
port: 3000 # connect to port 3000
hostnames: # only these hostnames will be left insecure
- example.com
```
**Note**: In the future unencrypted connections will only be allowed
on self-hosted and paid-hosted Telebit Relays. We don't want the
legal liability of transmitting your data in the clear, thanks. :p
### TLS Termination (Secure SSL decryption)
Telebit is designed for end-to-end security.
For convenience the Telebit Remote client uses Greenlock to handle all
HTTPS connections and then connect to a local webserver with the correct proxy headers.
However, if you want to handle the encrypted connection directly, you can:
Proposed Configuration:
```
tls:
example.com: 3000 # specific servername
'*': 3000 # all servernames
'!': 3000 # missing servername
```
2018-05-27 04:26:34 -06:00
TODO
====
Install for user
* https://wiki.archlinux.org/index.php/Systemd/User
* https://developer.apple.com/library/content/documentation/MacOSX/Conceptual/BPSystemStartup/Chapters/CreatingLaunchdJobs.html
* `sudo launchctl load -w ~/Library/LaunchAgents/cloud.telebit.remote`
* https://serverfault.com/questions/194832/how-to-start-stop-restart-launchd-services-from-the-command-line
2018-06-04 18:32:18 -06:00
-->
2018-05-27 04:26:34 -06:00
2018-06-05 01:27:36 -06:00
Check Logs
==========
**Linux**:
```
sudo journalctl -xefu telebit
```
**macOS**:
```
sudo tail -f /opt/telebit/var/log/info.log
```
```
sudo tail -f /opt/telebit/var/log/error.log
```
2018-06-05 00:04:05 -06:00
Uninstall
=======
**Linux**:
```
sudo systemctl disable telebit; sudo systemctl stop telebit
sudo rm -rf /etc/systemd/system/telebit.service /opt/telebit /usr/local/bin/telebit
2018-06-05 00:05:48 -06:00
rm -rf ~/.config/telebit ~/.local/share/telebit
2018-06-05 00:04:05 -06:00
```
**macOS**:
```
sudo launchctl unload -w /Library/LaunchDaemons/cloud.telebit.remote.plist
sudo rm -rf /Library/LaunchDaemons/cloud.telebit.remote.plist /opt/telebit /usr/local/bin/telebit
2018-06-05 00:05:48 -06:00
rm -rf ~/.config/telebit ~/.local/share/telebit
2018-06-05 00:04:05 -06:00
```
2018-05-27 01:58:37 -06:00
Browser Library
=======
This is implemented with websockets, so you should be able to
2018-06-02 02:58:42 -06:00
LICENSE
=======
Copyright 2016 AJ ONeal