Use LetsEncrypt SSL certs with Heroku

How to use LetsEncrypt SSL certs with Heroku.


Update May 2017:

Heroku now offers free, automatic SSL certs from LetsEncrypt that are easier to manage than these are. Go Here for more information. This guide can still help if you want to run the cert process yourself.


To begin, go get CertBot from https://certbot.eff.org/

Then continue by typing the following:

sudo certbot certonly --manual

Follow the instructions on the screen. There is a step that talks about “type in the following and verify on your website” which doesn’t really work if you are running this in manualmode (or more specifically using Heroku, which makes it interesting to try and deploy single file updates easily.) so you can skip this and just hit enter.

Once that is done, go download your newly created certs. They should be located in /etc/letsencrypt/archive/your_domain_name/. Check the folder dates on that folder to make sure you have the newest ones. I actually had 3 of them as this was my 3rd time generating certs for this domain. That folder should include a few files:

cert1.pem
chain1.pem
fullchain1.pem
privkey1.pem

Simply log into Heroku and go to settings and click on add SSL. When you get to the screen asking for the public cert, provide fullchain1.pem and click continue. It will then ask you for the private key, which is (you guessed it) privkey1.pem. Then click continue again.

Once that is done, confirm your DNS settings and finish it up. Your cert should be all good to go.


SabNZBDPlus

  • Install prereq’s:
    “`
    sudo apt install python-gdbm python-cheetah python-openssl par2 unzip -y
    sudo apt install python-dev
    “`
  • Add Repo’s, update and upgrade:
    “`
    echo “deb http://ppa.launchpad.net/jcfp/ppa/ubuntu precise main” | sudo tee -a /etc/apt/sources.list.d/sabnzbdplus.list
    sudo apt-key adv –keyserver hkp://pool.sks-keyservers.net:11371 –recv-keys 0x98703123E0F52B2BE16D586EF13930B14BB9F05F
    sudo apt update
    sudo apt upgrade -y
    “`
  • Install SabNzbdPlus and Python PIP and Sabyenc:
    “`
    sudo apt-get install sabnzbdplus python-pip -y
    sudo pip install sabyenc
    “`
  • Edit config to update IP and Port:
    “`
    sudo emacs /etc/default/sabnzbdplus
    “`
  • Change the username to your user (I run mine as root):
    “`
    USER=root
    “`
  • Restart the Service:
    “`
    sudo service sabnzbdplus restart
    “`
  • Add to autostart:
    “`
    sudo update-rc.d sabnzbdplus defaults
    “`

MultiCore PAR2:
  • Install Dependencies:
    “`
    sudo apt update
    sudo apt install devscripts build-essential git debhelper dh-autoreconf libwww-perl libtbb-dev -y
    “`
  • Build Package:
    “`
    cd ~
    mkdir par2tbb
    cd par2tbb
    git clone https://github.com/jcfp/debpkg-par2tbb.git
    cd debpkg-par2tbb
    uscan –force-download
    dpkg-buildpackage -S -us -uc -d
    dpkg-source -x ../par2cmdline-tbb_*.dsc
    cd par2cmd*
    ./configure –prefix=/usr –includedir=${prefix}/include –mandir=${prefix}/share/man –infodir=${prefix}/share/info –sysconfdir=/etc –localstatedir=/var –disable-silent-rules –libdir=${prefix}/lib/arm-linux-gnu –libexecdir=${prefix}/lib/arm-linux-gnu
    sudo make
    make install
    “`
  • Confirm Installation:
    “`
    par2 -v
    “`
    You should see a line:
    “`
    Concurrent processing utilises Intel Thread Building Blocks 4.3 Update 1,
    “`
  • Once Successful, you can remove the directory:
    “`
    cd ~
    sudo rm -rf par2tbb/
    “`