Skip to main content

pci dss - Ubuntu PCI-DSS Compliance Issue




I'm trying to get PCI compliant and the PCI scanning company is flagging our Ubuntu 12.04 PHP 5.3.10-1ubuntu3.9 for CVE-2013-1635. According to http://people.canonical.com/~ubuntu-security/cve/2013/CVE-2013-1635.html the Ubuntu response is "We do not support the user of open_basedir" and all version have been marked as ignored.



I'm at a loss for what to do here. I've pointed my scanning company to this same URL, but they don't accept that as and answer.



What should I do?



Update



I do not use this functionality and the open_basedir directive is disabled in php.ini. However, they do not consider this a proper solution.




Here is their response to their denial of my dispute:




We have denied this dispute based on the information provided regarding how this finding has been addressed. The version of PHP that is currently running on this system has been found to not properly sanitize user-supplied input. Despite the fact that 'open_basedir' is disabled on this system, an attacker can exploit this issue and write wsdl files within the context of the affected application. Also, it has been found that other attacks are also possible. As a result, the 'soap.wsdl_cache_dir' directive sets the directory name where the SOAP extension will place the cache files. Disabling 'open_basedir' has not 1) removed cache files that already exist and/or 2) ceased the possibility of new cache files from being placed into an arbitrary directory.



Please review https://www.pcisecuritystandards.org/security_standards/glossary.php#Compensating%20Controls for the definition of a compensating control. Among other things "Compensating controls must:…Be “above and beyond” other PCI DSS requirements (not simply in compliance with other PCI DSS requirements)", and disabling 'open_basedir' does not really go above and beyond, the underlying issue should really be addressed here. Again, the requirements as listed within the scan report are to upgrade the system or utilize the compensating controls mentioned (which, disabling open_basedir would not be sufficient in this case).



Any issues detected on a system that is in scope for PCI DSS compliance would need to have all PCI non-compliant issues remediated (which is any system involved in the storage, processing, and/or transmission of credit card holder data and any system directly connected to a network involved in such processes which does not have proper network segmentation in place).




Please review the scan report and follow the suggestions found underneath the “Remediation” column and then perform another scan when the vulnerability has been remediated to clear the finding from your next scan report.



If the vulnerability continues to be detected after this point and/or if you have already performed this then please feel free to re-dispute this vulnerability and explain what was performed to address the finding.



Answer



It seems suspect that Ubuntu "doesn't support" a stock PHP configuration directive, since they've fixed bugs with it before (for instance).



Edit: Seems that Debian and Red Hat have the same policy, actually - "don't support" is bad wording, but all of these distros are of the opinion that flaws in an inherently flawed security mechanism aren't a concern.





For these reasons, bugs in the "safe mode" and "open_basedir" options, or any
bugs in the PHP interpreter or extensions which allow scripts to bypass these
options, will not be treated as security-sensitive.




However, that's likely irrelevant. Check your php.ini for open_basedir - if it's not in there, then you're completely unaffected by this security issue, since the bug is a bypass of the security restrictions that open_basedir provides.



If your auditor is especially bad at this, however, your best course of action might just be to stop showing them what version of PHP you're on - version string checking is a terrible way to do vulnerability assessment, anyway. If it's an Apache web server showing its version strings, give it ServerSignature Off and ServerTokens Prod.



Edit with notes on the response they sent you...





The version of PHP that is currently running on this system has been found to not properly sanitize user-supplied input.




This bug doesn't have anything to do with sanitizing input, it's a flaw in a sandboxing mechanic.




Despite the fact that 'open_basedir' is disabled on this system, an attacker can exploit this issue and write wsdl files within the context of the affected application.





I'm by no means an expert in the internals of PHP, but that seems like a serious misinterpretation of the vulnerability. From what I can tell about this bug, the issue is that an attacker can use the WSDL caching mechanic to load a WSDL from a directory location outside of the open_basedir root (but probably still within the soap.wsdl_cache_dir, which defaults to /tmp).



For this to matter at all, you'd have to have files that could actually be targeted in this way and an access method to trigger it being cached (directory traversal in your web server, maybe?)



At any rate, triggering the creation of a cached WSDL based on content already on the system is very different from writing files into your web application..




As a result, the 'soap.wsdl_cache_dir' directive sets the directory name where the SOAP extension will place the cache files. Disabling 'open_basedir' has not 1) removed cache files that already exist and/or 2) ceased the possibility of new cache files from being placed into an arbitrary directory.





While the CVE does say "arbitrary directory", what it seems to really mean is "the configured WSDL cache directory". This vulnerability would be much more serious if it included a directory traversal component. In reality, all that was changed was adding validation to make sure that the cache directory is within the open_basedir. See here.




disabling 'open_basedir' does not really go above and beyond, the underlying issue should really be addressed here




That's nonsense. This is a bug where the WSDL cache directory didn't properly validate that it was within open_basedir. If you don't have an open_basedir configured, the entire vulnerability is completely irrelevant - no other changes were made to provide any additional security benefit whatsoever.


Comments

Popular posts from this blog

linux - iDRAC6 Virtual Media native library cannot be loaded

When attempting to mount Virtual Media on a iDRAC6 IP KVM session I get the following error: I'm using Ubuntu 9.04 and: $ javaws -version Java(TM) Web Start 1.6.0_16 $ uname -a Linux aud22419-linux 2.6.28-15-generic #51-Ubuntu SMP Mon Aug 31 13:39:06 UTC 2009 x86_64 GNU/Linux $ firefox -version Mozilla Firefox 3.0.14, Copyright (c) 1998 - 2009 mozilla.org On Windows + IE it (unsurprisingly) works. I've just gotten off the phone with the Dell tech support and I was told it is known to work on Linux + Firefox, albeit Ubuntu is not supported (by Dell, that is). Has anyone out there managed to mount virtual media in the same scenario?

ubuntu - Monitoring CPU, Mem, disk, on a single server

I've been looking for a simple starter solution for monitoring my [currently] single server hosted solution. Other than Nagios and similar, are there other good (simple) solutions people are using? Answer Everything depends on what you want. For example Munin is very simple, you can install and configure it in less then 10 minutes (on one server), it can sends alarms, make graphs from monitoring cpu, mem. apache connections, eaccellerator, disk io and many many more (it has many plugins). But if you are planning in future get some more machines, munin may not be enough. For example in munin you cant monitor state of individual processes, can't monitor changes in files (for security purpose). So if you wanna only see what is the utilization of basics parameters on your server and don't plan to buy some more servers Munin is what you are looking for, but if you wanna be alarmed when some of your service is down, take more control on what is happeninig on...

hp proliant - Smart Array P822 with HBA Mode?

We get an HP DL360 G8 with an Smart Array P822 controller. On that controller will come a HP StorageWorks D2700 . Does anybody know, that it is possible to run the Smart Array P822 in HBA mode? I found only information about the P410i, who can run HBA. If this is not supported, what you think about the LSI 9207-8e controller? Will this fit good in that setup? The Hardware we get is used but all original from HP. The StorageWorks has 25 x 900 GB SAS 10K disks. Because the disks are not new I would like to use only 22 for raid6, and the rest for spare (I need to see if the disk count is optimal or not for zfs). It would be nice if I'm not stick to SAS in future. As OS I would like to install debian stretch with zfs 0.71 as file system and software raid. I have see that hp has an page for debian to. I would like to use hba mode because it is recommend, that zfs know at most as possible about the disk, and I'm independent from the raid controller. For us zfs have many benefits, ...