manual ctunnel - tunnel any TCP or UDP connection in a cryptographic tunnel
Section: User Commands (1)
Updated: May 15, 2010
Index  

NAME

ctunnel - Cryptographic tunnel for TCP and UDP protocols.  

SYNOPSIS

ctunnel [options]  

DESCRIPTION

This manual page documents briefly the ctunnel command.

ctunnel is a command line program for tunneling and/or proxying TCP or UDP connections via a cryptographic tunnel.

ctunnel can be used to secure any existing TCP or UDP based protocol, such as (but not limited to) HTTP, Telnet, FTP, RSH, MySQL, VNC, SSH, XDMCP and NFS.

ctunnel can also proxy connections, effectivly bouncing a cryptographic tunnel via any number of intermediary hosts (at a loss of speed of course).

 

OPTIONS

-U
Use the UDP Protocol (if not set, use TCP by default)
-n
Stay in the foreground, do no daemonize.
-p
Print Stored Key, IV, and Cipher then exit.
-v
Print version iformation then exit.
-h
Print usage syntax.
-z
Enable libz compression on the tunnel. (Good for slow connections, however this can actually slow down a fast connection)
-c
(manditory) Operate in Client Mode. (do not use with -s)
-s
(manditory) Operate in Server Mode. (do not use with -c)
-l
(manditory) Listen for TCP/UDP connections on this port.
-f
(manditory) Forward TCP/UDP from -l to this port.
-H
(manditory) Forward TCP/UDP encrypted packets to this host.
-C
(manditory) Encrypt TCP/UDP packets with this ciper. See CIPHERS below.
-M
(manditory/libgcrypt only) Encryption mode for TCP/UDP. See CIPHERS below.
 

KEYS

On first invocation (or when then ~/.passkey file is missing), ctunnel will prompt via STDIN for a Key and IV.

After you input your Key and IV, ctunnel will automatically use the Key and IV it stores in ~/.passkey until this file is removed.

It is IMPERATIVE that this keyfile (~/.passkey) be protected with STRONG permissions. Anyone with access to this Key and IV can protential decrypt your stream.  

CIPHERS

In order for ctunnel to reliably encrypt traffic, it rely's on a synchronous stream cipher, such as CFB or OFB. Other cipher modes might be supported.

If ctunnel was compiled with OpenSSL, ciphers may be specified with only the -C option, in the OpenSSL format. Example:

-C aes-256-cfb

See ENC(1SSL) - SUPPORTED CIPHERS

If ctunnel was compiled with libgcrypt, ciphers must be specified with the -C and -M options, for example:

-C aes256 -M cfb
 

EXAMPLE

 

Mysql encrypted tunnel

Server (remote machine):
 ./ctunnel -s -l 2021 -f 3306 -H 127.0.0.1 -C aes256 -M cfb
  Client (local):
 ./ctunnel -c -l 2020 -f 2021 -H <remote ip> -C aes256 -M cfb

Now simply connect with the Mysql Client to the local end of the encrypted tunnel:
 mysql -u root -p -h 127.0.0.1 -P 2020  

Mysql encrypted tunnel proxy

Server (remote machine);
 ./ctunnel -s -H 127.0.0.1 -l 2224 -f 3306 -C aes-256-cfb

Proxy (intermediary machine):
 ./ctunnel -s -H 127.0.0.1 -l 2222 -f 2223 -C aes-256-cfb
 ./ctunnel -c -H 10.0.0.4 -l 2223 -f 2224 -C aes-256-cfb

Client (local):
 ./ctunnel -c -H 10.0.0.3 -l 2221 -f 2222 -C aes-256-cfb

This example provides an ecrypted tunnel from 10.0.0.3, via 10.0.0.4 to the remote machine.  

AUTHOR

Written by Jess Mahan.  

REPORTING BUGS

Report bugs to ctunnel-`date +%s`@nardcore.org. Please include as much details as possible.  

COPYRIGHT

Copyright © 2011 Jess Mahan. License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>. This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law.


 

Index

NAME
SYNOPSIS
DESCRIPTION
OPTIONS
KEYS
CIPHERS
EXAMPLE
Mysql encrypted tunnel
Mysql encrypted tunnel proxy
AUTHOR
REPORTING BUGS
COPYRIGHT

Home
ChangeLog
Download
Manual
Examples
Contact