| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380 | <?php/* vim: set expandtab sw=4 ts=4 sts=4: *//** * User preferences management page * * @package PhpMyAdmin */use PhpMyAdmin\Config\ConfigFile;use PhpMyAdmin\Config\Forms\User\UserFormList;use PhpMyAdmin\Core;use PhpMyAdmin\File;use PhpMyAdmin\Message;use PhpMyAdmin\Response;use PhpMyAdmin\Sanitize;use PhpMyAdmin\ThemeManager;use PhpMyAdmin\Url;use PhpMyAdmin\UserPreferences;use PhpMyAdmin\Util;/** * Gets some core libraries and displays a top message if required */require_once 'libraries/common.inc.php';$userPreferences = new UserPreferences();$cf = new ConfigFile($GLOBALS['PMA_Config']->base_settings);$userPreferences->pageInit($cf);$response = Response::getInstance();$error = '';if (isset($_POST['submit_export'])    && isset($_POST['export_type'])    && $_POST['export_type'] == 'text_file') {    // export to JSON file    $response->disable();    $filename = 'phpMyAdmin-config-' . urlencode(Core::getenv('HTTP_HOST')) . '.json';    Core::downloadHeader($filename, 'application/json');    $settings = $userPreferences->load();    echo json_encode($settings['config_data'], JSON_PRETTY_PRINT);    exit;} elseif (isset($_POST['submit_export'])    && isset($_POST['export_type'])    && $_POST['export_type'] == 'php_file') {    // export to JSON file    $response->disable();    $filename = 'phpMyAdmin-config-' . urlencode(Core::getenv('HTTP_HOST')) . '.php';    Core::downloadHeader($filename, 'application/php');    $settings = $userPreferences->load();    echo '/* ' . __('phpMyAdmin configuration snippet') . " */\n\n";    echo '/* ' . __('Paste it to your config.inc.php') . " */\n\n";    foreach ($settings['config_data'] as $key => $val) {        echo '$cfg[\'' . str_replace('/', '\'][\'', $key) . '\'] = ';        echo var_export($val, true) . ";\n";    }    exit;} elseif (isset($_POST['submit_get_json'])) {    $settings = $userPreferences->load();    $response->addJSON('prefs', json_encode($settings['config_data']));    $response->addJSON('mtime', $settings['mtime']);    exit;} elseif (isset($_POST['submit_import'])) {    // load from JSON file    $json = '';    if (isset($_POST['import_type'])        && $_POST['import_type'] == 'text_file'        && isset($_FILES['import_file'])        && $_FILES['import_file']['error'] == UPLOAD_ERR_OK        && is_uploaded_file($_FILES['import_file']['tmp_name'])    ) {        $import_handle = new File($_FILES['import_file']['tmp_name']);        $import_handle->checkUploadedFile();        if ($import_handle->isError()) {            $error = $import_handle->getError();        } else {            // read JSON from uploaded file            $json = $import_handle->getRawContent();        }    } else {        // read from POST value (json)        $json = isset($_POST['json']) ? $_POST['json'] : null;    }    // hide header message    $_SESSION['userprefs_autoload'] = true;    $config = json_decode($json, true);    $return_url = isset($_POST['return_url']) ? $_POST['return_url'] : null;    if (! is_array($config)) {        if (! isset($error)) {            $error = __('Could not import configuration');        }    } else {        // sanitize input values: treat them as though        // they came from HTTP POST request        $form_display = new UserFormList($cf);        $new_config = $cf->getFlatDefaultConfig();        if (!empty($_POST['import_merge'])) {            $new_config = array_merge($new_config, $cf->getConfigArray());        }        $new_config = array_merge($new_config, $config);        $_POST_bak = $_POST;        foreach ($new_config as $k => $v) {            $_POST[str_replace('/', '-', $k)] = $v;        }        $cf->resetConfigData();        $all_ok = $form_display->process(true, false);        $all_ok = $all_ok && !$form_display->hasErrors();        $_POST = $_POST_bak;        if (!$all_ok && isset($_POST['fix_errors'])) {            $form_display->fixErrors();            $all_ok = true;        }        if (!$all_ok) {            // mimic original form and post json in a hidden field            include 'libraries/user_preferences.inc.php';            $msg = Message::error(                __('Configuration contains incorrect data for some fields.')            );            $msg->display();            echo '<div class="config-form">';            echo $form_display->displayErrors();            echo '</div>';            echo '<form action="prefs_manage.php" method="post">';            echo Url::getHiddenInputs() , "\n";            echo '<input type="hidden" name="json" value="'                , htmlspecialchars($json) , '" />';            echo '<input type="hidden" name="fix_errors" value="1" />';            if (! empty($_POST['import_merge'])) {                echo '<input type="hidden" name="import_merge" value="1" />';            }            if ($return_url) {                echo '<input type="hidden" name="return_url" value="'                    , htmlspecialchars($return_url) , '" />';            }            echo '<p>';            echo __('Do you want to import remaining settings?');            echo '</p>';            echo '<input type="submit" name="submit_import" value="'                , __('Yes') , '" />';            echo '<input type="submit" name="submit_ignore" value="'                , __('No') , '" />';            echo '</form>';            exit;        }        // check for ThemeDefault        $params = array();        $tmanager = ThemeManager::getInstance();        if (isset($config['ThemeDefault'])            && $tmanager->theme->getId() != $config['ThemeDefault']            && $tmanager->checkTheme($config['ThemeDefault'])        ) {            $tmanager->setActiveTheme($config['ThemeDefault']);            $tmanager->setThemeCookie();        }        if (isset($config['lang'])            && $config['lang'] != $GLOBALS['lang']        ) {            $params['lang'] = $config['lang'];        }        // save settings        $result = $userPreferences->save($cf->getConfigArray());        if ($result === true) {            if ($return_url) {                $query =  PhpMyAdmin\Util::splitURLQuery($return_url);                $return_url = parse_url($return_url, PHP_URL_PATH);                foreach ($query as $q) {                    $pos = mb_strpos($q, '=');                    $k = mb_substr($q, 0, $pos);                    if ($k == 'token') {                        continue;                    }                    $params[$k] = mb_substr($q, $pos + 1);                }            } else {                $return_url = 'prefs_manage.php';            }            // reload config            $GLOBALS['PMA_Config']->loadUserPreferences();            $userPreferences->redirect($return_url, $params);            exit;        } else {            $error = $result;        }    }} elseif (isset($_POST['submit_clear'])) {    $result = $userPreferences->save(array());    if ($result === true) {        $params = array();        $GLOBALS['PMA_Config']->removeCookie('pma_collaction_connection');        $GLOBALS['PMA_Config']->removeCookie('pma_lang');        $userPreferences->redirect('prefs_manage.php', $params);        exit;    } else {        $error = $result;    }    exit;}$response = Response::getInstance();$header   = $response->getHeader();$scripts = $header->getScripts();$scripts->addFile('config.js');require 'libraries/user_preferences.inc.php';if ($error) {    if (!$error instanceof Message) {        $error = Message::error($error);    }    $error->display();}?><script type="text/javascript"><?phpSanitize::printJsValue("PMA_messages['strSavedOn']", __('Saved on: @DATE@'));?></script><div id="maincontainer">    <div id="main_pane_left">        <div class="group"><?phpecho '<h2>' , __('Import') , '</h2>'    , '<form class="group-cnt prefs-form disableAjax" name="prefs_import"'    , ' action="prefs_manage.php" method="post" enctype="multipart/form-data">'    , Util::generateHiddenMaxFileSize($GLOBALS['max_upload_size'])    , Url::getHiddenInputs()    , '<input type="hidden" name="json" value="" />'    , '<input type="radio" id="import_text_file" name="import_type"'    , ' value="text_file" checked="checked" />'    , '<label for="import_text_file">' . __('Import from file') . '</label>'    , '<div id="opts_import_text_file" class="prefsmanage_opts">'    , '<label for="input_import_file">' , __('Browse your computer:') , '</label>'    , '<input type="file" name="import_file" id="input_import_file" />'    , '</div>'    , '<input type="radio" id="import_local_storage" name="import_type"'    , ' value="local_storage" disabled="disabled" />'    , '<label for="import_local_storage">'    , __('Import from browser\'s storage') , '</label>'    , '<div id="opts_import_local_storage" class="prefsmanage_opts disabled">'    , '<div class="localStorage-supported">'    , __('Settings will be imported from your browser\'s local storage.')    , '<br />'    , '<div class="localStorage-exists">'    , __('Saved on: @DATE@')    , '</div>'    , '<div class="localStorage-empty">';Message::notice(__('You have no saved settings!'))->display();echo  '</div>'    , '</div>'    , '<div class="localStorage-unsupported">';Message::notice(    __('This feature is not supported by your web browser'))->display();echo '</div>'    , '</div>'    , '<input type="checkbox" id="import_merge" name="import_merge" />'    , '<label for="import_merge">'    , __('Merge with current configuration') . '</label>'    , '<br /><br />'    , '<input type="submit" name="submit_import" value="'    , __('Go') . '" />'    , '</form>'    , '</div>';if (@file_exists('setup/index.php') && ! @file_exists(CONFIG_FILE)) {            // show only if setup script is available, allows to disable this message            // by simply removing setup directory            // Also do not show in config exists (and setup would refuse to work)            ?>            <div class="group">            <h2><?php echo __('More settings') ?></h2>            <div class="group-cnt">                <?php                echo sprintf(                    __(                        'You can set more settings by modifying config.inc.php, eg. '                        . 'by using %sSetup script%s.'                    ), '<a href="setup/index.php" target="_blank">', '</a>'                ) , PhpMyAdmin\Util::showDocu('setup', 'setup-script');                ?>            </div>            </div>        <?php}        ?>    </div>    <div id="main_pane_right">        <div class="group">            <h2><?php echo __('Export'); ?></h2>            <div class="click-hide-message group-cnt hide">                <?php                Message::rawSuccess(                    __('Configuration has been saved.')                )->display();                ?>            </div>            <form class="group-cnt prefs-form disableAjax" name="prefs_export"                  action="prefs_manage.php" method="post">                <?php echo Url::getHiddenInputs(); ?>                <div style="padding-bottom:0.5em">                    <input type="radio" id="export_text_file" name="export_type"                           value="text_file" checked="checked" />                    <label for="export_text_file">                        <?php echo __('Save as file'); ?>                    </label><br />                    <input type="radio" id="export_php_file" name="export_type"                           value="php_file" />                    <label for="export_php_file">                        <?php echo __('Save as PHP file'); ?>                    </label><br />                    <input type="radio" id="export_local_storage" name="export_type"                           value="local_storage" disabled="disabled" />                    <label for="export_local_storage">                        <?php echo __('Save to browser\'s storage'); ?></label>                </div>                <div id="opts_export_local_storage"                     class="prefsmanage_opts disabled">                    <span class="localStorage-supported">                        <?php                        echo __(                            'Settings will be saved in your browser\'s local '                            . 'storage.'                        );                        ?>                        <div class="localStorage-exists">                            <b>                                <?php                                echo __(                                    'Existing settings will be overwritten!'                                );                                ?>                            </b>                        </div>                    </span>                    <div class="localStorage-unsupported">                        <?php                        Message::notice(                            __('This feature is not supported by your web browser')                        )->display();                        ?>                    </div>                </div>                <br />                <?php                echo '<input type="submit" name="submit_export" value="' , __(                    'Go'                ) , '" />';                ?>            </form>        </div>        <div class="group">            <h2><?php echo __('Reset'); ?></h2>            <form class="group-cnt prefs-form disableAjax" name="prefs_reset"                  action="prefs_manage.php" method="post">                <?php                echo Url::getHiddenInputs() , __(                    'You can reset all your settings and restore them to default '                    . 'values.'                );                ?>                <br /><br />                <input type="submit" name="submit_clear"                       value="<?php echo __('Reset'); ?>"/>            </form>        </div>    </div>    <br class="clearfloat" /></div><?phpif ($response->isAjax()) {    $response->addJSON('_disableNaviSettings', true);} else {    define('PMA_DISABLE_NAVI_SETTINGS', true);}
 |