#ssh #mosh #cli

app moshudp

Alternative simplistic UDP-based session establisher for mosh-client and mosh-server

5 releases

0.1.4 May 10, 2022
0.1.3 May 8, 2022
0.1.2 May 7, 2022
0.1.1 May 7, 2022
0.1.0 May 7, 2022

#132 in #ssh

MIT/Apache

28KB
584 lines

moshudp

Typically mosh uses ssh to establish session. However sometimes SSH is not available due to bad network, or you could lose access to SSH (and therefore to Mosh) because of some misconfiguration.

Moshudp provides alternative, simplified UDP-based session establishment mechanism for mosh-client and mosh-server.

This allows connecting mosh-client and mosh-server using only one UDP port, without SSH or another TCP connection. Authentication is based on one static keyfile.

Limitations

  • Only one client at a time. Connecting competing client disconnects earlier one (you can use --ping mode to check server nondestructively).
  • Only symmetric crypto - keyfile is the same on client and server.
  • No NAT traversal or ICE.
  • No security audit. I tried my best to protect it from replay attacks or being a DoS amplifier, but I'm not a security specialist.
  • No replies at all if key is incorrect - client would just time out.
  • Security model of moshudp assumes that mosh-server is ready to accept arbitrary (i.e. malicious) datagrams from open internet.

Installation

Use Github Releases to obtain pre-built version for your platform or install Rust toolchain and do cargo install moshudp.

Help outputs

$ moshudp --help
Usage: moshudp <command> [<args>]

mosh-server and mosh-client interconnector based on UDP and a static key file

Options:
  --help            display usage information

Commands:
  serve             server mode
  connect           client mode
  keygen            generate 32-byte random file to use as a key on client and
                    server

$ moshudp serve  --help
Usage: moshudp serve <addr> <keyfile> [-4] [-6]

server mode

Positional Arguments:
  addr              socket address to listen
  keyfile           32-byte file to generate use as a key

Options:
  -4, --ipv4        limit hostname resolution to IPv4 addresses
  -6, --ipv6        limit hostname resolution to IPv6 addresses
  --help            display usage information

$ moshudp connect  --help
Usage: moshudp connect <addr> <keyfile> [-4] [-6] [--ping]

client mode

Positional Arguments:
  addr              socket address to connect
  keyfile           32-byte file to generate use as a key

Options:
  -4, --ipv4        limit hostname resolution to IPv4 addresses
  -6, --ipv6        limit hostname resolution to IPv6 addresses
  --ping            skip most of the algorithm, just send a ping
  --help            display usage information

See also

Dependencies

~4MB
~85K SLoC