Ошибка не удалось скопировать файл restore php

 

Добрый день!
На виртуальную машину (VMBitrix7.4-0), где уже развёрнут проект, по ftp закачиваю резервную копию, кладу в папку /bitrix/backup/
В админке нажимаю «Восстановить» — и получаю «Ошибка Не удалось скопировать файл: restore.php»
Иду на него посмотреть — а он пустой.
Загружаю новый, повторяю — и он опять пустой.
Почему так происходит?

 

Если исходный файл не битый, у вас недостаточно прав для загрузки файла

 

Ну как бы, администратор.. Файл качал с оф.сайта. Несколько раз.
Для restore.php даже 777 выставлял — результат тот же.
Может, недостаточно прав для восстановления? Где эти права можно поправить?

 

Пользователь 1488151

Эксперт

Сообщений: 290
Баллов: 74
Регистрация: 18.10.2017

#5

0

24.12.2019 11:29:30

Цитата
Андрей написал:
Ну как бы, администратор.. Файл качал с оф.сайта. Несколько раз.
Для restore.php даже 777 выставлял — результат тот же.
Может, недостаточно прав для восстановления? Где эти права можно поправить?
Код
chown bitrix:bitrix -R /home/bitrix/www/
 

Пользователь 966697

Посетитель

Сообщений: 31
Баллов: 4
Регистрация: 22.02.2017

#6

0

24.12.2019 12:02:52

Даже так ради эксперимента сделал:

Код
sudo find /home/bitrix/www/ -type d -exec chmod 777 {} ;
sudo find /home/bitrix/www/ -type f -exec chmod 777 {} ;

Не помогло. restore.php продолжает обнуляться.

Диск на VM динамический, 56ГБ, занято 6ГБ — места предостаточно.

 

Может быть связано с тем, что у боевого проекта, с которого снята копия, не продлена лицензия?

 

Когда выставляю права на restore.php 555 — конечно, не обнуляется, но ошибка та же.

 

Пользователь 1488151

Эксперт

Сообщений: 290
Баллов: 74
Регистрация: 18.10.2017

#9

0

25.12.2019 12:20:30

Цитата
Андрей написал:
chown bitrix:bitrix -R /home/bitrix/www/

chown bitrix:bitrix -R /home/bitrix/backup/

 

Пользователь 1488151

Эксперт

Сообщений: 290
Баллов: 74
Регистрация: 18.10.2017

#10

0

25.12.2019 12:24:26

Сделав 777 гугл проиндексирует все папки и будут в поиске висеть все названия файлов.

