You’ve probably heard of the Pwnie awards.
Every year, alongside the BlackHat convention in Las Vegas, the Pwnie ceremony “celebrat[es] the achievements and failures of security researchers and the security community.”
We’ve written about some of the winners before.
The TLS bug known as Heartbleed, for example, scooped a Pwnie.
So did the data breach implosion at the Mt Gox Bitcoin exchange, which saw more than half a billion dollars worth of BTC vanish in a puff of…well, a puff of nothing, apparently.
IBM was once short-listed for the remarkable, if amusing, blunder of giving away USB keys infected with not one but two two strains of malware – at a security conference.
The bug that trumps them all
But the bug we’re about to describe surely trumps them all.
If you’re a bookmaker who offers bets on the Pwnies, we reckon this is a wager you should open at the comedy odds of $1.01. (That’s an out-there 100-to-one on in fractional odds.)
The flaw is designated CVE-2015-0932, and documented by cert.org as Vulnerability Note VU#930956.
The headline says most of what you need to know:
Multiple ANTlabs InnGate models allow unauthenticated read/write to filesystem.
Simply put, some versions of a popular hotel internet access server – those portals you interact with to get Wi-Fi access while you’re at a conference centre or staying in a hotel – can be completely drained of data, and then reprogrammed arbitrarily, via the outside (internet-facing) interface.
Without any authentication.
You connect to TCP port 873 using rsync, and you can read and write any file you like.
Just like that.
Why we’re betting on this one
And that’s why this is, surely, not just a bug, but a $1.01-class Pwnie-winning bug.
To explain, we should probably give a very brief overview of rsync, which was born in Canberra, Australia, in the 1990s.
Andrew Tridgell, a splendid fellow who is probably better known for Samba, the open source reimplementation of Microsoft’s SMB (Server Message Block) file sharing system, actually wrote up rsync as his PhD thesis in 1999.
So the protocol has an academic as well as an intensely practical history.
Basically, rsync does remote synchronisation, so that a source and a destination server can compare two filesystems (or directory trees) across the network, and automatically make their contents match.
Obviously, you can do that simply by coping the whole directory tree from the source to a new folder on the destination every time, and then deleting the old tree off the destination server, but that’s not very efficient.
Rsync works out the differences between the two sides “on the fly,” and automatically copies across a close-to-minimal set of changes, compressing them as it goes.
Files that are missing from the destination are copied in full.
Files that have been deleted from the source are automatically removed from the destination as well.
Files that have been changed are updated by working out in real time a compact set of “diffs”, or differences, that can be applied to the destination to make it match the corresponding source file.
Best of all, neither side needs any advance knowledge about what’s at the other end: the diffs are cleverly negotiated as part of the protocol.
For example, imagine you have a 1000-line configuration file, but all you want to do is sneak in a line in the middle saying:
dangerous_unauthenticated_remote_login = true
With rsync, you don’t have to copy the whole 1000-line file; the protocol will work out that it needs to tell the destination server something along the lines of, “go forwards 45,755 bytes in the file you already have, and insert this line, then you’re done.”
In other words, rsync gives you a completely general-purpose way to do both full and incremental backups, and it is super-efficient about doing it.
So if you were actually setting out to create an insecure, remotely-updatable router, unauthenticated rsync would be a truly efficient and hacker-friendly way to do it.
If you had a hammer…
Imagine you were an attacker.
You could start off by rsyncing the whole router outwards to your own computer, starting with an empty directory tree.
In that case, rsync would work out you have nothing at all, and send you the entire filesystem, neatly compressed to save bandwidth.
At your leisure, after you’d milked the stolen files for anything private, like usernames, passwords, email addresses, user registration data and so on, you could then decide which configuration files you wished to tweak.
For example, you might decide to add your own secret access points; to enable HTTP interception; to turn on remote root login; to change the root password; and even to add a comedy login message to the Wi-Fi portal.
You could also Trojanise some of the software on the router, such as the DNS server (to run DNS hijacks), the web filtering proxy (to do HTTPS man-in-middle attacks), or the POP3 relay (to read email passing by).
If software you wanted to abuse wasn’t there already, you could just add it in on your side.
Once you’d made the changes to your local copy of the router’s filesystem, you could use rsync again in the other direction to put your changes into place.
Your hacking would not only be easy, but also quick and efficient, thanks to rsync's automatic smarts in difference detection.
If you were a cracker, and you could write your own specifications for a remote unauthorised read/write hole, this is probably what you’d ask for.
And that’s why the InnGate bug is on our extra-super-short-list for a 2015 Pwnie Award, even though there are still several months to go before the results will be decided.
What to do?
• If you run a affected InnGate router, patch it right now: there is a fix available.
This flaw was responsibly disclosed so that a patch was ready well before the bug was made publicised.
• Don’t be afraid to ask at the hotel or conference centre what Wi-Fi access portal they use, and whether they’re patched.
If no-one can tell you, see the next suggestion.
• Consider using your own 3G/4G mobile connection whenever you can.
If you travel a lot, you will find that many countries make it easy for overseas visitors to buy pre-paid SIM cards with a reasonable data allowance.
Just swap your home SIM for the overseas one and you won’t get stung by roaming charges.
• Consider setting up a Virtual Private Network (VPN).
You can do this at home, or urge your IT guys at work to do so if they haven’t already, so you never have to (and, indeed, can’t by accident) send unencrypted traffic through Wi-Fi hotspots.
A VPN encrypts all the network traffic from your laptop or mobile device, even traffic such as HTTPS that is already encrypted, back to head office or your home, where it emerges onto the open internet.
That means you are no less secure on the road than you would be on your own network, which can cut a lot of security uncertainty out of the equation.
• If you are a router vendor, ask yourself, “Could a hole of this sort get past my quality assurance (QA) and testing?”
By rights, this sort of bug ought to be out of the question.
Even the most cursory port scan would show the listening port, and the most cursory cross-check of the software running on the router would reveal which program had that port open.
Remember, if you are selling network products, there are some QA questions you simply can’t afford not to answer.
“What on earth is that network service, and should it be listening at all?” is one of them.
Sophos UTM Home Edition
Want to set up a VPN at home for your laptops and mobile devices?
Try our award winning UTM.
The Home Edition includes all the Sophos UTM features: a VPN, email scanning, web filtering, web application security, and everything you need to keep up to 50 devices on your home network secure, 100% free for home use.
In you live in a shared house, or you have children to look out for online, this could be just the product you need.
Better yet, you get 12 free licences for Sophos Anti-Virus for Windows that you can install and manage throughout your household, right from the UTM web console.
Understanding firewalls and secure gateways
Listen to our Sophos Techknow podcast, Firewalls Demystified
(Audio player above not working? Download, or listen on Soundcloud.)
Dan
Is there a recommended VPN for an OSX laptop running Yosemite?
Paul Ducklin
OS X comes with a VPN network client. You add and configure a VPN instance by going to System Preferences | Network. Click on [+] to add a new network interface, and choose VPN from the pull-down list against Interface.
If you use the Sophos UTM, it comes with VPN clients for Windows, Linux and OS X. You’ll find an overview here:
https://www.sophos.com/en-us/medialibrary/PDFs/factsheets/sophosvpnclientsdsna.pdf
HtH.
Anonymous
+1 for explaining the built-in VPN client before mentioning the product provided through Sophos.
Honesty for the win!
Jim
An open port which doubles as a replication robot? My gosh that’s stupid.
And it’s on a ROUTER? I could see it if you were running your own home-grown Linux variant, but a real product from a real vendor that’s a ROUTER?
I think I’ve heard it all now.
Isn’t one of the first things one should do when hardening ANY system to whitelist the ports? And a router. I’m just shaking my head in disbelief.
And I sure won’t take your bet.
Paul Ducklin
At odds of $1.01 you could earn a whopping $100 (before Interest, Taxes, Depreciation and Amortisation, of course)…all for a low, low outlay of just $10,000 :-)
Jim
You know, it’s possible to top this. But, I don’t think I’ve ever heard of it actually happening. Unless maybe you count the Adobe “store your records in clear-text or hashed-once text”. Still, they’re few and far between at this level of … wow I can’t even think of an appropriate word.
Maybe we need a “Hall of Fame” for security gaffes? Or “Hall of Shame”?
humanrights86
Wifi security – Telnet and upnp are insecure also. Consider port-scanning equipment that you own to see if those and any other insecure services are running. If they are running then disable them! Contact the manufacturers of your routers and switches asking them what they are doing to ensure their devices are secure!
rohitzidu
hey paul don’t you think for above case scenario, there must be wifi router/gateway strength checker with vulns. and basic attacks checkups on mobile and laptop after that the VPN channel will be doing its job.
ABehrens
When you install rsync, you also create a config file that lists the directories which a remote user is allowed to access. ANTlabs must have added at least two lines to the file before they shipped the routers: one that says “allow access to all directories”, and other that says “… with write permission”.
Bill Ender
I would have been gracious for you to have given credit to e Cylance SPEAR team — Justin Clarke, in particular — for discovering, documenting and reporting this vuln.
Paul Ducklin
We did link to the Cylance article, right where we state the port number of the bug:
http://blog.cylance.com/spear-team-cve-2015-0932
Interestingly, Cylance’s official article effectively credits a chap called Brian Wallace. Justin Clarke isn’t mentioned even by Cylance, so I’m not sure how I’d have known to credit him at all, let alone in particular.