123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737 |
- <?php
- /* Copyright (C) 2004 Rodolphe Quiedeville <rodolphe@quiedeville.org>
- * Copyright (C) 2004 Eric Seigne <eric.seigne@ryxeo.com>
- * Copyright (C) 2004-2012 Laurent Destailleur <eldy@users.sourceforge.net>
- * Copyright (C) 2004 Benoit Mortier <benoit.mortier@opensides.be>
- * Copyright (C) 2004 Sebastien DiCintio <sdicintio@ressource-toi.org>
- * Copyright (C) 2005-2011 Regis Houssin <regis.houssin@inodbox.com>
- * Copyright (C) 2016 Raphaël Doursenaud <rdoursenaud@gpcsolutions.fr>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- */
- /**
- * \file htdocs/install/fileconf.php
- * \ingroup install
- * \brief Ask all information required to build Dolibarr htdocs/conf/conf.php file (will be written to disk on next page step1)
- */
- include_once 'inc.php';
- global $langs;
- $err = 0;
- $setuplang = GETPOST("selectlang", 'alpha', 3) ? GETPOST("selectlang", 'alpha', 3) : (GETPOST('lang', 'alpha', 1) ? GETPOST('lang', 'alpha', 1) : 'auto');
- $langs->setDefaultLang($setuplang);
- $langs->loadLangs(array("install", "errors"));
- dolibarr_install_syslog("- fileconf: entering fileconf.php page");
- // You can force preselected values of the config step of Dolibarr by adding a file
- // install.forced.php into directory htdocs/install (This is the case with some wizard
- // installer like DoliWamp, DoliMamp or DoliBuntu).
- // We first init "forced values" to nothing.
- if (!isset($force_install_noedit)) {
- $force_install_noedit = ''; // 1=To block vars specific to distrib, 2 to block all technical parameters
- }
- if (!isset($force_install_type)) {
- $force_install_type = '';
- }
- if (!isset($force_install_dbserver)) {
- $force_install_dbserver = '';
- }
- if (!isset($force_install_port)) {
- $force_install_port = '';
- }
- if (!isset($force_install_database)) {
- $force_install_database = '';
- }
- if (!isset($force_install_prefix)) {
- $force_install_prefix = '';
- }
- if (!isset($force_install_createdatabase)) {
- $force_install_createdatabase = '';
- }
- if (!isset($force_install_databaselogin)) {
- $force_install_databaselogin = '';
- }
- if (!isset($force_install_databasepass)) {
- $force_install_databasepass = '';
- }
- if (!isset($force_install_databaserootlogin)) {
- $force_install_databaserootlogin = '';
- }
- if (!isset($force_install_databaserootpass)) {
- $force_install_databaserootpass = '';
- }
- // Now we load forced values from install.forced.php file.
- $useforcedwizard = false;
- $forcedfile = "./install.forced.php";
- if ($conffile == "/etc/dolibarr/conf.php") {
- $forcedfile = "/etc/dolibarr/install.forced.php"; // Must be after inc.php
- }
- if (@file_exists($forcedfile)) {
- $useforcedwizard = true;
- include_once $forcedfile;
- }
- /*
- * View
- */
- session_start(); // To be able to keep info into session (used for not losing pass during navigation. pass must not transit through parmaeters)
- pHeader($langs->trans("ConfigurationFile"), "step1", "set", "", (empty($force_dolibarr_js_JQUERY) ? '' : $force_dolibarr_js_JQUERY.'/'), 'main-inside-bis');
- // Test if we can run a first install process
- if (!is_writable($conffile)) {
- print $langs->trans("ConfFileIsNotWritable", $conffiletoshow);
- dolibarr_install_syslog("fileconf: config file is not writable", LOG_WARNING);
- dolibarr_install_syslog("- fileconf: end");
- pFooter(1, $setuplang, 'jscheckparam');
- exit;
- }
- if (!empty($force_install_message)) {
- print '<div><br>'.$langs->trans($force_install_message).'</div>';
- /*print '<script type="text/javascript">';
- print ' jQuery(document).ready(function() {
- jQuery("#linktoshowtechnicalparam").click(function() {
- jQuery(".hidewhenedit").hide();
- jQuery(".hidewhennoedit").show();
- });';
- if ($force_install_noedit) print 'jQuery(".hidewhennoedit").hide();';
- print '});';
- print '</script>';
- print '<br><a href="#" id="linktoshowtechnicalparam" class="hidewhenedit">'.$langs->trans("ShowEditTechnicalParameters").'</a><br>';
- */
- }
- ?>
- <div>
- <table class="nobordernopadding<?php if ($force_install_noedit) {
- print ' hidewhennoedit';
- } ?>">
- <tr>
- <td colspan="3" class="label">
- <h3><img class="valignmiddle inline-block paddingright" src="../theme/common/octicons/build/svg/globe.svg" width="20" alt="webserver"> <?php echo $langs->trans("WebServer"); ?></h3>
- </td>
- </tr>
- <!-- Documents root $dolibarr_main_document_root -->
- <tr>
- <td class="label"><label for="main_dir"><b><?php print $langs->trans("WebPagesDirectory"); ?></b></label></td>
- <?php
- if (empty($dolibarr_main_document_root)) {
- $dolibarr_main_document_root = GETPOSTISSET('main_dir') ? GETPOST('main_dir') : detect_dolibarr_main_document_root();
- }
- ?>
- <td class="label">
- <input type="text"
- class="minwidth300"
- id="main_dir"
- name="main_dir"
- value="<?php print $dolibarr_main_document_root ?>"
- <?php
- if (!empty($force_install_noedit)) {
- print ' disabled';
- }
- ?>
- >
- </td>
- <td class="comment"><?php
- print '<span class="opacitymedium">'.$langs->trans("WithNoSlashAtTheEnd")."</span><br>";
- print $langs->trans("Examples").":<br>";
- ?>
- <ul>
- <li>/var/www/dolibarr/htdocs</li>
- <li>C:/wwwroot/dolibarr/htdocs</li>
- </ul>
- </td>
- </tr>
- <!-- Documents URL $dolibarr_main_data_root -->
- <tr>
- <td class="label"><label for="main_data_dir"><b><?php print $langs->trans("DocumentsDirectory"); ?></b></label></td>
- <?php
- if (!empty($force_install_main_data_root)) {
- $dolibarr_main_data_root = @$force_install_main_data_root;
- }
- if (empty($dolibarr_main_data_root)) {
- $dolibarr_main_data_root = GETPOSTISSET('main_data_dir') ? GETPOST('main_data_dir') : detect_dolibarr_main_data_root($dolibarr_main_document_root);
- }
- ?>
- <td class="label">
- <input type="text"
- class="minwidth300"
- id="main_data_dir"
- name="main_data_dir"
- value="<?php print $dolibarr_main_data_root ?>"
- <?php if (!empty($force_install_noedit)) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php
- print '<span class="opacitymedium">'.$langs->trans("WithNoSlashAtTheEnd")."</span><br>";
- print $langs->trans("DirectoryRecommendation")."<br>";
- print $langs->trans("Examples").":<br>";
- ?>
- <ul>
- <li>/var/lib/dolibarr/documents</li>
- <li>C:/My Documents/dolibarr/documents</li>
- </ul>
- </td>
- </tr>
- <!-- Root URL $dolibarr_main_url_root -->
- <?php
- if (empty($dolibarr_main_url_root)) {
- $dolibarr_main_url_root = GETPOSTISSET('main_url') ? GETPOST('main_url') : detect_dolibarr_main_url_root();
- }
- ?>
- <tr>
- <td class="label"><label for="main_url"><b><?php echo $langs->trans("URLRoot"); ?></b></label>
- </td>
- <td class="label">
- <input type="text"
- class="minwidth300"
- id="main_url"
- name="main_url"
- value="<?php print $dolibarr_main_url_root; ?> "
- <?php if (!empty($force_install_noedit)) {
- print ' disabled';
- }
- ?>
- >
- </td>
- <td class="comment"><?php print $langs->trans("Examples").":<br>"; ?>
- <ul>
- <li>http://localhost/</li>
- <li>http://www.myserver.com:8180/dolibarr</li>
- <li>https://www.myvirtualfordolibarr.com/</li>
- </ul>
- </td>
- </tr>
- <?php
- if (!empty($_SERVER["HTTPS"]) && $_SERVER["HTTPS"] == 'on') { // Enabled if the installation process is "https://"
- ?>
- <tr>
- <td class="label"><label for="main_force_https"><?php echo $langs->trans("ForceHttps"); ?></label></td>
- <td class="label">
- <input type="checkbox"
- id="main_force_https"
- name="main_force_https"
- <?php if (!empty($force_install_mainforcehttps)) {
- print ' checked';
- } ?>
- <?php if ($force_install_noedit == 2 && $force_install_mainforcehttps !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("CheckToForceHttps"); ?>
- </td>
- </tr>
- <?php
- }
- ?>
- <!-- Dolibarr database -->
- <tr>
- <td colspan="3" class="label"><br>
- <h3><img class="valignmiddle inline-block paddingright" src="../theme/common/octicons/build/svg/database.svg" width="20" alt="webserver"> <?php echo $langs->trans("DolibarrDatabase"); ?></h3>
- </td>
- </tr>
- <tr>
- <td class="label"><label for="db_name"><b><?php echo $langs->trans("DatabaseName"); ?></b></label></td>
- <td class="label">
- <input type="text"
- id="db_name"
- name="db_name"
- value="<?php echo (!empty($dolibarr_main_db_name)) ? $dolibarr_main_db_name : ($force_install_database ? $force_install_database : 'dolibarr'); ?>"
- <?php if ($force_install_noedit == 2 && $force_install_database !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("DatabaseName"); ?></td>
- </tr>
- <?php
- if (!isset($dolibarr_main_db_host)) {
- $dolibarr_main_db_host = "localhost";
- }
- ?>
- <tr>
- <!-- Driver type -->
- <td class="label"><label for="db_type"><b><?php echo $langs->trans("DriverType"); ?></b></label></td>
- <td class="label">
- <?php
- $defaultype = !empty($dolibarr_main_db_type) ? $dolibarr_main_db_type : (empty($force_install_type) ? 'mysqli' : $force_install_type);
- $modules = array();
- $nbok = $nbko = 0;
- $option = '';
- // Scan les drivers
- $dir = DOL_DOCUMENT_ROOT.'/core/db';
- $handle = opendir($dir);
- if (is_resource($handle)) {
- while (($file = readdir($handle)) !== false) {
- if (is_readable($dir."/".$file) && preg_match('/^(.*)\.class\.php$/i', $file, $reg)) {
- $type = $reg[1];
- if ($type === 'DoliDB') {
- continue; // Skip abstract class
- }
- $class = 'DoliDB'.ucfirst($type);
- include_once $dir."/".$file;
- if ($type == 'sqlite') {
- continue; // We hide sqlite because support can't be complete until sqlite does not manage foreign key creation after table creation (ALTER TABLE child ADD CONSTRAINT not supported)
- }
- if ($type == 'sqlite3') {
- continue; // We hide sqlite3 because support can't be complete until sqlite does not manage foreign key creation after table creation (ALTER TABLE child ADD CONSTRAINT not supported)
- }
- // Version min of database
- $versionbasemin = explode('.', $class::VERSIONMIN);
- $note = '('.$class::LABEL.' >= '.$class::VERSIONMIN.')';
- // Switch to mysql if mysqli is not present
- if ($defaultype == 'mysqli' && !function_exists('mysqli_connect')) {
- $defaultype = 'mysql';
- }
- // Show line into list
- if ($type == 'mysql') {
- $testfunction = 'mysql_connect';
- $testclass = '';
- }
- if ($type == 'mysqli') {
- $testfunction = 'mysqli_connect';
- $testclass = '';
- }
- if ($type == 'pgsql') {
- $testfunction = 'pg_connect';
- $testclass = '';
- }
- if ($type == 'mssql') {
- $testfunction = 'mssql_connect';
- $testclass = '';
- }
- if ($type == 'sqlite') {
- $testfunction = '';
- $testclass = 'PDO';
- }
- if ($type == 'sqlite3') {
- $testfunction = '';
- $testclass = 'SQLite3';
- }
- $option .= '<option value="'.$type.'"'.($defaultype == $type ? ' selected' : '');
- if ($testfunction && !function_exists($testfunction)) {
- $option .= ' disabled';
- }
- if ($testclass && !class_exists($testclass)) {
- $option .= ' disabled';
- }
- $option .= '>';
- $option .= $type.' ';
- if ($note) {
- $option .= ' '.$note;
- }
- // Deprecated and experimental
- if ($type == 'mysql') {
- $option .= ' '.$langs->trans("Deprecated");
- } elseif ($type == 'mssql') {
- $option .= ' '.$langs->trans("VersionExperimental");
- } elseif ($type == 'sqlite') {
- $option .= ' '.$langs->trans("VersionExperimental");
- } elseif ($type == 'sqlite3') {
- $option .= ' '.$langs->trans("VersionExperimental");
- } elseif (!function_exists($testfunction)) {
- // No available
- $option .= ' - '.$langs->trans("FunctionNotAvailableInThisPHP");
- }
- $option .= '</option>';
- }
- }
- }
- ?>
- <select id="db_type"
- name="db_type"
- <?php if ($force_install_noedit == 2 && $force_install_type !== null) {
- print ' disabled';
- } ?>
- >
- <?php print $option; ?>
- </select>
- </td>
- <td class="comment"><?php echo $langs->trans("DatabaseType"); ?></td>
- </tr>
- <tr class="hidesqlite">
- <td class="label"><label for="db_host"><b><?php echo $langs->trans("DatabaseServer"); ?></b></label></td>
- <td class="label">
- <input type="text"
- id="db_host"
- name="db_host"
- value="<?php print(!empty($force_install_dbserver) ? $force_install_dbserver : (!empty($dolibarr_main_db_host) ? $dolibarr_main_db_host : 'localhost')); ?>"
- <?php if ($force_install_noedit == 2 && $force_install_dbserver !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("ServerAddressDescription"); ?>
- </td>
- </tr>
- <tr class="hidesqlite">
- <td class="label"><label for="db_port"><?php echo $langs->trans("Port"); ?></label></td>
- <td class="label">
- <input type="text"
- name="db_port"
- id="db_port"
- value="<?php print (!empty($force_install_port)) ? $force_install_port : $dolibarr_main_db_port; ?>"
- <?php if ($force_install_noedit == 2 && $force_install_port !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("ServerPortDescription"); ?>
- </td>
- </tr>
- <tr class="hidesqlite">
- <td class="label"><label for="db_prefix"><?php echo $langs->trans("DatabasePrefix"); ?></label></td>
- <td class="label">
- <input type="text"
- id="db_prefix"
- name="db_prefix"
- value="<?php echo(!empty($force_install_prefix) ? $force_install_prefix : (!empty($dolibarr_main_db_prefix) ? $dolibarr_main_db_prefix : 'llx_')); ?>"
- <?php if ($force_install_noedit == 2 && $force_install_prefix !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("DatabasePrefixDescription"); ?></td>
- </tr>
- <tr class="hidesqlite">
- <td class="label"><label for="db_create_database"><?php echo $langs->trans("CreateDatabase"); ?></label></td>
- <td class="label">
- <input type="checkbox"
- id="db_create_database"
- name="db_create_database"
- value="on"
- <?php
- $checked = 0;
- if ($force_install_createdatabase) {
- $checked = 1;
- print ' checked';
- } ?>
- <?php if ($force_install_noedit == 2 && $force_install_createdatabase !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment">
- <?php echo $langs->trans("CheckToCreateDatabase"); ?>
- </td>
- </tr>
- <tr class="hidesqlite">
- <td class="label"><label for="db_user"><b><?php echo $langs->trans("Login"); ?></b></label></td>
- <td class="label">
- <input type="text"
- id="db_user"
- name="db_user"
- value="<?php print (!empty($force_install_databaselogin)) ? $force_install_databaselogin : $dolibarr_main_db_user; ?>"
- <?php if ($force_install_noedit == 2 && $force_install_databaselogin !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("AdminLogin"); ?></td>
- </tr>
- <tr class="hidesqlite">
- <td class="label"><label for="db_pass"><b><?php echo $langs->trans("Password"); ?></b></label></td>
- <td class="label">
- <input type="password" class="text-security"
- id="db_pass" autocomplete="off"
- name="db_pass"
- value="<?php
- // If $force_install_databasepass is on, we don't want to set password, we just show '***'. Real value will be extracted from the forced install file at step1.
- $autofill = ((!empty($_SESSION['dol_save_pass'])) ? $_SESSION['dol_save_pass'] : str_pad('', strlen($force_install_databasepass), '*'));
- if (!empty($dolibarr_main_prod) && empty($_SESSION['dol_save_pass'])) { // So value can't be found if install page still accessible
- $autofill = '';
- }
- print dol_escape_htmltag($autofill);
- ?>"
- <?php if ($force_install_noedit == 2 && $force_install_databasepass !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("AdminPassword"); ?></td>
- </tr>
- <tr class="hidesqlite">
- <td class="label"><label for="db_create_user"><?php echo $langs->trans("CreateUser"); ?></label></td>
- <td class="label">
- <input type="checkbox"
- id="db_create_user"
- name="db_create_user"
- value="on"
- <?php
- $checked = 0;
- if (!empty($force_install_createuser)) {
- $checked = 1;
- print ' checked';
- } ?>
- <?php if ($force_install_noedit == 2 && $force_install_createuser !== null) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment">
- <?php echo $langs->trans("CheckToCreateUser"); ?>
- </td>
- </tr>
- <!-- Super access -->
- <?php
- $force_install_databaserootlogin = parse_database_login($force_install_databaserootlogin);
- $force_install_databaserootpass = parse_database_pass($force_install_databaserootpass);
- ?>
- <tr class="hidesqlite hideroot">
- <td colspan="3" class="label"><br>
- <h3><img class="valignmiddle inline-block paddingright" src="../theme/common/octicons/build/svg/shield.svg" width="20" alt="webserver"> <?php echo $langs->trans("DatabaseSuperUserAccess"); ?></h3>
- </td>
- </tr>
- <tr class="hidesqlite hideroot">
- <td class="label"><label for="db_user_root"><b><?php echo $langs->trans("Login"); ?></b></label></td>
- <td class="label">
- <input type="text"
- id="db_user_root"
- name="db_user_root"
- class="needroot"
- value="<?php print (!empty($force_install_databaserootlogin)) ? $force_install_databaserootlogin : (GETPOSTISSET('db_user_root') ? GETPOST('db_user_root') : (isset($db_user_root) ? $db_user_root : '')); ?>"
- <?php if ($force_install_noedit > 0 && !empty($force_install_databaserootlogin)) {
- print ' disabled';
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("DatabaseRootLoginDescription"); ?>
- <!--
- <?php echo '<br>'.$langs->trans("Examples").':<br>' ?>
- <ul>
- <li>root (Mysql)</li>
- <li>postgres (PostgreSql)</li>
- </ul>
- </td>
- -->
- </tr>
- <tr class="hidesqlite hideroot">
- <td class="label"><label for="db_pass_root"><b><?php echo $langs->trans("Password"); ?></b></label></td>
- <td class="label">
- <input type="password"
- autocomplete="off"
- id="db_pass_root"
- name="db_pass_root"
- class="needroot text-security"
- value="<?php
- // If $force_install_databaserootpass is on, we don't want to set password here, we just show '***'. Real value will be extracted from the forced install file at step1.
- $autofill = ((!empty($force_install_databaserootpass)) ? str_pad('', strlen($force_install_databaserootpass), '*') : (isset($db_pass_root) ? $db_pass_root : ''));
- if (!empty($dolibarr_main_prod)) {
- $autofill = '';
- }
- // Do not autofill password if instance is a production instance
- if (!empty($_SERVER["SERVER_NAME"]) && !in_array(
- $_SERVER["SERVER_NAME"],
- array('127.0.0.1', 'localhost', 'localhostgit')
- )
- ) {
- $autofill = '';
- } // Do not autofill password for remote access
- print dol_escape_htmltag($autofill);
- ?>"
- <?php if ($force_install_noedit > 0 && !empty($force_install_databaserootpass)) {
- print ' disabled'; /* May be removed by javascript*/
- } ?>
- >
- </td>
- <td class="comment"><?php echo $langs->trans("KeepEmptyIfNoPassword"); ?>
- </td>
- </tr>
- </table>
- </div>
- <script type="text/javascript">
- function init_needroot()
- {
- console.log("init_needroot force_install_noedit=<?php echo $force_install_noedit?>");
- console.log(jQuery("#db_create_database").is(":checked"));
- console.log(jQuery("#db_create_user").is(":checked"));
- if (jQuery("#db_create_database").is(":checked") || jQuery("#db_create_user").is(":checked"))
- {
- console.log("init_needroot show root section");
- jQuery(".hideroot").show();
- <?php
- if (empty($force_install_noedit)) { ?>
- jQuery(".needroot").removeAttr('disabled');
- <?php } ?>
- }
- else
- {
- console.log("init_needroot hide root section");
- jQuery(".hideroot").hide();
- jQuery(".needroot").prop('disabled', true);
- }
- }
- function checkDatabaseName(databasename) {
- if (databasename.match(/[;\.]/)) { return false; }
- return true;
- }
- function jscheckparam()
- {
- console.log("Click on jscheckparam");
- var ok = true;
- if (document.forminstall.main_dir.value == '')
- {
- ok=false;
- alert('<?php echo dol_escape_js($langs->transnoentities("ErrorFieldRequired", $langs->transnoentitiesnoconv("WebPagesDirectory"))); ?>');
- }
- else if (document.forminstall.main_data_dir.value == '')
- {
- ok=false;
- alert('<?php echo dol_escape_js($langs->transnoentities("ErrorFieldRequired", $langs->transnoentitiesnoconv("DocumentsDirectory"))); ?>');
- }
- else if (document.forminstall.main_url.value == '')
- {
- ok=false;
- alert('<?php echo dol_escape_js($langs->transnoentities("ErrorFieldRequired", $langs->transnoentitiesnoconv("URLRoot"))); ?>');
- }
- else if (document.forminstall.db_host.value == '')
- {
- ok=false;
- alert('<?php echo dol_escape_js($langs->transnoentities("ErrorFieldRequired", $langs->transnoentitiesnoconv("Server"))); ?>');
- }
- else if (document.forminstall.db_name.value == '')
- {
- ok=false;
- alert('<?php echo dol_escape_js($langs->transnoentities("ErrorFieldRequired", $langs->transnoentitiesnoconv("DatabaseName"))); ?>');
- }
- else if (! checkDatabaseName(document.forminstall.db_name.value))
- {
- ok=false;
- alert('<?php echo dol_escape_js($langs->transnoentities("ErrorFieldCanNotContainSpecialCharacters", $langs->transnoentitiesnoconv("DatabaseName"))); ?>');
- }
- // If create database asked
- else if (document.forminstall.db_create_database.checked == true && (document.forminstall.db_user_root.value == ''))
- {
- ok=false;
- alert('<?php echo dol_escape_js($langs->transnoentities("YouAskToCreateDatabaseSoRootRequired")); ?>');
- init_needroot();
- }
- // If create user asked
- else if (document.forminstall.db_create_user.checked == true && (document.forminstall.db_user_root.value == ''))
- {
- ok=false;
- alert('<?php echo dol_escape_js($langs->transnoentities("YouAskToCreateDatabaseUserSoRootRequired")); ?>');
- init_needroot();
- }
- return ok;
- }
- jQuery(document).ready(function() { // TODO Test $( window ).load(function() to see if the init_needroot work better after a back
- var dbtype = jQuery("#db_type");
- dbtype.change(function () {
- if (dbtype.val() == 'sqlite' || dbtype.val() == 'sqlite3') {
- jQuery(".hidesqlite").hide();
- } else {
- jQuery(".hidesqlite").show();
- }
- // Automatically set default database ports and admin user
- if (dbtype.val() == 'mysql' || dbtype.val() == 'mysqli') {
- jQuery("#db_port").val(3306);
- jQuery("#db_user_root").val('root');
- } else if (dbtype.val() == 'pgsql') {
- jQuery("#db_port").val(5432);
- jQuery("#db_user_root").val('postgres');
- } else if (dbtype.val() == 'mssql') {
- jQuery("#db_port").val(1433);
- jQuery("#db_user_root").val('sa');
- }
- });
- jQuery("#db_create_database").click(function() {
- console.log("click on db_create_database");
- init_needroot();
- });
- jQuery("#db_create_user").click(function() {
- console.log("click on db_create_user");
- init_needroot();
- });
- <?php if ($force_install_noedit == 2 && empty($force_install_databasepass)) { ?>
- jQuery("#db_pass").focus();
- <?php } ?>
- init_needroot();
- });
- </script>
- <?php
- // $db->close(); Not database connexion yet
- dolibarr_install_syslog("- fileconf: end");
- pFooter($err, $setuplang, 'jscheckparam');
|