<?php if (ini_get(‘short_open_tag’) == 0 && strtoupper(ini_get(‘short_open_tag’)) != ‘ON’) die(‘Error: short_open_tag parameter must be turned on in php.ini’); ?><? error_reporting(E_ALL & ~E_NOTICE & ~E_STRICT); @ini_set(‘pcre.backtrack_limit’, 1024*1024); define(‘IP_LIMIT_DEFAULT’, ‘#IP’.‘_LIMIT_PLACEHOLDER#’); define(‘IP_LIMIT’, ‘#IP_LIMIT_PLACEHOLDER#’); define(‘INIT_TIMESTAMP’, ‘#INIT_TIMESTAMP#’); if (getenv(‘BITRIX_VA_VER’)) define(‘VMBITRIX’, ‘defined’); if (version_compare(phpversion(),‘5.6’,‘<‘)) // 5.6 для старых версий Битрикс, без поддержки PHP 7 die(‘Error: PHP version 5.6 or higher is required’); if(realpath(dirname(__FILE__)) != realpath($_SERVER[‘DOCUMENT_ROOT’])) die(‘Error: this script must be started from Web Server’s DOCUMENT ROOT’); if(isset($_SERVERBX_PERSONAL_ROOT«]) && $_SERVERBX_PERSONAL_ROOT«] <> «») define(«BX_PERSONAL_ROOT«, $_SERVERBX_PERSONAL_ROOT«]); else define(«BX_PERSONAL_ROOT«, «/bitrix«); if(!defined(«START_EXEC_TIME«)) define(«START_EXEC_TIME«, microtime(true)); $START_TIME = START_EXEC_TIME; define(«STEP_TIME«, defined(‘VMBITRIX’) ? 30 : 15); # xdebug_start_trace(); define(‘RESTORE_FILE_LIST’, $_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/tmp/restore.file_list.php’); define(‘RESTORE_FILE_DIR’, $_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/tmp/restore.removed’); if (file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/restore_cloud.txt’) && file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/restore_cloud.php’)) unlink($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/restore_cloud.txt’); define(‘RESTORE_CLOUD_FILE_LIST’, file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/restore_cloud.txt’) ? $_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/restore_cloud.txt’ : $_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/restore_cloud.php’); $strWarning = »; if (function_exists(‘mb_internal_encoding’)) { switch (ini_get(«mbstring.func_overload«)) { case 0: $bUTF_serv = false; break; case 2: $bUTF_serv = mb_internal_encoding() == ‘UTF-8’; break; default: die(‘PHP parameter mbstring.func_overload=’.ini_get(«mbstring.func_overload«).‘. The only supported values are 0 or 2.’); break; } mb_internal_encoding(‘ISO-8859-1’); } else $bUTF_serv = false; if (!function_exists(‘htmlspecialcharsbx’)) { function htmlspecialcharsbx($string, $flags = ENT_COMPAT) { //shitty function for php 5.4 where default encoding is UTF-8 return htmlspecialchars($string, $flags, «ISO-8859-1«); } } define(‘DEBUG’, file_exists(dirname(__FILE__).‘/restore.debug’)); #@set_time_limit(0); ob_start(); if (@preg_match(‘#ru#i’,$_SERVER[‘HTTP_ACCEPT_LANGUAGE’])) $lang = ‘ru’; elseif (@preg_match(‘#de#i’,$_SERVER[‘HTTP_ACCEPT_LANGUAGE’])) $lang = ‘de’; if ($_REQUEST[‘lang’]) $lang = $_REQUEST[‘lang’]; if (!in_array($lang,array(‘ru’,‘en’,‘de’))) $lang = ‘en’; define(«LANG«, $lang); if (!headers_sent()) header(«Content-type:text/html; charset=utf-8«); $dbconn = $_SERVER[‘DOCUMENT_ROOT’].»/bitrix/php_interface/dbconn.php«; $arc_name = $_REQUESTarc_name«]; if (LANG == ‘ru’) { $MESS = array( «BEGIN» => « <p> <ul> <li>Перейдите в административную панель своего сайта на страницу <b>Настройки &gt; Инструменты &gt; Резервное копирование</b> <li>Создайте полную резервную копию, которая будет включать <b>публичную часть</b>, <b>ядро</b> и <b>базу данных</b> </ul> <a href=’https://dev.1c-bitrix.ru/~4thxV’ target=’_blank’>Документация</a> </p> «, «ARC_DOWN» => «Скачать резервную копию с дальнего сайта«, «ARC_DOWN_BITRIXCLOUD» => «Развернуть резервную копию из облака &quot;1С-Битрикс&quot;«, «BITRIXCLOUD_KEYS» => «Обновление ключей доступа к файлам в облаке«, «LICENSE_KEY» => «Ваш лицензионный ключ:«, «ARC_LOCAL_NAME» => «Имя архива:«, «DB_SELECT» => «Выберите дамп БД:«, «DB_SETTINGS» => «Параметры подключения к базе данных«, «DB_SKIP» => «Пропустить восстановление базы«, «SKIP» => «Пропустить«, «DELETE_FILES» => «Удалить локальную резервную копию и служебные скрипты«, «ARC_DOWN_URL» => «Ссылка на архив:«, «TITLE0» => «Подготовка архива«, «TITLE1» => «Загрузка резервной копии«, «TITLE_PROCESS1» => «Распаковка архива«, «FILE_IS_ENC» => «Архив зашифрован, для продолжения распаковки необходимо ввести пароль (с учетом регистра и пробелов): «, «WRONG_PASS» => «Введенный пароль неверен«, «ENC_KEY» => «Пароль: «, «TITLE_PROCESS2» => «Выполняется восстановление базы данных«, «TITLE2» => «Восстановление базы данных«, «TITLE3» => «Загрузка файлов из облака«, «ARC_SKIP» => «Архив уже распакован«, «ARC_SKIP_DESC» => «переход к восстановлению базы данных«, «ARC_NAME» => «Архив загружен в корневую папку сервера«, «ARC_DOWN_PROCESS» => «Загружается:«, «ERR_LOAD_FILE_LIST» => «Ошибочный ответ от сервиса 1С-Битрикс«, «ARC_LOCAL» => «Загрузить с локального диска«, «ARC_LOCAL_WARN» => «Загрузите все части многотомного архива«, «ERR_NO_PARTS» => «Доступны не все части многотомного архива.<br>Общее число частей: «, «BUT_TEXT1» => «Далее«, «BUT_TEXT_BACK» => «Назад«, «DUMP_RETRY» => «Попробовать снова«, «USER_NAME» => «Имя пользователя«, «USER_PASS» => «Пароль«, «SEARCHING_UNUSED» => «Поиск посторонних файлов в ядре…«, «BASE_NAME» => «Имя базы данных«, «BASE_HOST» => «Сервер баз данных«, «BASE_RESTORE» => «Восстановить«, «ERR_EXTRACT» => «Ошибка«, «ERR_MSG» => «Ошибка!«, «LICENSE_NOT_FOUND» => «Лицензионный ключ не найден«, «SELECT_ARC» => «Выберите архив«, «CNT_PARTS» => «частей«, «ARC_LIST_EMPTY» => «Нет резервных копий, связанных с этим ключом«, «ERR_UNKNOWN» => «Неизвестный ответ сервера«, «ERR_UPLOAD» => «Не удалось загрузить файл на сервер«, «ERR_DUMP_RESTORE» => «Ошибка восстановления базы данных«, «ERR_CREATE_DB» => «Ошибка создания базы«, «ERR_TAR_TAR» => «Присутствуют файлы с расширением tar.tar. Вместо них должны быть архивы с номерами: tar.1, tar.2 и т.д.«, «FINISH» => «Операция выполнена успешно«, «FINISH_MSG» => «Операция восстановления системы завершена.«, «FINISH_BTN» => «Перейти на сайт«, «BASE_CREATE_DB» => «Создать базу данных если не существует«, «BASE_CLOUDS» => «Файлы из облачных хранилищ:«, «BASE_CLOUDS_Y» => «сохранить локально«, «BASE_CLOUDS_N» => «оставить в облаке«, «FINISH_ERR_DELL» => «Не удалось удалить все временные файлы! Обязательно удалите их вручную.«, «FINISH_ERR_DELL_TITLE» => «Ошибка удаления файлов«, «NO_READ_PERMS» => «Нет прав на чтение корневой папки сайта«, «UTF8_ERROR1» => «Сайт работал в кодировке UTF-8. Конфигурация сервера не соответствует требованиям.<br>Для продолжения установите настройки PHP: mbstring.func_overload=2 и mbstring.internal_encoding=UTF-8.«, «UTF8_ERROR2» => «Сайт работал в однобайтовой кодировке, а конфигурация сервера рассчитана на кодировку UTF-8.<br>Для продолжения установите настройки PHP: mbstring.func_overload=0 или mbstring.internal_encoding=ISO-8859-1.«, «DOC_ROOT_WARN» => «Во избежание проблем с доступом был переписан путь к корню сайта в настройках сайтов. Проверьте настройки сайтов.«, «CDN_WARN» => «Ускорение CDN было отключено т.к. текущий домен не соответствует домену из настроек CDN.«, «HOSTS_WARN» => «Было отключено ограничение по доменам в модуле проактивной защиты т.к. текущий домен попадает под ограничения.«, «WARN_CLEARED» => «При распаковке ядра были обнаружены файлы, которых не было в архиве. Эти файлы перенесены в /bitrix/tmp/restore.removed«, «WARN_SITES» => «Вы распаковали многосайтовый архив, файлы дополнительных сайтов следует скопировать вручную из папки /bitrix/backup/sites«, «WARNING» => «Внимание!«, «DBCONN_WARN» => «Данные подключения взяты из dbconn.php. Если их не изменить, будет переписана база данных текущего сайта.«, «HTACCESS_RENAMED_WARN» => «Файл .htaccess из архива был сохранен в корне сайта под именем .htaccess.restore, т.к. он может содержать директивы, недопустимые на данном сервере.«, «HTACCESS_WARN» => «Файл .htaccess из архива был сохранен в корне сайта под именем .htaccess.restore, т.к. он может содержать директивы, недопустимые на данном сервере. В корне сайта создан .htaccess по умолчанию. Измените его вручную через FTP.«, «HTACCESS_ERR_WARN» => «Файл .htaccess из архива был сохранен в корне сайта под именем .htaccess.restore, т.к. он может содержать директивы, недопустимые на данном сервере. <br> Не удалось создать корне сайта .htaccess по умолчанию. Переименуйте файл .htaccess.restore в .htaccess через FTP.«, «ERR_CANT_DECODE» => «Невозможно восстановить архив т.к. он содержит файлы, имена которых нужно перекодировать, а модуль mbstring недоступен.«, «ERR_CANT_DETECT_ENC» => «Невозможно восстановить архив т.к. он содержит файлы с именами в неизвестной кодировке:«, ‘TAR_ERR_FILE_OPEN’ => ‘Не удалось открыть файл: ‘, «ARC_DOWN_OK» => «Все части архива загружены«, «LOADER_SUBTITLE1» => «Загрузка резервной копии«, «LOADER_SUBTITLE1_ERR» => «Ошибка загрузки«, «LOADER_LOAD_QUERY_DISTR» => «Запрашиваю файл #DISTR#«, «LOADER_LOAD_CONN2HOST» => «Подключение к серверу #HOST#«, «LOADER_LOAD_NO_CONN2HOST» => «Не могу соединиться с #HOST#:«, «LOADER_LOAD_SERVER_ANSWER» => «Ошибка загрузки. Сервер ответил: #ANS#«, «LOADER_LOAD_SERVER_ANSWER1» => «Ошибка загрузки. У вас нет прав на доступ к этому файлу. Сервер ответил: #ANS#«, «LOADER_LOAD_LOAD_DISTR» => «Загружаю файл #DISTR#«, «LOADER_LOAD_ERR_RENAME» => «Не могу переименовать файл #FILE1# в файл #FILE2#«, «ERROR_CANT_WRITE» => «Не могу записать файл #FILE#. Место на диске: #SPACE#«, «ERROR_IP_CHANGED» => «IP адрес клиента изменился, продолжение невозможно.«, «ERROR_INIT_TIMESTAMP» => «Время работы скрипта восстановления истекло. Загрузите новую версию.«, «LOADER_LOAD_CANT_REDIRECT» => «Ошибочное перенаправление на адрес #URL#. Проверьте адрес для скачивания.«, «LOADER_LOAD_CANT_OPEN_READ» => «Не могу открыть файл #FILE# на чтение«, «LOADER_LOAD_LOADING» => «Загружаю файл, дождитесь окончания загрузки…«, «LOADER_LOAD_FILE_SAVED» => «Файл сохранен: #FILE# [#SIZE# байт]«, «UPDATE_SUCCESS» => «Обновлено успешно. <a href=’?’>Открыть</a>.«, «LOADER_NEW_VERSION» => «Доступна новая версия скрипта восстановления, но загрузить её не удалось«, ); } elseif (LANG == ‘de’) { $MESS = array( «BACK» => «Zurück«, «BEGIN» => « <p> <ul> <li>Öffnen Sie den Administrativen Bereich Ihrer alten Website und wählen Sie <b>Einstellungen &gt; Tools &gt; Backup</b> <li>Erstellen Sie ein vollständiges Archiv mit <b>öffentlichen Website-Dateien</b>, <b>Kernel-Dateien</b> und <b>Datenbank-Dump</b> </ul> <b>Dokumentation:</b> <a href=’https://training.bitrix24.com/support/training/course/?COURSE_ID=12&LESSON_ID=5913&LESSON_PATH=3884.5489.5913′ target=’_blank’>Trainingskurs</a> </p> «, «ARC_DOWN» => «Von Remote-Server herunterladen«, «ARC_DOWN_BITRIXCLOUD» => «Backup aus der Bitrix Cloud wiederherstellen«, «BITRIXCLOUD_KEYS» => «Refreshing Bitrix Cloud access keys«, «LICENSE_KEY» => «Ihr Lizenzschlüssel:«, «ARC_LOCAL_NAME» => «Archivname:«, «DB_SELECT» => «Datenbank-Dump auswählen:«, «DB_SETTINGS» => «Datenbank-Einstellungen«, «DB_SKIP» => «Überspringen«, «SKIP» => «Überspringen«, «DELETE_FILES» => «Archiv und temporäre Scripts löschen«, «ARC_DOWN_URL» => «Archiv-URL:«, «TITLE0» => «Archiv erstellen«, «TITLE1» => «Archiv herunterladen«, «TITLE_PROCESS1» => «Archiv wird entpackt«, «TITLE_PROCESS2» => «Datenbank wird wiederhergestellt…«, «FILE_IS_ENC» => «Archiv ist verschlüsselt. Passwort eingeben: «, «WRONG_PASS» => «Passwort ist falsch«, «ENC_KEY» => «Passwort: «, «TITLE2» => «Datenbank wiederherstellen«, «TITLE3» => «Herunterladen von cloud-Dateien«, «ARC_SKIP» => «Archiv wurde bereits entpackt«, «ARC_SKIP_DESC» => «Wiederherstellung der Datenbank starten«, «ARC_NAME» => «Archiv ist im Dokumenten-Root abgespeichert«, «ARC_DOWN_PROCESS» => «Wird herunterladen:«, «ERR_LOAD_FILE_LIST» => «Falsche Antwort vom Bitrixsoft Server«, «ARC_LOCAL» => «Vom lokalen Speicher hochladen«, «ARC_LOCAL_WARN» => «Vergessen Sie nicht, alle Teile eines mehrbändigen Archivs hochzuladen.«, «ERR_NO_PARTS» => «Einige Teile des mehrbändigen Archivs fehlen.<br>Teile gesamt: «, «BUT_TEXT1» => «Fortfahren«, «BUT_TEXT_BACK» => «Zurück«, «DUMP_RETRY» => «Wiederholen«, «USER_NAME» => «Name des datenbank-Nutzers«, «USER_PASS» => «Passwort«, «BASE_NAME» => «Datenbankname«, «SEARCHING_UNUSED» => «Ungenutzte Kernel-Dateien werden gesucht…«, «BASE_HOST» => «Datenbank-Host«, «BASE_RESTORE» => «Wiederherstellen«, «ERR_EXTRACT» => «Fehler«, «ERR_MSG» => «Fehler!«, «LICENSE_NOT_FOUND» => «Lizenz wurde nicht gefunden«, «SELECT_ARC» => «Backup auswählen«, «CNT_PARTS» => «Teile«, «ARC_LIST_EMPTY» => «Backup-Liste ist leer für den aktuellen Lizenzschlüssel«, «ERR_UNKNOWN» => «Unbekannte Server-Antwort«, «ERR_UPLOAD» => «Datei kann nicht hochgeladen werden«, «ERR_DUMP_RESTORE» => «Fehler bei Wiederherstellung der Datenbank:«, «ERR_CREATE_DB» => «Fehler bei Erstellung der Datenbank«, «ERR_TAR_TAR» => «Es gibt Dateien mit Erweiterung tar.tar. Es müssten tar.1, tar.2 und so weiter sein«, «FINISH» => «Erfolgreich abgeschlossen«, «FINISH_MSG» => «Wiederherstellung des Systems wurde abgeschlossen.«, «FINISH_BTN» => «Website öffnen«, «BASE_CREATE_DB» => «Datenbank erstellen«, «BASE_CLOUDS» => «Cloud-Dateien:«, «BASE_CLOUDS_Y» => «lokal speichern«, «BASE_CLOUDS_N» => «in der Cloud lassen«, «FINISH_ERR_DELL» => «Löschen von temporären Dateien ist fehlgeschlagen. Sie sollten diese manuell löschen«, «FINISH_ERR_DELL_TITLE» => «Fehler beim Löschen von dateien«, «NO_READ_PERMS» => «Sie haben nicht genügend Rechte, um Web-Server Root zu lesen«, «UTF8_ERROR1» => «Ihr Server ist für die Codierung UTF-8 nicht konfiguriert. Definieren Sie bitte mbstring.func_overload=2 und mbstring.internal_encoding=UTF-8 um fortzufahren.«, «UTF8_ERROR2» => «Ihr Server ist für die Codierung UTF-8 konfiguriert. Definieren Sie bitte mbstring.func_overload=0 oder mbstring.internal_encoding=ISO-8859-1 um fortzufahren.«, «DOC_ROOT_WARN» => «Um Probleme mit Zugriffsrechten zu vermeiden, wurde das Dokumenten-Root in den Einstellungen der Website aufgeräumt.«, «CDN_WARN» => «CDN Web-Accelerator wurde deaktiviert, weil die aktuelle Domain sich von der unterscheidet, die in den CDN-Einstellungen gespeichrt ist.«, «HOSTS_WARN» => «Domain-Einschränkung wurde deaktiviert (Sicherheitsmodul), weil die aktuelle Domain den Einstellungen nicht entspricht.«, «WARN_CLEARED» => «Einige Dateien wurden in /bitrix gefunden, sie sind in der Backup nicht enthalten. Sie wurden nach /bitrix/tmp/restore.removed verschoben«, «WARN_SITES» => «Sie haben das Multisite-Archiv entpackt, kopieren Sie bitte die Dateien zusätzlicher Websites von /bitrix/backup/sites in einen entsprechenden Ort«, «WARNING» => «Warnung!«, «DBCONN_WARN» => «Die Verbindungseinstellungen werden von dbconn.php gelesen. Wenn Sie sie nicht ändern, wird aktuelle Datenbank überschrieben.«, «HTACCESS_RENAMED_WARN» => «Die Datei .htaccess wurde unter .htaccess.restore gespeichert, weil sie Anweisungen enthalten kann, die auf diesem Server nicht erlaubt sind.«, «HTACCESS_WARN» => «Die Datei .htaccess wurde unter .htaccess.restore gespeichert, weil sie die Anweisungen enthalten kann, die auf diesem Server nicht erlaubt sind. Standarddatei .htaccess wurde im Dokumenten-Root erstellt. Sie sollten sie manuell via FTP aktualisieren.«, «HTACCESS_ERR_WARN» => «Die Datei .htaccess wurde unter .htaccess.restore gespeichert, weil sie Anweisungen enthalten kann, die auf diesem Server nicht erlaubt sind. Es gab einen Fehler beim Erstellen der Standarddatei .htaccess. Sie sollten .htaccess.restore in .htaccess via FTP umbenennen.«, «ERR_CANT_DECODE» => «Unmöglich fortzufahren, weil das Modul MBString nicht verfügbar ist.«, «ERR_CANT_DETECT_ENC» => «Unmöglich fortzufahren wegen eines Fehlers in der Erkennung der Codierung des Dateinamen: «, ‘TAR_ERR_FILE_OPEN’ => ‘Datei kann nicht geöffnet werden: ‘, «ARC_DOWN_OK» => «Alle Archivteile wurden heruntergeladen«, «LOADER_SUBTITLE1» => «Wird geladen«, «LOADER_SUBTITLE1_ERR» => «Fehler beim Laden«, «LOADER_LOAD_QUERY_DISTR» => «Paket #DISTR# wird angefragt«, «LOADER_LOAD_CONN2HOST» => «Verbindung mit #HOST#«, «LOADER_LOAD_NO_CONN2HOST» => «Keine Verbindung mit #HOST#:«, «LOADER_LOAD_SERVER_ANSWER» => «Fehler beim Herunterladen. Die Antwort vom Server war: #ANS#«, «LOADER_LOAD_SERVER_ANSWER1» => «Fehler beim Herunterladen. Sie können dieses Paket nicht herunterladen. Die Antwort vom Server war: #ANS#«, «LOADER_LOAD_LOAD_DISTR» => «Das Paket #DISTR# wird heruntergeladen«, «LOADER_LOAD_ERR_RENAME» => «Die Datei #FILE1# kann nicht in #FILE2# umbenannt werden«, «ERROR_CANT_WRITE» => «In der Datei #FILE# kann nicht geschrieben werden. Freier Speicherplatz: #SPACE#«, «ERROR_IP_CHANGED» => «IP address has changed. Permission denied.«, «ERROR_INIT_TIMESTAMP» => «This script is outdated. Please upload the new version.«, «LOADER_LOAD_CANT_REDIRECT» => «Inkorrekte Weiterleitung an #URL#. Überprüfen Sie die Download-URL.«, «LOADER_LOAD_CANT_OPEN_READ» => «Die Datei #FILE# kann nicht zum Lesen geöffnet werden«, «LOADER_LOAD_LOADING» => «Es wird nun heruntergeladen. Bitte warten…«, «LOADER_LOAD_FILE_SAVED» => «Datei gespeichert: #FILE# [#SIZE# bytes]«, «UPDATE_SUCCESS» => «Aktualisierung war erfolgreich. <a href=’?’>Öffnen</a>.«, «LOADER_NEW_VERSION» => «Beim Aktualisieren des Scripts restore.php ist ein Fehler aufgetreten.«, ); } else { $MESS = array( «BEGIN» => « <p> <ul> <li>Open Control Panel section of your old site and select <b>Settings &gt; Tools &gt; Backup</b> <li>Create full archive which contains <b>public site files</b>, <b>kernel files</b> and <b>database dump</b> </ul> <b>Documentation:</b> <a href=’https://training.bitrix24.com/support/training/course/?COURSE_ID=12&LESSON_ID=5913&LESSON_PATH=3884.5489.5913′ target=’_blank’>learning course</a> </p> «, «ARC_DOWN» => «Download from remote server«, «ARC_DOWN_BITRIXCLOUD» => «Restore the backup from the Bitrix Cloud«, «BITRIXCLOUD_KEYS» => «Refreshing Bitrix Cloud access keys«, «LICENSE_KEY» => «Your license key:«, «ARC_LOCAL_NAME» => «Archive name:«, «DB_SELECT» => «Select Database Dump:«, «DB_SETTINGS» => «Database settings«, «DB_SKIP» => «Skip«, «SKIP» => «Skip«, «DELETE_FILES» => «Delete archive and temporary scripts«, «ARC_DOWN_URL» => «Archive URL:«, «TITLE0» => «Archive Creation«, «TITLE1» => «Archive download«, «TITLE_PROCESS1» => «Extracting an archive«, «TITLE_PROCESS2» => «Restoring database…«, «FILE_IS_ENC» => «Archive is encrypted. Enter password: «, «WRONG_PASS» => «Wrong password«, «ENC_KEY» => «Password: «, «TITLE2» => «Database restore«, «TITLE3» => «Downloading cloud files«, «ARC_SKIP» => «Archive is already extracted«, «ARC_SKIP_DESC» => «Starting database restore«, «ARC_NAME» => «Archive is stored in document root folder«, «ARC_DOWN_PROCESS» => «Downloading:«, «ERR_LOAD_FILE_LIST» => «Wrong Bitrixsoft server response«, «ARC_LOCAL» => «Upload from local disk«, «ARC_LOCAL_WARN» => «Don’t forget to upload all the parts of multi-volume archive.«, «ERR_NO_PARTS» => «Some parts of the multivolume archive are missed.<br>Total number of parts: «, «BUT_TEXT1» => «Continue«, «BUT_TEXT_BACK» => «Back«, «DUMP_RETRY» => «Retry«, «USER_NAME» => «Database User Name«, «USER_PASS» => «Password«, «BASE_NAME» => «Database Name«, «SEARCHING_UNUSED» => «Searching for unused kernel files…«, «BASE_HOST» => «Database Host«, «BASE_RESTORE» => «Restore«, «ERR_EXTRACT» => «Error«, «ERR_MSG» => «Error!«, «LICENSE_NOT_FOUND» => «License not found«, «SELECT_ARC» => «Select backup«, «CNT_PARTS» => «parts«, «ARC_LIST_EMPTY» => «Backup list is empty for current license key«, «ERR_UNKNOWN» => «Unknown server response«, «ERR_UPLOAD» => «Unable to upload file«, «ERR_DUMP_RESTORE» => «Error restoring the database:«, «ERR_CREATE_DB» => «Error creating the database«, «ERR_TAR_TAR» => «There are files with tar.tar extension presents. Should be tar.1, tar.2 and so on«, «FINISH» => «Successfully completed«, «FINISH_MSG» => «Restoring of the system was completed.«, «FINISH_BTN» => «Open site«, «BASE_CREATE_DB» => «Create database«, «BASE_CLOUDS» => «Cloud files:«, «BASE_CLOUDS_Y» => «store locally«, «BASE_CLOUDS_N» => «leave in the cloud«, «FINISH_ERR_DELL» => «Failed to delete temporary files! You should delete them manually«, «FINISH_ERR_DELL_TITLE» => «Error deleting the files«, «NO_READ_PERMS» => «No permissions for reading Web Server root«, «UTF8_ERROR1» => «Your server is not configured for UTF-8 encoding. Please set mbstring.func_overload=2 and mbstring.internal_encoding=UTF-8 to continue.«, «UTF8_ERROR2» => «Your server is configured for UTF-8 encoding. Please set mbstring.func_overload=0 or mbstring.internal_encoding=ISO-8859-1 to continue.«, «DOC_ROOT_WARN» => «To prevent access problems the document root has been cleared in the site settings.«, «CDN_WARN» => «CDN Web Accelerator has been disabled because current domain differs from the one stored in CDN settings.«, «HOSTS_WARN» => «Domain restriction has beed disabled (security module) because current domain doesn’t correspond settings.«, «WARN_CLEARED» => «Some files were found in /bitrix which don’t present in the backup. They were moved to /bitrix/tmp/restore.removed«, «WARN_SITES» => «You have extracted the multisite archive, please copy files of additional sites from /bitrix/backup/sites to an appropriate place«, «WARNING» => «Warning!«, «DBCONN_WARN» => «The connection settings are read from dbconn.php. If you don’t change them, current database will be overwriten.«, «HTACCESS_RENAMED_WARN» => «The file .htaccess was saved as .htaccess.restore, because it may contain directives which are not permitted on this server.«, «HTACCESS_WARN» => «The file .htaccess was saved as .htaccess.restore, because it may contain directives which are not permitted on this server. Default .htaccess file has been created at the document root. Please modify it manually using FTP.«, «HTACCESS_ERR_WARN» => «The file .htaccess was saved as .htaccess.restore, because it may contain directives which are not permitted on this server. There was an error in creating default .htaccess file. Please rename .htaccess.restore to .htaccess using FTP.«, «ERR_CANT_DECODE» => «Unable to continue because the module MBString is not available.«, «ERR_CANT_DETECT_ENC» => «Unable to continue due to error in encoding detection of file name: «, ‘TAR_ERR_FILE_OPEN’ => ‘Can’t open file: ‘, «ARC_DOWN_OK» => «All archive parts have been downloaded«, «LOADER_SUBTITLE1» => «Loading«, «LOADER_SUBTITLE1_ERR» => «Loading Error«, «LOADER_MENU_UNPACK» => «Unpack file«, «LOADER_LOAD_QUERY_DISTR» => «Requesting package #DISTR#«, «LOADER_LOAD_CONN2HOST» => «Connection to #HOST#…«, «LOADER_LOAD_NO_CONN2HOST» => «Cannot connect to #HOST#:«, «LOADER_LOAD_SERVER_ANSWER» => «Error while downloading. Server reply was: #ANS#«, «LOADER_LOAD_SERVER_ANSWER1» => «Error while downloading. Your can not download this package. Server reply was: #ANS#«, «LOADER_LOAD_LOAD_DISTR» => «Downloading package #DISTR#«, «LOADER_LOAD_ERR_RENAME» => «Cannot rename file #FILE1# to #FILE2#«, «ERROR_CANT_WRITE» => «Cannot write to file #FILE#. Free disk space: #SPACE#«, «ERROR_IP_CHANGED» => «IP address has changed. Permission denied.«, «ERROR_INIT_TIMESTAMP» => «This script is outdated. Please upload the new version.«, «LOADER_LOAD_CANT_REDIRECT» => «Wrong redirect to #URL#. Check download url.«, «LOADER_LOAD_CANT_OPEN_READ» => «Cannot open file #FILE# for reading«, «LOADER_LOAD_LOADING» => «Download in progress. Please wait…«, «LOADER_LOAD_FILE_SAVED» => «File saved: #FILE# [#SIZE# bytes]«, «UPDATE_SUCCESS» => «Successful update. <a href=’?’>Open</a>.«, «LOADER_NEW_VERSION» => «Error occured while updating restore.php script!«, ); } $bClearUnusedStep = (bool) $_REQUEST[‘clear’]; $bSelectDumpStep = $_REQUEST[‘source’] == ‘dump’; $bCloudDownloadStep = $_REQUEST[‘cloud_download’]; $Step = IntVal($_REQUESTStep«]); $strErrMsg = »; if (!DEBUG && !$Step && $_SERVER[‘REQUEST_METHOD’] == ‘GET’) { $this_script_name = basename(__FILE__); $bx_host = ‘www.1c-bitrix.ru’; $bx_url = ‘/download/files/scripts/’.$this_script_name; $form = »; // Check for updates $res = fsockopen(‘ssl://’.$bx_host, 443, $errno, $errstr, 3); if($res) { $strRequest = «HEAD «.$bx_url HTTP/1.1rn»; $strRequest.= «Host: «.$bx_host.»rn»; $strRequest.= «rn»; fputs($res, $strRequest); while ($line = fgets($res, 4096)) { if (preg_match(«/Content-Length: *([0-9]+)/i«, $line, $regs)) { if (filesize(__FILE__) != trim($regs[1])) { $tmp_name = $this_script_name.‘.tmp’; if (LoadFile(‘https://’.$bx_host.$bx_url, $tmp_name)) { if (rename($_SERVER[‘DOCUMENT_ROOT’].‘/’.$tmp_name,__FILE__)) { bx_accelerator_reset(); echo ‘<script>document.location=»?lang=’.LANG.‘»;</script>’.getMsg(‘UPDATE_SUCCESS’); die(); } else $strErrMsg = getMsg(«ERROR_CANT_WRITE«, [«#FILE#» => $this_script_name, ‘#SPACE#’ => freeSpace()]); } else $strErrMsg = getMsg(‘LOADER_NEW_VERSION’); } break; } } fclose($res); } } @ini_set(‘pcre.backtrack_limit’, 1024*1024); if (!DEBUG) { if (IP_LIMIT == IP_LIMIT_DEFAULT) { ($str = file_get_contents(__FILE__)) || die(getMsg(«LOADER_LOAD_CANT_OPEN_READ«, [«#FILE#» => __FILE__])); $size = strlen($str); $str = str_replace(IP_LIMIT, $_SERVER[‘REMOTE_ADDR’], $str); $str = str_replace(INIT_TIMESTAMP, time(), $str); $str = str_pad($str, $size, ‘ ‘); file_put_contents(__FILE__, $str) || die(getMsg(«ERROR_CANT_WRITE«, [«#FILE#» => __FILE__, ‘#SPACE#’ => freeSpace()])); bx_accelerator_reset(); header(‘Location: ‘.$_SERVER[‘REQUEST_URI’]); die(); } elseif ($_SERVER[‘REMOTE_ADDR’] != IP_LIMIT) $strErrMsg = getMsg(‘ERROR_IP_CHANGED’); elseif (time() — INIT_TIMESTAMP > 86400) $strErrMsg = getMsg(‘ERROR_INIT_TIMESTAMP’); if ($strErrMsg) { echo ‘<div style=»color:red»>’.getMsg(‘ERR_MSG’).‘ ‘.$strErrMsg.‘</div>’; die(); } } if ($_REQUEST[‘LoadFileList’]) { $strLog = »; if (LoadFilehttps://www.1c-bitrix.ru/buy_tmp/backup.php?license=«.md5(trim($_REQUEST[‘license_key’])).»&lang=«.LANG&action=get_info«, $file = $_SERVER[‘DOCUMENT_ROOT’].‘/file_list.xml’) && ($str = file_get_contents($file))) { if (preg_match_all(‘/<file name=»([^»]+)» size=»([^»]+)».*?/>/’, $str, $regs)) { $arFiles = array(); $arParts = array(); foreach($regs[0] as $i => $wholeMatch) { $name = CTar::getFirstName($regs[1][$i]); $arFiles[$name] += $regs[2][$i]; $arParts[$name]++; } krsort($arFiles); echo getMsg(‘SELECT_ARC’).‘:&nbsp;<select name=»bitrixcloud_backup»>’; foreach($arFiles as $name => $size) echo ‘<option value=»‘.htmlspecialcharsbx($name).‘» ‘.($_REQUEST[‘bitrixcloud_backup’] == $name ? ‘selected’ : »).‘>’.htmlspecialcharsbx($name).‘ (‘.floor($size/1024/1024), ‘ Mb’.($arParts[$name] > 1 ? ‘, ‘.getMsg(‘CNT_PARTS’).‘: ‘.$arParts[$name] : »).‘)</option>’; echo ‘</select><br>’; echo getMsg(‘ENC_KEY’).‘&nbsp;<input type=»password» size=30 name=»EncryptKey» autocomplete=»off»>’; } else { if (strpos($str, ‘<files>’) !== false) // valid answer $strErrMsg = getMsg(‘ARC_LIST_EMPTY’); elseif (preg_match(‘#error#i’,$str)) { $code = strip_tags($str); if ($code == ‘LICENSE_NOT_FOUND’) $strErrMsg = getMsg(‘LICENSE_NOT_FOUND’); else $strErrMsg = $code; } else $strErrMsg = getMsg(‘ERR_UNKNOWN’); echo ‘<div style=»color:red»>’.getMsg(‘ERR_MSG’).‘ ‘.$strErrMsg.‘</div>’; } bx_unlink($file); } else echo ‘<div style=»color:red»>’.getMsg(‘ERR_LOAD_FILE_LIST’).‘</div><div style=»text-align:left;color:#CCC»>’.nl2br($strLog).‘</div>’; die(); } elseif ($Step == 2 && !$bSelectDumpStep) { if (is_array($_REQUEST[‘arHeaders’])) $arHeaders = $_REQUEST[‘arHeaders’]; else $arHeaders = array(); $source = $_REQUEST[‘source’]; if ($source == ‘bitrixcloud’ && !$_REQUEST[‘arc_down_url’]) { $strLog = »; if (LoadFile(‘https://www.1c-bitrix.ru/buy_tmp/backup.php?license=’.md5(trim($_REQUEST[‘license_key’])).‘&lang=’.LANG.‘&action=read_file&file_name=’.urlencode($_REQUEST[‘bitrixcloud_backup’]).‘&check_word=’.CTar::getCheckword($_REQUEST[‘EncryptKey’]), $file = $_SERVER[‘DOCUMENT_ROOT’].‘/file_info.xml’) && ($str = file_get_contents($file))) { bx_unlink($file); $host = preg_match(‘#<host>([^<]+)</host>#i’,$str,$regs) ? $regs[1] : false; $path = preg_match(‘#<path>([^<]+)</path>#i’,$str,$regs) ? $regs[1] : false; if (preg_match_all(‘/<header name=»([^»]+)» value=»([^»]+)».*?/>/’, $str, $regs)) { foreach($regs[0] as $i => $wholeMatch) $arHeaders[$regs[1][$i]] = $regs[2][$i]; } if ($host && $path) { $_REQUEST[‘arc_down_url’] = $host.$path; } elseif (strpos($str, ‘WRONG_FILE_NAME_OR_CHECKWORD’) !== false) $strErrMsg = ‘<div style=»color:red»>’.getMsg(‘WRONG_PASS’).‘</div>’; else $strErrMsg = ‘<div style=»color:red»>’.getMsg(‘ERR_LOAD_FILE_LIST’).‘</div>’; } else $strErrMsg = ‘<div style=»color:red»>’.getMsg(‘ERR_LOAD_FILE_LIST’).‘</div><div style=»text-align:left;color:#CCC»>’.nl2br($strLog).‘</div>’; if (!$_REQUEST[‘try_next’] && $strErrMsg) { $text = $strErrMsg. getMsg(‘ENC_KEY’).‘<input type=»password» size=30 name=»EncryptKey» autocomplete=»off» value=»»>’. ‘<input type=»hidden» name=»license_key» value=»‘.htmlspecialcharsbx($_REQUEST[‘license_key’]).‘»>’. ‘<input type=»hidden» name=»source» value=»bitrixcloud»>’. ‘<input type=»hidden» name=»bitrixcloud_backup» value=»‘.htmlspecialcharsbx($_REQUEST[‘bitrixcloud_backup’]).‘»>’. ‘<input type=»hidden» name=»Step» value=»2″>’; $bottom .= <a href=»/restore.php?Step=1&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> <input type=»button» id=»start_button» value=»‘.getMsg(«BUT_TEXT1«).‘» onClick=»reloadPage(2)»>’; showMsg(getMsg(‘TITLE1’),$text,$bottom); die(); } } if ($source == ‘download’ || $source == ‘bitrixcloud’) { $strUrl = $_REQUEST[‘arc_down_url’]; $res = false; if ($strUrl) { if (!preg_match(‘#https?://#’,$strUrl)) $strUrl = ‘http://’.$strUrl; $arc_name = trim(basename($strUrl)); if ($arc_name == CTar::getFirstName($arc_name)) { $full = false; $tar = new CTar(); $n = CTar::getLastNum($_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name); $arc_name1 = $arc_name; while(file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name1)) { if ($n && $arc_name1 == $arc_name.‘.’.$n) { $full = true; break; } $arc_name1 = $tar->getNextName($arc_name1); } if (!$full) { $strUrl = str_replace($arc_name, $arc_name1, $strUrl); $_REQUEST[‘bitrixcloud_backup’] = $arc_name = $arc_name1; } } $strLog = »; $status = »; if ($_REQUEST[‘continue’]) { $res = LoadFile($strUrl, $_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name, $arHeaders); if (file_exists($file = $_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name)) { if ($res == 1) { $f = fopen($_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name, ‘rb’); $id = fread($f, 2); fclose($f); if ($id != chr(31).chr(139)) // not gzip { $s = filesize($_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name); if ($s == 0 || $s%512 > 0) // not tar { bx_unlink($_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name); $res = false; } } } } } else { $res = 2; SetCurrentProgress(0); } } if ($res) { $text = getMsg(‘ARC_DOWN_PROCESS’).‘ <b>’.htmlspecialcharsbx($arc_name).‘</b>’ . $status . ‘<input type=hidden name=Step value=2>’. ‘<input type=hidden name=continue value=Y>’. ‘<input type=hidden name=»EncryptKey» value=»‘.htmlspecialcharsbx($_REQUEST[‘EncryptKey’]).‘»>’. ‘<input type=hidden name=»license_key» value=»‘.htmlspecialcharsbx($_REQUEST[‘license_key’]).‘»>’; if ($res == 2) { $text .= ‘<input type=hidden name=arc_down_url value=»‘.htmlspecialcharsbx($strUrl).‘»>’; $text .= ‘<input type=hidden name=source value=download>’; $text .= ‘<input type=hidden name=»bitrixcloud_backup» value=»‘.htmlspecialcharsbx($_REQUEST[‘bitrixcloud_backup’]).‘»>’; } else { $tar = new CTar(); $text .= ‘<input type=hidden name=try_next value=Y>’; if (count($arHeaders)) // bitrixcloud { $text .= ‘<input type=hidden name=source value=bitrixcloud>’; $text .= ‘<input type=hidden name=»bitrixcloud_backup» value=»‘.htmlspecialcharsbx($tar->getNextName($_REQUEST[‘bitrixcloud_backup’])).‘»>’; } else { $text .= ‘<input type=hidden name=source value=download>’; $text .= ‘<input type=hidden name=arc_down_url value=»‘.htmlspecialcharsbx($tar->getNextName($strUrl)).‘»>’; } } if (count($arHeaders)) { foreach($arHeaders as $k=>$v) $text .= ‘<input type=hidden name=»arHeaders[‘.htmlspecialcharsbx($k).‘]» value=»‘.htmlspecialcharsbx($v).‘»>’; } } elseif ($_REQUEST[‘try_next’]) { $text = getMsg(‘ARC_DOWN_OK’). ‘<input type=hidden name=Step value=2>’. ‘<input type=hidden name=»EncryptKey» value=»‘.htmlspecialcharsbx($_REQUEST[‘EncryptKey’]).‘»>’; if ($_REQUEST[‘bitrixcloud_backup’]) $text .= ‘<input type=hidden name=arc_name value=»‘.htmlspecialcharsbx(CTar::getFirstName($_REQUEST[‘bitrixcloud_backup’])).‘»>’; else $text .= ‘<input type=hidden name=arc_name value=»‘.htmlspecialcharsbx(CTar::getFirstName($arc_name)).‘»>’; } else { if ($_REQUEST[‘bitrixcloud_backup’] && $replycode == 403 && count($arHeaders) && (!$_REQUEST[‘timestamp’] || time() — $_REQUEST[‘timestamp’] > 10)) // Retry for bitrixcloud { $status = ‘<div>’.getMsg(‘BITRIXCLOUD_KEYS’).‘</div>’; $text = getMsg(‘ARC_DOWN_PROCESS’).‘ <b>’.htmlspecialcharsbx($arc_name).‘</b>’ . $status . ‘<input type=hidden name=Step value=2>’. ‘<input type=hidden name=timestamp value=’.time().‘>’. ‘<input type=hidden name=continue value=Y>’. ‘<input type=hidden name=»EncryptKey» value=»‘.htmlspecialcharsbx($_REQUEST[‘EncryptKey’]).‘»>’. ‘<input type=hidden name=»license_key» value=»‘.htmlspecialcharsbx($_REQUEST[‘license_key’]).‘»>’; $text .= ‘<input type=hidden name=source value=bitrixcloud>’; $text .= ‘<input type=hidden name=»bitrixcloud_backup» value=»‘.htmlspecialcharsbx($_REQUEST[‘bitrixcloud_backup’]).‘»>’; } else { $ar = array( ‘TITLE’ => getMsg(‘LOADER_SUBTITLE1_ERR’), ‘TEXT’ => nl2br($strLog), ‘BOTTOM’ => ‘<a href=»/restore.php?Step=1&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a>’ ); html($ar); die(); } } $bottom = ‘<a href=»/restore.php?Step=1&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a>’; showMsg(getMsg(‘LOADER_SUBTITLE1’),$text,$bottom); ?><script>reloadPage(2, 1);</script><? die(); } elseif($source == ‘upload’) { if (!count($_FILES[‘archive’][‘tmp_name’])) { $ar = array( ‘TITLE’ => getMsg(‘ERR_EXTRACT’), ‘TEXT’ => getMsg(‘ERR_UPLOAD’), ‘BOTTOM’ => ‘<a href=»/restore.php?Step=1&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a>’ ); html($ar); die(); } foreach($_FILES[‘archive’][‘tmp_name’] as $k => $v) { if (!$v) continue; $arc_name = $_FILES[‘archive’][‘name’][$k]; if (!@move_uploaded_file($v, $_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name)) { $ar = array( ‘TITLE’ => getMsg(‘ERR_EXTRACT’), ‘TEXT’ => getMsg(‘ERR_UPLOAD’), ‘BOTTOM’ => ‘<a href=»/restore.php?Step=1&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a>’ ); html($ar); die(); } } $text = ‘<input type=hidden name=Step value=2>’. ‘<input type=hidden name=arc_name value=»‘.htmlspecialcharsbx(CTar::getFirstName($arc_name)).‘»>’; showMsg(getMsg(‘LOADER_SUBTITLE1’),$text); ?><script>reloadPage(2, 1);</script><? die(); } } elseif($Step == 3) { $d_pos = (double) $_REQUESTd_pos«]; if ($d_pos < 0) $d_pos = 0; $oDB = new CDBRestore($_REQUESTDBHost«], $_REQUESTDBName«], $_REQUESTDBLogin«], $_REQUESTDBPassword«], $_REQUESTdump_name«], $d_pos); $oDB->LocalCloud = $_REQUEST[‘LocalCloud’]; if(!$oDB->Connect()) { $strErrMsg = $oDB->getError(); $Step = 2; $bSelectDumpStep = true; } } ##################################### GUI ################################# if(!$Step) { $ar = array( ‘TITLE’ => getMsg(«TITLE0«), ‘TEXT’ => ($strErrMsg ? ‘<div style=»color:red;padding:10px;border:1px solid red»>’.$strErrMsg.‘</div>’ : »). getMsg(‘BEGIN’), ‘BOTTOM’ => (defined(‘VMBITRIX’) ? ‘<a href=»/?lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘ : »). ‘<input type=»button» value=»‘.getMsg(«BUT_TEXT1«).‘» onClick=»reloadPage(1)»>’ ); html($ar); } elseif($Step == 1) { $arc_down_url = $_REQUEST[‘arc_down_url’] ? $_REQUEST[‘arc_down_url’] : »; $local_arc_name = htmlspecialcharsbx(ltrim($_REQUEST[‘local_arc_name’],‘/’)); if ($_REQUEST[‘bitrixcloud_backup’]) { @include($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/license_key.php’); $license_key = $LICENSE_KEY; } $option = getArcList(); $ar = array( ‘TITLE’ => getMsg(«TITLE1«), ‘TEXT’ => $local_arc_name ? ‘<div class=t_div><input type=hidden name=arc_name value=»‘.$local_arc_name.‘»> ‘.getMsg(«ARC_LOCAL_NAME«).‘ <b>’.$local_arc_name.‘</div>’ : ($strErrMsg ? ‘<div style=»color:red»>’.$strErrMsg.‘</div>’ : »). ‘<input type=»hidden» name=»Step» value=»2″>’. ‘<div class=t_div> <label><input type=radio name=x_source onclick=»div_show(0)» ‘.($_REQUEST[‘bitrixcloud_backup’] ? ‘checked’ : »).‘>’.getMsg(«ARC_DOWN_BITRIXCLOUD«).‘</label> <div id=div0 class=»div-tool» style=»display:none»> <nobr>’.getMsg(«LICENSE_KEY«).‘</nobr> <input name=license_key type=»text» id=license_key size=30 value=»‘.htmlspecialcharsbx($license_key).‘»> <input type=»button» value=» OK » onclick=»LoadFileList()»><br> <div id=file_list></div> </div> </div> <div class=t_div> <label><input type=radio name=x_source onclick=»div_show(1)» ‘.($_REQUEST[‘arc_down_url’] ? ‘checked’ : »).‘>’.getMsg(«ARC_DOWN«).‘</label> <div id=div1 class=»div-tool» style=»display:none»><nobr>’.getMsg(«ARC_DOWN_URL«).‘</nobr> <input name=arc_down_url type=»text» size=40 value=»‘.htmlspecialcharsbx($arc_down_url).‘»></div> </div> <div class=t_div> <label><input type=radio name=x_source onclick=»div_show(2)»>’. getMsg(«ARC_LOCAL«).‘</label> <div id=div2 class=»div-tool» style=»display:none»><span style=»color:#666″>’.getMsg(«ARC_LOCAL_WARN«).‘</span><br/><input type=file name=»archive[]» size=40 multiple onchange=»addFileField()»></div> </div> .(strlen($option) ? ‘<div class=t_div> <label><input type=radio name=x_source onclick=»div_show(3)»>’.getMsg(«ARC_NAME«).‘</label> <div id=div3 class=»div-tool» style=»display:none»> <select name=»arc_name»>’.$option.‘</select> </div>’. ‘</div>’ : ») .($option === false ? ‘<div style=»color:red»>’.getMsg(‘NO_READ_PERMS’).‘</div>’ : ») .(count(getDumpList()) ? ‘<div class=t_div>’. ‘<label><input type=radio name=x_source onclick=»div_show(4)»>’.getMsg(«ARC_SKIP«).‘</label> <div id=div4 class=»div-tool» style=»display:none;color:#999999″>’.getMsg(‘ARC_SKIP_DESC’).‘</div> </div>’ : ») , ‘BOTTOM’ => ‘<a href=»/restore.php?Step=0&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘. ‘<input type=»button» id=»start_button» value=»‘.getMsg(«BUT_TEXT1«).‘» onClick=»reloadPage(2)» ‘.($local_arc_name ? » : ‘disabled’).‘>’ ); html($ar); } elseif($Step == 2) { if(!$bSelectDumpStep && !$bClearUnusedStep && !$bCloudDownloadStep) { $tar = new CTarRestore; $tar->path = $_SERVER[‘DOCUMENT_ROOT’]; $tar->ReadBlockCurrent = intval($_REQUEST[‘ReadBlockCurrent’]); $tar->EncryptKey = $_REQUEST[‘EncryptKey’]; $bottom = ‘<a href=»/restore.php?Step=1&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘; if ($rs = $tar->openRead($file1 = $file = $_SERVER[‘DOCUMENT_ROOT’].‘/’.$arc_name)) { $DataSize = intval($_REQUEST[‘DataSize’]); $skip = »; if(!$DataSize) // first step { bx_unlink(RESTORE_FILE_LIST); DeleteDirRec(RESTORE_FILE_DIR); $Block = $tar->Block; if (!$ArchiveSize = $tar->getDataSize($file)) $ArchiveSize = filesize($file) * 2; // for standard gzip files $DataSize = $ArchiveSize; while(file_exists($file1 = $tar->getNextName($file1))) $DataSize += $ArchiveSize; $r = true; SetCurrentProgress(0); if ($n = CTar::getLastNum($file)) { for($i=1;$i<=$n;$i++) { if (!file_exists($file.‘.’.$i)) { $strErrMsg = getMsg(‘ERR_NO_PARTS’).‘ <b>’.($n + 1).‘</b>’; $r = false; break; } } } } else { $Block = intval($_REQUEST[‘Block’]); $skip = ‘ <input type=button value=»‘.getMsg(‘SKIP’).‘» onClick=»document.forms.restore.skip.value=1;reloadPage(2)»>’; if ($r = $tar->SkipTo($Block)) { if ($_REQUEST[‘skip’]) { while($tar->readHeader() === false); $tar->SkipFile(); } while(($r = $tar->extractFile()) && haveTime()); } $strErrMsg = implode(‘<br>’,$tar->err); } if ($r === 0) // Finish $bClearUnusedStep = true; else { SetCurrentProgress(($tar->BlockHeader + $tar->ReadBlockCurrent) * 512,$DataSize, $red=false); $hidden = ‘<input type=»hidden» name=»Block» value=»‘.$tar->BlockHeader.‘»>’. ‘<input type=»hidden» name=»ReadBlockCurrent» value=»‘.$tar->ReadBlockCurrent.‘»>’. ‘<input type=»hidden» name=»EncryptKey» value=»‘.htmlspecialcharsbx($tar->EncryptKey).‘»>’. ‘<input type=»hidden» name=»DataSize» value=»‘.$DataSize.‘»>’. ‘<input type=»hidden» name=»arc_name» value=»‘.htmlspecialcharsbx($arc_name).‘»>’; if($r === false) // Error { showMsg(getMsg(«ERR_EXTRACT«), $status.$hidden.‘<div style=»color:red»>’.$strErrMsg.‘</div>’, $bottom.$skip); die(); } else { showMsg(getMsg(‘TITLE_PROCESS1’),$status.$hidden,$bottom); ?><script>reloadPage(2, 1);</script><? die(); } } $tar->close(); } elseif ($tar->LastErrCode == ‘ENC_KEY’) { $text = ($tar->EncryptKey ? ‘<div style=»color:red»>’.getMsg(‘WRONG_PASS’).‘</div>’ : »). getMsg(‘FILE_IS_ENC’). ‘<input type=»password» size=30 name=»EncryptKey» autocomplete=»off»>’. ‘<input type=»hidden» name=»arc_name» value=»‘.htmlspecialcharsbx($arc_name).‘»>’. ‘<input type=»hidden» name=»Step» value=»2″>’; $bottom .= ‘ <input type=»button» id=»start_button» value=»‘.getMsg(«BUT_TEXT1«).‘» onClick=»reloadPage(2)»>’; showMsg(getMsg(‘TITLE_PROCESS1’),$text,$bottom); die(); } else { showMsg(getMsg(«ERR_EXTRACT«), getMsg(‘TAR_ERR_FILE_OPEN’).‘ ‘.implode(‘<br>’,$tar->err),$bottom); die(); } } if ($bClearUnusedStep) { if (file_exists(RESTORE_FILE_LIST) && $f = fopen(RESTORE_FILE_LIST, ‘rb’)) { $modules = $_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/modules’; $components = $_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/components/bitrix’; fgets($f); // «die» line $a = array(); while(false !== $l = fgets($f)) $a[trim($l)] = 1; fclose($f); $ds = new CDirRealScan; $ds->startPath = $_REQUEST[‘nextPath’]; if (strpos($_REQUEST[‘nextPath’], $components) === 0) $init_path = $components; else $init_path = $modules; $res = $ds->Scan($init_path); if ($res === true && $init_path == $modules) { $ds->nextPath = $components; $res = ‘BREAK’; } if ($res === ‘BREAK’) { $status = getMsg(«SEARCHING_UNUSED«); $hidden = ‘<input type=»hidden» name=»nextPath» value=»‘.$ds->nextPath.‘»>’. ‘<input type=»hidden» name=»clear» value=»1″>’.GetHidden(array(‘dump_name’, ‘arc_name’)); $bottom = ‘<a href=»javascript:reloadPage(1)»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘; showMsg(getMsg(‘TITLE_PROCESS1’),$status.$hidden,$bottom); ?><script>reloadPage(2, 1);</script><? die(); } bx_unlink(RESTORE_FILE_LIST); } if (file_exists(RESTORE_FILE_DIR)) $strWarning.= ‘<li>’.getMsg(‘WARN_CLEARED’); if (file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/backup/sites’)) $strWarning.= ‘<li>’.getMsg(‘WARN_SITES’); $bSelectDumpStep = true; } if ($strWarning) { $status = ‘<div style=»color:red;text-align:center»><b>’.getMsg(‘WARNING’).‘</b></div> <ul style=»color:red»>’.$strWarning.‘</ul>’; $hidden = ‘<input type=»hidden» name=»source» value=»dump»>’.GetHidden(array(‘dump_name’, ‘arc_name’)); $bottom = ‘<a href=»javascript:reloadPage(1)»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘. ‘<input type=»button» value=»‘.getMsg(«BUT_TEXT1«).‘» onClick=»reloadPage(2)»>’; showMsg(getMsg(‘TITLE_PROCESS1’),$status.$hidden,$bottom); die(); } if (file_exists(RESTORE_CLOUD_FILE_LIST)) { $skip = $_REQUEST[‘skip’]; if ($skip) { } elseif ($rsFile = fopen(RESTORE_CLOUD_FILE_LIST, ‘rb’)) { if ($start_position = intval($_REQUEST[‘position’])) fseek($rsFile, $start_position); if (is_array($_REQUEST[‘mirror_list’]) && time() — intval($_REQUEST[‘init_time’]) < 600) // раз в 10 минут снова измеряем зеркала { $mirror_list = $_REQUEST[‘mirror_list’]; arsort($mirror_list); // выбираем самое быстрое зеркало } else { $mirror_list = [ ‘cdn.bitrix24.ru’ => 999999, ‘cdn.bitrix24.com’ => 999999, ‘cdn.bitrix24.de’ => 999999, ‘cdn-ru.bitrix24.ru’ => 999999, ‘cdn-ru.bitrix24.de’ => 999999, ]; $_REQUEST[‘init_time’] = $init_time = time(); } $mirror = key($mirror_list); if (DEBUG) { echo time() — intval($_REQUEST[‘init_time’]); echo ‘<pre>’;print_r($mirror_list);echo ‘</pre>’; } $file_list = []; if (is_array($_REQUEST[‘file_list’])) { foreach($_REQUEST[‘file_list’] as $file => $str) { if (!$f = unserialize($str)) { $strErrMsg = ‘Unserialize failure: ‘.$str; break; } $file_list[$file] = $f; $url = ‘https://’.$mirror.‘/’.$f[‘path’]; CMultiGet::startLoad($url, $file); } } $concurrency = 20; $num = 0; while(!$strErrMsg) { while (haveTime() && count(CMultiGet::$connections) < $concurrency && (false !== $line = fgets($rsFile))) { $num++; if (strpos($line, ‘<‘.‘?php’) === 0) continue; if (!preg_match(‘#^(d{4}-d{2}-d{2} [d:]{8})[ t]+(d+)[ t]+(.+)$#’, trim($line), $regs)) { $strErrMsg = ‘File parse error ‘.RESTORE_CLOUD_FILE_LIST.‘ for line ‘.$num.‘: ‘.$line; break; } $date = $regs[1]; $size = $regs[2]; $path = str_replace(‘ ‘, ‘%20’, $regs[3]); $save_path = preg_replace(‘#^[^/]+/#’, », $regs[3]); if (preg_match(‘#^[^/]*(cache/|tmp/|test.txt)#’, $save_path)) continue; $url = ‘https://’.$mirror.‘/’.$path; $file = $_SERVER[‘DOCUMENT_ROOT’].‘/upload/’.$save_path; if (file_exists($file)) { if (filesize($file) == $size) continue; if (filesize($file) > $size) bx_unlink($file); } if (!CMultiGet::startLoad($url, $file)) { $strErrMsg = nl2br(htmlspecialcharsbx(CMultiGet::$error)); break; } $file_list[$file] = [ ‘date’ => $date, ‘size’ => $size, ‘path’ => $path, ]; } if (!CMultiGet::getPart()) { debug(CMultiGet::$error); $connection = CMultiGet::$connections[CMultiGet::$current]; $url = $connection[‘url’]; CMultiGet::dropConnection(CMultiGet::$current); foreach($mirror_list as $mirror => $speed) { if (strpos($url, ‘https://’.$mirror) === 0) { unset($mirror_list[$mirror]); CMultiGet::$bytes = 0; $START_TIME = microtime(1); break; } } if (count($mirror_list)) { $mirror = key($mirror_list); continue; } $strErrMsg = nl2br(htmlspecialcharsbx(CMultiGet::$error)); } if (!haveTime()) break; } if (!$strErrMsg && (!feof($rsFile) || count(CMultiGet::$connections))) { $position = ftell($rsFile); $size = filesize(RESTORE_CLOUD_FILE_LIST); SetCurrentProgress($position, $size); if (strlen($file) > 80) $file = ‘…’.substr($file, —80); $text = getMsg(‘ARC_DOWN_PROCESS’).‘ <b>’.htmlspecialcharsbx($file).‘</b>’. $status. GetHidden(array(‘source’, ‘dump_name’, ‘arc_name’, ‘init_time’)). <input type=»hidden» name=»cloud_download» value=»Y»> <input type=»hidden» name=»position» value=»‘.$position.‘»>’; foreach($file_list as $file => $f) { if (!file_exists($file) || filesize($file) < $f[‘size’]) $text .= ‘<input type=»hidden» name=»file_list[‘.htmlspecialcharsbx($file).‘]» value=»‘.htmlspecialcharsbx(serialize($f)).‘»>’; } $mirror_list[$mirror] = round(CMultiGet::$bytes * 8/1024/1024/STEP_TIME, 2); // Mbit/s foreach($mirror_list as $mirror => $speed) { $text .= ‘<input type=»hidden» name=»mirror_list[‘.htmlspecialcharsbx($mirror).‘]» value=»‘.$speed.‘»>’; } $bottom = ‘<a href=»javascript:reloadPage(1)»>’.getMsg(‘BUT_TEXT_BACK’).‘</a>’. ‘ <input type=button value=»‘.getMsg(‘SKIP’).‘» onClick=»document.forms.restore.skip.value=1;reloadPage(2)»>’; showMsg(getMsg(‘TITLE3’),$text,$bottom); ?><script>reloadPage(2, 1);</script><? die(); } fclose($rsFile); } else $strErrMsg = getMsg(«LOADER_LOAD_CANT_OPEN_READ«, [«#FILE#» => RESTORE_CLOUD_FILE_LIST]); if (!$strErrMsg) { bx_unlink(RESTORE_CLOUD_FILE_LIST) || $strErrMsg = getMsg(‘FINISH_ERR_DELL_TITLE’).‘: ‘.RESTORE_CLOUD_FILE_LIST; $bSelectDumpStep = true; } if ($strErrMsg) { $ar = array( ‘TITLE’ => getMsg(«TITLE3«), ‘TEXT’ => ‘<div style=»color:red»>’.$strErrMsg.‘</div>’, ‘BOTTOM’ => ‘<input type=»hidden» name=»cloud_download» value=»Y»>’. GetHidden(array(‘source’, ‘dump_name’, ‘arc_name’)). ‘<a href=»javascript:reloadPage(1)»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘. ‘<input type=»button» value=»‘.getMsg(«DUMP_RETRY«).‘» onClick=»reloadPage(2)»> ‘ ); html($ar); ?><script>reloadPage(2, 300);</script><? die(); } } if ($bSelectDumpStep) { if (file_exists($dbconn) && $strFile = file_get_contents($dbconn)) { $bUTF_conf = preg_match(‘#^[ t]*define(.BX_UTF.+true)#mi’, $strFile); if ($bUTF_conf && !$bUTF_serv) $strErrMsg = getMsg(‘UTF8_ERROR1’).‘<br><br>’.$strErrMsg; elseif (!$bUTF_conf && $bUTF_serv) $strErrMsg = getMsg(‘UTF8_ERROR2’).‘<br><br>’.$strErrMsg; } if ($strErrMsg) { $ar = array( ‘TITLE’ => getMsg(«TITLE2«), ‘TEXT’ => ‘<div style=»color:red»>’.$strErrMsg.‘</div>’, ‘BOTTOM’ => ‘<input type=»hidden» name=»source» value=»dump»>’.GetHidden(array(‘dump_name’, ‘arc_name’)). ‘<a href=»javascript:reloadPage(1)»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘. ‘<input type=»button» value=»‘.getMsg(«DUMP_RETRY«).‘» onClick=»reloadPage(2)»> ‘ ); html($ar); } else { if (!$_REQUEST[‘DBName’]) { $DBName = »; if (file_exists($dbconn) && $str = file_get_contents($dbconn)) { $ar = explode(«n», $str); foreach($ar as $l) if (preg_match(‘#^[ t]*$(DBHost|DBLogin|DBPassword|DBName)[ t]*=[ t]*[«‘]([^»‘]+)[«‘]#’, $l)) eval($l); } if ($DBName && !preg_match(‘#^*+$#’, $DBName)) { $strWarning .= ‘<li>’.getMsg(‘DBCONN_WARN’); $create_db = false; } else { $DBHost = ‘localhost’.(file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/../BitrixEnv.exe’) ? ‘:31006’ : »); $DBLogin = ‘root’; $DBPassword = »; $DBName = ‘bitrix_’.(rand(11,99)); $create_db = «Y«; } } else { $DBHost = $_REQUESTDBHost«]; $DBLogin = $_REQUESTDBLogin«]; $DBPassword = $_REQUESTDBPassword«]; $DBName = $_REQUESTDBName«]; $create_db = $_REQUESTcreate_db«] == «Y«; } $arDName = getDumpList(); $strDName = »; foreach($arDName as $db) $strDName .= ‘<option value=»‘.htmlspecialcharsbx($db).‘»>’.htmlspecialcharsbx($db).‘</option>’; if(count($arDName)) { $ar = array( ‘TITLE’ => getMsg(«TITLE2«), ‘TEXT’ => ($strWarning ? ‘<div style=»color:red;text-align:center»><b>’.getMsg(‘WARNING’).‘</b></div> <ul style=»color:red»>’.$strWarning.‘</ul>’ : »). ‘<input type=»hidden» name=»arc_name» value=»‘.htmlspecialcharsbx($arc_name).‘»>’. (count($arDName)>1 ? getMsg(«DB_SELECT«).‘ <select name=»dump_name»>’.$strDName.‘</select>’ : ‘<input type=hidden name=dump_name value=»‘.htmlspecialcharsbx($arDName[0]).‘»>’). ‘<div style=»border:1px solid #aeb8d7;padding:5px;margin-top:4px;margin-bottom:4px;»> <div style=»text-align:center;color:#aeb8d7;margin:4px»><b>’.getMsg(«DB_SETTINGS«).‘</b></div> <table width=100% cellspacing=0 cellpadding=2 border=0 class=»content-table»> <tr><td align=right>’. getMsg(«BASE_HOST«).‘:</td><td><input autocomplete=off type=»text» name=»DBHost» value=»‘.htmlspecialcharsbx($DBHost).‘»></td></tr> <tr><td align=right>’. getMsg(«USER_NAME«).‘:</td><td><input autocomplete=off type=»text» name=»DBLogin» value=»‘.htmlspecialcharsbx($DBLogin).‘»></td></tr> <tr><td align=right>’. getMsg(«USER_PASS«).‘:</td><td><input type=»password» autocomplete=off name=»DBPassword» value=»‘.htmlspecialcharsbx($DBPassword).‘»></td></tr> <tr><td align=right>’. getMsg(«BASE_NAME«).‘:</td><td><input autocomplete=off type=»text» name=»DBName» value=»‘.htmlspecialcharsbx($DBName).‘»></td></tr> <tr><td align=right>’. getMsg(«BASE_CREATE_DB«).‘</td><td><input type=»checkbox» name=»create_db» value=»Y» ‘.($create_db ? ‘checked’ : »).‘></td></tr> </table> </div>’. ( file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/backup/clouds’) ? ‘<div>’.getMsg(«BASE_CLOUDS«). <select name=»LocalCloud»> <option value=»Y»>’.getMsg(«BASE_CLOUDS_Y«).‘</option> <option value=»»>’.getMsg(«BASE_CLOUDS_N«).‘</option> </select> </div>’ : » ) , ‘BOTTOM’ => ‘<a style=»padding: 0 13px;» href=»/restore.php?Step=1&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘. ‘<input type=»button» style=»padding: 0 13px;» value=»‘.getMsg(«DB_SKIP«).‘» onClick=»reloadPage(4)»> ‘. ‘<input type=»button» style=»padding: 0 13px;» value=»‘.getMsg(«BASE_RESTORE«).‘» onClick=»reloadPage(3)»>’ ); html($ar); } else showMsg(getMsg(‘FINISH’),GetHidden(array(‘dump_name’, ‘arc_name’)).‘<script>reloadPage(4);</script>’); } } } elseif($Step == 3) { $d_pos = (double) $_REQUESTd_pos«]; if ($d_pos < 0) $d_pos = 0; if (!isset($_REQUEST[‘d_pos’])) // start { if(!file_exists($dbconn)) { if (!is_dir($dir = dirname($dbconn))) mkdir($dir, 0777, true); file_put_contents($dbconn, ‘<?’.»n». ‘define(«DBPersistent», false);’.»n». ‘$DBType = «mysql»;’.»n». ‘$DBHost = «»;’.»n». ‘$DBLogin = «»;’.»n». ‘$DBPassword = «»;’.»n». ‘$DBName = «»;’.»n». «n». ‘$DBDebug = false;’.»n». ‘$DBDebugToFile = false;’.»n». ‘?>’); } if (file_exists($tmp = str_replace(‘dbconn.php’,‘dbconn.restore.php’,$dbconn))) { bx_unlink($dbconn); rename($tmp, $dbconn); } $arFile = file($dbconn); foreach($arFile as $line) { $line = str_replace(«rn», «n», $line); if (preg_match(‘#^[ t]*$(DBHost|DBLogin|DBPassword|DBName)#’,$line,$regs)) { $key = $regs[1]; $line = ‘$’.$key.‘ = «‘.str_replace(‘$’,‘$’,addslashes($_REQUEST[$key])).‘»;’.»n»; } $strFile .= $line; } if (defined(‘VMBITRIX’) && !preg_match(‘#^[ t]*define..BX_CRONTAB_SUPPORT#mi’, $strFile)) $strFile = ‘<‘.‘?define(«BX_CRONTAB_SUPPORT», true);?’.‘>’.$strFile; file_put_contents($dbconn, $strFile); if (file_exists($config = $_SERVER[‘DOCUMENT_ROOT’].»/bitrix/.settings.php«)) { ob_start(); $ar = include($config); ob_end_clean(); if (is_array($ar)) { if (is_array($ar[‘connections’][‘value’][‘default’])) { $ar[‘connections’][‘value’][‘default’][‘host’] = $_REQUEST[‘DBHost’]; $ar[‘connections’][‘value’][‘default’][‘database’] = $_REQUEST[‘DBName’]; $ar[‘connections’][‘value’][‘default’][‘login’] = $_REQUEST[‘DBLogin’]; $ar[‘connections’][‘value’][‘default’][‘password’] = $_REQUEST[‘DBPassword’]; $data = var_export($ar, true); file_put_contents($config, «<«.»?phpnreturn «.$data;n»); } } else rename($config, $_SERVER[‘DOCUMENT_ROOT’].»/bitrix/.settings.restore.php«); // workaround for bug #47641 } SetCurrentProgress(0); $r = true; } else $r = $oDB->restore(); $bottom = ‘<a href=»/restore.php?Step=2&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘; if($r && !$oDB->is_end()) { $d_pos = $oDB->getPos(); $oDB->close(); $arc_name = $_REQUESTarc_name«]; $dump_name = preg_replace(‘#.[0-9]+$#’, », $_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/backup/’.$_REQUEST[‘dump_name’]); $dump_size = 0; while(file_exists($dump_name)) { $dump_size += filesize($dump_name); $dump_name = CDBRestore::getNextName($dump_name); } SetCurrentProgress($d_pos, $dump_size); $text = $status . <input type=»hidden» name=»arc_name» value=»‘.htmlspecialcharsbx($arc_name).‘»> <input type=»hidden» name=»dump_name» value=»‘. htmlspecialcharsbx($_REQUESTdump_name«]).‘»> <input type=»hidden» name=»check_site_path» value=»Y»> <input type=»hidden» name=»d_pos» value=»‘.$d_pos.‘»> <input type=»hidden» name=»DBLogin» value=»‘.htmlspecialcharsbx($_REQUESTDBLogin«]).‘»> <input type=»hidden» name=»DBPassword» value=»‘. (strlen($_REQUESTDBPassword«]) > 0 ? htmlspecialcharsbx($_REQUESTDBPassword«]) : «»).‘»> <input type=»hidden» name=»DBName» value=»‘. htmlspecialcharsbx($_REQUESTDBName«]).‘»> <input type=»hidden» name=»DBHost» value=»‘. htmlspecialcharsbx($_REQUESTDBHost«]).‘»> <input type=»hidden» name=»LocalCloud» value=»‘. ($_REQUESTLocalCloud«] ? ‘Y’ : »).‘»> ; showMsg(getMsg(‘TITLE_PROCESS2’),$text,$bottom); ?><script>reloadPage(3, 1);</script><? } else { if($oDB->getError() != «») showMsg(getMsg(«ERR_DUMP_RESTORE«), ‘<div style=»color:red»>’.$oDB->getError().‘</div>’, $bottom); else { if (!$oDB->ft_index) { $oDB->Query(‘UPDATE b_option SET VALUE=»‘.$oDB->escapeString(serialize(array())).‘» WHERE MODULE_ID=»main» AND NAME LIKE «~ft_%»‘); } showMsg(getMsg(‘FINISH’),GetHidden(array(‘DBLogin’,‘DBPassword’,‘DBHost’,‘DBName’,‘dump_name’, ‘arc_name’, ‘check_site_path’)).‘<script>reloadPage(4);</script>’); } } } elseif($Step == 4) { $strWarning .= CheckHtaccessAndWarn(); if ($_REQUEST[‘check_site_path’]) { $oDB = new CDBRestore($_REQUESTDBHost«], $_REQUESTDBName«], $_REQUESTDBLogin«], $_REQUESTDBPassword«], $_REQUESTdump_name«], $d_pos); if ($oDB->Connect()) { if ($rs = $oDB->Query(‘SELECT * FROM b_lang WHERE DOC_ROOT != «‘.$oDB->escapeString($_SERVER[‘DOCUMENT_ROOT’]).‘» AND DOC_ROOT IS NOT NULL AND DOC_ROOT != «»‘)) { if ($oDB->Fetch($rs)) { $oDB->Query(‘UPDATE b_lang SET DOC_ROOT = «» ‘); $strWarning .= ‘<li>’.getMsg(‘DOC_ROOT_WARN’); } } $rs = $oDB->Query(‘SHOW TABLES LIKE «b_bitrixcloud_option»‘); if ($oDB->Fetch($rs)) { $rs = $oDB->Query(‘SELECT * FROM b_bitrixcloud_option WHERE NAME=»cdn_config_active» AND PARAM_VALUE=1’); if ($oDB->Fetch($rs)) { $rs = $oDB->Query(‘SELECT * FROM b_bitrixcloud_option WHERE NAME=»cdn_config_domain»‘); if (($f = $oDB->Fetch($rs)) && $f[‘PARAM_VALUE’] != $_SERVER[‘HTTP_HOST’]) { $oDB->Query(‘UPDATE b_bitrixcloud_option SET PARAM_VALUE=0 WHERE NAME=»cdn_config_active»‘); $oDB->Query(‘UPDATE b_bitrixcloud_option SET PARAM_VALUE=’.(time() + 86400 * 3650).‘ WHERE NAME=»cdn_config_expire_time»‘); $strWarning .= ‘<li>’.getMsg(‘CDN_WARN’); } } } if ($rs = $oDB->Query(‘SELECT * FROM b_module_to_module WHERE FROM_MODULE_ID=»main» AND MESSAGE_ID=»OnPageStart» AND TO_CLASS=»Bitrix\Security\HostRestriction»‘)) { if ($f = $oDB->Fetch($rs)) // host restriction is turned on { $rs0 = $oDB->Query(‘SELECT * FROM b_option WHERE MODULE_ID=»security» AND NAME=»restriction_hosts_hosts»‘); if ($f0 = $oDB->Fetch($rs0)) { if (strpos($f0[‘VALUE’], $_SERVER[‘HTTP_HOST’]) === false) { $oDB->Query(‘DELETE FROM b_module_to_module WHERE ID=’.$f[‘ID’]); $strWarning .= ‘<li>’.getMsg(‘HOSTS_WARN’); } } } } } else $strWarning .= ‘<li>’.$oDB->getError(); } $text = ($strWarning ? ‘<div style=»color:red;padding:10px;text-align:center»><b>’.getMsg(‘WARNING’).‘</b></div> <ul style=»color:red»>’.$strWarning.‘</ul>’ : »). getMsg(«FINISH_MSG«).GetHidden(array(‘dump_name’, ‘arc_name’)); $bottom = ‘<a style=»padding:0 13px;font-size:13px;» href=»/restore.php?Step=2&source=dump&lang=’.LANG.‘»>’.getMsg(‘BUT_TEXT_BACK’).‘</a> ‘. ‘<input type=button style=»padding:0 13px;font-size:13px;» value=»‘.getMsg(‘DELETE_FILES’).‘» onClick=»reloadPage(5)»>’; showMsg(getMsg(«FINISH«), $text, $bottom); } elseif($Step == 5) { $ok = true; $ok = bx_unlink($_SERVER[‘DOCUMENT_ROOT’].‘/bitrixsetup.php’) && $ok; if ($_REQUEST[‘dump_name’]) { $ok = bx_unlink($_SERVERDOCUMENT_ROOT«].»/bitrix/backup/«.$_REQUESTdump_name«]) && $ok; $ok = bx_unlink($_SERVERDOCUMENT_ROOT«].»/bitrix/backup/«.str_replace(‘.sql’,‘_after_connect.sql’,$_REQUESTdump_name«])) && $ok; } if($_REQUEST[‘arc_name’] && strpos($_REQUEST[‘arc_name’],‘bitrix/’) === false) { $ok = bx_unlink($_SERVERDOCUMENT_ROOT«].»/«.$_REQUESTarc_name«]) && $ok; $i = 0; while(file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/’.$_REQUEST[‘arc_name’].‘.’.++$i)) $ok = bx_unlink($_SERVER[‘DOCUMENT_ROOT’].‘/’.$_REQUEST[‘arc_name’].‘.’.$i) && $ok; } foreach(array(‘cache’, ‘stack_cache’, ‘managed_cache’, ‘resize_cache’, ‘tmp’) as $dir) { $ok = DeleteDirRec($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/’.$dir) && $ok; } $ok = bx_unlink($_SERVERDOCUMENT_ROOT«].»/restore.php«) && $ok; if (!$ok) showMsg(getMsg(«FINISH_ERR_DELL_TITLE«), ‘<span style=»color:red»>’.getMsg(«FINISH_ERR_DELL«).‘</span>’); else { showMsg(getMsg(«FINISH«), getMsg(«FINISH_MSG«), ‘<input type=button onclick=»document.location=’/’» value=»‘.getMsg(«FINISH_BTN«).‘»>’); ?><script>window.setTimeout(function(){document.location=«/»;},5000);</script><? } } #################### END ############ class CDBRestore { var $type = «»; var $DBHost =»»; var $DBName = «»; var $DBLogin = «»; var $DBPassword = «»; var $DBdump = «»; var $db_Conn = «»; var $db_Error = «»; var $f_end = false; var $start; var $d_pos; var $_dFile; var $mysqli; public function __construct($DBHost, $DBName, $DBLogin, $DBPassword, $DBdump, $d_pos) { $this->DBHost = $DBHost; $this->DBLogin = $DBLogin; $this->DBPassword = $DBPassword; $this->DBName = $DBName; $this->DBdump = $_SERVERDOCUMENT_ROOT«].»/bitrix/backup/«.$DBdump; $this->d_pos = $d_pos; $this->mysqli = function_exists(‘mysqli_connect’); $this->ft_index = null; } function Query($sql) { if ($this->ft_index === false && preg_match(«#^CREATE TABLE.*FULLTEXT KEY#ms«, $sql)) { $sql = preg_replace(«#[rns]*FULLTEXT KEY[^rn]*[rn]*#m«, «», $sql); $sql = str_replace(«),)«, «))«, $sql); } $rs = $this->mysqli ? mysqli_query($this->db_Conn, $sql) : mysql_query($sql, $this->db_Conn); if ($this->ft_index === null) { if (preg_match(«#^CREATE TABLE.*FULLTEXT KEY#ms«, $sql)) { $this->ft_index = (bool) $rs; return $rs ? $rs : $this->Query($sql); } } if (!$rs) { $this->db_Error = «<font color=#ff0000>MySQL query error!</font><br>«.($this->mysqli ? mysqli_error($this->db_Conn) : mysql_error()).‘<br><br>’.htmlspecialcharsbx($sql); return false; } return $rs; } function Connect() { $this->db_Conn = $this->mysqli ? @mysqli_connect($this->DBHost, $this->DBLogin, $this->DBPassword) : @mysql_connect($this->DBHost, $this->DBLogin, $this->DBPassword); if (!$this->db_Conn) { $this->db_Error = «<font color=#ff0000>MySQL connect error!</font><br>«.($this->mysqli ? mysqli_connect_error() : mysql_error()).‘<br>’; return false; } $this->Query(‘SET FOREIGN_KEY_CHECKS = 0’); $dbExists = $this->mysqli ? @mysqli_select_db($this->db_Conn, $this->DBName) : @mysql_select_db($this->DBName, $this->db_Conn); if(!$dbExists) { if (@$_REQUESTcreate_db«]==»Y«) { if(!@$this->QueryCREATE DATABASE `«.$this->escapeString($this->DBName).»`«)) { $this->db_Error = getMsg(«ERR_CREATE_DB«).‘: ‘.($this->mysqli ? mysqli_error($this->db_Conn) : mysql_error()); return false; } $dbExists = $this->mysqli ? @mysqli_select_db($this->db_Conn, $this->DBName) : @mysql_select_db($this->DBName, $this->db_Conn); } if(!$dbExists) { $this->db_Error = «<font color=#ff0000>Error! mysql«.($this->mysqli ? ‘i’ : »).»_select_db(«.htmlspecialcharsbx($this->DBName).»)</font><br>«.($this->mysqli ? mysqli_error($this->db_Conn) : mysql_error()).»<br>«; return false; } } $this->QuerySET SQL_MODE=»«); $this->QuerySET innodb_strict_mode=0«); $after_file = str_replace(‘.sql’,‘_after_connect.sql’,$this->DBdump); if (file_exists($after_file)) { $arSql = explode(‘;’,file_get_contents($after_file)); foreach($arSql as $sql) { $sql = str_replace(‘<DATABASE>’, $this->DBName, $sql); if (trim($sql)) $this->Query($sql); } } return true; } function Fetch($rs) { return $this->mysqli ? mysqli_fetch_assoc($rs) : mysql_fetch_assoc($rs); } function escapeString($str) { return $this->mysqli ? mysqli_real_escape_string($this->db_Conn, $str) : mysql_real_escape_string($str, $this->db_Conn); } function readSql() { $cache = «»; while(CTar::substr($cache, —2, 1) != «;«) { $line = fgets($this->_dFile); if (feof($this->_dFile) || $line === false) { fclose($this->_dFile); if (file_exists($next_part = self::getNextName($this->DBdump))) { $this->DBdump = $next_part; if (!$this->_dFile = fopen($this->DBdump, ‘rb’)) { $this->db_Error = «Can’t open file: «.$this->DBdump; return false; } } else { $this->f_end = true; break; } } $cache .= $line; } if($this->f_end) return false; return $cache; } function restore() { clearstatcache(); while($this->d_pos > ($s = filesize($this->DBdump)) && file_exists($this->DBdump)) { $this->d_pos -= $s; $this->DBdump = self::getNextName($this->DBdump); } if (!$this->_dFile = fopen($this->DBdump, ‘rb’)) { $this->db_Error = «Can’t open file: «.$this->DBdump; return false; } if($this->d_pos > 0) fseek($this->_dFile, $this->d_pos); while(haveTime() && ($sql = $this->readSql())) { if (defined(‘VMBITRIX’)) { if (preg_match(‘#^CREATE TABLE#i’,$sql)) { $sql = preg_replace(‘#ENGINE=MyISAM#i’,»,$sql); $sql = preg_replace(‘#TYPE=MyISAM#i’,»,$sql); } } $rs = $this->Query($sql); if(!$rs) { if ($this->getErrorNum() != 1062) // Duplicate entry return false; if (preg_match(‘#^(INSERT[^(]+VALUES[^(]+)((.+));?$#mis’, $sql, $regs)) { $insert = $regs[1]; foreach(preg_split(‘#),[^(](#’, $regs[2]) as $values) { $rs = $this->Query($insert.‘(‘.$values.‘)’); if (!$rs && $this->getErrorNum() != 1062) return false; } return true; } } } $this->Query(‘SET FOREIGN_KEY_CHECKS = 1’); if ($this->LocalCloud && $this->f_end) { $i = »; while(file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/upload/’.($name = ‘clouds’.$i))) $i++; if (!file_exists($f = $_SERVER[‘DOCUMENT_ROOT’].‘/upload’)) mkdir($f); if (rename($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/backup/clouds’, $_SERVER[‘DOCUMENT_ROOT’].‘/upload/’.$name)) { $arFiles = scandir($_SERVER[‘DOCUMENT_ROOT’].‘/upload/’.$name); foreach($arFiles as $file) { if ($id = intval($file)) $this->Query(‘UPDATE b_file SET SUBDIR = CONCAT(«‘.$name.‘/’.$id.‘/», SUBDIR), HANDLER_ID=NULL WHERE HANDLER_ID =’.$id); } } } return true; } function getError() { return $this->db_Error; } function getErrorNum() { return $this->mysqli ? mysqli_errno($this->db_Conn) : mysql_errno(); } function getPos() { if (is_resource($this->_dFile)) { $res = ftell($this->_dFile); $prev = preg_replace(‘#.[0-9]+$#’, », $this->DBdump); clearstatcache(); while($this->DBdump != $prev) { if (!file_exists($prev)) return false; $res += filesize($prev); $prev = self::getNextName($prev); } return $res; } } function close() { unset($this->_dFile); return true; } function is_end() { return $this->f_end; } public static function getNextName($file) { static $CACHE; $c = &$CACHE[$file]; if (!$c) { $l = strrpos($file, ‘.’); $num = CTar::substr($file,$l+1); if (is_numeric($num)) $file = CTar::substr($file,0,$l+1).++$num; else $file .= ‘.1’; $c = $file; } return $c; } } function getDumpList() { $arDump = array(); if (is_dir($back_dir = $_SERVERDOCUMENT_ROOT«].»/bitrix/backup«)) { $handle = opendir($back_dir); while (false !== ($file = readdir($handle))) { if($file == «.» || $file == «..«) continue; if(is_dir($back_dir.‘/’.$file)) continue; if (strpos($file,‘_after_connect.sql’)) continue; if(substr($file, strlen($file) — 3, 3) == «sql«) $arDump[] = $file; } } return $arDump; } function getMsg($index, $ar = []) { global $MESS; $str = $MESS[$index]; foreach($ar as $k => $v) $str = str_replace($k, $v, $str); return $str; } function getArcList() { $arc = «»; global $strErrMsg; $handle = @opendir($_SERVERDOCUMENT_ROOT«]); if (!$handle) return false; while (false !== ($file = @readdir($handle))) { if($file == «.» || $file == «..«) continue; if(is_dir($_SERVERDOCUMENT_ROOT«].»/«.$file)) continue; if(preg_match(‘#.(tar|enc)(.gz)?$#’,$file)) $arc .= «<option value=«$file«> «.$file; if(substr($file, strlen($file) — 7, 7) == «tar.tar«) $strErrMsg = getMsg(‘ERR_TAR_TAR’); } return $arc; } function showMsg($title, $msg, $bottom=») { $ar = array( ‘TITLE’ => $title, ‘TEXT’ => $msg, ‘BOTTOM’ => $bottom ); html($ar); } function html($ar) { $isCrm = getenv(‘BITRIX_ENV_TYPE’) == ‘crm’; ?> <html> <head> <title><?=$ar[‘TITLE’]?></title> </head> <body> <style> html, body { padding: 0 10px; margin: 0; background: #2fc6f7; position: relative; } p { margin: 0 0 40px; font-family: «Helvetica Neue», Helvetica, Arial, sans-serif; font-size:13px; } .wrap { min-height: 100vh; position: relative; } .cloud { background-size: contain; position: absolute; z-index: 1; background-repeat: no-repeat; background-position: center; opacity: .8; } .cloud-fill { background-image: url(); } .cloud-border { background-image: url(); } .cloud-1 { top: 9%; left: 50%; width: 60px; height: 38px; } .cloud-2 { top: 14%; left: 12%; width: 80px; height: 51px; } .cloud-3 { top: 11%; right: 14%; width: 106px; height: 67px; } .cloud-4 { top: 33%; right: 13%; width: 80px; height: 51px; } .cloud-5 { bottom: 23%; right: 12%; width: 80px; height: 51px; } .cloud-6 { bottom: 23%; left: 12%; width: 80px; height: 51px; } .cloud-7 { top: 13%; left: 6%; width: 60px; height: 31px; opacity: 1; } .cloud-8 { top: 43%; right: 6%; width: 86px; height: 54px; opacity: 1; } .header { min-height: 220px; max-width: 727px; margin: 0 auto; box-sizing: border-box; position: relative; z-index: 10; } .logo-link, .buslogo-link{ position: absolute; top: 50%; margin-top: -23px; } .logo { width: 255px; display: block; height: 46px; background-repeat: no-repeat; /*background-size:cover;*/ } .wrap.en .logo, .wrap.de .logo { background-image: url(); } .wrap.ru .logo { background-image: url(); } .wrap.ua .logo { background-image: url(); } .buslogo { width: 255px; display: block; height: 46px; background-repeat: no-repeat; /*background-size:cover;*/ } .wrap.en .buslogo, .wrap.de .buslogo { background-image: url(); } .wrap.ru .buslogo { background-image: url(); } .wrap.ua .buslogo { background-image: url(); } .content { z-index: 10; position: relative; margin-bottom: 20px; } .content-container { z-index: 10; max-width: 727px; margin: 0 auto; padding: 28px 25px 25px; border-radius: 11px; box-shadow: 0 4px 20px 0 rgba(6, 54, 70, .15); box-sizing: border-box; text-align: center; background-color: #fff; position: relative; } .content-block { position: relative; z-index: 10; } hr { margin: 79px 0 45px; border: none; height: 1px; background: #f2f2f2; } h1.content-header { color: #2fc6f7; font: 500 40px/45px «Helvetica Neue», Helvetica, Arial, sans-serif; margin-bottom: 13px; margin-top: 62px; } h2.content-header { color: #2fc6f7; font: 400 27px/27px «Helvetica Neue», Helvetica, Arial, sans-serif; margin-bottom: 13px; margin-top: 31px; } h3.content-header { color: #000; font: 400 30px/41px «Helvetica Neue», Helvetica, Arial, sans-serif; margin-bottom: 40px; margin-top: 46px; } .content-logo { width: 100%; height: 57px; background-repeat: no-repeat; background-position: center 0; } .wrap.de .content-logo, .wrap.en .content-logo{ background-image: url(); } .wrap.ru .content-logo { background-image: url(); } .wrap.ua .content-logo { background-image: url(); } .setup-btn, .content-table input[type=«submit»], .content-table input[type=«button»]{ height: 45px; line-height: 45px; color: #fff; background-color: #b5e00f; padding: 0 45px; text-transform: uppercase; text-decoration: none; font-family: «Open Sans», «Helvetica Neue», Helvetica, Arial, sans-serif; vertical-align: middle; border-radius: 25px; transition: all 250ms ease; display: inline-block; font-size: 15px; border: none; cursor: pointer; } .setup-btn:hover { background-color: #9bc40e; } .lnk { color: #2fc6f7; font: 15px/25px «Open Sans», «Helvetica Neue», Helvetica, Arial, sans-serif; border-bottom: 1px solid; text-decoration: none; transition: all 250ms ease; } .lnk:hover { border-bottom-color: transparent; } .progressbar-container { width: 70%; margin: 55px auto; } .progressbar-track { height: 19px; background: #edf2f5; border-radius: 9px; overflow: hidden; position: relative; } .progressbar-loader { position: absolute; left: 0; top: 0; bottom: 0; border-radius: 9px; background-image: url(); background-position: 0 0; background-size: auto 19px; -webkit-animation: progressbar 2s infinite linear; -moz-animation: progressbar 2s infinite linear; -ms-animation: progressbar 2s infinite linear; -o-animation: progressbar 2s infinite linear; animation: progressbar 2s infinite linear; } @-webkit-keyframes progressbar { 0 {background-position: 0 0;} 100% {background-position: 75px 0;} } @-moz-keyframes progressbar { 0 {background-position: 0 0;} 100% {background-position: 75px 0;} } @-ms-keyframes progressbar { 0 {background-position: 0 0;} 100% {background-position: 75px 0;} } @-o-keyframes progressbar { 0 {background-position: 0 0;} 100% {background-position: 75px 0;} } @keyframes progressbar { 0 {background-position: 0 0;} 100% {background-position: 75px 0;} } .progressbar-counter { padding-top: 10px; color: #000; font: 300 28px/29px «Helvetica Neue», Helvetica, Arial, sans-serif; text-align: center; } .lang { vertical-align: middle; text-align: left; box-sizing: border-box; color: #333; font: 12px/22px «Helvetica Neue», Helvetica, Arial, sans-serif; display: block; text-decoration: none; padding: 5px 5px 5px 35px; } .lang:after { background: no-repeat center url(); content: »; display: block; width:16px; height:12px; position: absolute; top: 50%; left: 12px; margin-top: -6px; } .lang.ru:after{ background-position: 0 0;} .lang.en:after{ background-position: 0 -13px;} .lang.ua:after{ background-position: 0 -26px;} .lang.de:after{ background-position: 0 -39px;} /**/ .select-container{ border:2px solid #d5dde0; height: 32px; position: absolute; right: 0; bottom: 0; width:50px; border-radius: 2px; } .select-container > .select-block, .selected-lang { width:100%; display: block; height: 32px; position: relative; cursor: pointer; } .selected-lang:before{ content: »; border:4px solid #fff; border-top:4px solid #7e939b; display: block; position: absolute; right: 8px; top: 15px; } .selected-lang:after{ left:11px; } .select-popup{ display: none; position: absolute; top:100%; z-index:100; min-width:100%; border-radius:2px; padding:5px 0; background-color: #fff; box-shadow: 0 5px 5px rgba(0,0,0,.4); } .select-lang-item{ height: 32px; width:100%; position: relative; padding:0 10px; box-sizing: border-box; transition: 220ms all ease; } .select-lang-item:hover{ background-color: #f3f3f3; } .sub-header{ font-size:21px; font-family: «Helvetica Neue», Helvetica, Arial, sans-serif; text-align: left; margin-bottom: 10px; } .select-version-container{ padding: 10px 20px 20px; text-align: left; font-size:16px; line-height:25px; font-family: «Helvetica Neue», Helvetica, Arial, sans-serif; } .content-table { text-align: left; font-size:16px; font-family: «Helvetica Neue», Helvetica, Arial, sans-serif; width: 100%; } .input-license-container input, .content-table input[type=«text»], .content-table input[type=«password»], .content-table select{ /*width:100%;*/ box-sizing: border-box; border: 2px solid #e0e6e9; border-radius:3px; font-size:15px; padding: 10px; outline: none !important; } .input-license-container{ padding-bottom:40px; } .div-tool { border:1px solid #CCCCCC; padding:10px; margin: 10px; } .t_div { padding:5px; } </style> <script> var frm; function reloadPage(val, delay) { frm = document.forms.restore; frm.Step.value = val; window.setTimeout(function() {frm.submit()}, delay == null ? 0 : delay * 1000); } function addFileField() { var input = document.createElement(‘input’); input.type = ‘file’; input.name = ‘archive[]’; input.size = 40; input.onchange = addFileField; input.multiple = true; var div = document.getElementById(‘div2’); div.appendChild(input); } function div_show(i) { document.getElementById(‘start_button’).disabled = i == 0; for(j=0;j<=4;j++) { if (ob = document.getElementById(‘div’ + j)) ob.style.display = i == j ? ‘block’ : ‘none’; } arSources = [ ‘bitrixcloud’,‘download’,‘upload’,‘local’,‘dump’ ]; document.forms.restore.source.value = arSources[i]; if (i == 2) document.forms.restore.action = ‘/restore.php?lang=<?=LANG?>&Step=2&source=’ + arSources[i]; } function LoadFileList() { xml = new XMLHttpRequest(); // forget IE6 xml.onreadystatechange = function () { if (xml.readyState == 4) { str = xml.responseText; document.getElementById(‘file_list’).innerHTML = str; document.getElementById(‘start_button’).disabled = !/<select/.test(str); } } xml.open(‘POST’, ‘/restore.php’, true); query = ‘LoadFileList=Y&lang=<?=LANG?>&bitrixcloud_backup=<?=htmlspecialcharsbx($_REQUEST[‘bitrixcloud_backup’])?>&license_key=’ + document.getElementById(‘license_key’).value; xml.setRequestHeader(«Content-type», «application/x-www-form-urlencoded»); xml.send(query); } <? if ($_REQUEST[‘arc_down_url’]) { ?> window.onload = div_show(1); <? } elseif ($_REQUEST[‘bitrixcloud_backup’]) { ?> window.onload = function() { div_show(0); LoadFileList(); } <? } ?> </script> <div classwrap <?=LANG?>«> <form namerestore» namerestore» actionrestore.php» enctypemultipart/form-data» methodPOST«> <input typehidden» namelang» value<?=LANG?>«> <input typehidden» namesource«> <input typehidden» nameskip«> <input typehidden» nameStep» value<?=$Step?>«> <header classheader«> <?if ($isCrm):?> <a href=»» target_blank» classlogo-link«><span classlogo <?=LANG?>«></span></a> <?else:?> <a href=»» target_blank» classbuslogo-link«><span classbuslogo <?=LANG?>«></span></a> <?endif?> </header> <section classcontent«> <div classcontent-container«> <table classcontent-table«> <tr> <td valignmiddle«> <table cellpadding=0 cellspacing=0 border=0 width=100%><tr> <td align=left > <h3 classcontent-header» stylemargin: 0;padding: 0;text-align: left;«><?=$ar[‘TITLE’]?></h3> <hr stylemargin: 15px 0;«> </td> <td align=right> <? $arLang = array(); foreach(array(‘en’) as $l) $arLang[] = LANG == $l ? «<span style=’color:grey’>$l</span>» : «<a href=’?lang=$l‘ style=’color:black’>$l</a>«; # echo implode(‘ | ‘,$arLang); ?> </td> </tr></table> </td> </tr> <tr> <td stylepadding:10px;font-size:10pt» valign<?=$ar[‘TEXT_ALIGN’]?$ar[‘TEXT_ALIGN’]:‘top’?>«> <?=$ar[‘TEXT’]?> </td> </tr> <tr> <td stylefont-size:10pt» aligncenter» valignmiddle» height40px«><?=$ar[‘BOTTOM’]?></td> </tr> </table> <div classcontent-block«> <div classselect-container» onclickdocument.getElementById(‘lang-popup’).style.display = document.getElementById(‘lang-popup’).style.display == ‘block’ ? ‘none’ : ‘block’«> <label forss«><span classselected-lang lang <?=LANG?>«></span></label> <div classselect-popup» idlang-popup«> <? foreach(array(‘en’,‘de’,‘ru’) as $l) { ?> <div classselect-lang-item«> <a href?lang=<?=$l?>» classlang <?=$l?>«><?=$l?></a> </div> <? } ?> </div> </div> </div> </div> </section> <div classcloud-layer«> <div classcloud cloud-1 cloud-fill«></div> <div classcloud cloud-2 cloud-border«></div> <div classcloud cloud-3 cloud-border«></div> <div classcloud cloud-4 cloud-border«></div> <div classcloud cloud-5 cloud-border«></div> <div classcloud cloud-6 cloud-border«></div> </div> </form> </div> </body></html> <? } function SetCurrentProgress($cur,$total=0,$red=true) { global $status; if (!$total) { $total=100; $cur=0; } $val = intval($cur/$total*100); if ($val > 100) $val = 99; $status = <div class=»progressbar-container»> <div class=»progressbar-track»> <div class=»progressbar-loader» style=»width:’.$val.‘%»></div> </div> <div class=»progressbar-counter»>’.$val.‘%</div> </div>’; } function LoadFile($strRealUrl, $strFilename, $arHeaders = array(), $customHost = ») { global $proxyaddr, $proxyport, $strUserAgent, $replycode; $ssl = preg_match(‘#^https://#i’, $strRealUrl); $iStartSize = 0; if (file_exists($strFilename.tmp«)) $iStartSize = filesize($strFilename.tmp«); $parsedurl = parse_url($strRealUrl); $strOriginalFile = basename($parsedurl[‘path’]); SetCurrentStatus(getMsg(«LOADER_LOAD_QUERY_DISTR«, [«#DISTR#» => $strOriginalFile])); $sockethandle = false; do { $lasturl = $strRealUrl; $redirection = «»; $parsedurl = parse_url($strRealUrl); $useproxy = (($proxyaddr != «») && ($proxyport != «»)); if (!$useproxy) { $host = $parsedurlhost«]; $port = $parsedurlport«]; $hostname = $host; } else { $host = $proxyaddr; $port = $proxyport; $hostname = $parsedurlhost«]; } if ($customHost) $host = $customHost; SetCurrentStatus(getMsg(«LOADER_LOAD_CONN2HOST«, [«#HOST#» => $host])); $port = $port ? $port : ($ssl ? 443 : 80); $context = stream_context_create( array( ‘ssl’ => array( ‘verify_peer’ => false, ‘allow_self_signed’ => true, ) ) ); $sockethandle = stream_socket_client(($ssl ? ‘ssl://’ : »).$host.‘:’.$port, $error_id, $error_msg, 10, STREAM_CLIENT_CONNECT, $context); if (!$sockethandle) { SetCurrentStatus(getMsg(«LOADER_LOAD_NO_CONN2HOST«, [«#HOST#» => $host]).» [«.$error_id] «.$error_msg); return false; } else { debug(«n======nConnected to «.($ssl ? ‘ssl://’ : »).»$host:$portn»); if (!$parsedurlpath«]) $parsedurlpath«] = «/«; $request = «»; if (!$useproxy) { $request .= «GET «.$parsedurlpath«].($parsedurlquery«] ? ‘?’.$parsedurlquery«] : »).» HTTP/1.0rn»; $request .= «Host: $hostnamern»; } else { $request .= «GET «.$strRealUrl HTTP/1.0rn»; $request .= «Host: $hostnamern»; } if ($strUserAgent != «») $request .= «User-Agent: $strUserAgentrn»; if ($iStartSize > 0) $request .= «Range: bytes=«.$iStartSizern»; foreach($arHeaders as $k => $v) $request .= $k.‘: ‘.$v.»rn»; $request .= «rn»; fwrite($sockethandle, $request); $result = «»; $replyheader = «»; while (($result = fgets($sockethandle, 4096)) && $result!=»rn») $replyheader .= $result; debug(«n======n».$request.»nn».$replyheader); $ar_replyheader = explode(«rn», $replyheader); $replyproto = «»; $replyversion = «»; $replycode = 0; $replymsg = «»; if (preg_match(«#([A-Z]{4})/([0-9.]{3}) ([0-9]{3})#«, $ar_replyheader[0], $regs)) { $replyproto = $regs[1]; $replyversion = $regs[2]; $replycode = IntVal($regs[3]); $replymsg = substr($ar_replyheader[0], strpos($ar_replyheader[0], $replycode) + strlen($replycode) + 1, strlen($ar_replyheader[0]) — strpos($ar_replyheader[0], $replycode) + 1); } if ($replycode!=200 && $replycode!=206 && $replycode!=302 && $replycode!=301) { if ($replycode==403) SetCurrentStatus(getMsg(«LOADER_LOAD_SERVER_ANSWER1«, [«#ANS#» => $replycode«.$replymsg])); else SetCurrentStatus(getMsg(«LOADER_LOAD_SERVER_ANSWER«, [«#ANS#» => $replycode«.$replymsg])); return false; } $strContentRange = «»; $strAcceptRanges = «»; $strLocationUrl = «»; $iNewRealSize = 0; foreach ($ar_replyheader as $i => $headerLine) { if (strpos($headerLine, «Content-Range«) !== false) $strContentRange = trim(substr($headerLine, strpos($headerLine, «:«) + 1, strlen($headerLine) — strpos($headerLine, «:«) + 1)); elseif (strpos($headerLine, «Location«) === 0) $strLocationUrl = trim(substr($headerLine, strpos($headerLine, «:«) + 1, strlen($headerLine) — strpos($headerLine, «:«) + 1)); elseif (strpos($headerLine, «Content-Length«) !== false) $iNewRealSize = IntVal(Trim(substr($headerLine, strpos($headerLine, «:«) + 1, strlen($headerLine) — strpos($headerLine, «:«) + 1))); elseif (strpos($headerLine, «Accept-Ranges«) !== false) $strAcceptRanges = Trim(substr($headerLine, strpos($headerLine, «:«) + 1, strlen($headerLine) — strpos($headerLine, «:«) + 1)); } if (strlen($strLocationUrl)>0) { $redirection = $strLocationUrl; $redirected = true; if (!preg_match(‘#^https?://#’, $redirection)) $strRealUrl = dirname($lasturl).»/«.$redirection; else $strRealUrl = $redirection; $ssl = preg_match(‘#^https://#i’, $strRealUrl); } if (!$strLocationUrl) // нет редиректа, загружаем файл { if (strpos($strRealUrl, $strOriginalFile) === false) { SetCurrentStatus(getMsg(«LOADER_LOAD_CANT_REDIRECT«, [«#URL#» => htmlspecialcharsbx($strRealUrl)])); return false; } SetCurrentStatus(getMsg(«LOADER_LOAD_LOAD_DISTR«, [«#DISTR#» => $strRealUrl])); $fh = fopen($strFilename.tmp«, «ab«); if (!$fh) { SetCurrentStatus(getMsg(«ERROR_CANT_WRITE«, [«#FILE#» => $strFilename.tmp«, ‘#SPACE#’ => freeSpace()])); return false; } $bFinished = True; $downloadsize = (double) $iStartSize; SetCurrentStatus(getMsg(«LOADER_LOAD_LOADING«)); while (!feof($sockethandle)) { if (!haveTime()) { $bFinished = False; break; } $result = fread($sockethandle, 40960); $downloadsize += strlen($result); if ($result==»») break; if (fwrite($fh, $result) === false) { SetCurrentStatus(getMsg(«ERROR_CANT_WRITE«, [«#FILE#» => $strFilename.tmp«, ‘#SPACE#’ => freeSpace()])); return false; } } SetCurrentProgress($downloadsize,$iNewRealSize); fclose($fh); fclose($sockethandle); if ($bFinished) { bx_unlink($strFilename); if (rename($strFilename.tmp«, $strFilename)) { SetCurrentStatus(getMsg(«LOADER_LOAD_FILE_SAVED«, [«#FILE#» => $strFilename, «#SIZE#» => $downloadsize])); return 1; } else { SetCurrentStatus(getMsg(«LOADER_LOAD_ERR_RENAME«, [«#FILE1#» => $strFilename.tmp«, «#FILE2#» => $strFilename])); return false; } } else return 2; } fclose($sockethandle); } } while (true); } function SetCurrentStatus($str) { global $strLog; $strLog .= $str.»n»; } class CTar { var $gzip; var $file; var $err = array(); var $LastErrCode; var $res; var $Block = 0; var $BlockHeader; var $path; var $FileCount = 0; var $DirCount = 0; var $ReadBlockMax = 2000; var $ReadBlockCurrent = 0; var $ReadFileSize = 0; var $header = null; var $ArchiveSizeLimit; const BX_EXTRA = ‘BX0000’; const BX_SIGNATURE = ‘Bitrix Encrypted File’; var $BufferSize; var $Buffer; var $dataSizeCache = array(); var $EncryptKey; var $prefix = »; ############## # READ # { function openRead($file) { if (!isset($this->gzip) && (self::substr($file,-3)==‘.gz’ || self::substr($file,-4)==‘.tgz’)) $this->gzip = true; $this->BufferSize = 51200; if ($this->open($file, ‘r’)) { if (» !== $str = $this->gzip ? gzread($this->res,512) : fread($this->res,512)) { $data = unpack(«a100empty/a90signature/a10version/a56tail/a256enc«, $str); if (trim($data[‘signature’]) != self::BX_SIGNATURE) { if (self::strlen($this->EncryptKey)) $this->Error(‘Invalid encryption signature’,‘ENC_SIGN’); // Probably archive is not encrypted $this->gzip ? gzseek($this->res, 0) : fseek($this->res, 0); $this->EncryptKey = null; return $this->res; } $version = trim($data[‘version’]); if (version_compare($version, ‘1.2’, ‘>’)) return $this->Error(‘Unsupported archive version: ‘.$version, ‘ENC_VER’); $key = $this->getEncryptKey(); $this->BlockHeader = $this->Block = 1; if (!$key || self::substr($str, 0, 256) != self::decrypt($data[‘enc’], $key)) return $this->Error(‘Invalid encryption key’, ‘ENC_KEY’); } } return $this->res; } function readBlock($bIgnoreOpenNextError = false) { if (!$this->Buffer) { $str = $this->gzip ? gzread($this->res, $this->BufferSize) : fread($this->res, $this->BufferSize); if ($str === » && $this->openNext($bIgnoreOpenNextError)) $str = $this->gzip ? gzread($this->res, $this->BufferSize) : fread($this->res, $this->BufferSize); if ($str !== » && $key = $this->getEncryptKey()) $str = self::decrypt($str, $key); $this->Buffer = $str; } $str = »; if ($this->Buffer) { $str = self::substr($this->Buffer, 0, 512); $this->Buffer = self::substr($this->Buffer, 512); $this->Block++; } return $str; } function SkipFile() { if ($this->Skip(ceil(intval($this->header[‘size’])/512))) { $this->header = null; return true; } return false; } function Skip($Block) { if ($Block == 0) return true; $this->Block += $Block; $toSkip = $Block * 512; if (self::strlen($this->Buffer) > $toSkip) { $this->Buffer = self::substr($this->Buffer, $toSkip); return true; } $this->Buffer = »; $NewPos = $this->Block * 512; if ($ArchiveSize = $this->getDataSize($file = self::getFirstName($this->file))) { while($NewPos > $ArchiveSize) { $file = $this->getNextName($file); $NewPos -= $ArchiveSize; } } if ($file != $this->file) { $this->close(); if (!$this->open($file, $this->mode)) return false; } if (0 === ($this->gzip ? gzseek($this->res, $NewPos) : fseek($this->res, $NewPos))) return true; return $this->Error(‘File seek error (file: ‘.$this->file.‘, position: ‘.$NewPos.‘)’); } function SkipTo($Block) { return $this->Skip($Block$this->Block); } function readHeader($Long = false) { $str = »; while(trim($str) == ») { if (!($l = self::strlen($str = $this->readBlock($bIgnoreOpenNextError = true)))) return 0; // finish } if (!$Long) $this->BlockHeader = $this->Block1; if ($l != 512) return $this->Error(‘Wrong block size: ‘.self::strlen($str).‘ (block ‘.$this->Block.‘)’); $data = unpack(«a100filename/a8mode/a8uid/a8gid/a12size/a12mtime/a8checksum/a1type/a100link/a6magic/a2version/a32uname/a32gname/a8devmajor/a8devminor/a155prefix«, $str); $chk = $data[‘devmajor’].$data[‘devminor’]; if (!is_numeric(trim($data[‘checksum’])) || $chk!=» && $chk!=0) return $this->Error(‘Archive is corrupted, wrong block: ‘.($this->Block1).‘, file: ‘.$this->file.‘, md5sum: ‘.md5_file($this->file)); $header[‘filename’] = trim(trim($data[‘prefix’], «x00»).‘/’.trim($data[‘filename’], «x00»),‘/’); $header[‘mode’] = OctDec($data[‘mode’]); $header[‘uid’] = OctDec($data[‘uid’]); $header[‘gid’] = OctDec($data[‘gid’]); $header[‘size’] = OctDec($data[‘size’]); $header[‘mtime’] = OctDec($data[‘mtime’]); $header[‘type’] = trim($data[‘type’], «x00»); // $header[‘link’] = $data[‘link’]; if (self::strpos($header[‘filename’],‘./’) === 0) $header[‘filename’] = self::substr($header[‘filename’], 2); if ($header[‘type’]==‘L’) // Long header { $filename = »; $n = ceil($header[‘size’]/512); for ($i = 0; $i < $n; $i++) $filename .= $this->readBlock(); if (!is_array($header = $this->readHeader($Long = true))) return $this->Error(‘Wrong long header, block: ‘.$this->Block); $header[‘filename’] = self::substr($filename,0,self::strpos($filename,chr(0))); } if (self::strpos($header[‘filename’],‘/’) === 0) // trailing slash $header[‘type’] = 5; // Directory if ($header[‘type’]==‘5’) $header[‘size’] = »; if ($header[‘filename’]==») return $this->Error(‘Filename is empty, wrong block: ‘.($this->Block1)); if (!$this->checkCRC($str, $data)) return $this->Error(‘Checksum error on file: ‘.$header[‘filename’]); $this->header = $header; return $header; } function checkCRC($str, $data) { $checksum = $this->checksum($str); $res = octdec($data[‘checksum’]) == $checksum || $data[‘checksum’]===0 && $checksum==256; return $res; } function extractFile() { if ($this->header === null) { if(($header = $this->readHeader()) === false || $header === 0 || $header === true) { if ($header === true && $this->SkipFile() === false) return false; return $header; } $this->lastPath = $f = $this->path.‘/’.$header[‘filename’]; if ($this->ReadBlockCurrent == 0) { if ($header[‘type’]==5) // dir { if(!file_exists($f) && !self::xmkdir($f)) return $this->ErrorAndSkip(‘Can’t create folder: ‘.$f); //chmod($f, $header[‘mode’]); } else // file { if (!self::xmkdir($dirname = dirname($f))) return $this->ErrorAndSkip(‘Can’t create folder: ‘.$dirname); elseif (($rs = fopen($f, ‘wb’))===false) return $this->ErrorAndSkip(getMsg(‘ERROR_CANT_WRITE’, [‘#FILE#’ => $f, ‘#SPACE#’ => freeSpace()])); } } else return $this->Skip($this->ReadBlockCurrent); } else // файл уже частично распакован, продолжаем на том же хите { $header = $this->header; $this->lastPath = $f = $this->path.‘/’.$header[‘filename’]; } if ($header[‘type’] != 5) // пишем контент в файл { if (!$rs) { if (($rs = fopen($f, ‘ab’))===false) return $this->ErrorAndSkip(getMsg(‘ERROR_CANT_WRITE’, [‘#FILE#’ => $f, ‘#SPACE#’ => freeSpace()])); } $i = 0; $FileBlockCount = ceil($header[‘size’] / 512); while(++$this->ReadBlockCurrent <= $FileBlockCount && ($contents = $this->readBlock())) { if ($this->ReadBlockCurrent == $FileBlockCount && ($chunk = $header[‘size’] % 512)) $contents = self::substr($contents, 0, $chunk); $ret = fwrite($rs, $contents); if ($ret === false || $ret === 0) return $this->Error(getMsg(‘ERROR_CANT_WRITE’, [‘#FILE#’ => $f, ‘#SPACE#’ => freeSpace()])); if ($this->ReadBlockMax && ++$i >= $this->ReadBlockMax) { fclose($rs); return true; // Break } } fclose($rs); if (($s = filesize($f)) != $header[‘size’]) return $this->Error(‘File size is wrong: ‘.$header[‘filename’].‘ (real: ‘.$s.‘ expected: ‘.$header[‘size’].‘)’); //chmod($f, $header[‘mode’]); } if ($this->header[‘type’]==5) $this->DirCount++; else $this->FileCount++; $this->debug_header = $this->header; $this->BlockHeader = $this->Block; $this->ReadBlockCurrent = 0; $this->header = null; return true; } function openNext($bIgnoreOpenNextError) { if (file_exists($file = $this->getNextName())) { $this->close(); return $this->open($file,$this->mode); } elseif (!$bIgnoreOpenNextError) return $this->ErrorFile doesn’t exist: «.$file); return false; } public static function getLastNum($file) { $file = self::getFirstName($file); if (!file_exists($file)) return false; $f = fopen($file, ‘rb’); fseek($f, 12); if (fread($f, 2) == ‘LN’) $res = end(unpack(‘va’,fread($f, 2))); else $res = false; fclose($f); return $res; } # } ############## ############## # BASE # { function open($file, $mode=‘r’) { $this->file = $file; $this->mode = $mode; if (is_dir($file)) return $this->Error(‘File is directory: ‘.$file); if ($this->EncryptKey && !function_exists(‘mcrypt_encrypt’) && !function_exists(‘openssl_encrypt’)) return $this->Error(‘Function mcrypt_encrypt/openssl_encrypt is not available’); if ($mode == ‘r’ && !file_exists($file)) return $this->Error(‘File does not exist: ‘.$file); if ($this->gzip) { if(!function_exists(‘gzopen’)) return $this->Error(‘Function &quot;gzopen&quot; is not available’); else { if ($mode == ‘a’ && !file_exists($file) && !$this->createEmptyGzipExtra($file)) return false; $this->res = gzopen($file,$modeb«); } } else $this->res = fopen($file,$modeb«); return $this->res; } function close() { if ($this->mode == ‘a’) $this->flushBuffer(); if ($this->gzip) { gzclose($this->res); if ($this->mode == ‘a’) { // добавим фактический размер всех несжатых данных в extra поле $f = fopen($this->file, ‘rb+’); fseek($f, 18); fwrite($f, pack(«V«, $this->ArchiveSizeCurrent)); fclose($f); $this->dataSizeCache[$this->file] = $this->ArchiveSizeCurrent; // сохраним номер последней части в первый архив для многотомных архивов if (preg_match(‘#^(.+).([0-9]+)$#’, $this->file, $regs)) { $f = fopen($regs[1], ‘rb+’); fseek($f, 12); fwrite($f, ‘LN’.pack(«v«,$regs[2])); fclose($f); } } } else fclose($this->res); clearstatcache(); } public function getNextName($file = ») { if (!$file) $file = $this->file; static $CACHE; $c = &$CACHE[$file]; if (!$c) { $l = strrpos($file, ‘.’); $num = self::substr($file,$l+1); if (is_numeric($num)) $file = self::substr($file,0,$l+1).++$num; else $file .= ‘.1’; $c = $file; } return $c; } function checksum($s) { $chars = count_chars(self::substr($s,0,148).‘ ‘.self::substr($s,156,356)); $sum = 0; foreach($chars as $ch => $cnt) $sum += $ch*$cnt; return $sum; } public static function substr($s, $a, $b = null) { if (function_exists(‘mb_orig_substr’)) return $b === null ? mb_orig_substr($s, $a) : mb_orig_substr($s, $a, $b); return $b === null ? substr($s, $a) : substr($s, $a, $b); } public static function strlen($s) { if (function_exists(‘mb_orig_strlen’)) return mb_orig_strlen($s); return strlen($s); } public static function strpos($s, $a) { if (function_exists(‘mb_orig_strpos’)) return mb_orig_strpos($s, $a); return strpos($s, $a); } function getDataSize($file) { $size = &$this->dataSizeCache[$file]; if (!$size) { if (!file_exists($file)) $size = false; else { if (preg_match(‘#.gz(.[0-9]+)?$#’,$file)) { $f = fopen($file, «rb«); fseek($f, 16); if (fread($f, 2) == ‘BX’) $size = end(unpack(«V«, fread($f, 4))); else { // $this->Error(‘Wrong GZIP Extra Field’); $size = false; } fclose($f); } else $size = filesize($file); } } return $size; } function Error($str = », $code = ») { if ($code) $this->LastErrCode = $code; $this->err[] = $str; return false; } function ErrorAndSkip($str = », $code = ») { $this->Error($str, $code); $this->SkipFile(); if ($this->readHeader() === 0) $this->BlockHeader = $this->Block; return false; } public static function xmkdir($dir) { if (!file_exists($dir)) { $upper_dir = dirname($dir); if (!file_exists($upper_dir) && !self::xmkdir($upper_dir)) return $this->Error(‘Can’t create folder: ‘.$upper_dir); return mkdir($dir); } return is_dir($dir); } function getEncryptKey() { if (!$this->EncryptKey) return false; static $key; if (!$key) $key = md5($this->EncryptKey); return $key; } function getFileInfo($f) { $f = str_replace(‘’, ‘/’, $f); $path = self::substr($f,self::strlen($this->path) + 1); $ar = array(); if (is_dir($f)) { $ar[‘type’] = 5; $path .= ‘/’; } else $ar[‘type’] = 0; if (!$info = stat($f)) return $this->Error(‘Can’t get file info: ‘.$f); if ($info[‘size’] < 0) return $this->Error(‘File is too large: ‘.$f); $ar[‘mode’] = 0777 & $info[‘mode’]; $ar[‘uid’] = $info[‘uid’]; $ar[‘gid’] = $info[‘gid’]; $ar[‘size’] = $ar[‘type’]==5 ? 0 : $info[‘size’]; $ar[‘mtime’] = $info[‘mtime’]; $ar[‘filename’] = $this->prefix.$path; return $ar; } public static function getCheckword($key) { return md5(‘BITRIXCLOUDSERVICE’.$key); } public static function getFirstName($file) { return preg_replace(‘#.[0-9]+$#’,»,$file); } public static function encrypt($data, $md5_key) { if ($m = self::strlen($data)%8) $data .= str_repeat(«x00», 8$m); if (function_exists(‘openssl_encrypt’)) return openssl_encrypt($data, ‘BF-ECB’, $md5_key, OPENSSL_RAW_DATA | OPENSSL_NO_PADDING); else return mcrypt_encrypt(MCRYPT_BLOWFISH, $md5_key, $data, MCRYPT_MODE_ECB); } public static function decrypt($data, $md5_key) { if (function_exists(‘openssl_encrypt’)) $val = openssl_decrypt($data, ‘BF-ECB’, $md5_key, OPENSSL_RAW_DATA | OPENSSL_NO_PADDING); else $val = mcrypt_decrypt(MCRYPT_BLOWFISH, $md5_key, $data, MCRYPT_MODE_ECB); return $val; } # } ############## } class CTarRestore extends CTar { function readHeader($Long = false) { $header = parent::readHeader($Long); if (!$Long && is_array($header)) { $dr = str_replace(array(‘/’,‘’),»,$_SERVER[‘DOCUMENT_ROOT’]); $f = str_replace(array(‘/’,‘’),»,$this->path.‘/’.$header[‘filename’]); if ($header[‘type’] != 5 && (self::strpos($f, $dr.‘bitrixmodules’) === 0 || self::strpos($f, $dr.‘bitrixcomponentsbitrix’) === 0)) { if (!file_exists(RESTORE_FILE_LIST)) { self::xmkdir($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/tmp’); file_put_contents(RESTORE_FILE_LIST, ‘<‘.‘?php die(); ?’>n»); } file_put_contents(RESTORE_FILE_LIST, addslashes(self::substr(str_replace(‘’,‘/’,$header[‘filename’]), 7)).»n», 8); // strlen(bitrix/) = 7 } if ($f == $dr.‘restore.php’) return true; elseif ($f == $dr.‘.htaccess’) { $header[‘filename’] .= ‘.restore’; $this->header[‘filename’] = $header[‘filename’]; } elseif ($f == $dr.‘bitrixphp_interfacedbconn.php’ && file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/php_interface/dbconn.php’)) $header[‘filename’] = str_replace(‘dbconn.php’,‘dbconn.restore.php’,$header[‘filename’]); elseif (preg_match(‘#[^x00-x7f]#’, $header[‘filename’])) // non ASCII character detected { $this->header[‘filename’] = $header[‘filename’] = $this->DecodeFileName($header[‘filename’]); if ($this->header[‘filename’] === false) return false; } } return $header; } function DecodeFileName($str) { if (!$this->EncCurrent) { if (PHP_EOL == «rn») // win { if (preg_match(‘#.([0-9]+)$#’, setlocale(LC_CTYPE, 0), $regs)) $this->EncCurrent = ‘cp’.$regs[1]; else $this->EncCurrent = ‘cp1251’; } else $this->EncCurrent = ‘utf-8’; if (preg_match(«/[xC0xDF][x80xBF]{1}|[xE0xEF][x80xBF]{2}|[xF0xF7][x80xBF]{3}/«, $str)) // 110xxxxx 10xxxxxx | 1110xxxx 10xxxxxx 10xxxxxx | 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx $this->EncRemote = ‘utf-8’; elseif (preg_match(«/[xC0xFF]/«,$str)) $this->EncRemote = ‘cp1251’; else return $this->Error(getMsg(‘ERR_CANT_DETECT_ENC’).‘ /’.$str); } if ($this->EncCurrent == $this->EncRemote) return $str; if (!function_exists(‘mb_convert_encoding’)) return $this->Error(getMsg(‘ERR_CANT_DECODE’)); return mb_convert_encoding($str, $this->EncCurrent, $this->EncRemote); } } function haveTime() { return microtime(true) — START_EXEC_TIME < STEP_TIME; } function img($name) { if (file_exists($_SERVER[‘DOCUMENT_ROOT’].‘/images/’.$name)) return ‘/images/’.$name; return ‘https://www.1c-bitrix.ru/images/bitrix_setup/’.$name; } function bx_accelerator_reset() { if(function_exists(«accelerator_reset«)) accelerator_reset(); elseif(function_exists(«wincache_refresh_if_changed«)) wincache_refresh_if_changed(); } function DeleteDirRec($path) { if (file_exists($path) && $dir = opendir($path)) { while(($item = readdir($dir)) !== false) { if ($item == ‘.’ || $item == ‘..’) continue; if (is_file($f = $path.‘/’.$item)) { if (!bx_unlink($f)) return false; } else { if (!DeleteDirRec($f)) return false; } } closedir($dir); if (!rmdir($path)) return false; } return true; return true; } function CheckHtaccessAndWarn() { $tmp = $_SERVER[‘DOCUMENT_ROOT’].‘/.htaccess’; $tmp1 = $tmp.‘.restore’; if (!file_exists($tmp1)) return »; if (file_exists($tmp)) { if (trim(file_get_contents($tmp)) == trim(file_get_contents($tmp1))) { bx_unlink($tmp1); return »; } else return ‘<li>’.getMsg(‘HTACCESS_RENAMED_WARN’); } else { if (file_put_contents($tmp, ‘Options -Indexes ErrorDocument 404 /404.php <IfModule mod_php5.c> php_flag allow_call_time_pass_reference 1 php_flag session.use_trans_sid off #php_value display_errors 1 #php_value mbstring.internal_encoding UTF-8 </IfModule> <IfModule mod_rewrite.c> Options +FollowSymLinks RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-l RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !/bitrix/urlrewrite.php$ RewriteRule ^(.*)$ /bitrix/urlrewrite.php [L] RewriteRule .* — [E=REMOTE_USER:%{HTTP:Authorization}] </IfModule> <IfModule mod_dir.c> DirectoryIndex index.php index.html </IfModule> <IfModule mod_expires.c> ExpiresActive on ExpiresByType image/jpeg «access plus 3 day» ExpiresByType image/gif «access plus 3 day» </IfModule>’)) return ‘<li>’.getMsg(‘HTACCESS_WARN’); else return ‘<li>’.getMsg(‘HTACCESS_ERR_WARN’); } } function GetHidden($ar) { $str = »; foreach($ar as $k) { if (is_array($_REQUEST[$k])) { foreach($_REQUEST[$k] as $k0 => $v) $str .= ‘<input type=hidden name=»‘.$k.‘[‘.htmlspecialcharsbx($k0).‘]» value=»‘.htmlspecialcharsbx($_REQUEST[$k][$k0]).‘»>’; } else $str .= ‘<input type=hidden name=»‘.$k.‘» value=»‘.htmlspecialcharsbx($_REQUEST[$k]).‘»>’; } return $str; } class CDirScan { var $DirCount = 0; var $FileCount = 0; var $err= array(); var $bFound = false; var $nextPath = »; var $startPath = »; var $arIncludeDir = false; function __construct() { } function ProcessDirBefore($f) { return true; } function ProcessDirAfter($f) { return true; } function ProcessFile($f) { return true; } function Skip($f) { if ($this->startPath) { if (strpos($this->startPath.‘/’, $f.‘/’) === 0) { if ($this->startPath == $f) unset($this->startPath); return false; } else return true; } return false; } function Scan($dir) { $dir = str_replace(‘’,‘/’,$dir); if ($this->Skip($dir)) return; $this->nextPath = $dir; if (is_dir($dir)) { ############################# # DIR ############################# if (!$this->startPath) { $r = $this->ProcessDirBefore($dir); if ($r === false) return false; } if (!($handle = opendir($dir))) { $this->err[] = ‘Error opening dir: ‘.$dir; return false; } while (($item = readdir($handle)) !== false) { if ($item == ‘.’ || $item == ‘..’ || false !== CTar::strpos($item,‘’)) continue; $f = $dir/«.$item; $r = $this->Scan($f); if ($r === false || $r === ‘BREAK’) { closedir($handle); return $r; } } closedir($handle); if (!$this->startPath) { if ($this->ProcessDirAfter($dir) === false) return false; $this->DirCount++; } } else { ############################# # FILE ############################# $r = $this->ProcessFile($dir); if ($r === false) return false; elseif ($r === ‘BREAK’) return $r; $this->FileCount++; } return true; } } class CDirRealScan extends CDirScan { function Scan($dir) { if (!$this->cut) $this->cut = CTar::strlen($_SERVER[‘DOCUMENT_ROOT’].‘/bitrix/’); return parent::Scan($dir); } function ProcessFile($f) { if (!haveTime()) return ‘BREAK’; global $a; if (!$a) return; $k = CTar::substr($f, $this->cut); if (!isset($a[$k])) { $to = RESTORE_FILE_DIR.‘/’.$k; CTar::xmkdir(dirname($to)); rename($f, $to); } return true; } } class CMultiGet { static $error = »; static $free_connections = []; static $connections = []; static $current; static $bytes = 0; static function getConnection($connect_string) { $new_connection = null; foreach(self::$free_connections as $key => $connection) { if ($connection[‘connect_string’] == $connect_string) { if (!self::isAlive($connection[‘socket’])) // сервер закрыл соединение { unset(self::$free_connections[$key]); continue; } $new_connection = self::$free_connections[$key]; unset(self::$free_connections[$key]); break; } } if (!$new_connection) { if ($sock = stream_socket_client($connect_string, $errno, $errstr, 5)) { stream_set_blocking($sock, false); } else { self::$error = ‘Can’t connect to ‘.$connect_string.‘ [‘.$errno.‘] ‘.$errstr; return false; } $new_connection = [ ‘connect_string’ => $connect_string, ‘socket’ => $sock, ‘code’ => 0, ‘length’ => 0, ‘saved_length’ => 0, ‘microtime’ => microtime(1), ]; } return $new_connection; } static function startLoad($url, $file) { $u = parse_url($url); if (!$u[‘port’]) $u[‘port’] = $u[‘scheme’] == ‘https’ ? 443 : 80; $connect_string = ($u[‘scheme’] == ‘https’ ? ‘ssl://’ : ‘tcp://’).$u[‘host’].‘:’.$u[‘port’]; if (!$connection = self::getConnection($connect_string)) return false; $connection[‘state’] = 0; $connection[‘url’] = $url; $connection[‘file’] = $file; $strReq = ‘GET ‘.$u[‘path’].($u[‘query’] ? ‘?’.$u[‘query’] : »).‘ HTTP/1.0’.»rn». ‘Connection: keep-alive’.»rn». ‘Host: ‘.$u[‘host’].»rn»; if (file_exists($file)) $strReq .= ‘Range: bytes=’.filesize($file).‘-‘.»rn»; $strReq .= «rn»; if (!fwrite($connection[‘socket’], $strReq)) { self::$error = ‘Can’t write to ‘.$connect_string; return false; } self::$connections[] = $connection; end(self::$connections); debug(‘Connection #’.key(self::$connections).‘ request’.»n».$strReq); return true; } static function getPart() { if (!count(self::$connections)) return true; $arReadSock = []; foreach(self::$connections as $key => $connection) { if (self::isAlive($connection[‘socket’])) $arReadSock[] = $connection[‘socket’]; } $n = stream_select($arReadSock, $w = null, $e = null, 1); if ($n === 0) return true; foreach($arReadSock as $sock) { $key = null; foreach(self::$connections as $key => $connection) if ($connection[‘socket’] == $sock) break; self::$current = $key; $file = self::$connections[$key][‘file’]; $state =& self::$connections[$key][‘state’]; $header = »; if ($state == 0) // начало загрузки, читаем заголовки { if (false === $line = fgets($sock)) continue; if (!preg_match(‘#^HTTP/1.. ([0-9]+)#’, trim($line), $regs)) { self::$error = ‘Invalid reply header: ‘.trim($line).»n».‘File: ‘.$file; return false; } $header .= $line; $state = $regs[1]; if ($state == 416) // Requested Range Not Satisfiable { // файл загружен, ничего не делаем } elseif (!preg_match(‘#^2d{2}$#’, $state)) { self::$error = ‘Wrong reply code: ‘.trim($line).»n».‘File: ‘.$file; return false; } do { $line = fgets($sock); if (preg_match(‘#Content-length: (d+)#i’, $line, $regs)) { self::$connections[$key][‘length’] = $regs[1]; } $header .= $line; } while ($line != «rn»); debug(‘Connection #’.$key.‘ response’.»n».$header); } if (feof($sock) || $state == 416) { self::freeConnection($key); } else { $str = fread($sock, 1024 * 1024); $dir = dirname($file); if (!file_exists($dir)) mkdir($dir, 0777, true); $bytes = file_put_contents($file, $str, 8); if ($bytes === false) { self::$error = getMsg(‘ERROR_CANT_WRITE’, [‘#FILE#’ => $file, ‘#SPACE#’ => freeSpace()]); return false; } self::$bytes += $bytes; self::$connections[$key][‘saved_length’] += $bytes; if (self::$connections[$key][‘saved_length’] >= self::$connections[$key][‘length’]) { self::freeConnection($key); } } } return true; } static function isAlive($sock) { return is_resource($sock) && get_resource_type($sock) == ‘stream’; } static function freeConnection($key) { $sock = self::$connections[$key][‘socket’]; if (self::isAlive($sock)) { self::$free_connections[] = [ ‘connect_string’ => self::$connections[$key][‘connect_string’], ‘microtime’ => self::$connections[$key][‘microtime’], ‘socket’ => $sock, ]; unset(self::$connections[$key]); } } static function dropConnection($key) { $sock = self::$connections[$key][‘socket’]; if (self::isAlive($sock)) fclose($sock); unset(self::$connections[$key]); } } function bx_unlink($file) { if (!file_exists($file)) return true; if (DEBUG) return rename($file, $file.‘.debug’); return unlink($file); } function debug($str) { if (!DEBUG) return; if (is_array($str)) $str = print_r($str, 1); file_put_contents($_SERVER[‘DOCUMENT_ROOT’].‘/log.txt’, date(‘[Y-m-d H:i:s] ‘).$str.»n», 8); } function freeSpace() { $d = disk_free_space(__FILE__); if ($d === false) return ‘N/A’; return HumanSize($d); } function HumanSize($s) { $i = 0; $ar = array(‘b’,‘kb’,‘Mb’,‘Gb’); while($s > 1024) { $s /= 1024; $i++; } return round($s,2).».$ar[$i]; }

Пытаюсь перенести сайт на 1С-Битрикс на виртуальный сервер VPS, панель управления Vesta. Сделал резервную копию. Кинул её файлы и restore.php (скачал по ссылке из официального урока) в нужную папку виртуального сервера. Права на родительскую папку — 751, на файлы — 644. Владелец — root. Другой сайт с такими же правами функционирует нормально.
Когда захожу из браузера https://***.ru/restore.php , меня вместо страницы приветствует сообщение об ошибке:

Не могу записать файл /home/***/public_html/restore.php. Место на диске: 13.56Gb


  • Вопрос задан

    13 дек. 2022

  • 917 просмотров

Пригласить эксперта

Если у вас хостинг и нет возможности сделать бэкап средствами хостинга, то сделайте бэкап средствами битрикс с пропуском логов и кеша без пароля.
Из папки /bitrix/backup скачайте архив на компьютер, пересоберите архив: распакуйте архив, соберите все части в Тотал Коммандер, например, упакуйте в zip и залейте его в корень сайта, средствами админки Vesta распакуйте zip.
Запустите restore.php, выберите, что архив уже распакован, и там же выберите импортировать БД.
Инструмент бэкапа через restore.php иногда криво работает с файлами.
Найти информацию про распаковку битриксовского архива можно тут
https://qna.habr.com/q/373442


  • Показать ещё
    Загружается…

25 июн. 2023, в 03:19

4500 руб./за проект

25 июн. 2023, в 02:28

10000 руб./за проект

24 июн. 2023, в 23:21

5000 руб./за проект

Минуточку внимания

Зашел в админку сайта и создал резервную копию, скачал ее на комп, тут же скачал restore.php, скофигурировал апач, закинул рестор в папку с сайтом, открыл в браузере localhost/restore.php, выбрал пункт «загрузить с локального диска», указал путь к скаченному бекапу .tar.gz, и получаю ошибку:
Не удалось открыть файл: File is a directory
Менял права на папку, переносил бекап — ничего не помогает.

Как вообще, при указании на на архив, можно получить ошибку, что данный файл — директория ?
Помогите ребят, я уже не знаю, что и делать.

Устранение неполадок при просмотре файлов PDF в Интернете

Устранение распространенных проблем, возникающих при просмотре PDF-файлов с веб-сайта.

Общие признаки, когда невозможно посмотреть PDF-файл в Интернете:

  • Пустая страница в веб-браузере
  • Красный значок X
  • Значок нерабочей ссылки: красный квадрат, синий треугольник или синий круг
  • Ошибка: «Запущенное приложение Adobe Acrobat/Reader не используется для просмотра PDF-файлов в веб-браузере. Требуется приложение Adobe Acrobat/Reader версии 8 или 9. Закройте программу и повторите попытку».

Для устранения некоторых распространенных проблем при отображении PDF-файлов выполните указанные действия в следующем порядке: обновите Reader или Acrobat, устраните неисправности PDF-файла, проверьте настройки браузера, восстановите или переустановите Reader или Acrobat.

Adobe выпускает пакеты бесплатных обновлений безопасности раз в три месяца. Убедитесь в том, что вы обновили свое приложение Reader или Acrobat до последней версии.

Обновления зачастую содержат исправления часто встречающихся проблем. Загрузка последней версии бесплатного пакета обновлений.

  1. Открыть Reader или Acrobat.

  2. Выберите Справка > Проверить наличие обновлений. 

    Acrobat 9 и более ранние версии: при наличии обновления оно загрузится автоматически.

    Acrobat X и XI: нажмите Обновление, а затем Установить.

    Acrobat : перейдите к следующему шагу.

  3. В появившемся диалоговом окне «Средство обновления» нажмите Загрузить.

  4. После завершения загрузки нажмите на значок установки Acrobat. В окне «Средство обновления Acrobat» нажмите Установить.

  5. После установки обновления перезагрузите компьютер и проверьте, открывается ли PDF-файл.

Обновите или перезагрузите страницу

Часто после перезагрузки страницы в браузере PDF-файл полностью загружается.

  • Удерживая кнопку Shift, нажмите в браузере кнопку  Обновить или  Перезагрузить.

Попробуйте открыть другой PDF-файл

Попробуйте открыть другой PDF-файл. Например, попробуйте открыть в своем браузере эту типовую форму. Если эта форма открывается в Acrobat или Reader, возможно, PDF-файл поврежден или неисправен веб-сервер. Если возможно, свяжитесь с лицом или компанией, отвечающей за работу веб-сайта.

Попробуйте открыть PDF-файл со своего жесткого диска

Проверьте, открывается ли PDF-файл в вашем веб-браузере с жесткого диска. Для этого необходимо сохранить PDF-файл на компьютер.

  1. В веб-браузере выполните одно из следующих действий:

    • Mac OS: выберите Файл > Открыть (или Открыть файл).
    • Windows: нажмите Control + O.
  2. Нажмите «Обзор».

  3. (Только в ОС Windows) В меню «Тип файлов» выберите Все файлы.

  4. Найдите в своем компьютере PDF-файл, выберите его и нажмите Открыть.

    Если он открылся, проблема в веб-сайте, на котором вы хотели просмотреть файл. Свяжитесь с лицом или компанией, отвечающей за работу веб-сайта.

Использование другого браузера

Просмотру PDF могут препятствовать определенные условия на компьютере, например настройки безопасности или cookie-файлы браузера. Часто самое быстрое решение – попробовать открыть страницу с помощью другого браузера. Попробуйте любой из следующих неиспользованных браузеров:

 Google Chrome
 Mozilla Firefox
 Microsoft Internet Explorer
 Apple Safari

Список браузеров, совместимых с приложениями Reader и Acrobat, см. в разделе Совместимые веб-браузеры.

Переключитесь в режим совместимости (Internet Explorer)

Некоторые веб-сайты лучше отображаются в режиме совместимости в браузере Internet Explorer. В режиме совместимости страница отображается, как в предыдущей версии браузера.

Подробную информацию о том, как переключиться в данный режим, см. в разделе Устранение проблем отображения с помощью режима совместимости.

Перезагрузите компьютер и попробуйте открыть PDF-файл еще раз

Перезагрузите компьютер и откройте веб-страницу еще раз. Перезагрузка позволяет очистить память и кэш компьютера. Часто проблему отображения файлов можно устранить, просто перезагрузив компьютер.

Удалите временные файлы Интернета (Internet Explorer, Firefox и Chrome)

Очистите кэш браузера (иногда называется временные файлы Интернета), чтобы убедиться, что вы просматриваете свежую версию страницы. 

Будьте внимательны при выборе параметров. Очистите только кэш браузера. Если удалить


все
временные файлы Интернета, можно удалить cookie-файлы с данными входа в систему и предпочтениями. В большинстве браузеров можно выбрать тип удаляемого содержимого.

Диалоговое окно Firefox «Очистить историю» позволяет удалить только кэш браузера.

Чтобы узнать, как очистить кэш браузера, см. следующие статьи: 

Firefox: Удаление истории просмотра страниц, поиска и загрузок

Chrome: Удаление кэша, истории и других данных браузера

Internet Explorer 8-11: Просмотр и удаление истории браузера

Internet Explorer 7: Удалить историю просмотра

Сбросьте установку «Отобразить PDF-файл в браузере» (Acrobat/Reader X и более ранние версии)

Чтобы устранить проблему с просмотром файла, попробуйте сбросить установки отображения в браузере.

  1. В приложении Reader или Acrobat щелкните правой кнопкой мыши в окне документа и выберите Установки отображения страниц.

  2. Из списка слева выберите Интернет.

  3. Отключите параметр Отображать PDF-файлы в браузере и нажмите ОК.

  4. Попробуйте открыть PDF-файл с веб-сайта еще раз.

Просмотрите PDF-файл в 32-разрядной версии Internet Explorer или Safari (только ОС Windows Vista)

Это относится только к пользователям ОС Windows Vista с браузером Internet Explorer 9 или более ранней версии.

В ОС Windows Acrobat и Reader являются 32-разрядными приложениями. При попытке открыть PDF-файл в 64-разрядной версии Internet Explorer, он откроется в приложении Acrobat или Reader, а не в Internet Explorer.

Только Reader 10.1, Acrobat 10.1 и более поздние версии поддерживают Internet Explorer 9.

Чтобы убедиться, что вы пользуетесь 32-разрядной версией Internet Explorer, выполните следующие действия:

  1. В Internet Explorer выберите Справка > Об Internet Explorer. (В некоторых версиях Internet Explorer для этого необходимо выбрать знак вопроса в правом верхнем углу.)

    Если рядом с версией указано «64 -разрядная версия», перейдите к шагу 2.

  2. Чтобы переключиться на 32-разрядную версию Internet Explorer, сначала необходимо закрыть 64-разрядную версию Internet Explorer. Затем дважды щелкните по значку 32-разрядной версии программы:

    C:Program Files (x86)Internet Exploreriexplore.exe

Восстановите приложение Reader или Acrobat

Приложения Reader или Acrobat могут работать некорректно. Восстановление установки — быстрый способ решить проблему.

Восстановление из Reader или Acrobat

Выберите Справка > Восстановить установку.

Восстановление в Панели управления (ОС Windows)

Восстановить установку Acrobat или Reader можно также в Панели управления Windows.

  1. Закройте Reader или Acrobat.

  2. Выберите «Пуск» > «Панель управления».

  3. Выполните следующие шаги в панели управления в зависимости от версии Windows:

    • (Windows 8/7/Vista) Нажмите Программы, а затем Программы и компоненты.
    • (Windows XP) Дважды щелкните по пункту Добавление или удаление программ.
  4. В списке программ выберите Adobe Reader или Adobe Acrobat.

  5. Нажмите «Изменить» и следуйте инструкциям, чтобы восстановить приложение.

  6. По окончании процесса нажмите кнопку Готово.

Если ни одно из вышеприведенных решений не помогло устранить проблему с просмотром PDF-файлов, можно прибегнуть к продвинутым решениям

Включите в браузере надстройку Adobe PDF (Internet Explorer 8 и более поздние версии)

Убедитесь, что в браузере включена надстройка Adobe PDF.

  1. Откройте Internet Explorer и выберите Сервис > Настроить надстройки.

  2. В разделе «Типы надстроек» выберите Панели инструментов и расширения.

  3. В меню «Отображать» выберите Все надстройки.

  4. В списке надстроек выберите Adobe PDF Reader.

    Если вы не видите надстройку Adobe PDF Reader, посмотрите другие пункты меню. Например, в некоторых системах дополнение появляется при выборе параметра «Запуск без получения разрешения».

  5. Нажмите на кнопку Включить.

    Если на кнопке указано «Отключить», значит, надстройка уже включена. Эта кнопка позволяет включать и отключать выбранную надстройку в зависимости от ее состояния.

    Параметр Включить включает надстройку Adobe PDF Reader для просмотра PDF-файлов в браузере.

    Параметр Выключить отключает надстройку, поэтому PDF-файлы в браузере открываться не будут.

Включите надстройку Adobe PDF в браузере (Firefox)

Убедитесь, что в браузере включена надстройка Adobe PDF (nppdf32.dll).

  1. В адресной строке Firefox наберите about:plugins

  2. Переместитесь вниз в раздел «Adobe Acrobat».

  3. Убедитесь в том, что файл называется «nppdf32. dll» и «Надстройка Adobe Acrobat для Netscape».
    Если эта запись недоступна, установите последнюю версию Reader или Acrobat.

Запустите Acrobat или Reader из новой локальной учетной записи администратора.

Создайте учетную запись пользователя с такими же разрешениями, как и в учетной записи, при использовании которой возникают проблемы, или создайте локальную учетную запись администратора. Если при входе в новую учетную запись проблема не возникает, возможно, исходная учетная запись пользователя повреждена.

Чтобы создать учетную запись, см. следующие ресурсы или обратитесь к своему сетевому администратору:

Windows XP:  «Добавление нового пользователя на компьютер»

Windows Vista/7/8: Создание учетной записи пользователя

Mac OS X: Настройка пользователей компьютера Mac

Оптимизируйте крупные PDF-файлы

Если размер PDF-файла превышает 4 МБ, попросите поставщика оптимизировать его. Информацию об оптимизации PDF-файлов см. в разделе Оптимизация PDF-файлов.

Проверьте путь реестра приложения Acrobat или Reader (Windows)

Отказ от ответственности: в реестре содержится важная системная информация, необходимая для работы компьютера и приложений. Перед внесением изменений в реестр необходимо создать его резервную копию. Компания Adobe не оказывает помощь в устранении проблем, связанных с некорректным изменением реестра. Компания Adobe настоятельно рекомендует заниматься изменением реестра только пользователям с опытом редактирования файлов. Для получения подробной информации о реестре см. Документацию Windows или обратитесь в компанию Microsoft.

  1. Откройте Пуск > Выполнить.

  2. Введите regedit и нажмите кнопку ОК.

  3. Найдите раздел HKEY_CLASSES_ROOTSoftwareAdobeAcrobatExe.

  4. Убедитесь в том, что значение (по умолчанию) указывает путь к месту установки приложения Acrobat или Reader.

    • По умолчанию место установки Reader – C:Program Files (x86)AdobeAcrobat Reader ReaderAcroRd32. exe.
    • По умолчанию место установки Acrobat – C:Program Files (x86)AdobeAcrobat AcrobatAcrobat.exe.

    Если приложения Acrobat или Reader установлены в другом месте, убедитесь, что в разделе (по умолчанию) указан путь к фактическому месту установки.

Видеодемонстрацию этой процедуры см. в разделе Проверка пути в реестре.

Если в системе нет вышеуказанного элемента реестра, выполните одно из следующих действий:

  1. Откройте Пуск > Выполнить.

  2. Введите regedit и нажмите кнопку ОК.

  3. Создайте резервную копию текущего файла реестра:

    • В диалоговом окне «Редактор реестра» выберите Файл > Экспорт.
    • Укажите имя файла и выберите его местонахождение.
    • В поле «Диапазон экспорта» выберите Все.
    • Нажмите Сохранить.
  4. Откройте Изменить > Создать > Раздел и создайте отсутствующий раздел HKEY_CLASSES_ROOTSoftwareAdobeAcrobatExe.

  5. Откройте Изменить > Создать > Значение строки и назовите этот раздел (по умолчанию).

  6. Выберите (по умолчанию), а затем перейдите в Изменить > Правка. В поле «Значение» укажите место установки вашего продукта по умолчанию (указано выше).

  7. Перезагрузите компьютер.

Восстановите раздел реестра HKCRAcroExch.Document (Windows)

Возможно, данный раздел поврежден, указывает на устаревшую версию приложения Acrobat или Reader или на средство просмотра PDF-файлов стороннего разработчика.

Отказ от ответственности: в реестре содержится важная системная информация, необходимая для работы компьютера и приложений. Перед внесением изменений в реестр необходимо создать его резервную копию. Компания Adobe не оказывает помощь в устранении проблем, связанных с некорректным изменением реестра. Компания Adobe настоятельно рекомендует заниматься изменением реестра только пользователям с опытом редактирования файлов. Для получения подробной информации о реестре см. Документацию Windows или обратитесь в компанию Microsoft.

  1. Откройте Пуск > Выполнить, наберите regedit в открытом текстовом поле диалогового окна «Выполнить» и нажмите ОК.

  2. Создайте резервную копию текущего файла реестра:

    • В диалоговом окне «Редактор реестра» выберите Файл > Экспорт.
    • Укажите имя файла и выберите его местонахождение.
    • В поле «Диапазон экспорта» выберите Все.
    • Нажмите Сохранить.
  3. Откройте раздел HKEY_CLASSES_ROOT n AcroExch.Document.

  4. Щелкните правой кнопкой мыши по AcroExch.Document и выберите Удалить. Убедитесь, что выбран правильный раздел; при появлении любых подсказок нажмите Да.

  5. Щелкните правой кнопкой мыши по AcroExch.Document.7 и выберите Удалить. Убедитесь, что выбран правильный раздел; при появлении любых подсказок нажмите Да.

  6. Исправьте установку приложений Acrobat или Reader.

    Как это сделать, можно узнать из данного видеоролика.

Если вы являетесь веб-мастером или имеете право администрировать сайт, настройте веб-сервер на отправку заголовков content-type «application/pdf» для PDF-файлов. Подробную информацию см. в документации, прилагаемой к веб-серверу, или в данной справочной статье Microsoft.

Связанные материалы

  • Не удается открыть документ PDF
  • Отображение документа PDF в браузере | Acrobat, Reader
  • Устранение неполадок при печати PDF | Acrobat, Reader
  • Открытие, редактирование или удаление документов PDF

Внутренняя ошибка сервера 500 на сайте: что значит код ошибки и как исправить Internal Server Error

В статье мы расскажем, как исправить ошибку (код состояния) 500 со стороны пользователя и администратора сайта, а также подробно разберём, что такое ошибка запроса 500.

Что такое внутренняя ошибка сервера 500

Код ошибки 5хх говорит о том, что браузер отправил запрос корректно, но сервер не смог его обработать. Что значит ошибка 500? Это проблема сервера, причину которой он не может распознать.

Сообщение об ошибке сопровождается описанием. Самые популярные варианты:

  • Внутренняя ошибка сервера 500,
  • Ошибка 500 Internal Server Error,
  • Временная ошибка (500),
  • Внутренняя ошибка сервера,
  • 500 ошибка сервера,
  • Внутренняя ошибка HTTP 500,
  • Произошла непредвиденная ошибка,
  • Ошибка 500,
  • HTTP status 500 internal server error (перевод ― HTTP статус 500 внутренняя ошибка сервера).

Дизайн и описание ошибки 500 может быть любым, так как каждый владелец сайта может создать свою версию страницы. Например, так выглядит страница с ошибкой на REG.RU:

Как ошибка 500 влияет на SEO-продвижение

Для продвижения сайта в поисковых системах используются поисковые роботы. Они сканируют страницы сайта, проверяя их доступность. Если страница работает корректно, роботы анализируют её содержимое. После этого формируются поисковые запросы, по которым можно найти ресурс в поиске.

Когда поисковый робот сканирует страницу с ошибкой 500, он не изменяет её статус в течение суток. В течение этого времени администратор может исправить ошибку. Если робот перейдёт на страницу и снова столкнётся с ошибкой, он исключит эту страницу из поисковой выдачи.

Проверить, осталась ли страница на прежних позициях, можно с помощью Google Search Console. Если робот исключил страницу из поисковой выдачи, её можно добавить снова.

Код ошибки 500: причины

Если сервер вернул ошибку 500, это могло случиться из-за настроек на web-хостинге или проблем с кодом сайта. Самые распространённые причины:

  • ошибки в файле .htaccess,
  • неподходящая версия PHP,
  • некорректные права на файлы и каталоги,
  • большое количество запущенных процессов,
  • большие скрипты,
  • несовместимые или устаревшие плагины.

Решить проблему с сервером можно только на стороне владельца веб-ресурса. Однако пользователь тоже может выполнить несколько действий, чтобы продолжить работу на сайте.

Что делать, если вы пользователь

Если на определённом ресурсе часто возникает ошибка 500, вы можете связаться с владельцем сайта по инструкции.

Перезагрузите страницу

Удаленный сервер возвращает ошибку не только из-за серьёзных проблем на сервере. Иногда 500 ошибка сервера может быть вызвана небольшими перегрузками сайта.

Чтобы устранить ошибку, перезагрузите страницу с помощью сочетания клавиш:

  • на ПК — F5,
  • на ноутбуке — Fn + F5,
  • на устройствах от Apple — Cmd + R.

Обратите внимание! Если вы приобретаете товары в интернет-магазине и при оформлении заказа появляется 500 Internal Server Error (перевод — внутренняя ошибка сервера), при перезагрузке страницы может создаться несколько заказов. Поэтому сначала проверьте, оформился ли ваш предыдущий заказ. Если нет, попробуйте оформить заказ заново.

Очистите кэш и cookies браузера

Кэш и cookies сохраняют данные посещаемых сайтов и данные аутентификаций, чтобы в будущем загружать веб-ресурсы быстрее. Если на ресурсе уже был статус ошибки 500, при повторном входе на сайт может загружаться старая версия страницы с ошибкой из кэша, хотя на самом деле страница уже работает. Очистить кэш и куки браузера вам поможет инструкция.

Если ни одно из этих действий не решило проблему, значит, некорректно работает сам сервер сайта. Вернитесь на страницу позже, как только владелец решит проблему.

Что делать, если вы владелец сайта

В большинстве случаев устранить проблему может только владелец сайта. Как правило, ошибка связана с проблемами в коде. Реже проблемы могут быть на физическом сервере хостинг-провайдера.

Ниже рассмотрим самые популярные причины и способы решения.

Ошибки в файле .htaccess

Неверные правила в файле .htaccess — частая причина возникновения ошибки. Чтобы это проверить, найдите .htaccess в файлах сайта и переименуйте его (например, в test). Так директивы, прописанные в файле, не повлияют на работу сервера. Если сайт заработал, переименуйте файл обратно в .htaccess и найдите ошибку в директивах. Если вы самостоятельно вносили изменения в .htaccess, закомментируйте новые строки и проверьте доступность сайта.Также может помочь замена текущего файла .htaccess на стандартный в зависимости от CMS.

Найти директиву с ошибкой можно с помощью онлайн-тестировщика. Введите содержимое .htaccess и ссылку на сайт, начиная с https://. Затем нажмите Test:

Произошла непредвиденная ошибка

На экране появится отчёт. Если в .htaccess есть ошибки, они будут выделены красным цветом:

500 ошибка nginx

Активирована устаревшая версия PHP

Устаревшие версии PHP не получают обновления безопасности, работают медленнее и могут вызывать проблемы с плагинами и скриптами. Возможно, для работы вашего веб-ресурса нужна более новая версия PHP. Попробуйте сменить версию PHP на другую по инструкции.

Установлены некорректные права на файлы и каталоги сайта

В большинстве случаев корректными правами для каталогов являются «755», для файлов — «644». Проверьте, правильно ли они установлены, и при необходимости измените права на файлы и папки.

Запущено максимальное количество процессов

На тарифах виртуального хостинга REG.RU установлены ограничения на количество одновременно запущенных процессов. Например, на тарифах линейки «Эконом» установлено ограничение в 18 одновременно запущенных процессов, на тарифах «+Мощность» ― 48 процессов. Если лимит превышен, новый процесс не запускается и возникает системная ошибка 500.

Такое большое число одновременных процессов может складываться из CRON-заданий, частых подключений с помощью почтовых клиентов по протоколу IMAP, подключения по FTP или других процессов.

Чтобы проверить количество процессов, подключитесь по SSH. Выполните команду:

ps aux | grep [u]1234567 |wc -l

Вместо u1234567 укажите ваш логин хостинга: Как узнать логин хостинга.

Чтобы посмотреть, какие процессы запущены, введите команду:

ps aux | grep [u]1234567

Вместо u1234567 укажите логин услуги хостинга.

Командная строка отобразит запущенные процессы:

Код ошибки 500

Где:

  • u1234567 — логин услуги хостинга,
  • 40522 — PID процесса,
  • S — приоритет процесса,
  • /usr/libexec/sftp-server — название процесса.

Процесс можно завершить командой kill, например:

kill 40522

Вместо 40522 укажите PID процесса.

Чтобы решить проблему, вы также можете:

  • увеличить интервал запуска заданий CRON,
  • ограничить количество IMAP-соединений в настройках почтового клиента. Подробнее в статье Ограничение IMAP-соединений,
  • проанализировать запущенные процессы самостоятельно или обратившись за помощью к разработчикам сайта.

Если вам не удалось самостоятельно устранить ошибку 500, обратитесь в техподдержку.

Скрипты работают слишком медленно

На каждом виртуальном хостинге есть ограничения на время выполнения скрипта. Если за установленное время скрипт не успевает выполниться, возникает ошибка сервера 500. Для решения проблемы обратитесь к разработчику сайта и оптимизируйте скрипты. Если оптимизировать нельзя, перейдите на более мощный вид сервера.

У пользователей VPS есть возможность увеличить максимальное использование оперативной памяти на процесс, но лучше делать скрипты меньшего размера.

Ошибка 500 на сайте, созданном на WordPress

WordPress предлагает много плагинов для создания хорошего сайта. Они значительно расширяют возможности CMS. Однако они же могут нарушать работу сайта и вызывать ошибку 500. Вызвать ошибку могут как недавно установленные плагины, так и старые.

Для начала проверьте, нужно ли обновить плагины. Часто устаревшие плагины перестают работать и вызывают проблемы работы сайта. Если все плагины обновлены, но 500 Internal Server Error остаётся, отключите все плагины, чтобы убедиться, что именно они мешают работе сайта. Как только станет понятно, что виноват один из плагинов, отключайте их по очереди, пока не найдёте тот, который нарушает работу сервера.

Как отключить плагин в WordPress

  1. 1.

    Войдите в панель управления WordPress. Если вы пользуетесь услугой REG.Site, войти в панель управления CMS можно прямо из Личного кабинета.

  2. 2.

    Перейдите во вкладку «Плагины» ― «Установленные».

  3. 3.

    Нажмите Деактивировать у плагина, который, как вам кажется, повлиял на работу сайта:

Если все ваши действия не решили проблему или вы не уверены в своих технических знаниях, обратитесь к службе технической поддержки. Сообщите время обнаружения проблемы и опишите все действия, которые вы предприняли перед обращением. Специалисты сделают детальную проверку настроек вашего сайта и при необходимости обратятся к администраторам сервера на стороне хостинг-провайдера.

Помогла ли вам статья?

Да

7
раз уже помогла

Переезд Битрикс24 из облака в коробку – Блог Соль Битрикс24

Итак, настал день Х. Ваш бизнес достаточно окреп, команда растёт, а функционала облачного портала вам маловато. Вы решились на переезд в “коробочную” версию Битрикс24. Процесс вроде бы не уникальный, но вам нужно принять ряд правильных решений, чтобы сохранить надёжность и получить эффективный инструмент развития бизнеса. Эта статья должна помочь вам пройти эту процедуру правильно, а не сделать процесс увлекательно-негативным, с применением граблей и прочего инвентаря.

На какие вопросы вы должны знать ответы, прежде чем ввязываться в эту процедуру:

1. Хостинг, где будет располагаться ваш собственный портал?

2. Кто управляет настройками вашего домена?

3. Какой текущий размер портала и сколько занимает пользовательский контент?

4. Активирован ли лицензионный ключ?

5. Авторизационные данные создателя (сотрудник с ID=1)?


1. Хостинг, где будет располагаться ваш собственный портал?

Самый фундаментальный, пожалуй, это хостинг. Здесь работает правило: чем стабильнее, тем лучше. Битрикс — не самая требовательная в плане производительности платформа. Доступность и возможность выдержать постоянно высокую нагрузку — гораздо важнее. Будете выбирать между дополнительными гигабайтами ОЗУ или вторым диском, выбирайте второй диск. Если это VPS, проверьте, есть ли возможность делать бэкапы из панели управления. На счёт использования своего сервера подумайте дважды. Возможно, экономия станет не столь очевидной, когда посчитаете сколько часов квалифицированного персонала уйдёт на поддержку и мониторинг каналов связи и оборудования. Ведь портал нужен 24 часа в сутки. В среднем, можно ориентироваться на 2 000 р./мес. для обеспечения работы до 20-30 пользователей. За эти деньги вы получите одно выскопроизводительное ядро серверного процессора Intel Xeon E5-2670 v3 2.3 ГГц, 2 ГБ DDR4, 35 ГБ диска с 640/320 IOPS чтение/запись, а также, возможность делать моментальные бэкапы автоматически, хоть каждый час. Если речь идёт о аренде выделенного сервера, то тут ставки уже выше — от 8 000 р./мес. Примерная конфигурация Intel Xeon E3-1230 3.4 ГГц, 32 ГБ DDR4, 2 × 2 ТБ SATA + 2 × 240 ГБ SSD. Конечно, во втором варианте вы получите в своё распоряжение значительно больше ресурсов и их стоимость за единицу будет ниже. Только чтобы воспользоваться всеми плюсами и не сгенерировать минусы, эксплуатировать данное решение нужно соответствующим образом — тут за вас никто не подумает, как оптимизировать производительность и свести к минимуму риски сбоя оборудования. Вот набор обязательных процедур:

отключение функций энергосбережения — к отключению все C-State, ACPI и прочие ECO — чудеса, снижающие производительность минимум в 1,5 раза. Вот список на примере платформы X11SSL-F:

· Boot Performance Mode — Turbo Performance

· CPU C-States — Disabled

· Enhanced C-States — Disabled

· C-State Auto Demotion — Disabled

· C-State Un-Demotion — Disabled

· C-State Pre-Wake — Disabled

· DMI Link ASPM Control — Disabled

· intel EIST — Disabled

· intel speedstep – Disabled

подбор решения для организации RAID-массива — вообще говоря, хорошо бы использовать ZFS, но CentOS, рекомендуемая ОС для Битрикс, пока не научилась поддерживать её нативно, так что выбор прост либо md-raid, либо аппаратное решение от Broadcom (бывший LSI) или Microsemi Adaptec. Настоятельно не рекомендую использовать промежуточные решения вроде HBA адаптеров. Также, обязательно организуйте мониторинг состояния массива.

модель создания и хранения бэкапов — Битрикс-бэкапы, конечно, хорошо, но с ростом объёмов SQL-базы вы можете столкнуться с тремя неприятными вещами: (1) процедура создания завершится по таймауту из-за размера базы, (2) ошибки в структуре базы не позволят Битриксу завершить бэкап, (3) низкая скорость исполнения задания. Задача резервного копирования решается гораздо эффективнее при использовании mysqldump и rsync, причём это позволит вам избежать указанных сложностей. Ко всему прочему, на ваших же плечах останется задача по хранению бэкапов вне сервера и создание плана восстановления в случае аварии.

Если же трудностей вы не боитесь совсем и выбрали размещение портала на своём сервере, то ко всему прочему добавьте ещё и резерв комплектующих на замену вышедшим из строя. Строго говоря, рядом у вас должен стоять такой же сервер в качестве донора. На него, кстати, можно настроить полное реплицирование данных, но это совсем другая история. Про охлаждение и дублирование каналов связи я упоминать не буду, т.к. если вы выбрали вариант со своим сервером в серверной, будем считать, что обо всём этом вы подумали гораздо раньше.

Подводя итог к этому разделу, можно заключить что у вас (или у вашего системного администратора) должно быть сложившееся, цельное представление о том, как будет функционировать ваш портал в его новом доме. А мы рекомендуем VPS-хостинг, например в Selectel

2. Кто управляет настройками вашего домена?

Готово, с хостингом сервера разобрались, пошли дальше. Вам понадобиться логин и пароль от панели управления DNS-записями. Сам DNS-хостинг, скорее всего, находится у одного из этих провайдеров: nic.ru, reg.ru, pdd.yandex.ru, godaddy.com. Например, так выглядит панель управления DNS у pdd.yandex.ru:

Первое, что вам потребуется указать, это новую A-запись с именем портала и значением IP адреса нового сервера, где будет располагаться портал (эту информацию вам предоставит хостер, в случае VPS или выделенного сервера, а в случае своего сервера — системный администратор). Проверить, корректно ли вы установили значение, очень просто: откройте командную строку и напишите там:

ping demo.saltpro.ru

(demo.saltpro.ru, конечно же, замените своим значением). В ответ вы должны получить что-то вроде этого:

Если вы увидите “превышен интервал ожидания”, но при этом в квадратных скобках будет виден присвоенный IP адрес — всё в порядке!

Второе — проверьте настройки SOA домена, в частности, значение TTL. Оно должно быть равным 900 секунд. Это позволит вам оперативно менять значения в домене, без длительного ожидания.

Наконец, третье. Добавьте новую MX запись для портала. Это не очень очевидное решение и, возможно, оно вызовет у вас вопросы, но вам нужно знать две вещи: это не сломает вашу существующую почту и это необходимо для функционирования внутреннего почтового сервиса портала. Рассмотрим на примере. Допустим наш портал, это demo.saltpro.ru Тогда значения хоста — demo, тип записи — MX, значение записи mail-001. bitrix24.com. (точка в конце обязательна). Приоритет можете выбрать любой. Так будет выглядеть финальная запись:

Подробнее почитать можно тут:

https://dev.1c-bitrix.ru/learning/course/index.php?COURSE_ID=71&LESSON_ID=7655&LESSO…

3. Какой текущий размер портала и сколько занимает пользовательский контент?

Отлично, записи добавили. Следующим шагом нам надо понять место, занимаемое порталом. Всё просто. В вашем текущем облачном портале, в меню слева есть пункт “Мой тариф”. Он может быть скрыт и нужно нажать кнопку “Ещё”, чтобы его увидеть. Тут, в разделе “Место в облаке” и увидите размер портала:

Помимо того, что эта информация необходима для расчёта ресурсов на новом сервере, так ещё это способ сэкономить. Дело в том, что пользовательский контент обычно не удаляется, требуется не всем и не часто. Скажем, скан договора, прикреплённый к задаче, как свидетельство завершения бизнес-процесса, после его загрузки может быть никто так и не откроет. А “весить” он может не один мегабайт. А если таких договоров сотни? А если вместо них фото с корпоративов за последние 3 года? Контент, бесспорно, важный, но в оперативном доступе нужен редко. Как раз его и можно разместить на “дешёвых”, объёмных дисках, где условная стоимость за 1 гигабайт данных гораздо ниже, чем на быстрых SSD дисках, где мы разместим сам портал, ядро и SQL базу. Так же учтите, что свободного места на сервере должно хватить на полный архив портала + место, которое займёт содержимое после разархивирования.

4. Активирован ли лицензионный ключ?

Постепенно подбираемся к точке невозврата. Проверить активацию ключа и сделать это, при необходимости, можно тут: http://www.1c-bitrix.ru/support/key_info.php С технической точки зрения, нас интересует только пункт “Список адресов, включая тестовые, по которым будет доступна данная копия продукта «1С-Битрикс». Как раз тут нужно указать адрес, который вы добавили в панели управления DNS. Адресов может быть несколько. Остальная информация носит административный характер и для нас ценности не представляет, хотя и обязательна к заполнению.

5. Авторизационные данные создателя (сотрудник с ID=1)?

Последним подготовительным шагом нужно получит логин и пароль создателя. Сначала узнаем, кто это. Для этого откройте ваш облачный портал, в адресной строке после .bitrix24.ru вставьте следующее значение /company/personal/user/1/ Теперь вы знаете чей логин/пароль вам нужен и вооружившись средствами криптоанализа, без промедлений направляйтесь к этому сотруднику.

Сервер арендован и установлена ОС, все данные для переноса получены. Начинаем.

Первым делом идём сюда http://www.1c-bitrix.ru/support/ и создаём обращение с произвольным текстом о том, что хотим получить бэкап (бэкап можно запросить только 1 раз!!!).
В тексте обращения, обязательно укажите 5 пунктов:

1. Лицензионный ключ с числом пользователей не меньше, чем число пользователей на Битрикс24. Если вы докупали пользователей, то также понадобится купон на дополнительных пользователей.

2. Имя портала на Битрикс24. (например, intranet.bitrix24.ru)

3. Авторизационные данные создателя (сотрудник с ID=1) облачного портала Битрикс24, логин (email) и пароль.

4. Предпочтительную дату, после которой можно приступать к подготовке бэкапа (последний день работы в облачной версии).

5. Подтверждение, что с условиями переноса ознакомлены и согласны (сошлитесь на статью https://helpdesk.bitrix24.ru/open/1272913/)

Пользователю с ID=1 придёт уведомление с запросом доступа. Его нужно будет предоставить. Когда конкретно поддержка битрикса создаст бэкап — неизвестно. Это зависит от размеров портала, количества заявок, вспышек на солнце.. Вам нужно знать лишь то, что бэкап будет актуален на 00 часов 00 минут дня создания бэкапа.

Теперь, когда запрос создан и подтверждён, вернёмся к нашему новом серверу. На нём следует установить «1С-Битрикс: Веб-окружение». Для этого выполните следующее:

mkdir /service

cd /service

wget http://repos.1c-bitrix.ru/yum/bitrix-env.sh

chmod u+x bitrix-env.sh

./bitrix-env.sh


Скорее всего вам будет предложено согласиться на отключение SELinux, перезагрузиться и повторить процедуру. Соглашайтесь. После повторного запуска произойдёт процедура установки. Она может занять пару минут.

Окей, окружение установлено и вэб-сервер готов принимать подключения через браузер для установки нового портала по шаблону или для восстановления бэкапа. Нюанс в том, что это он предложит сделать это любому перешедшему по адресу вашего портала. Чтобы избежать неожиданностей, на период переезда, добавьте запрещающие правила сетевого экрана:

iptables -I INPUT -p tcp ! -s 8. 8.8.8 -m multiport —dports 80,443 -j DROP

Где 8.8.8.8 замените IP адресом с которого вы будете подключаться к серверу. Теперь только вы сможете подключиться к вэб-серверу.

Очень рекомендую для повышения безопасности, установить fail2ban. Нужен он чтобы исключить попытки подбора пароля для подключения к серверу по SSH. Установив эту службу, вы можете ограничить количество попыток ввода неправильного пароля.

yum install fail2ban

После чего нужно немного поправить его конфиг, приведя файл /etc/fail2ban/jail.d/00-firewalld.conf к виду:

[DEFAULT]

banaction = firewallcmd-ipset

bantime = 86400

findtime = 3600

maxretry = 3

[sshd]

enabled = true

и перезапустить службу:

systemctl restart fail2ban

Логика такова, что есть только три попытки в час ввести неправильный пароль. Если лимит достигнут, хост, с которого велись попытки подключения, блокируется на 24 часа.

Если до сервера с порталом установлен какой-либо дополнительный сетевой экран, убедитесь, что разрешили на нём следующие порты для доступа:

443/tcp

80/tcp

25/tcp

5222/tcp

5223/tcp

8070/tcp

8890/tcp

8891/tcp

8893/tcp

8894/tcp


Далее, запустите скрипт /root/menu.sh

Выберите пункт 1 для создания нового пула, введите полный адрес вашего сервера, например demo.saltpro.ru

На этом этапе, пока всё, выходим.

К этому времени ваш бэкап, скорее всего, готов и ждёт вас. Об этом будет свидетельствовать новый ответ в тикете службы поддержки. Внимательно прочитайте всё, что там написано. Возможно, вам будет рекомендовано использовать особенный скрипт restore.php, который нужно будет скачать и заменить им тот, что лежит по адресу /home/bitrix/www (проверьте права и владельца файла, они должны совпадать с тем, что были у старого файла).

Прочитали, применили рекомендации, теперь открываем браузер, вводим туда https://адрес_вашего_портала Выбираем восстановление из бэкапа, указываем, что бэкап доступен по ссылке, нажимаем далее и медитируем. Длится процесс будет долго. После скачивания вам потребуется ввести пароль от архива, который будет указан в тикете. Главное не закрывать вкладку браузера! В процессе восстановления вас могут поджидать два нюанса: (1) бесчисленное количество сообщений Deprecated: Function mcrypt_decrypt() is deprecated in /home/bitrix/www/restore.php on line 3451 — это не страшно и на суть вопроса не влияет; (2) восстановление бэкапа может прерваться из-за ошибки Got a packet bigger than ‘max_allowed_packet’ bytes.  Если первое — безобидное, то со вторым нужно что-то делать. А именно отредактировать файл /etc/mysql/conf.d/z_bx_custom.cnf, привести его к виду:

[mysqld]

max_allowed_packet=100M


После чего перезапустить MySQL:

systemctl restart mysqld


Теперь повторите процедуру восстановления базы. Если ошибка повторится, увеличьте значение и повторите процедуру.

Хорошо, с восстановлением закончили, продолжаем настраивать)

Снимайте ограничение на подключение:

iptables -D INPUT -p tcp ! -s 8.8.8.8 -m multiport —dports 80,443 -j DROP

не забываем поменять 8.8.8.8 на своё значение.

Установим SSL сертификат, чтобы соединение с сервером было безопасным и работали сервисы интеграции. Для этого, в терминале:

yum install python2-certbot-nginx


Чтобы сервис letsencrypt корректно определил, для кого ставим сертификат, нужно поправить конфигурацию nginx. В файле /etc/nginx/bx/site_enabled/ssl.s1.conf ищем строку server_name и задаём ей значение, например, server_name demo.saltpro.ru;


После чего, выполним

certbot —nginx

Отвечаем на вопросы и в результате получаем сертификат. На этом этапе лучше перезагрузить сервер. Это связано с поведением утилиты выдачи сертификата, которая не самым правильным образом производит перезапуск вэб-сервера. Чтобы ваше соединение всегда было защищено сертификатом, положите в директорию /home/bitrix/www пустой файл .htsecure

Сразу проверьте два значения php в конфигурационном файле, по адресу /etc/php.d/bitrixenv.ini

Нас интересуют эти:

date.timezone = Europe/Moscow

memory_limit = 512M

Для поддержки Push&Pull сервиса, вам нужно запустить скрипт по адресу /root/menu.sh, выбрать 10-ый пункт и произвести установку. Задание будет выполняться в фоне, его статус можно проверить, нажав 5 из главного меню. Выполняться будет минут 5, дождитесь завершения и выходите.

Завершающее действие в консоли — это настройка сервисного мэйл-аккаунта, через который портал будет оповещать пользователей о изменениях, позволит восстанавливать пароли и т.д. Кстати, пару слов о паролях. После переезда из облака в коробку, пользователи больше не смогут заходить под своими паролями, так что им обязательно нужна функция восстановления паролей! Иначе нужно будет вручную из панели управления порталом, назначать новый пароль каждому пользователю.

Для настройки мэйл-аккаунта сделайте следующее:

cd /home/bitrix

touch .msmtprc

chmod 600 .msmtprc

chown bitrix:bitrix .msmtprc


Пример файла .msmtprc, в случае если вы используете сервис Яндекс. Почта:

account default

logfile /home/bitrix/.msmtp.log

host smtp.yandex.ru

port 465

from [email protected]

keepbcc on

auth on

user xxx

password xxx

tls on

tls_starttls off

tls_certcheck off

Перезапустите вэб-сервер nginx и apache:

systemctl restart nginx

systemctl restart apache2

И открывайте панель управления порталом.


В разделе Панель управления — Настройки продукта — Настройки модулей — Push and Pull приведите значение элементов к следующему виду:

— На сервер установлена: Виртуальная машина 7. 1 и выше (Bitrix Push server)

— Путь для публикации команд: http://127.0.0.1:8895/bitrix/pub/

— Отправлять PUSH уведомления на мобильные телефоны: убрать чкбокс

— На сервере установлен и активирован «Push server»: убрать чекбокс

После чего нажмите сохранить, затем верните чекбоксы для:

— Отправлять PUSH уведомления на мобильные телефоны

— На сервере установлен и активирован «Push server»

И снова нажмите сохранить.

В разделе Панель управления — Настройки продукта — Настройки модулей — Главный модуль

На вкладке “Настройки”, в разделе “Файлы”, включите опцию “Быстрая отдача файлов через Nginx”

На вкладке “Авторизация” выключите опцию “Продлевать сессию при активности посетителя в окне браузера”

С настройками всё, давайте проверим, что получилось. Откройте Панель управления — Инструменты — Проверка системы и нажмите “Выполнить проверку”. Если всё сделано верно, то вы увидите примерно такую картинку:

Ну вот и всё, ваш портал настроен и готов принимать пользователей!

Не работает интеграция Битрикс24 бокс

Статус
Закрыто для дальнейших ответов.
  • 28 марта 2019 г.

  • Ошибка не удалось скопировать превью изображения discord
  • Ошибка не удалось скопировать лист автокад
  • Ошибка не удалось скачать яндекс телемост
  • Ошибка не удалось скачать файл яндекс диск
  • Ошибка не удалось скачать торрент