Background
Espresso? Sure why not! |
I remember when I first saw this type of malware and thought "wow how the hell do you stop someone from stealing plain text data in memory". After a bit of contemplation you realise the answers are pretty simple because I was asking the wrong question. Firstly, like every piece of sensitive data, if you don't need it, don't store, process or transmit it. Yep as I said - simple but not always achievable. If your business is not able to live by the "golden rule", then you must live by the "silver rule" which is "keep the bad guys out of your sensitive data". This is all common sense really, but common sense is not often applied practice and business large and small get caught out every day.
The moment of realisation
Merchants that become a victim os POS data breach typically as at least one of the following statements:
- We didn't know they had any sensitive data
- My vendor told me there was nothing to worry about
- It's been working for years why now?
- Why would someone from <Eastern-Eurpoean-country-here> login to my computer in <anywhere>?
- How did they find my computer/network in <anywhere> and how did they know where to look?
- I didn't tell anyone so how did they know my password?
From this list of statements you can see the general understanding of most merchants is pretty low and they don't have much capacity to look for problems they didn't know existed.
Preventing and stopping RAM dumpers
In the previous blog entry I talked about RAM dumpers and scrapers. Given the US POS environment it is necessary for the card data to be in the RAM of the POS system in plain text, so we have to protect the system from having bad guys on it. Follow the PCI-DSS and you're almost certain to be good. The PCI-DSS is a very large document and will take a lot of time to digest and even more to implement. A more abridged list to maximise effectiveness of controls is:
- Do not use vendor default passwords especially for remote access (Yes this REALLY happens still today). This means use unique passwords for vendors as well. In days gone past (I hope) support vendors used to use their company name as the password for the hundreds or thousands of POS devices. What could possibly go wrong hey?
- Run the POS systems as an unprivileged user. Seriously why in the world would a POS need to run as admin? There's only three answers - stupidity, laziness and really bad software. Neither are acceptable.
- Really restrict access to the payment network. Most POS are protected by a single credential and a large proportion of POS have unfiltered outbound Internet access.
- Remove Internet access from the POS network. Why does a POS need Internet access? If you are using Internet based payments, filter access to the necessary addresses/ports and nothing else. I've seen POS' send data and alerts to drop servers via email, FTP and HTTP. There is simply no need to provide a direct outbound path for malware to send data.
- Any connections in/out of the POS network must be authenticated.
- Monitor your POS devices for new services and processes. Most POS malware must remain memory resident and will be installed as a service or as an auto-start application. A new service or auto-start application on a POS is a big red flag and must be investigated. If you have least privilege on your POS this should not happen anyway.
Of course there are ways to circumvent many of these controls, but realistically very few bad guys want to put in a whole lot of effort when there is so much low hanging fruit out there. It's back to the old saying, "when you are being chased by a bear you only have to out run one of your mates to be safe". It's similar in cyber-crime, but the analogy does not hold true for ever so we have to continuously improve our defences and detection of events.