Times are a-changin’
It was the price of SSL cert that was the tipping point for me. In general, I like paying for high quality services. Companies like Github is a perfect example; low up-front cost, easy to use interface and a bunch of useful integrations that actually increases productivity.
Other companies have a different business model, where the only revenue stream steams from the knowledge that people wont go about changing things that works, even though it is not an optimal solution.
Back when I first registered my very first domain, I found a hosting company that had a package deal; I could set up one-click blogs, access a web based email client and deploy my site over FTP.
This was the state of affairs for several years. To be honest I didn’t deploy that frequently to bother with any sophisticated CI. I didn’t use the email accounts enough to bother with the outdated design. One thing that do matter for me is privacy and secure connections over the internet, and it was the pursuit of this that was the wake-up call me.
Security and privacy
The most important point of secure communication is the privacy aspect. In the post-Snowden world, it is obvious that governments engage is mass surveillance. This is the reason for initiatives like Encrypt all the things, that highlights the ease “by which unauthorized actors can access large amounts of personal information without any judicial process or oversight”.
Luckily, Google is pushing hard for https and they have the muscle to make it a business priority. Back in 2014, they announced that sites with secure connections will rank higher. The next step in their plan will be taken early 2017. The upcoming version 56 of Chrome, will flag login/payment pages not using https as “Not Secure”.
Long story short, TLS is almost a hygiene factor1, but it has always been something that comes with a price tag and complicated process of installation and renewal. This was before Let’s Encrypt, that not only automates the process, but makes it cost free, too! If you haven’t heard about Let’s Encrypt, head over and read about their mission.
To my surprise, my hosting company didn’t offer Let’s Encrypt. They sold the certificates from one of the larger vendors for a pretty hefty price. It annoyed me when I realized that if I bought the certs from them, it was almost double the price as if I would go to a Certificate Authority myself. When asking them about it, they replied it was due to “installation costs”.
Let’s encrypt at Azure
It was this that finally made me begin migrate my sites to Azure. I was hesitant, as Microsoft is known to collaborate with US government. What convinced me is that they have taken steps to make data inaccessible to NSA (and even themselves!) in order to provide data privacy. Hopefully they will continue to work for privacy, as I believe that is going to be something that organizations will look at when deciding on hosting.
It took me about one hour to get TLS working. Azure’s site extensions is a cool way to add functionality to an Azure App. There are not that many extensions, but amongst them I found Azure Let’s Encrypt, that automates the installation and updates of the short-lived certificates. There are great installation instructions at the project site that I followed. It was a bit tricky, as the instructions involved creating and configuring a service principal in Azure classic mode2 before setting up the web jobs. I always get disoriented in the legacy parts of Azure, and it feels like the things done there are totally separated from everything else.
I really like that there is a cost and friction free way to get https working. Let’s Encrypt is a perfect option for the large segment of middle-sized sites with a too small budget for SSL certs. There are good reasons and arguments for taking the time to secure the sites you are working on. Let’s make 2017 about privacy.
Currently not supported for Github Pages, which is the reason why this blog is still over http. ↩
I do believe that you could follow this guide to set up a service principal without entering classic mode. ↩