.@ Tony Finch – blog


Yay, I’ve had interesting comments on my previous article about using curl to test web servers before going live!

I think there are a couple of things that are worth unpacking: what kind of problems am I trying to spot? and why curl with a wrapper rather than some other tool?

What webmasters get wrong before deployment

Here are some of the problems that I have found with my curl checks:

This is all really basic, but these problems happen often enough that when I am making the DNS change, I check the web server so I don’t have to deal with follow-up panic rollbacks.

Usually if it passes the smoke test, the content is good enough, e.g. when I get HTML I look for a title or h1 that makes sense. Anything content-related is clearly a web problem not a DNS problem even to non-technical people.

What other tools might I have chosen?

Maciej Sołtysiak said, “I usually just speak^H^H^H^H^Htype HTTP over telnet or openssl s_client for tls’d services.” I’m all in favour of protocols that can be typed at a server by hand :-) but in practice typing the protocol soon becomes quite annoying.

HTTP is vexing because the URL gets split between the Host: header and the request path, so you can’t trivially copy and paste the user-visible target into the protocol (in the way you can for SMTP, say). [And by “trivially” I mean it’s usual for terminal/email/chat apps to make it extra easy to copy entire URLs as a unit, and comparatively hard to copy just the hostname.]

And when I’m testing a site, especially if it’s a bit broken and I need to explain what is wrong and how to fix it, I’m often repeating variations of an HTTP(S) request. The combination of command line histroy and curl’s flexibility makes it super easy to swicth between GET and HEAD (-I) or ignore or follow redirects (-L), and so on.

OK, so I don’t want to type in HTTP, but often I don’t even need to HTTP to find a site is broken. But checking TLS is also a lot more faff without curl.

For example, using my script,

    curlto chiark.greenend.org.uk https://dotat.at

How do I do that with openssl?

    openssl s_client -verify_return_error \
        -servername dotat.at \
        -connect chiark.greenend.org.uk:443

OK, that’s pretty tedious to type, and it also has the chopped-up URL problem.

And, while curl checks subject names in certificates, openssl s_client only checks the certificate chain. It does print the certificate’s DN, so you can check that part, but it doesn’t print the subjectAltName fields which are crucial for proper browser-style verification.

So if you’re manually doing it properly, you need to copy the certificate printed by s_client, then paste it into openssl x509 -text and have a good eyeball at the subjectAltName fields.

I have done all these things in the past, but really, curl is awesome and it makes this kind of smoke test much easier.