Web Developer Security Checklist is a good collection of security issues to keep in mind when building web applications. Â Not much new in there, but it’s nice to have all of these conveniently gathered in one place. Â All items are grouped into a few sections – database, development, authentication, denial of services protection, web traffic, APIs, validation, cloud configuration, infrastructure, operation, etc.
Tag: security
HTTPS on Stack Overflow: The End of a Long Road
Way too often I hear rants from random people (unfortunately, many of them are also from the IT industry, with the deep understanding of the underlying issues) complaining about why company X or product Y doesn’t implement this or that feature. Â As someone who has been involved a dozens, if not hundreds, of projects, I pretty much always can think of a number of reasons why even seemingly the simplest of features aren’t implemented for years. Â These can vary from business side of things – insufficient budgets, strategic goals, and the like – to technical, such as architectural limitations, insufficient expertise, insufficient resources, etc.
One of the recent frequent rant that keeps coming up is “Why don’t they just enable HTTPS?”. Â Again, as someone being involved in HTTPS setup for several different environments I can think of a number of reasons why. Â SSL certificates used to cost money and were quite cumbersome to install until very recently. Â Thanks to Let’s Encrypt effort, SSL certificates are now free and quite easy to issue and renew. Â But that’s only part of the problem. Â Enabling HTTPS requires infrastructural changes, and the more complex your infrastructure, the more changes are needed. Â Just think of a few points here – web server configuration (especially when you have multiple web servers, with varied software (Apache, Nginx, IIS) and varied versions of that software), load balancers, web application firewalls, reverse proxies, caching servers, and so on.
Apart from the infrastructural changes, HTTPS often needs changes on the application level. Â Caching, cookies, headers, making sure that all your resources are HTTPS-only, redirects, and the like.
All of the above issues are multiplied by a gadzillion, when your project is publicly available, used by tonnes of people, and provides embeddable content or APIs to third-party (hello, backward compatibility).
This is not to mention that HTTPS itself is a complex subject, not well understood by even the most experienced system administrators and developers. Â There are different protocols and versions (SSL vs. TLS), cipher suites, handshakes, and protocol details. Â Just have a look at the variety of checks and the report length done by Qualys’ SSL Labs Server Test. Â Even giants like Google, who employ thousands of smart people, can’t get it all right.
But for some reason, people either don’t know or prefer to ignore all this complexities, and whine and cry anyway.
Recently, Stack Overflow – a well known collection of sites on a variety of technical subjects, has completed the migration to HTTPS everywhere. Â These are also people with a lot of knowledge and expertise and with access to all the information. Â Just have a look at their long way, which took not months, but years:Â HTTPS on Stack Overflow: The End of a Long Road.
Today, we deployed HTTPS by default on Stack Overflow. All traffic is now redirected to
https://
and Google links will change over the next few weeks. The activation of this is quite literally flipping a switch (feature flag), but getting to that point has taken years of work. As of now, HTTPS is the default on all Q&A websites.We’ve been rolling it out across the Stack Exchange network for the past 2 months. Stack Overflow is the last site, and by far the largest. This is a huge milestone for us, but by no means the end. There’s still more work to do, which we’ll get to. But the end is finally in sight, hooray!
So next time you are about to start crying about somebody not having feature X or Y, just give it a minute first. Â Try to imagine what goes on on the other side. Â You aren’t the only one with low budgets, pressing deadlines, insufficient knowledge, bad colleagues and horrible bosses…
The Ultimate WordPress Security Guide – Step by Step (2017)
WPBeginner, a website for beginner guides to WordPress, has published an updated and comprehensive guide to WordPress security – “The Ultimate WordPress Security Guide – Step by Step (2017)“.  Most of the things are well known to seasoned WordPress users – keep things updated, use strong passwords, remove unnecessary plugins, make sure to pick the right hosting, add security enhancing plugins, etc.  But it’s a good place to start for  people who are not too technical and those who don’t think about security implications of having a publicly accessible website on a daily basis.
There are plenty of questions, answers, simple explanations, and links to other resources in the article. Â So even if you are an experienced WordPress user, you might find a useful thing or two in there.
You might also want to checkout my earlier blog posts:
Using the Strict-Transport-Security header
Julia Evans has an excellent write-up on “Using the Strict-Transport-Security header” – what it is, why you’d want to use it, and what are some of the consequences of using one.
As always with her blog posts, this one is very focused on one particular subject, easy to read, and explains things simply, so that the reader’s technical level is always irrelevant (OK, OK, you do need a basic understanding of how HTTP works, but not more than that).
AWS IAM Policies in a Nutshell
J Cole Morrison wrote an excellent guide into AWS IAM policies. It’s super useful for anyone who have tried implementing IAM policies and failed (or even barely succeeded).
What is an AWS IAM Policy?
A set of rules that, under the correct
conditions
, define whatactions
the policyprincipal
or holder can take to specified AWSresources
.That still sounds a bit stiff. How about:
Who can do what to which resources. When do we care?
There we go. Let’s break down the simple statement even more…
Compared to all the AWS documentation one has to dive through, this one is a giant time saver!