# WeTTY = Web + TTY. [![All Contributors](https://img.shields.io/badge/all_contributors-40-orange.svg?style=flat-square)](#contributors-) ![Version](https://img.shields.io/badge/version-1.1.7-blue.svg?cacheSeconds=2592000) ![Node Version](https://img.shields.io/badge/node-%3E%3D14.0-blue.svg) [![Documentation](https://img.shields.io/badge/documentation-yes-brightgreen.svg)](https://github.com/butlerx/wetty/tree/main/docs) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://github.com/butlerx/wetty/blob/main/LICENSE) [![Twitter: cianbutlerx](https://img.shields.io/twitter/follow/cianbutlerx.svg?style=social)](https://twitter.com/cianbutlerx) > Terminal access in browser over http/https ![WeTTy](./docs/terminal.png?raw=true) Terminal over HTTP and https. WeTTy is an alternative to ajaxterm and anyterm but much better than them because WeTTy uses xterm.js which is a full fledged implementation of terminal emulation written entirely in JavaScript. WeTTy uses websockets rather then Ajax and hence better response time. ## Prerequisites - node >=14 - make - python - build-essential ## Install ```sh yarn global add wetty ``` ## Usage ```sh $ wetty --help Options: --help, -h Print help message [boolean] --version Show version number [boolean] --conf config file to load config from [string] --ssl-key path to SSL key [string] --ssl-cert path to SSL certificate [string] --ssh-host ssh server host [string] --ssh-port ssh server port [number] --ssh-user ssh user [string] --title window title [string] --ssh-auth defaults to "password", you can use "publickey,password" instead [string] --ssh-pass ssh password [string] --ssh-key path to an optional client private key (connection will be password-less and insecure!) [string] --ssh-config Specifies an alternative ssh configuration file. For further details see "-F" option in ssh(1) [string] --force-ssh Connecting through ssh even if running as root [boolean] --known-hosts path to known hosts file [string] --base, -b base path to wetty [string] --port, -p wetty listen port [number] --host wetty listen host [string] --command, -c command to run in shell [string] --allow-iframe Allow wetty to be embedded in an iframe, defaults to allowing same origin [boolean] ``` Open your browser on `http://yourserver:3000/wetty` and you will prompted to login. Or go to `http://yourserver:3000/wetty/ssh/` to specify the user beforehand. If you run it as root it will launch `/bin/login` (where you can specify the user name), else it will launch `ssh` and connect by default to `localhost`. The SSH connection can be forced using the `--force-ssh` option. If instead you wish to connect to a remote host you can specify the `--ssh-host` option, the SSH port using the `--ssh-port` option and the SSH user using the `--ssh-user` option. Check out the [Flags docs](https://github.com/butlerx/wetty/blob/main/docs/flags.md) for a full list of flags ### Docker container To use wetty as a docker container, a docker image is available on [docker hub](https://hub.docker.com/r/wettyoss/wetty). To run this image, use ```sh docker run --rm -p 3000:3000 wettyoss/wetty --ssh-host= ``` and you will be able to open a ssh session to the host given by `YOUR-IP` under the URL [http://localhost:3000/wetty](http://localhost:3000/wetty). It is recommended to drive wetty behind a reverse proxy to have HTTPS security and possibly Let’s Encrypt support. Popular containers to achieve this are [nginx-proxy](https://github.com/nginx-proxy/nginx-proxy) and [traefik](https://traefik.io/traefik/). For traefik there is an example docker-compose file in the containers directory. ## FAQ Check out the [docs](https://github.com/butlerx/wetty/tree/main/docs) - [Running as daemon](https://github.com/butlerx/wetty/blob/main/docs/service.md) - [HTTPS Support](https://github.com/butlerx/wetty/blob/main/docs/https.md) - [Using NGINX](https://github.com/butlerx/wetty/blob/main/docs/nginx.md) - [Using Apache](https://github.com/butlerx/wetty/blob/main/docs/apache.md) - [Automatic Login](https://github.com/butlerx/wetty/blob/main/docs/auto-login.md) - [Downloading Files](https://github.com/butlerx/wetty/blob/main/docs/downloading-files.md) ### What browsers are supported? WeTTy supports all browsers that [xterm.js supports](https://github.com/xtermjs/xterm.js#browser-support). ## Author πŸ‘€ **Cian Butler ** - Twitter: [@cianbutlerx](https://twitter.com/cianbutlerx) - Github: [@butlerx](https://github.com/butlerx) ## Contributing ✨ Contributions, issues and feature requests are welcome!
Feel free to check [issues page](https://github.com/butlerx/wetty/issues). Please read the [development docs](https://github.com/butlerx/wetty/blob/main/docs/development.md) for installing from source and running is dev node Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):

Cian Butler

πŸ’» πŸ“–

Krishna Srinivas

πŸ’»

acalatrava

πŸ’»

Strubbl

πŸ’»

Oleg Kurapov

πŸ’»

Boyan Rabchev

πŸ’»

Jimmy

πŸ’»

Luca Milanesio

πŸ’»

Anthony Jund

πŸ’»

mirtouf

πŸ’»

Bertrand Roussel

πŸ’»

Ben Letchford

πŸ’»

SouraDutta

πŸ’»

Koushik M.L.N

πŸ’»

Imuli

πŸ’»

perpen

πŸ’»

Nathan LeClaire

πŸ’»

Mihir Kumar

πŸ’»

Chris Suszynski

πŸ’»

Felix Bartels

πŸ’»

Jarrett Gilliam

πŸ’»

Harry Lee

πŸ’»

Andreas KlΓΆckner

πŸ’»

DenisKramer

πŸ’»

Vamshi K Ponnapalli

πŸ’»

Tri Nguyen

πŸ“–

Felix Pojtinger

πŸ“–

Neale Pickett

πŸ’»

Matthew Piercey

πŸ“–

Kasper Holbek Jensen

πŸ“–

Farhan Khan

πŸ’»

Jurre Vriesen

πŸ’»

James Turnbull

πŸ’»

Dean Shub

πŸ’»

lozbrown

πŸ’» πŸ’‘

sergeir82

πŸ’»

Kyle Lucy

πŸ’»

userdocs

πŸ“–

Janos Kasza

πŸ’»

Grant Handy

πŸ“–
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome! ## Show your support Give a ⭐️ if this project helped you! ## πŸ“ License Copyright Β© 2019 [Cian Butler ](https://github.com/butlerx).
This project is [MIT](https://github.com/butlerx/wetty/blob/main/LICENSE) licensed. ---