Jump to content

RUT900 VPN: Difference between revisions

9,301 bytes added ,  15 January 2019
no edit summary
No edit summary
Line 754: Line 754:
     </tr>
     </tr>
</table>
</table>
==Stunnel==
'''Stunnel''' is an open-source multi-platform software application used to provide a TLS/SSL tunneling service for already existing clients and servers. Below is an overview of the Stunnel application and its WebUI configuration section implemented on RUTxxx routers. For in-depth examples please visit '''[[Stunnel configuration examples|Stunnel page]]'''.
Here is an approximate visual representation of Stunnel connection:
[[Image:draw_io_simple_stunnel.png]]
Upon creation, Stunnel configuration will be empty. User is expected to define their own configuration using the created configuration template. Stunnel provided encryption and connection will only work with properly configured Stunnel server(s) and client(s).
Duplicate configuration names are not allowed.
Stunnel configuration list window is located at '''Services → VPN → Stunnel''':
Services menu, VPN section:
[[Image:stunnel_config_menu.png]]
Stunnel tab:
[[Image:stunnel_config_tab.png]]
To create a new configuration, enter the desired name in field below all configuration list entries and click button '''Add''':
[[Image:stunnel_config_creation.png]]
Once you’ve added a new Stunnel configuration, it is automatically saved - no need to press the '''Save''' button.
By default the configuration will be disabled and unconfigured. You can change the configuration by clicking the '''Edit''' button and delete the configuration by clicking the '''Delete''' button.
[[Image:stunnel_edit_button.png]]
To establish an Stunnel connection you must have configured and enabled Stunnel client and server instances on either same or different routers.
===Stunnel Configuration===
Default Stunnel configuration:
[[Image:stunnel_default_config.png]]
Stunnel configuration field explanation table:
<table class="nd-mantable">
    <tr>
        <th>Field Name</th>
        <th>Value</th>
        <th>Description</th>
    </tr>
    <tr>
        <td>Enabled</td>
        <td>yes {{!}} no; Default: '''no'''</td>
        <td>Enables the Stunnel configuration.</td>
    </tr>
    <tr>
        <td>Operating Mode</td>
        <td>Client {{!}} Server; Default: ""</td>
        <td>Specifies whether this configuration will be used for Stunnel client or server.</td>
    </tr>
    <tr>
        <td>Listen IP</td>
        <td>ip {{!}} host; Default: ""</td>
        <td>'''OPTIONAL'''
Specifies which IP address or host should Stunnel listen to. If left empty, defaults to '''localhost'''.</td>
    </tr>
    <tr>
        <td>Listen Port</td>
        <td>port (integer [0..65535]); Default: ""</td>
        <td>Specifies TCP port which Stunnel should listen to. '''Port cannot be taken by another service!'''</td>
    </tr>
    <tr>
        <td>Connect IP's</td>
        <td>[host:]port; Default: ""</td>
        <td>Uses the standard host:port convetion (e.g. 127.0.0.1:6001; localhost:6001). Host part can be emmited - empty host part defaults to '''localhost'''.
Must contain at least one item. If multiple options are specified, remote address is chosen using a round-robin algorithm.</td>
    </tr>
    <tr>
        <td>TLS Cipher</td>
        <td>None {{!}} Secure {{!}} Custom</td>
        <td>Select permitted TLS ciphers (TLSv1.2 and below). If custom is selected, a new field appears to enter custom ciphers.</td>
    </tr>
    <tr>
        <td>Allowed TLS Ciphers</td>
        <td>Cipher[:Cipher]..; Default: ""</td>
        <td>''Only appears if a Custom TLS Cipher is selected''<br>
A colon-delimited TLS cipher list (e.g. DES-CBC3-SHA:IDEA-CBC-MD5)</td>
    </tr>
    <tr>
        <td>Application Protocol</td>
        <td>Not specified {{!}} Connect {{!}} SMTP; Default: '''Not specified'''</td>
        <td>'''CLIENT SIDE ONLY'''
This option enables initial, protocol-specific negotiation of the TLS encryption. The protocol option should not be used with TLS encryption on a separate port.
If ''Connect'' or ''SMTP'' is selected, more customization fields appear.</td>
    </tr>
    <tr>
        <td>Protocol Authentication</td>
        <td>'''Connect:''' Basic {{!}} NTLM; Default: '''Basic'''
            '''SMTP:''' Plain {{!}} Login; Default: '''Plain'''</td>
        <td>'''CLIENT SIDE ONLY'''
''Options depend on the selected protocol''
Authentication type for the protocol negotiations.</td>
    </tr>
    <tr>
        <td>Protocol Domain</td>
        <td>domain (text); Default: ""</td>
        <td>'''CLIENT SIDE ONLY'''
       
''Only appears if a Connect protocol is selected''
           
