Twoje komentarze
any way i can have that auto injected at FCGI generation? some mod i can make to the panel itself?
10 lat temu
Great Links Wrrr, will give them a thorough read through tonight.
I know fastCGI isnt enabled by deafult, but when you do create it in the websites panel, a lot of stuff is auto inserted, including apparently, open_basedir = none. agreed none is better than blank, but based on how fluid the rest of the panel is at inserting the proper values, one would think by default that the parameter would be set
it only makes sense, ESPECIALLY with ajenti V. V is designed for hosting. hosting means clients with accounts, those clients wont know better. Heck, I'm the admin and i didn't catch this. it seems unreasonable to allow those clients who don't know, to compromise the security of the rest of the server, including the clients who DO know. is there a value set up stopping open_basedir form leaving the /srv directory at least? if not, you are asking for a whole server to be compromised. anyone with fs access can do just about anything...
open_basedir = /srv/webroot/of/this/site
it only makes sense, ESPECIALLY with ajenti V. V is designed for hosting. hosting means clients with accounts, those clients wont know better. Heck, I'm the admin and i didn't catch this. it seems unreasonable to allow those clients who don't know, to compromise the security of the rest of the server, including the clients who DO know. is there a value set up stopping open_basedir form leaving the /srv directory at least? if not, you are asking for a whole server to be compromised. anyone with fs access can do just about anything...
Ok well ill throw this up for anyone who is interested. i used 2 scripts to fix this:
firstly i made a list of infected files using this:
i did not write this php script myself, i found it online though i dont recall where (probably stack overflow tbh) but whoever the originator was is briliant, as it works great.
firstly i made a list of infected files using this:
find /srv -name "*.php" -exec grep -li "eval(gzinflate" {} \; >> results.txtThen after unsucessfully using sed for a while i just used this php script which you should run using php5-cli
<?php // vim (or your favorite editor) a file from results.txt and copy the entire string of bad code including // the <?php \>? brackets exactly as the line appears and place it in the finewhat variable. // Make sure $findWhat won't match any code you actually want!!! Any line that matches will be deleted. $findWhat = '<?php your-infection-code ?>'; $listOfFiles = "results.txt"; $infectionCounter = 0; try { $cleanLog = fopen('cleanLog.txt', 'a+'); $infectedFileList = fopen($listOfFiles, 'r'); if ($infectedFileList !== FALSE) { while ($file = rtrim(fgets($infectedFileList))) { $possibleInfectedFile = fopen($file, 'r'); $tmpFile = fopen($file . '.tmp', 'w+'); if ($possibleInfectedFile !== FALSE && $tmpFile !== FALSE) { while ($lineToCheck = fgets($possibleInfectedFile)) { if (strpos($lineToCheck, $findWhat) === FALSE) { fwrite($tmpFile, $lineToCheck); } else { $infectionCounter++; } } fclose($possibleInfectedFile); fclose($tmpFile); unlink($file); rename($file . '.tmp', $file); fwrite($cleanLog, $file . " was cleaned\n"); } else { echo $file . ' was skipped' . "\n"; } } fclose($cleanLog); fclose($infectedFileList); echo "Number of infections found: " . $infectionCounter; } } catch (Exception $e) { echo $e->getMessage(); die("\nAn Unknown exception occured!"); } ?>you should run the first command again after the php script as more than one version of the gzinflatecode may exist on the server and if that is the case repeat the php script placing the next infection string into the findWhat variable.
i did not write this php script myself, i found it online though i dont recall where (probably stack overflow tbh) but whoever the originator was is briliant, as it works great.
wow. i didnt even catch that. this seems like ahorrible design flaw that the correct value isnt already inserted upon site creation! if you use this for hosting your clients arent going to know that they need to do this, as mine didnt! for such a security focused panel, why would we leave such a huge potential for error? thank you Wrrrr
Anything? Anyone? i really need to get this sorted. i spent hours sanitizing all the files and by this morning everything has been reinfected! can someone give me something/anything to work with? can i pay for support? something??
additional info: if this were just a wordpress hack id disable the clients site and alert the client of the hack and after they have fixed it id unsuspend it, but in this case i need to find out how the hack escaped the wordpress directory and hit other php documents. several site designs have nothing more than a common menu file (a site with all .php extensions and the nav menu is in menu.html and php has an include statement to include menu.html.). no vulnerabilities, still got hit. looking for some info here. where can i start looking??
OK i got it to connect at FQDN by matching the hostname to my internal IP (IE: the ip of Eth0). im not sure why this fixed that issue. care to shed some light? however the inaccessible from my IP thing still pops up any time i change anything in config aside from users. why is this?
Ah! that could be a factor. im on Ubuntu!
Customer support service by UserEcho