Вход Регистрация
Файл: mc-2.7.1/install/index.php
Строк: 175
<?php
/**
 * MobileCMS
 *
 * Open source content management system for mobile sites
 *
 * @author MobileCMS Team <support@mobilecms.pro>
 * @copyright Copyright (c) 2011-2019, MobileCMS Team
 * @link https://mobilecms.pro Official site
 * @license MIT license
 */
// Отключаем генерирование ошибок
error_reporting(7);
// Название системы
define('SYSTEM_NAME''MobileCMS');
// Адрес сайта
define('SITE_URL''http://' $_SERVER['HTTP_HOST'] . str_replace('install/index.php'''$_SERVER['PHP_SELF']));

// Шаги установки
$steps = array(
    
'greeting' => 'Приветствие',
    
'license' => 'Лицензионное соглашение',
    
'chmod' => 'Настройка прав доступа к файлам',
    
'site_data' => 'Заполнение данных сайта',
    
'end_of_install' => 'Завершение установки',
);

$step = !empty($_GET['step']) ? $_GET['step'] : 'greeting';

if (!
array_key_exists($step$steps))
    die(
'Шаг не определён!');
?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <link rel="stylesheet" type="text/css" href="../views/admin/css/ui/jquery-ui.css" media="screen" />
        <link rel="stylesheet" type="text/css" href="../views/admin/css/layout.css" media="screen" />
        <link rel="stylesheet" type="text/css" href="../views/admin/css/ui.tabs.css" media="screen" />
        <title>Установка <?php echo SYSTEM_NAME ?></title>
    </head>

    <body>
        <div id="logoProgress"></div>

        <div id="header">
            Установка <?php echo SYSTEM_NAME ?>
        </div>

        <div id="main">
            <div id="title">
                <h2><?php echo $steps[$step?></h2>
            </div>

            <div id="left">
                <div id="sidebar">
                    <h3>Шаг</h3>

                    <p>
                        <ul style="padding: 0 0 0 5px">
                            <li><?php if ($step == 'greeting'): ?><b>1. Приветствие</b><?php else: ?>1. Приветствие<?php endif; ?></li>
                            <li><?php if ($step == 'license'): ?><b>2. Лицензионное соглашение</b><?php else: ?>2. Лицензионное соглашение<?php endif; ?></li>
                            <li><?php if ($step == 'chmod'): ?><b>3. Настройка прав доступа</b><?php else: ?>3. Настройка прав доступа<?php endif; ?></li>
                            <li><?php if ($step == 'site_data'): ?><b>4. Заполнение данных сайта</b><?php else: ?>4. Заполнение данных сайта<?php endif; ?></li>
                            <li><?php if ($step == 'end_of_install'): ?><b>5. Завершение установки</b><?php else: ?>5. Завершение установки<?php endif; ?></li>
                        </ul>
                    </p>
                </div>
            </div>

            <div id="content">

                <?php
// Если установка уже произведена, выводим сообщение об ошибке
                
if (file_exists('../data_files/config.php') && $step != 'end_of_install')
                    exit(
'<div class="box"><p>Установка была произведена ранее. Рекомендуем удалить папку install.</p></div></div></div></body></html>');

                switch (
$step) {
                    
// Приветствие
                    
case 'greeting':
                        
?>
                        <div class="box">
                            <p><?php echo file_get_contents('./greeting.txt'?></p>
                        </div>

                        <p><button onclick="location.href = '?step=license'">Далее</button></p>
                        <?php
                        
break;

                    
// Лицензионное соглашение
                    
case 'license':
                        
?>
                        <div class="box">
                            <p><?php echo nl2br(file_get_contents('../LICENSE.txt')) ?></p>
                        </div>

                        <p><button onclick="location.href = '?step=chmod'">Согласен</button>&nbsp;<button onclick="location.href = 'http://ant0ha.ru'">Не согласен</button></p>
                        <?php
                        
break;

                    
// Проверка прав доступа
                    
case 'chmod':
                        
$chmod_files file('./chmod_files.txt');
                        
$flag TRUE;
                        
?>
                        <table cellspacing="0" cellpadding="0" class="table">
                            <thead align="left" valign="middle">
                                <tr>
                                    <td>Файл / Папка</td>
                                    <td>Статус</td>
                                </tr>
                            </thead>

                            <tbody align="left" valign="middle">
                                <?php foreach ($chmod_files as $file): ?>
                                    <tr>
                                        <td><b><?php echo str_replace('../'''$file?></b></td>
                                        <td>
                                            <?php
                                            
if (is_writable(trim($file))) {
                                                echo 
'<span style="color: green">Записываемый</span>';
                                            } else {
                                                echo 
'<span style="color: red">Необходимо выставить chmod 777</span>';
                                                
$flag FALSE;
                                            }
                                            
?>
                                        </td>
                                    </tr>
                                <?php endforeach; ?>
                            </tbody>
                        </table>
                        <?php
                        
if ($flag == TRUE) {
                            echo 
"<div class="box"><p>Все необходимые файлы и папки доступны для записи, можно продолжать установку</p></div>";
                            echo 
"<p><button onclick="location.href='?step=site_data'">Далее</button></p>";
                        } else {
                            echo 
"<div class="box"><p>Для продолжения установки необходимо чтобы все файлы и папки из списка выше были записываемыми</p></div>";
                            echo 
"<p><button onclick="location.href='?step=chmod&amp;" . rand(111, 999) . "'">Обновить</button></p>";
                        }
                        break;

                    
// Настройка базы данных и генерация файла конфигурации
                    
case 'site_data':
                        if (isset(
$_POST['submit'])) {
                            
$error FALSE;

                            if (empty(
$_POST['db_server']))
                                
$error .= 'Укажите MySQL сервер<br />';

                            if (empty(
$_POST['db_user']))
                                
$error .= 'Укажите имя пользователя базы MySQL<br />';

                            if (empty(
$_POST['db_base']))
                                
$error .= 'Укажите имя базы данных<br />';

                            if (empty(
$_POST['site_url']))
                                
$error .= 'Укажите адрес сайта<br />';

                            if (empty(
$_POST['admin_login']))
                                
$error .= 'Укажите логин администратора<br />';

                            if (empty(
$_POST['admin_email']))
                                
$error .= 'Укажите e-mail администратора<br />';

                            if (empty(
$_POST['admin_password']))
                                
$error .= 'Укажите пароль администратора<br />';

                            if (
$_POST['admin_password'] != $_POST['admin_password2'])
                                
$error .= 'Пароли не совпадают<br />';

                            if (!
$error) {
                                
# Коннектимся к базе данных
                                
$link mysqli_connect($_POST['db_server'], $_POST['db_user'], $_POST['db_password'], $_POST['db_base'], 3306)
                                        or die(
"Не возможно подключиться к MySQL серверу, проверьте правильность введенных данных</div></div></body></html>");
                                
mysqli_query($link"SET NAMES utf8");

                                
# Заливаем дамп системы
                                
$dump file_get_contents('./system_dump.sql');
                                
$dump str_replace('{ADMIN_LOGIN}'$_POST['admin_login'], $dump);
                                
$dump str_replace('{ADMIN_EMAIL}'$_POST['admin_email'], $dump);
                                
$dump str_replace('{ADMIN_PASSWORD}'md5(md5($_POST['admin_password'])), $dump);
                                
$dump str_replace('{CMS_VERSION}''2.7.1 beta'$dump);

                                
$queryes explode('//=====================================//'$dump);
                                
$i 0;
                                foreach (
$queryes as $query) {
                                    if (@
mysqli_query($linktrim($query))) {
                                        
$i++;
                                    }
                                }

                                
# Создаем файл конфигурации системы
                                
$config_data file_get_contents('./config_data.txt');
                                
$config_data str_replace('{DB_HOST}'$_POST['db_server'], $config_data);
                                
$config_data str_replace('{DB_USER}'$_POST['db_user'], $config_data);
                                
$config_data str_replace('{DB_PASS}'$_POST['db_password'], $config_data);
                                
$config_data str_replace('{DB_BASE}'$_POST['db_base'], $config_data);
                                
$config_data str_replace('{SITE_URL}'$_POST['site_url'], $config_data);

                                
file_put_contents('../data_files/config.php'$config_data);
                                
?>
                                <div class="box">
                                    <p>
                                        <?php echo 'Запросов отправлено: 'count($queryes); ?>
                                        <br />
                                        <?php echo 'Успешно : 'count($queryes); ?>
                                        <br />
                                        Файл конфигурации системы успешно создан, дамп базы данных залит.
                                    </p>
                                </div>
                                <p><button onclick="location.href = '?step=end_of_install'">Завершить установку</button>
                                    <?php
                                
}
                            }
                            if (!isset(
$_POST['submit']) OR $error) {
                                if (
$error) {
                                    echo 
"<div class="error">";
                                    echo 
$error;
                                    echo 
"</div>";
                                }
                                
?>
                                <form action="?step=site_data" method="post">
                                    <div class="box">
                                        <p>
                                            <label>Сервер MySQL</label>
                                            <input name="db_server" type="text" value="localhost">
                                        </p>
                                        <p>
                                            <label>Пользователь базы MySQL</label>
                                            <input name="db_user" type="text" value="<?php echo @$_POST['db_user'?>">
                                        </p>
                                        <p>
                                            <label>Пароль пользователя MySQL</label>
                                            <input name="db_password" type="password" value="">
                                        </p>
                                        <p>
                                            <label>Имя базы данных MySQL</label>
                                            <input name="db_base" type="text" value="<?php echo @$_POST['db_base'?>">
                                        </p>
                                        <p>
                                            <label>Адрес сайта</label>
                                            <input name="site_url" type="text" value="<?php echo SITE_URL ?>">
                                        </p>
                                        <p>
                                            <label>Логин администратора</label>
                                            <input name="admin_login" type="text" value="<?php echo @$_POST['admin_login'?>">
                                        </p>
                                        <p>
                                            <label>E-mail администратора</label>
                                            <input name="admin_email" type="text" value="<?php echo @$_POST['admin_email'?>">
                                        </p>
                                        <p>
                                            <label>Пароль администратора</label>
                                            <input name="admin_password" type="password" value="<?php echo @$_POST['admin_password'?>">
                                        </p>
                                        <p>
                                            <label>Повторите пароль администратора</label>
                                            <input name="admin_password2" type="password" value="<?php echo @$_POST['admin_password2'?>">
                                        </p>
                                    </div>
                                    <p><input type="submit" name="submit" value="Далее"></p>
                                </form>
                                <?php
                            
}
                            break;

                        
# Завершение установки
                        
case 'end_of_install':
                            
?>
                            <div class="box">
                                <p>
                                    Установка <?php echo SYSTEM_NAME ?> успешно завершена! Благодарим за выбор нашей CMS. Не забудьте удалить папку install.
                                </p>
                            </div>
                            <p><button onclick="location.href = '<?php echo SITE_URL ?>'">Перейти на сайт</button></p>
                            <?php
                            
break;
                    }
                    
?>
            </div>
        </div>
    </body>
</html>
Онлайн: 0
Реклама