Chat over SSH.
Go to file
Andrey Petrov cc01deb4bb OOops merge conflict. 2014-12-13 13:47:28 -08:00
.gitignore Add .gitignore for easier local development 2014-12-13 13:18:58 -06:00
.travis.yml Only go v1.4, to save travis some resources. 2014-12-13 11:01:11 -08:00
Dockerfile Add Dockerfile 2014-12-12 21:26:53 -08:00
LICENSE LICENSE, todo. 2014-12-12 17:52:05 -08:00
Makefile Adds Travis-CI testing 2014-12-13 10:53:14 -08:00
README.md Updated the readme to reflect tab completion 2014-12-13 16:17:03 +05:30
client.go OOops merge conflict. 2014-12-13 13:47:28 -08:00
cmd.go Add multiple admins. 2014-12-12 23:29:11 -08:00
colors.go Allow for 256 different colors for username colors 2014-12-13 06:38:52 -06:00
history.go Hacky fixes with notes. 2014-12-12 01:15:58 -08:00
history_test.go More commands, history, tests. 2014-12-11 22:03:32 -08:00
logger.go Progress: Echo working. 2014-12-06 23:31:23 -08:00
pty.go Set term width properly. 2014-12-09 19:26:55 -08:00
server.go Yay conflicts 2014-12-13 16:36:19 -05:00

README.md

ssh-chat

Custom SSH server written in Go. Instead of a shell, you get a chat prompt.

Demo

Join the party:

$ ssh chat.shazow.net

(Apologies if the server is down.)

Quick Start

Usage:
  ssh-chat [OPTIONS]

Application Options:
  -v, --verbose   Show verbose logging.
  -b, --bind=     Host and port to listen on. (0.0.0.0:22)
  -i, --identity= Private key to identify server with. (~/.ssh/id_rsa)

Help Options:
  -h, --help      Show this help message

After doing go get github.com/shazow/ssh-chat on this repo, you should be able to run a command like:

$ ssh-chat --verbose --bind ":2022" --identity ~/.ssh/id_dsa

To bind on port 22, you'll need to make sure it's free (move any other ssh daemons to another port) and run ssh-chat as root (or with sudo).

ssh-chat on Docker

You can run ssh-chat using a Docker image without manually installing go-lang:

$ docker pull alvin/ssh-chat
$ docker run -d -p 0.0.0.0:(your host machine port):2022 --name ssh-chat alvin/ssh-chat

Or you can build your own image:

$ docker build -t (your-docker-username)/ssh-chat .

then run it:

$ docker run -d -p 0.0.0.0:(your host machine port):2022 --name ssh-chat (your-docker-username)/ssh-chat

Developing

If you're developing on this repo, there is a handy Makefile that should set things up with make run.

TODO:

  • Welcome message.
  • set term width properly
  • client map rather than list
  • backfill chat history
  • tab completion
  • /ban
  • /ban by ip
  • /help
  • /about
  • /list
  • /nick
  • pubkey fingerprint
  • truncate usernames
  • rename collision bug
  • op ops on join
  • piped stdout bug
  • saner sanitizing of inputs (version string, allow space/period)
  • Some tests.
  • More tests.
  • Even more tests.
  • Lots of refactoring
  • Pull out the chat-related stuff into isolation from the ssh serving stuff

License

MIT