Files
archived-rtty/README.md
Jianhui Zhao 218e6a66dd Update README
Signed-off-by: Jianhui Zhao <jianhuizhao329@gmail.com>
2018-02-07 11:31:50 +08:00

169 lines
5.6 KiB
Markdown
Executable File

# rtty([中文](/README_ZH.md))
[1]: https://img.shields.io/badge/license-GPLV3-brightgreen.svg?style=plastic
[2]: /LICENSE
[3]: https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=plastic
[4]: https://github.com/zhaojh329/rtty/pulls
[5]: https://img.shields.io/badge/Issues-welcome-brightgreen.svg?style=plastic
[6]: https://github.com/zhaojh329/rtty/issues/new
[7]: https://img.shields.io/badge/release-3.1.1-blue.svg?style=plastic
[8]: https://github.com/zhaojh329/rtty/releases
[9]: https://travis-ci.org/zhaojh329/rtty.svg?branch=master
[10]: https://travis-ci.org/zhaojh329/rtty
[![license][1]][2]
[![PRs Welcome][3]][4]
[![Issue Welcome][5]][6]
[![Release Version][7]][8]
[![Build Status][9]][10]
[Xterm.js]: https://github.com/xtermjs/xterm.js
[libubox]: https://git.openwrt.org/?p=project/libubox.git
[libuwsc]: https://github.com/zhaojh329/libuwsc
[ustream-ssl]: https://git.openwrt.org/?p=project/ustream-ssl.git
[openssl]: https://github.com/openssl/openssl
[mbedtls]: https://github.com/ARMmbed/mbedtls
[CyaSSl(wolfssl)]: https://github.com/wolfSSL/wolfssl
[vue]: https://github.com/vuejs/vue
[iview]: https://github.com/iview/iview
A reverse proxy WebTTY. It is composed of the client and the
[server](https://github.com/zhaojh329/rttys). The server is written in go language and uses the [vue]+[iview].
You can access any of your terminals through a web browser based on the device ID you set(If the ID is not set,
the MAC address of the device is used).
rtty is very suitable for remote maintenance your or your company's thousands of Linux devices deployed around the world.
`Keep Watching for More Actions on This Space`
![](/rtty.svg)
![](/rtty.gif)
![](/upfile.gif)
![](/downfile.gif)
# Features
* Simple to deployment and easy to use
* Reverse Proxy
* Connect your device according to the ID you set up
* Fully-featured terminal based on [Xterm.js]
* SSL support: openssl, mbedtls, CyaSSl(wolfssl)
* Support upload file to device
* Support download file from devices
* Cross platform: macOS, Linux, FreeBSD/OpenBSD, OpenWrt/LEDE
# Dependencies for Client side
* [libubox] - C utility functions for OpenWrt, but can also be used for the same purposes in other Linux systems.
[Reference](https://wiki.openwrt.org/doc/techref/libubox)
* [libuwsc] - A Lightweight and fully asynchronous WebSocket client C library based on libubox for Embedded Linux.
* [ustream-ssl] - If you need to support SSL
* [mbedtls] - If you choose mbedtls as your SSL backend
* [CyaSSl(wolfssl)] - If you choose wolfssl as your SSL backend
* [openssl] - If you choose openssl as your SSL backend
# Deploying the server side
Install the GO language environment (if you haven't installed it)
sudo apt-get install golang # For Ubuntu
sudo yum install golang # For Centos
Set GOPATH environment variable(if you haven't set it)(since Go 1.8, default is $HOME/go)
export GOPATH=$HOME/go
Install rtty server
go get -u github.com/zhaojh329/rttys
Manual run
$GOPATH/bin/rttys -port 5912
Install the automatic boot script(debian/ubuntu)
cd $GOPATH/src/github.com/zhaojh329/rttys
sudo ./install.sh
sudo /etc/init.d/rttys start
# How to build and install the Client - rtty
## For Linux distribution, such as Ubuntu and Centos
Install build tools
sudo apt install gcc cmake git # For Ubuntu
yum install gcc cmake git # For Centos
Install dependent packages
sudo apt install libjson-c-dev # For Ubuntu
sudo apt install json-c-devel # For Centos
git clone https://git.openwrt.org/project/libubox.git
cd libubox && cmake -DBUILD_LUA=OFF . && sudo make install
git clone https://github.com/zhaojh329/libuwsc.git
cd libuwsc && cmake -DUWSC_SSL_SUPPORT=OFF . && sudo make install
Install RTTY
git clone https://github.com/zhaojh329/rtty.git
cd rtty && cmake . && sudo make install
Run RTTY
Replace the following parameters with your own parameters
sudo rtty -I 'My-device-ID' -h 'jianhuizhao.f3322.net' -p 5912 -a -v -d 'My Device Description'
Query online devices
curl http://jianhuizhao.f3322.net:5912/devs
[{"id":"My-device-ID","description":"My device"}]
## For Embedded Linux Platform
You need to cross compiling by yourself
## For OpenWRT
Install
opkg update
opkg list | grep rtty
opkg install rtty-nossl
If the install command fails, you can [compile it yourself](/BUILDOPENWRT.md).
Configuring the server parameter
uci add rtty rtty # If it's the first configuration
uci set rtty.@rtty[0].host='your server host'
uci set rtty.@rtty[0].port='your server port'
You can customize an ID for your device. If the ID is not configured, RTTY will use
the MAC address of the specified network interface as the ID.
The format of the MAC address as the ID is: 1A2A3A4A5A6A
uci set rtty.@rtty[0].id='your-device-id'
You can add a description to your device
uci set rtty.@rtty[0].description='My device'
Save configuration and apply
uci commit
/etc/init.d/rtty restart
# Usage
Query online devices: http://your-server-host:5912/devs
Use your web browser to access your server: http://your-server-host:5912,
then enter the id of the terminal you want to access, and then click the connection button
You can easily embed RTTY into your existing platform: http://your-server-host:5912?id=your-id
Automatic login: http://your-server:5912/?id=device-id&username=device-username&password=device-password
# Contributing
If you would like to help making [rtty](https://github.com/zhaojh329/rtty) better,
see the [CONTRIBUTING.md](https://github.com/zhaojh329/rtty/blob/master/CONTRIBUTING.md) file.