HEX
Server: Apache/2.4.46 (Unix) PHP/7.4.24
System: Linux dc15-w.ht-systems.ru 2.6.32-042stab142.1 #1 SMP Tue Jan 28 23:44:17 MSK 2020 x86_64
User: srv52894 (52894)
PHP: 7.4.24
Disabled: passthru,shell_exec,system,proc_open,popen,show_source
Upload Files
File: /home/srv52894/test/balkon.php
<?php
$find_marks = array(
'url' => array("'siteurl',",","),
'city' => array('всем жителям г.','.</'),
'city2' => array('Балконы и лоджии под ключ в ',"'"),
'address' => array('address="','"'),
'phone' => array('phone="','"'),
'email' => array("'bc_plugin_option',","',"),
'email2' => array("'bc_plugin_option',","',"),
'YmetricaId' => array("'YmetricaId',",','),
'VENYOOId' => array("'VENYOOId',",','),
'GMiframe' => array("'GMiframe',",",")
);
function get_string_between($string, $start, $end){
    $string = ' ' . $string;
    $ini = strpos($string, $start);
    if ($ini == 0) return '';
    $ini += strlen($start);
    $len = strpos($string, $end, $ini) - $ini;
    return substr($string, $ini, $len);
}
function get_data_from_dump($dump,$marks=array()){
	$data = array();
	foreach ($marks as $name=>$mark){
		$data[$name] = trim(get_string_between($dump,$mark[0],$mark[1]), "\x00..\x20.'");

		if ($name === 'email') {
		$d = @unserialize(stripslashes($data[$name]));
		$data[$name] = $d['mail_from_mail'];
		}
		if ($name === 'email2') {
		$d = @unserialize(stripslashes($data[$name]));
		$data[$name] = $d['extra_mails'];
		}
		if ($name === 'GMiframe') {
		$data[$name] = rawurldecode($data[$name]);
		}
	}
	return $data;
}
if (file_exists ( 'dump.sql' )) {
	$sql = file_get_contents('dump.sql');
	$data = get_data_from_dump($sql,$find_marks);
}
if ($_SERVER['REQUEST_METHOD'] == 'POST') { 
if (isset($_POST['ajax']) && (intval($_POST['ajax'][0]) === 1)) {
header("Content-Type: application/json");
$max_filesize = 51200000;
$errorr = '';
		$i = 0;
		while (list ($key, $val) = each ($_FILES)) {
			if ($_FILES[$key]['name'] != "" and file_exists($_FILES[$key]['tmp_name']) and $_FILES[$key]['size'] > 0) {
				$upload_SrcName[$i] = $_FILES[$key]['name'];
				$upload_DstName[$i] = "dump.".strtolower(pathinfo($upload_SrcName[$i], PATHINFO_EXTENSION));
				$upload_Size[$i] 	= ($_FILES[$key]['size']);
				$upload_Temp[$i] 	= ($_FILES[$key]['tmp_name']);
				$upload_Type[$i] 	= ($_FILES[$key]['type']);
				if ($upload_Size[$i] >= $max_filesize) {
					$errorr .= "Файл $upload_SrcName[$i] " . round($upload_Size[$i]/1024000, 2) . "МБ превышает допустимый размер " . round($max_filesize/1024000, 2) . "МБ!".PHP_EOL;			
				}
				if (strtolower(pathinfo($upload_SrcName[$i], PATHINFO_EXTENSION)) !== 'sql')
					$errorr .= "Только SQL!".PHP_EOL;	
				$i++;
				if ($i>1) {
					$errorr .= "Количество загружаемых файлов не соответствует ожидаемому - взлом формы! Загрузка отменена!".PHP_EOL;
				}
				
			}
		}
		if (!empty($errorr)) {
			die(json_encode([ 'status'=> false, 'error'=> $errorr, 'success'=> '']));
		}
		
		for ($i = 0; $i < count($upload_DstName); $i++) {
			$uploadFile = $upload_DstName[$i];
			move_uploaded_file($upload_Temp[$i] , $uploadFile);
			chmod($uploadFile, 0777);
		}
		
		echo json_encode([ 'status'=> true, 'error'=> '', 'success'=> get_data_from_dump(file_get_contents($uploadFile),$find_marks)]);
		
		
		
/* 		if(session_id()) session_write_close();

		$commandString = 'start /b c:\\PHP7nts\\php-win.exe -f "c:\\Apache24\\dvrgoods\\nh\\parser\\parse_excell.php"'; 
		pclose(popen($commandString, 'r')); */
		die; 
	}


	if (isset($_POST['url']) && (($_POST['url'])!='')) {
		$error = '';$success='';
		if (!isset($_POST['city']) || (($_POST['city'])=='')) {
					$error .= "Надо ввести город!".PHP_EOL;			
				}
		if (!isset($_POST['city2']) || (($_POST['city2'])=='')) {
					$error .= "Надо ввести город в форме локатива!".PHP_EOL;			
				}
		if (!isset($_POST['address']) || (($_POST['address'])=='')) {
					$error .= "Надо ввести адрес!".PHP_EOL;			
				}
		if (!isset($_POST['phone']) || (($_POST['phone'])=='')) {
					$error .= "Надо ввести телефон!".PHP_EOL;			
				}
		if (!isset($_POST['email']) || (($_POST['email'])=='')) {
					$error .= "Надо ввести отображаемый на сайте емэйл!".PHP_EOL;			
				}
		if (!isset($_POST['email2']) || (($_POST['email2'])=='')) {
					$error .= "Надо ввести дополнительные емэйлы".PHP_EOL;			
				}				
		if (empty($error)) {
			//die(json_encode([ 'status'=> false, 'error'=> $error, 'success'=> '']));
		
		//Херачим
$perfix = <<<'EOD'
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET NAMES utf8 */;
/*!40014 SET FOREIGN_KEY_CHECKS=0 */;

EOD;
$postfix =  <<<'EOD'

/*!40014 SET FOREIGN_KEY_CHECKS=1 */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
EOD;


$text = file_get_contents('dump.sql');
$adress = $_POST['address'];
$addr = explode(',', $adress);
$phn = $_POST['phone'];
$replace = $_POST['city'];
$replace_l = $_POST['city2'];
$email = $_POST['email'];
$email2 = $_POST['email2'];
$GMiframeo = $_POST['GMiframe'];
$GMiframef = rawurlencode($GMiframeo);
$url = $_POST['url'];
$ym = $_POST['YmetricaId'];
$vnyo = $_POST['VENYOOId'];

$re_message = '/
    # match (203...(...)...) message lines (having arbitrary nesting depth).
    \(203                     # Outermost opening bracket (with leading __().
    (                        # Group $1: Bracket contents (subroutine).
      (?:                    # Group of bracket contents alternatives.
      [^()]++           # Either one or more non-brackets
      | \( (?1) \)          # or a nested bracket (repeat group 1 here!).
      )*                    # Zero or more bracket contents alternatives.
    )                       # End $1: recursed subroutine.
    \)                      # Outermost closing bracket.
    /x';
$re_message2 = '/
    # match (22,...(...)...) message lines (having arbitrary nesting depth).
    \(22,                     # Outermost opening bracket (with leading __().
    (                        # Group $1: Bracket contents (subroutine).
      (?:                    # Group of bracket contents alternatives.
      [^()]++           # Either one or more non-brackets
      | \( (?1) \)          # or a nested bracket (repeat group 1 here!).
      )*                    # Zero or more bracket contents alternatives.
    )                       # End $1: recursed subroutine.
    \)                      # Outermost closing bracket.
    /x';
$re_message3 = '/
    # match (856...(...)...) message lines (having arbitrary nesting depth).
    \(856                     # Outermost opening bracket (with leading __().
    (                        # Group $1: Bracket contents (subroutine).
      (?:                    # Group of bracket contents alternatives.
      [^()]++           # Either one or more non-brackets
      | \( (?1) \)          # or a nested bracket (repeat group 1 here!).
      )*                    # Zero or more bracket contents alternatives.
    )                       # End $1: recursed subroutine.
    \)                      # Outermost closing bracket.
    /x';	
$re_message4 = '/
    # match (1926...(...)...) message lines (having arbitrary nesting depth).
    \(1926                     # Outermost opening bracket (with leading __().
    (                        # Group $1: Bracket contents (subroutine).
      (?:                    # Group of bracket contents alternatives.
      [^()]++           # Either one or more non-brackets
      | \( (?1) \)          # or a nested bracket (repeat group 1 here!).
      )*                    # Zero or more bracket contents alternatives.
    )                       # End $1: recursed subroutine.
    \)                      # Outermost closing bracket.
    /x';
$re_message_l = '/
    # match (3...(...)...) message lines (having arbitrary nesting depth).
    \(3                     # Outermost opening bracket (with leading __().
    (                        # Group $1: Bracket contents (subroutine).
      (?:                    # Group of bracket contents alternatives.
      [^()]++           # Either one or more non-brackets
      | \( (?1) \)          # or a nested bracket (repeat group 1 here!).
      )*                    # Zero or more bracket contents alternatives.
    )                       # End $1: recursed subroutine.
    \)                      # Outermost closing bracket.
    /x';
$piece = preg_match($re_message, $text, $matches);
$piece = $matches[0];
$t = preg_replace_callback($re_message, function($d)  use ($replace)  {
		return preg_replace_callback('#s:(\d+):"([^"]*)Оренбург([^"]*)(?<!jpg)"#', function($m) use ($replace) {
			return 's:'.(intval($m[1])+strlen($replace) - strlen('Оренбург')).':"'.$m[2].$replace.$m[3].'"';
		}, $d[0]);
	},
$text);
$t = preg_replace_callback($re_message2, function($d) use ($replace) {
		return str_replace('Оренбург', $replace, $d[0]);
	},
$t);
$t = preg_replace_callback($re_message3, function($d) use ($replace) {
		return str_replace('Оренбург', $replace, $d[0]);
	},
$t);
$t = preg_replace_callback($re_message4, function($d) use ($replace) {
		return str_replace('Оренбург', $replace, $d[0]);
	},
$t);
$t = preg_replace_callback('#s:(\d+):"([^"]*)Оренбурге([^"]*)(?<!jpg)"#', function($m) use ($replace_l) {
    return 's:'.(intval($m[1])+strlen($replace_l) - strlen('Оренбурге')).':"'.$m[2].$replace_l.$m[3].'"';
},
$t);
$t = str_replace('САМАРЕ', mb_strtoupper($replace_l), $t);
$t = str_replace('Оренбурге', $replace_l, $t);
$t = str_replace('Московское шоссе 17, офис 715 (Вертикаль)', $adress, $t);
$t = preg_replace_callback('#s:(\d+):"([^"]*)Московское шоссе 17, офис 715([^"]*)(?<!jpg)"#', function($m) use ($adress) {
    return 's:'.(intval($m[1])+strlen($adress) - strlen('Московское шоссе 17, офис 715')).':"'.$m[2].$adress.$m[3].'"';
},
$t);
$t = str_replace('Московское шоссе 17 (Вертикаль)', $addr[0], $t);
$t = str_replace('офис 715', $addr[1], $t);
$t = preg_replace_callback('#s:(\d+):"([\d ]*\(846\)[\d -]+)"#', function($m) use ($phn) {
    return 's:'.(intval($m[1])+strlen($phn) - strlen($m[2])).':"'.$phn.'"';
},
$t);
$t = preg_replace('#[\d ]*(%20)?\(846\)(%20)?([\d -]+)#', $phn, $t);
$t = preg_replace_callback('#s:(\d+):"([^"]*)info@balkon-avangard\.ru([^"]*)"#', function($m) use ($email) {
    return 's:'.(intval($m[1])+strlen($email) - strlen('info@balkon-avangard.ru')).':"'.$m[2].$email.$m[3].'"';
},
$t);
$t = str_replace('info@balkon-avangard.ru', $email, $t);
$t = preg_replace_callback('#s:(\d+):"([^"]*)cryptonic@mail\.ru,mydom63@yandex\.ru,DE24B823-1521-3465-8C68-172D0E66189C\+79170158380@sms\.ru([^"]*)"#', function($m) use ($email2) {
    return 's:'.(intval($m[1])+strlen($email2) - strlen('cryptonic@mail.ru,mydom63@yandex.ru,DE24B823-1521-3465-8C68-172D0E66189C+79170158380@sms.ru')).':"'.$m[2].$email2.$m[3].'"';
},
$t);
$t = str_replace('cryptonic@mail.ru,mydom63@yandex.ru,DE24B823-1521-3465-8C68-172D0E66189C+79170158380@sms.ru', $email2, $t);
$t = str_replace('mydom63@yandex.ru', $email2, $t);

$t = str_replace('5016390864732160',$vnyo, $t);
$t = str_replace('44889952',$ym, $t);

$t = str_replace('%3Ciframe%20src%3D%22https%3A%2F%2Fwww.google.com%2Fmaps%2Fembed%3Fpb%3D%211m18%211m12%211m3%211d1194.9092556977837%212d50.15568299088142%213d53.20317099770167%212m3%211f0%212f0%213f0%213m2%211i1024%212i768%214f13.1%213m3%211m2%211s0x0%253A0x0%212zNTPCsDEyJzExLjQiTiA1MMKwMDknMjMuMSJF%215e0%213m2%211sru%212sru%214v1495611626109%22%20width%3D%22100%25%22%20height%3D%22450%22%20frameborder%3D%220%22%20style%3D%22border%3A0%22%20allowfullscreen%3E%3C%2Fiframe%3E', $GMiframef, $t);

$t = preg_replace_callback('#s:(\d+):"([^"]*)http://balkon-avangard\.ru([^"]*)"#', function($m) use ($url) {
    return 's:'.(intval($m[1])+strlen($url) - strlen('http://balkon-avangard.ru')).':"'.$m[2].$url.$m[3].'"';
}, $t); 
$t = str_replace("http://balkon-avangard.ru", $url , $t);

$urle = rawurlencode($url);

$t = preg_replace_callback('#s:(\d+):"([^"]*)http%3A%2F%2Fbalkon-avangard\.ru([^"]*)"#', function($m) use ($urle) {
    return 's:'.(intval($m[1])+strlen($urle) - strlen('http%3A%2F%2Fbalkon-avangard.ru')).':"'.$m[2].$urle.$m[3].'"';
}, $t); 
$t = str_replace("http%3A%2F%2Fbalkon-avangard.ru", $urle , $t);

$rev_slider = <<<'EOD'
http:\\/\\/balkon-avangard.ru
EOD;
$rev_slider_urle = str_replace('/', '\\\\/', $url);

$t = str_replace($rev_slider, $rev_slider_urle , $t);

$t = $perfix . $t . $postfix;
//Закончили херачить
		unlink('dump.sql');
		header('Content-Disposition: attachment; filename="mod.sql"');
		header('Content-Type: application/sql');
		header('Content-Length: ' . strlen($t));
		header('Connection: close');

		$success = 'Модифицированный дамп успешно создан!';
		echo $t;	
			die;
		}			
				
	}
}
?>	
<!DOCTYPE html>
<html>
	
	<head>
		<meta charset="utf-8">
		<title>Модификация базы под новый сайт! Специально и только для http://balkon-avangard.ru</title>
		<link rel="icon" href="" type="image/png">
		<style>
		:focus {outline:none;    outline-offset: 0px;}
		*{padding:0;margin:0;box-sizing:border-box;}
		html{height:100%;}body{width:100%;}
		body{    font-family: Arial, sans-serif;
    font-size: 1.4em;color:#667;}
	a {text-decoration:none;color:#667; }
		form {    max-width: 1600px;
    width: 100%;
    margin: 10px auto 0; position:relative;}
		h3,h4 {position: relative;
    background-color: #fff;
    display: inline-block;
    padding: 0 10px;}
	h3{text-align:center;margin:9px 0;display:block;}
	h3 a,h3 a:hover,h3 a:focus,h3 a:visited{color:#4ea520; text-decoration:none;}
	.fields-block {    padding: 10px;
    outline: 1px solid #667;
    outline-offset: 13px;
    margin-bottom: 30px;}
	.fields-block:after {
		  content: "";
		  display: table;
		  clear: both;
		}
		.fields-block label{    display: block;
    margin-bottom: 10px;}
		.fields-block input[type=text]{ 
		    color: #0071d6;
		font-size: 1em;
    background: #ffe;
    outline: 1px solid #ddd;
    border: none;
    padding: 0 10px;
    float: right;
    width: 70%;}
	.fields-block textarea{height:5em; color: #0071d6;
		font-size: 1em;
    background: #ffe;
    outline: 1px solid #ddd;
    border: none;
    padding: 0 10px;
    float: right;
    width: 70%;
	vertical-align:middle; resize: none;}
		.fields-block h4{
    background: #fff;
    position: relative;
    padding: 0 10px;
    display: inline-block;
}
	button {
	padding: 10px;
    border: none;
    outline: none;
    font-size: 1em;
    cursor: pointer;
    line-height: 1em;
	color: #fff;
	}	

	button[disabled] {
    background-color: #cfcfcf;
    cursor: auto;
}

	.save{    display: block;
    width: 170px;
    margin: 0 auto;
    background: #4ea520;}
	.reset{width: 170px;
    margin: 0 auto;
    background: #a5204e;
	position:absolute;
	bottom:83px;
	left:10px;}
		.container-uf
			{
				width: 100%;
				/*max-width: 680px;  800 
				text-align: center;*/
				max-width: 1600px;
				margin: 0px auto 0;
			}

				.container-uf h1
				{       text-align: center;
					    font-size: 40px;
						font-weight: 300;
						color: #567aa0;
						margin-bottom: 30px;
						line-height: 36px;
				}
				.container-uf h1 a:hover,
				.container-uf h1 a:focus
				{
					color: #39bfd3;
				}

				.container-uf p
				{text-align: center;
					margin:0 0 10px 0;
					font-size:0.8em;
				}
					.container-uf nav a
					{
						border-bottom: 2px solid #c8dadf;
						display: inline-block;
						padding: 4px 8px;
						margin: 0 5px;
					}
					.container-uf nav a.is-selected
					{
						font-weight: 700;
						color: #39bfd3;
						border-bottom-color: currentColor;
					}
					.container-uf nav a:not( .is-selected ):hover,
					.container-uf nav a:not( .is-selected ):focus
					{
						border-bottom-color: #0f3c4b;
					}

				.container-uf footer
				{
					color: #92b0b3;
					margin-top: 40px;
				}
					.container-uf footer p + p
					{
						margin-top: 1em;
					}
					.container-uf footer a:hover,
					.container-uf footer a:focus
					{
						color: #39bfd3;
					}

				.box
				{text-align: center;
					font-size: 1.25rem; /* 20 */
					background-color: #c8d5df;
					position: relative;
					padding: 50px 20px;
				}
				.box.is-error 
				{
					background-color: #dfc8c8;
				}
				.box.is-success 
				{
					background-color: #c8dfc8
				}
				.box.has-advanced-upload
				{
					outline: 2px dashed #92b0b3;
					outline-offset: -10px;

					-webkit-transition: outline-offset .15s ease-in-out, background-color .3s linear;
					transition: outline-offset .15s ease-in-out, background-color .3s linear;
				}
				.box.is-dragover
				{
					outline-offset: -20px;
					outline-color: #c8dadf;
					background-color: #fff;
				}
					.box__dragndrop,
					.box__icon
					{
						display: none;
					}
					.box.has-advanced-upload .box__dragndrop
					{
						display: inline;
					}
					.box.has-advanced-upload .box__icon
					{
						width: 100%;
						height: 80px;
						fill: #92b0b3;
						display: block;
						margin-bottom: 40px;
					}

					.box.is-uploading .box__input,
					.box.is-success .box__input,
					.box.is-error .box__input
					{
						visibility: hidden;
					}

					.box__uploading,
					.box__success,
					.box__error
					{
						display: none;
					}
					.box.is-uploading .box__uploading,
					.box.is-success .box__success,
					.box.is-error .box__error
					{
						display: block;
						position: absolute;
						top: 50%;
						right: 15px;
						left: 15px;

						-webkit-transform: translateY( -50% );
						transform: translateY( -50% );
					}
					.box__uploading
					{
						font-style: italic;
					}
					.box__success
					{
						-webkit-animation: appear-from-inside .25s ease-in-out;
						animation: appear-from-inside .25s ease-in-out;
					}
						@-webkit-keyframes appear-from-inside
						{
							from	{ -webkit-transform: translateY( -50% ) scale( 0 ); }
							75%		{ -webkit-transform: translateY( -50% ) scale( 1.1 ); }
							to		{ -webkit-transform: translateY( -50% ) scale( 1 ); }
						}
						@keyframes appear-from-inside
						{
							from	{ transform: translateY( -50% ) scale( 0 ); }
							75%		{ transform: translateY( -50% ) scale( 1.1 ); }
							to		{ transform: translateY( -50% ) scale( 1 ); }
						}

					.box__restart
					{
						font-weight: 700;
					}
					.box__restart:focus,
					.box__restart:hover
					{
						color: #39bfd3;
					}

					.box__file
					{
						width: 0.1px;
						height: 0.1px;
						opacity: 0;
						overflow: hidden;
						position: absolute;
						z-index: -1;
					}
					.box__file + label
					{
						max-width: 80%;
						text-overflow: ellipsis;
						white-space: nowrap;
						cursor: pointer;
						display: inline-block;
						overflow: hidden;
					}
					.box__file + label:hover strong,
					.box__file:focus + label strong,
					.box__file.has-focus + label strong
					{
						color: #39bfd3;
					}
					.box__file:focus + label,
					.box__file.has-focus + label
					{
						outline: 1px dotted #000;
						outline: -webkit-focus-ring-color auto 5px;
						outline: none;
					}
						.box__file + label *
						{
							/* pointer-events: none; */ /* in case of FastClick lib use */
						}
					.box__button
					{
						font-weight: 700;
						color: #e5edf1;
						background-color: #39bfd3;
						display: none;
						padding: 8px 16px;
						margin: 40px auto 0;
					}
						.box__button:hover,
						.box__button:focus
						{
							background-color: #0f3c4b;
						}
						.elm{    position: fixed;
    color: #12a700;
    bottom: 10px;
    right: 10px;
    font-size: 0.6em;
	cursor:pointer;}
		</style>
		
	</head>
	<body>
		
		<div class="container-uf" role="main">
			<h3>Модификация базы под новый сайт. Специально и только для <a href="http://balkon-avangard.ru">balkon-avangard.ru</a></h3>
			<h4>Загрузка дампа</h4>
			<div class="fields-block">
				<p>Только SQL; имя файла может быть любым; после успешной обработки автоматически начнется скачивание модифицированного дампа.</p>
				
				<form class="box <?=($error)?'is-error':''?> <?=($success)?'is-success':''?>" method="post" action="" enctype="multipart/form-data" novalidate >
					
					<div class="box__input">
						<svg class="box__icon" xmlns="http://www.w3.org/2000/svg" width="50" height="43" viewBox="0 0 50 43"><path d="M48.4 26.5c-.9 0-1.7.7-1.7 1.7v11.6h-43.3v-11.6c0-.9-.7-1.7-1.7-1.7s-1.7.7-1.7 1.7v13.2c0 .9.7 1.7 1.7 1.7h46.7c.9 0 1.7-.7 1.7-1.7v-13.2c0-1-.7-1.7-1.7-1.7zm-24.5 6.1c.3.3.8.5 1.2.5.4 0 .9-.2 1.2-.5l10-11.6c.7-.7.7-1.7 0-2.4s-1.7-.7-2.4 0l-7.1 8.3v-25.3c0-.9-.7-1.7-1.7-1.7s-1.7.7-1.7 1.7v25.3l-7.1-8.3c-.7-.7-1.7-.7-2.4 0s-.7 1.7 0 2.4l10 11.6z"/></svg>
						<input type="file" name="sql" id="file" class="box__file" accept=".sql, application/sql" required/> 
						<label for="file"><strong>Выберите файл дампа</strong><span class="box__dragndrop"> или перетащите его сюда</span>.</label>
						<button type="submit" class="box__button">Отправить >></button>
					</div>

					
					<div class="box__uploading">Загружается&hellip;</div>
					<div class="box__success">Готово!  <span><?=$success?></span> <a href="" class="box__restart" role="button">Загрузить ещё раз?</a></div>
					<div class="box__error">Ошибка! <span><?=$error?></span> <a href="<?= $_SERVER["REQUEST_URI"]; ?>" class="box__restart" role="button">Попробовать ещё раз!</a></div>
				</form>
			</div>
		</div>
		
		<form id="dataset" method="post" action="">
			<h4>Данные</h4>
			<div class="fields-block">
			<label>Новый урл<input type="text" name="url" value="<?=isset($data['url'])?$data['url']:''?>"></label>
			<label>Город<input type="text" name="city" value="<?=isset($data['city'])?$data['city']:''?>"></label>
			<label>Город локатив<input type="text" name="city2" value="<?=isset($data['city2'])?$data['city2']:''?>"></label>
			<label>Адрес <input type="text" name="address" value="<?=isset($data['address'])?$data['address']:''?>"></label>
			<label>Телефон <input type="text" name="phone" value="<?=isset($data['phone'])?$data['phone']:''?>"></label>
			<label>Email <input type="text" name="email" value="<?=isset($data['email'])?$data['email']:''?>"></label>
			<label>Email(ы) для заявок через запятую <input type="text" name="email2" value="<?=isset($data['email2'])?$data['email2']:''?>"></label>
			<label>Yandex metrica ID <input type="text" name="YmetricaId" value="<?=isset($data['YmetricaId'])?$data['YmetricaId']:''?>"></label>
			<label>VENYOO ID <input type="text" name="VENYOOId" value="<?=isset($data['VENYOOId'])?$data['VENYOOId']:''?>"></label>
			<label>Код карты яндекс или гугл <textarea name="GMiframe"><?=isset($data['GMiframe'])?$data['GMiframe']:''?></textarea></label>
			<button type="reset" class="reset">Очистить!</button> 
			</div>
			<button type="submit" class="save">Прохерачить!</button> 
		</form>
		<div class="elm">Сделал Elm</div>
		<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
		<script>
	'use strict';

	;( function( $, window, document, undefined )
	{
		// feature detection for drag&drop upload

		var isAdvancedUpload = function()
			{
				var div = document.createElement( 'div' );
				return ( ( 'draggable' in div ) || ( 'ondragstart' in div && 'ondrop' in div ) ) && 'FormData' in window && 'FileReader' in window;
			}();


		// applying the effect for every form

		$( '.box' ).each( function()
		{
			var $form		 = $( this ),
				$input		 = $form.find( 'input[type="file"]' ),
				$label		 = $form.find( 'label' ),
				$errorMsg	 = $form.find( '.box__error span' ),
				$successMsg	 = $form.find( '.box__success span' ),
				$restart	 = $form.find( '.box__restart' ),
				droppedFiles = false,
				showFiles	 = function( files )
				{
					$label.text( files[ 0 ].name );
				};

			// letting the server side to know we are going to make an Ajax request
			$form.append( '<input type="hidden" name="ajax" value="1" />' );

			// automatically submit the form on file select
			$input.on( 'change', function( e )
			{
				showFiles( e.target.files );

				
				$form.trigger( 'submit' );
			});


			// drag&drop files if the feature is available
			if( isAdvancedUpload )
			{
				$form
				.addClass( 'has-advanced-upload' ) // letting the CSS part to know drag&drop is supported by the browser
				.on( 'drag dragstart dragend dragover dragenter dragleave drop', function( e )
				{
					// preventing the unwanted behaviours
					e.preventDefault();
					e.stopPropagation();
				})
				.on( 'dragover dragenter', function() //
				{
					$form.addClass( 'is-dragover' );
				})
				.on( 'dragleave dragend drop', function()
				{
					$form.removeClass( 'is-dragover' );
				})
				.on( 'drop', function( e )
				{
					droppedFiles = e.originalEvent.dataTransfer.files; // the files that were dropped
					showFiles( droppedFiles );

					
					$form.trigger( 'submit' ); // automatically submit the form on file drop
				});
			}


			// if the form was submitted

			$form.on( 'submit', function( e )
			{
				// preventing the duplicate submissions if the current one is in progress
				if( $form.hasClass( 'is-uploading' ) ) return false;

				$form.addClass( 'is-uploading' ).removeClass( 'is-error is-success' ); 

				if( isAdvancedUpload ) // ajax file upload for modern browsers
				{
					e.preventDefault();

					// gathering the form data
					var ajaxData = new FormData( $form.get( 0 ) );
					if( droppedFiles )
					{
						$.each( droppedFiles, function( i, file )
						{
							if ( gfe(file.name) == 'sql')
								ajaxData.append( $input.attr( 'name' ), file );
							else {
								$form.removeClass( 'is-uploading' ).addClass( 'is-error' );
								$errorMsg.text( 'Только SQL!' );
								return false; 
							}
						});
						if( $form.hasClass( 'is-error' ) ) return false;
					}

					// ajax request
					$.ajax(
					{
						//url: 			'',
						type:			$form.attr( 'method' ),
						data: 			ajaxData,
						dataType:		'json',
						cache:			false,
						contentType:	false,
						processData:	false,
						complete: function()
						{
							$form.removeClass( 'is-uploading' );
							$form[0].reset();
							droppedFiles = false;
						},
						success: function( data )
						{
							$form.addClass( data.status == true ? 'is-success' : 'is-error' );
							if ( !data.status ) $errorMsg.text( data.error );
							else {$successMsg.text( 'Теперь введите новые данные.' );
							//console.debug(data.success);
								for (var prop in data.success) {
									(prop==='GMiframe')?$('textarea[name='+prop+']').val(data.success[prop]):$('input[name='+prop+']').val(data.success[prop])	;
								}
							}
						},
						error: function()
						{
							$form.addClass( 'is-error' );
							$errorMsg.text( 'Не удалось выполнить запрос.' );
						}
					});
				}
				else // fallback Ajax solution upload for older browsers
				{
					var iframeName	= 'uploadiframe' + new Date().getTime(),
						$iframe		= $( '<iframe name="' + iframeName + '" style="display: none;"></iframe>' );

					$( 'body' ).append( $iframe );
					$form.attr( 'target', iframeName );

					$iframe.on( 'load', function()
					{
						var data = $.parseJSON( $iframe.contents().find( 'body' ).text() );
						$form.removeClass( 'is-uploading' ).addClass( data.status == true ? 'is-success' : 'is-error' ).removeAttr( 'target' );
						if( !data.status ) $errorMsg.text( data.error );
						$iframe.remove();
					});
				}
			});


			// restart the form if has a state of error/success

			$restart.on( 'click', function( e )
			{
				e.preventDefault();
				$form[0].reset();
				$form.removeClass( 'is-error is-success' );
				$label.html ( '<strong>Выберите файл дампа</strong><span class="box__dragndrop"> или перетащите его сюда</span>.' );
				$input.trigger( 'click' );
			});

			// Firefox focus bug fix for file input
			$input
			.on( 'focus', function(){ $input.addClass( 'has-focus' ); })
			.on( 'blur', function(){ $input.removeClass( 'has-focus' ); });
		});
		function gfe (fname)
		{return fname.substr((~-fname.lastIndexOf(".") >>> 0) + 2).toLowerCase();} 
 		$('.reset').on('click', function(e){
			e.preventDefault();
				$('#dataset input').val('');
				$('#dataset textarea').val('');
		}); 
	})( jQuery, window, document );
			
			
		</script>
	</body>
</html>