Domain for the protocol negotiations.</td>
    </tr>
    <tr>
        <td>Protocol Host</td>
        <td>host:port; Default: ""</td>
        <td>'''CLIENT SIDE ONLY'''
       
''Only appears if a Connect protocol is selected''
           
Destination address for the protocol negotiations.
           
Specifies the final TLS server to be connected to by the proxy, and not the proxy server directly connected by '''Stunnel'''. The proxy server should be specified with the '''connect''' option.</td>
    </tr>
    <tr>
        <td>Protocol Username</td>
        <td>username (text); Default: ""</td>
        <td>'''CLIENT SIDE ONLY'''
       
''Only appears if a protocol is selected''
           
Username for the protocol negotiations.</td>
    </tr>
    <tr>
        <td>Protocol Password</td>
        <td>password (text); Default: ""</td>
        <td>'''CLIENT SIDE ONLY'''
       
''Only appears if a protocol is selected''
           
Password for the protocol negotiations.</td>
    </tr>
    <tr>
        <td>Verification</td>
        <td>None {{!}} Verify Chain {{!}} Verify Peer; Default: '''None'''</td>
        <td>Verification type. '''Verify Chain''' verifies connections against a Certificate Authority (CA) file, while '''Verify Peer''' verifies connections against a list of approved certificates.</td>
    </tr>
    <tr>
        <td>Verification file</td>
        <td>file; Default: ""</td>
        <td>''Only appears if a verification type is selected''
       
File which is used to verify peer(s) or a peer chain. A different type of file is expected depending on the verification type selected:
           
'''Verify Chain:''' Expects a CA (Certificate Authority) file.
'''Verify Peer:''' Expects a file with one (or more, concatenated) peer certificate(s).</td>
    </tr>
    <tr>
        <td>Certificate File</td>
        <td>file; Default: ""</td>
        <td>'''Mandatory for a server configuration. Optional for a client configuration'''
       
The parameter specifies the file containing certificates used by stunnel to authenticate itself against the remote client or server.
       
The file should contain the whole certificate chain starting from the actual server/client certificate, and ending with the self-signed root CA certificate.
           
Can be a certificate only, or both certificate and private key concatenated into a single file.</td>
    </tr>
    <tr>
        <td>Private Key</td>
        <td>file; Default: '''Certificate File'''</td>
        <td>''Can be skipped if the Certificate File is appended with the private key''
       
''Must be uploaded if the Certificate File does not contain the private key''
           
A private key, required to authenticate the certificate owner.</td>
    </tr>
</table>
After setting the parameters, click the '''Save''' button; otherwise, changes will not be saved. Some parameters will be shown in the configuration list table.
===Stunnel Global Configuration===
Default Stunnel global configuration:
[[Image:stunnel_default_global_config.png]]
Stunnel global configuration field explanation table:
<table class="nd-mantable">
    <tr>
        <th>Field Name</th>
        <th>Value</th>
        <th>Description</th>
    </tr>
    <tr>
        <td>Enabled</td>
        <td>yes {{!}} no; Default: '''no'''</td>
        <td>Enables/activates all the enabled Stunnel configurations.</td>
    </tr>
    <tr>
        <td>Debug Level</td>
        <td>integer [0..7]; Default: '''5'''</td>
        <td>Debugging level.
       
Level is one of the syslog level names or numbers emerg (0), alert (1), crit (2), err (3), warning (4), notice (5), info (6), or debug (7). All logs for the specified level and all levels numerically less than it will be shown. Use '''7''' for greatest debugging output.</td>
    </tr>
    <tr>
        <td>Use alternative config</td>
        <td>yes {{!}} no; Default: '''no'''</td>
        <td>Enable alternative configuration option (Config upload).
       
Be aware that when using alternative configuration, all configurations in '''Stunnel Configuration''' section will be skipped.</td>
    </tr>
    <tr>
        <td>Upload alternative config</td>
        <td>file; Default: ""</td>
        <td>''Only appears if the "Use alternative config" is enabled''<br>
       
Upload the alternative Stunnel configuration file.</td>
    </tr>
</table>
'''''IMPORTANT:'''''
The router can have multiple configurations set up and enabled at the same time. Note that if at least one configuration is not set correctly, '''none of them will be enabled''', despite the "Enabled" flag being marked.
Also, you must mark the global "Enabled" flag to actually enable all the individually marked configurations.


==See also==
==See also==
Line 763: Line 1,003:
** [[PPTP configuration examples]]
** [[PPTP configuration examples]]
** [[L2TP configuration examples]]
** [[L2TP configuration examples]]
** [[Stunnel configuration examples]]
* Configuration examples for third party VPN services
* Configuration examples for third party VPN services
** [[expressvpn.com VPN configuration|expressvpn.com]]
** [[expressvpn.com VPN configuration|expressvpn.com]]