/ddwrt-secure-entware

Entware Over SSL/TLS For DD-WRT Installations

Primary LanguageShellGNU General Public License v3.0GPL-3.0

Entware Over SSL/TLS For DD-WRT Installations

All software modules from official Entware, including installation scripts, the packet manager, and installable packages, are distributed though the open Internet via HTTP without any kind of security. This is unacceptable: any actor between Entware's repository and its clients can trivially and completely compromise the clients.

Fortunately, the Entware servers themselves do support HTTPS. This repository provides tools that allow secure Entware over SSL/TLS installtions on DD-WRT devices. (Other devices can also use these tools but may require different installation procedures.)

Secure Entware Installation

Prerequisites:

  • A DD-WRT installation that supports SSL/TLS (HTTPS URLs) on its ẁget or curl commands.
  • A Linux filesystem partition on non-volatile storage auto-mounted on /opt (preferably formatted as ext4).

Procedure:

  1. If you have already installed Entware though insecure HTTP before, consider the possibility that your router may have been compromised. You might want to wipe /opt, reflash DD-WRT, and reset to factory defaults.

  2. Run these commands on the DD-WRT router via SSH or Telnet to download the Entware installation script patcher:

    cd /opt
    wget 'https://raw.githubusercontent.com/Lanchon/ddwrt-secure-entware/master/patch-installer.sh'
    

    As of October 2019, official builds of DD-WRT include a version of wget that does not support SSL/TLS (HTTPS URLs), so the previous wget command is expected to fail. If this is the case, install Curlize as explained bellow. Once that is done, restart the secure Entware installation from the top. The above wget command should now work.

  3. Check your router's architecture:

    uname -m
    
  4. Fetch the Entware installation script that corresponds to your hardware architecture as explained in regular Entware installation how-to's, but make sure to change the URL's protocol identifier from 'http:' to 'https:'.

    • For ARMv7 architecture:

      wget 'https://bin.entware.net/armv7sf-k3.2/installer/generic.sh'
      
    • For MIPSEL architecture:

      wget 'https://bin.entware.net/mipselsf-k3.4/installer/generic.sh'
      
    • For MIPS architecture:

      wget 'https://bin.entware.net/mipssf-k3.4/installer/generic.sh'
      
  5. Patch the installer you just downloaded to make it work via HTTPS and run it:

    sh patch-installer.sh generic.sh
    sh generic.sh
    
  6. Finally add this line at the end of the startup script in DD-WRT's Administration/Commands:

    /opt/etc/init.d/rc.unslung start
    
  7. And add this line at the beginning of the shutdown script in DD-WRT's Administration/Commands:

    /opt/etc/init.d/rc.unslung stop
    
  8. If you had to install Curlize earlier, please read the following section.

Curlize Replacement

If you had to install Curlize to bootstrap Entware, you can either keep using it indefinitely or you can replace it with a full-fledged version of wget.

  1. To replace Curlize, run these commands on the DD-WRT router via SSH or Telnet:

    opkg update
    opkg install wget ca-certificates
    ln -sf /opt/bin/wget /opt/bin-override/wget
    
  2. Finally test the full-fledged version of wget:

    opkg update
    

Curlize

The installation scripts and packet manager of the official Entware distribution use wget to access the network. Unfortunately, as of October 2019, official builds of DD-WRT include a version of wget that does not support SSL/TLS (HTTPS URLs). But on the other hand, the version of curl shipped with DD-WRT does support HTTPS.

Curlize is a simple script that intercepts a few hand-picked command-line formats used by Entware to invoke wget, and fulfills those requests using curl instead, thus allowing HTTPS URLs. All other non-matching invocations formats are passed verbatim to wget. Note that Curlize will never intercept non-HTTPS requests, meaning that the all wget invocations that are affected by Curlize were destined to fail anyway.

Curlize Installation

Prerequisites:

  • A DD-WRT installation that supports SSL/TLS (HTTPS URLs) on its curl command. (Larger DD-WRT builds do.)

Procedure:

  1. Run this command on the DD-WRT router via SSH or Telnet to test curl's HTTPS support:

    curl -fL -o /dev/null 'https://github.com/Lanchon/ddwrt-secure-entware'
    

    You should either see a progress report or a 'protocol not supported' error. If HTTPS is not supported on your installation, you are out of luck.

  2. Download and install the necessary files:

    mkdir -p /opt/bin-override /opt/sbin-override
    cd /opt/bin-override
    curl -fO 'https://raw.githubusercontent.com/Lanchon/ddwrt-secure-entware/master/curlize-wget'
    chmod +x curlize-wget
    ln -s curlize-wget wget
    
  3. Finally add these lines at the beginning of the startup script in DD-WRT's Administration/Commands:

    echo 'export PATH="/opt/bin-override:/opt/sbin-override:$PATH"' >>/tmp/root/.profile
    chmod +x /tmp/root/.profile
    
  4. And reboot the router.