29 define(
'DONOTLOADCONF', 1);
35 $action =
GETPOST(
'action',
'aZ09') ?
GETPOST(
'action',
'aZ09') : (empty($argv[1]) ?
'' : $argv[1]);
36 $setuplang =
GETPOST(
'selectlang',
'aZ09', 3) ?
GETPOST(
'selectlang',
'aZ09', 3) : (empty($argv[2]) ?
'auto' : $argv[2]);
37 $langs->setDefaultLang($setuplang);
39 $langs->loadLangs(array(
"admin",
"install",
"errors"));
42 $main_dir =
GETPOST(
'main_dir') ?
GETPOST(
'main_dir') : (empty($argv[3]) ?
'' : $argv[3]);
44 $main_data_dir =
GETPOST(
'main_data_dir') ?
GETPOST(
'main_data_dir') : (empty($argv[4]) ? ($main_dir.
'/documents') : $argv[4]);
46 $main_url =
GETPOST(
'main_url') ?
GETPOST(
'main_url') : (empty($argv[5]) ?
'' : $argv[5]);
48 $userroot =
GETPOST(
'db_user_root',
'alpha') ?
GETPOST(
'db_user_root',
'alpha') : (empty($argv[6]) ?
'' : $argv[6]);
49 $passroot =
GETPOST(
'db_pass_root',
'none') ?
GETPOST(
'db_pass_root',
'none') : (empty($argv[7]) ?
'' : $argv[7]);
51 $db_type =
GETPOST(
'db_type',
'aZ09') ?
GETPOST(
'db_type',
'aZ09') : (empty($argv[8]) ?
'' : $argv[8]);
52 $db_host =
GETPOST(
'db_host',
'alpha') ?
GETPOST(
'db_host',
'alpha') : (empty($argv[9]) ?
'' : $argv[9]);
53 $db_name =
GETPOST(
'db_name',
'aZ09') ?
GETPOST(
'db_name',
'aZ09') : (empty($argv[10]) ?
'' : $argv[10]);
54 $db_user =
GETPOST(
'db_user',
'alpha') ?
GETPOST(
'db_user',
'alpha') : (empty($argv[11]) ?
'' : $argv[11]);
55 $db_pass =
GETPOST(
'db_pass',
'none') ?
GETPOST(
'db_pass',
'none') : (empty($argv[12]) ?
'' : $argv[12]);
56 $db_port =
GETPOST(
'db_port',
'int') ?
GETPOST(
'db_port',
'int') : (empty($argv[13]) ?
'' : $argv[13]);
57 $db_prefix =
GETPOST(
'db_prefix',
'aZ09') ?
GETPOST(
'db_prefix',
'aZ09') : (empty($argv[14]) ?
'' : $argv[14]);
58 $db_create_database =
GETPOST(
'db_create_database',
'alpha') ?
GETPOST(
'db_create_database',
'alpha') : (empty($argv[15]) ?
'' : $argv[15]);
59 $db_create_user =
GETPOST(
'db_create_user',
'alpha') ?
GETPOST(
'db_create_user',
'alpha') : (empty($argv[16]) ?
'' : $argv[16]);
61 $main_force_https = ((
GETPOST(
"main_force_https",
'alpha') && (
GETPOST(
"main_force_https",
'alpha') ==
"on" ||
GETPOST(
"main_force_https",
'alpha') == 1)) ?
'1' :
'0');
63 $main_use_alt_dir = ((
GETPOST(
"main_use_alt_dir",
'alpha') ==
'' || (
GETPOST(
"main_use_alt_dir",
'alpha') ==
"on" ||
GETPOST(
"main_use_alt_dir",
'alpha') == 1)) ?
'' :
'//');
65 $main_alt_dir_name = ((
GETPOST(
"main_alt_dir_name",
'alpha') &&
GETPOST(
"main_alt_dir_name",
'alpha') !=
'') ?
GETPOST(
"main_alt_dir_name",
'alpha') :
'custom');
67 $dolibarr_main_distrib =
'standard';
72 $_SESSION[
'dol_save_pass'] = $db_pass;
76 $useforcedwizard =
false;
77 $forcedfile =
"./install.forced.php";
78 if ($conffile ==
"/etc/dolibarr/conf.php") $forcedfile =
"/etc/dolibarr/install.forced.php";
79 if (@file_exists($forcedfile)) {
80 $useforcedwizard =
true;
81 include_once $forcedfile;
83 if ($force_install_noedit) {
85 if (!empty($argv[1])) $main_dir = $argv[1];
86 if (!empty($force_install_main_data_root)) {
87 $main_data_dir = $force_install_main_data_root;
93 if (!empty($force_install_databaserootlogin)) {
96 if (!empty($force_install_databaserootpass)) {
100 if ($force_install_noedit == 2) {
101 if (!empty($force_install_type)) {
102 $db_type = $force_install_type;
104 if (!empty($force_install_dbserver)) {
105 $db_host = $force_install_dbserver;
107 if (!empty($force_install_database)) {
108 $db_name = $force_install_database;
110 if (!empty($force_install_databaselogin)) {
111 $db_user = $force_install_databaselogin;
113 if (!empty($force_install_databasepass)) {
114 $db_pass = $force_install_databasepass;
116 if (!empty($force_install_port)) {
117 $db_port = $force_install_port;
119 if (!empty($force_install_prefix)) {
120 $db_prefix = $force_install_prefix;
122 if (!empty($force_install_createdatabase)) {
123 $db_create_database = $force_install_createdatabase;
125 if (!empty($force_install_createuser)) {
126 $db_create_user = $force_install_createuser;
128 if (!empty($force_install_mainforcehttps)) {
129 $main_force_https = $force_install_mainforcehttps;
133 if (!empty($force_install_distrib)) {
134 $dolibarr_main_distrib = $force_install_distrib;
148 pHeader($langs->trans(
"ConfigurationFile"),
"step2");
151 if (!is_writable($conffile))
153 print $langs->trans(
"ConfFileIsNotWritable", $conffiletoshow);
154 pFooter(1, $setuplang,
'jscheckparam');
163 print '<div class="error">'.$langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"DatabaseType")).
'</div>';
166 $is_sqlite = ($db_type ===
'sqlite' || $db_type ===
'sqlite3');
168 if (empty($db_host) && !$is_sqlite)
170 print '<div class="error">'.$langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"Server")).
'</div>';
175 print '<div class="error">'.$langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"DatabaseName")).
'</div>';
178 if (empty($db_user) && !$is_sqlite)
180 print '<div class="error">'.$langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"Login")).
'</div>';
183 if (!empty($db_port) && !is_numeric($db_port))
185 print '<div class="error">'.$langs->trans(
"ErrorBadValueForParameter", $db_port, $langs->transnoentities(
"Port")).
'</div>';
188 if (!empty($db_prefix) && !preg_match(
'/^[a-z0-9]+_$/i', $db_prefix))
190 print '<div class="error">'.$langs->trans(
"ErrorBadValueForParameter", $db_prefix, $langs->transnoentities(
"DatabasePrefix")).
'</div>';
196 if (substr($main_dir,
dol_strlen($main_dir) - 1) ==
"/")
198 $main_dir = substr($main_dir, 0,
dol_strlen($main_dir) - 1);
202 if (!empty($main_url) && substr($main_url,
dol_strlen($main_url) - 1) ==
"/")
204 $main_url = substr($main_url, 0,
dol_strlen($main_url) - 1);
209 $result = @include_once $main_dir.
"/core/db/".$db_type.
'.class.php';
213 if (!empty($db_create_database) && !$userroot) {
214 print '<div class="error">'.$langs->trans(
"YouAskDatabaseCreationSoDolibarrNeedToConnect", $db_name).
'</div>';
216 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
217 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
220 if (!empty($db_create_user) && !$userroot) {
221 print '<div class="error">'.$langs->trans(
"YouAskLoginCreationSoDolibarrNeedToConnect", $db_user).
'</div>';
223 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
224 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
229 if (!$error && (!empty($db_create_database) || !empty($db_create_user))) {
230 $databasefortest = $db_name;
231 if (!empty($db_create_database)) {
232 if ($db_type ==
'mysql' || $db_type ==
'mysqli')
234 $databasefortest =
'mysql';
235 } elseif ($db_type ==
'pgsql')
237 $databasefortest =
'postgres';
239 $databasefortest =
'master';
244 $db =
getDoliDBInstance($db_type, $db_host, $userroot, $passroot, $databasefortest, $db_port);
246 dol_syslog(
"databasefortest=".$databasefortest.
" connected=".$db->connected.
" database_selected=".$db->database_selected, LOG_DEBUG);
249 if (empty($db_create_database) && $db->connected && !$db->database_selected) {
250 print '<div class="error">'.$langs->trans(
"ErrorConnectedButDatabaseNotFound", $db_name).
'</div>';
252 if (!$db->connected)
print $langs->trans(
"IfDatabaseNotExistsGoBackAndUncheckCreate").
'<br><br>';
253 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
255 } elseif ($db->error && !(!empty($db_create_database) && $db->connected)) {
257 if ($db->error ==
"No such file or directory")
print '<div class="error">'.$langs->trans(
"ErrorToConnectToMysqlCheckInstance").
'</div>';
258 else print '<div class="error">'.$db->error.
'</div>';
259 if (!$db->connected)
print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
261 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
267 if (!$error && (empty($db_create_database) && empty($db_create_user))) {
268 $db =
getDoliDBInstance($db_type, $db_host, $db_user, $db_pass, $db_name, $db_port);
272 print '<div class="error">'.$db->error.
'</div>';
273 if (!$db->connected)
print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
275 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
281 print "<br>\nFailed to include_once(\"".$main_dir.
"/core/db/".$db_type.
".class.php\")<br>\n";
282 print '<div class="error">'.$langs->trans(
"ErrorWrongValueForParameter", $langs->transnoentities(
"WebPagesDirectory")).
'</div>';
284 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
289 if (isset($db))
print $db->lasterror();
290 if (isset($db) && !$db->connected)
print '<br>'.$langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
291 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
295 if (!$error && $db->connected)
297 if (!empty($db_create_database)) {
298 $result = $db->select_db($db_name);
301 print '<div class="error">'.$langs->trans(
"ErrorDatabaseAlreadyExists", $db_name).
'</div>';
302 print $langs->trans(
"IfDatabaseExistsGoBackAndCheckCreate").
'<br><br>';
303 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
310 if (!$error && $db->connected)
312 if (!empty($db_create_database))
316 $defaultCharacterSet = $db->forcecharset;
317 $defaultDBSortingCollation = $db->forcecollate;
320 $defaultCharacterSet = $db->getDefaultCharacterSetDatabase();
321 $defaultDBSortingCollation = $db->getDefaultCollationDatabase();
326 if ($defaultCharacterSet ==
'utf8mb4' || $defaultDBSortingCollation ==
'utf8mb4_unicode_ci')
328 $defaultCharacterSet =
'utf8';
329 $defaultDBSortingCollation =
'utf8_unicode_ci';
332 print '<input type="hidden" name="dolibarr_main_db_character_set" value="'.$defaultCharacterSet.
'">';
333 print '<input type="hidden" name="dolibarr_main_db_collation" value="'.$defaultDBSortingCollation.
'">';
334 $db_character_set = $defaultCharacterSet;
335 $db_collation = $defaultDBSortingCollation;
341 if (!$error && $db->connected && $action ==
"set")
344 if (is_array($_POST))
346 foreach ($_POST as $key => $value)
348 if (!preg_match(
'/^db_pass/i', $key)) {
355 print '<h3><img class="valigntextbottom" src="../theme/common/octicons/build/svg/gear.svg" width="20" alt="Configuration"> '.$langs->trans(
"ConfigurationFile").
'</h3>';
356 print '<table cellspacing="0" width="100%" cellpadding="1" border="0">';
361 if (!is_dir($main_dir))
366 print $langs->trans(
"ErrorDirDoesNotExists", $main_dir).
'<br>';
367 print $langs->trans(
"ErrorWrongValueForParameter", $langs->transnoentitiesnoconv(
"WebPagesDirectory")).
'<br>';
368 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
370 print $langs->trans(
"Error");
386 if (!is_dir($main_data_dir))
391 if (!is_dir($main_data_dir))
393 print "<tr><td>".$langs->trans(
"ErrorDirDoesNotExists", $main_data_dir);
394 print ' '.$langs->trans(
"YouMustCreateItAndAllowServerToWrite");
396 print '<span class="error">'.$langs->trans(
"Error").
'</span>';
398 print '<tr><td colspan="2"><br>'.$langs->trans(
"CorrectProblemAndReloadPage",
$_SERVER[
'PHP_SELF'].
'?testget=ok').
'</td></tr>';
402 $pathhtaccess = $main_data_dir.
'/.htaccess';
403 if (!file_exists($pathhtaccess))
406 $handlehtaccess = @fopen($pathhtaccess,
'w');
409 fwrite($handlehtaccess,
'Order allow,deny'.
"\n");
410 fwrite($handlehtaccess,
'Deny from all'.
"\n");
412 fclose($handlehtaccess);
419 $dir[] = $main_data_dir.
"/mycompany";
420 $dir[] = $main_data_dir.
"/medias";
421 $dir[] = $main_data_dir.
"/users";
422 $dir[] = $main_data_dir.
"/facture";
423 $dir[] = $main_data_dir.
"/propale";
424 $dir[] = $main_data_dir.
"/ficheinter";
425 $dir[] = $main_data_dir.
"/produit";
426 $dir[] = $main_data_dir.
"/doctemplates";
430 for ($i = 0; $i < $num; $i++)
432 if (is_dir($dir[$i]))
439 print "Failed to create directory: ".$dir[$i];
441 print $langs->trans(
"Error");
450 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
453 $srcroot = $main_dir.
'/install/medias';
454 $destroot = $main_data_dir.
'/medias';
459 print "<tr><td>".$langs->trans(
"ErrorDirDoesNotExists", $main_data_dir);
460 print ' '.$langs->trans(
"YouMustCreateItAndAllowServerToWrite");
462 print '<span class="error">'.$langs->trans(
"Error").
'</span>';
464 print '<tr><td colspan="2"><br>'.$langs->trans(
"CorrectProblemAndReloadPage",
$_SERVER[
'PHP_SELF'].
'?testget=ok').
'</td></tr>';
467 $srcroot = $main_dir.
'/install/doctemplates';
468 $destroot = $main_data_dir.
'/doctemplates';
470 'contracts' =>
'contract',
471 'invoices' =>
'invoice',
473 'products' =>
'product',
474 'projects' =>
'project',
475 'proposals' =>
'proposal',
476 'shipments' =>
'shipment',
477 'supplier_proposals' =>
'supplier_proposal',
478 'tasks' =>
'task_summary',
479 'thirdparties' =>
'thirdparty',
480 'usergroups' =>
'usergroups',
483 foreach ($docs as $cursordir => $cursorfile)
485 $src = $srcroot.
'/'.$cursordir.
'/template_'.$cursorfile.
'.odt';
486 $dirodt = $destroot.
'/'.$cursordir;
487 $dest = $dirodt.
'/template_'.$cursorfile.
'.odt';
490 $result =
dol_copy($src, $dest, 0, 0);
493 print '<tr><td colspan="2"><br>'.$langs->trans(
'ErrorFailToCopyFile', $src, $dest).
'</td></tr>';
501 $main_db_prefix = (!empty($db_prefix) ? $db_prefix :
'llx_');
507 if (file_exists(
"$conffile"))
512 @
dol_copy($conffile, $conffile.
'.old',
'0400');
522 conf($dolibarr_main_document_root);
525 print $langs->trans(
"ConfFileReload");
527 print '<td><img src="../theme/eldy/img/tick.png" alt="Ok"></td></tr>';
530 if (isset($db_create_user) && ($db_create_user ==
"1" || $db_create_user ==
"on")) {
534 $databasefortest = $conf->db->name;
535 if ($conf->db->type ==
'mysql' || $conf->db->type ==
'mysqli')
537 $databasefortest =
'mysql';
538 } elseif ($conf->db->type ==
'pgsql')
540 $databasefortest =
'postgres';
541 } elseif ($conf->db->type ==
'mssql')
543 $databasefortest =
'master';
548 $db =
getDoliDBInstance($conf->db->type, $conf->db->host, $userroot, $passroot, $databasefortest, $conf->db->port);
552 print '<div class="error">'.$db->error.
'</div>';
563 $result = $db->DDLCreateUser($dolibarr_main_db_host, $dolibarr_main_db_user, $dolibarr_main_db_pass, $dolibarr_main_db_name);
566 if ($databasefortest ==
'mysql')
568 if (!in_array($dolibarr_main_db_host, array(
'127.0.0.1',
'::1',
'localhost',
'localhost.local')))
570 $resultbis = $db->DDLCreateUser(
'%', $dolibarr_main_db_user, $dolibarr_main_db_pass, $dolibarr_main_db_name);
574 if ($result > 0 && $resultbis > 0)
577 print $langs->trans(
"UserCreation").
' : ';
578 print $dolibarr_main_db_user;
580 print '<td><img src="../theme/eldy/img/tick.png" alt="Ok"></td></tr>';
582 if ($db->errno() ==
'DB_ERROR_RECORD_ALREADY_EXISTS'
583 || $db->errno() ==
'DB_ERROR_KEY_NAME_ALREADY_EXISTS'
584 || $db->errno() ==
'DB_ERROR_USER_ALREADY_EXISTS')
588 print $langs->trans(
"UserCreation").
' : ';
589 print $dolibarr_main_db_user;
591 print '<td>'.$langs->trans(
"LoginAlreadyExists").
'</td></tr>';
595 print $langs->trans(
"UserCreation").
' : ';
596 print $dolibarr_main_db_user;
598 print '<td>'.$langs->trans(
"Error").
': '.$db->errno().
' '.$db->error().($db->error ?
'. '.$db->error :
'').
"</td></tr>";
605 print $langs->trans(
"UserCreation").
' : ';
606 print $dolibarr_main_db_user;
608 print '<td><img src="../theme/eldy/img/error.png" alt="Error"></td>';
612 print '<tr><td colspan="2"><br>';
613 print $langs->trans(
"YouAskDatabaseCreationSoDolibarrNeedToConnect", $dolibarr_main_db_user, $dolibarr_main_db_host, $userroot);
615 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
616 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
626 if (!$error && (isset($db_create_database) && ($db_create_database ==
"1" || $db_create_database ==
"on"))) {
627 dolibarr_install_syslog(
"step1: create database: ".$dolibarr_main_db_name.
" ".$dolibarr_main_db_character_set.
" ".$dolibarr_main_db_collation.
" ".$dolibarr_main_db_user);
628 $newdb =
getDoliDBInstance($conf->db->type, $conf->db->host, $userroot, $passroot,
'', $conf->db->port);
631 if ($newdb->connected)
633 $result = $newdb->DDLCreateDb($dolibarr_main_db_name, $dolibarr_main_db_character_set, $dolibarr_main_db_collation, $dolibarr_main_db_user);
638 print $langs->trans(
"DatabaseCreation").
" (".$langs->trans(
"User").
" ".$userroot.
") : ";
639 print $dolibarr_main_db_name;
641 print '<td><img src="../theme/eldy/img/tick.png" alt="Ok"></td></tr>';
643 $newdb->select_db($dolibarr_main_db_name);
644 $check1 = $newdb->getDefaultCharacterSetDatabase();
645 $check2 = $newdb->getDefaultCollationDatabase();
653 print '<tr><td colspan="2"><br>';
654 print $langs->trans(
"ErrorFailedToCreateDatabase", $dolibarr_main_db_name).
'<br>';
655 print $newdb->lasterror().
'<br>';
656 print $langs->trans(
"IfDatabaseExistsGoBackAndCheckCreate");
660 dolibarr_install_syslog(
'step1: failed to create database '.$dolibarr_main_db_name.
' '.$newdb->lasterrno().
' '.$newdb->lasterror(), LOG_ERR);
666 print $langs->trans(
"DatabaseCreation").
" (".$langs->trans(
"User").
" ".$userroot.
") : ";
667 print $dolibarr_main_db_name;
669 print '<td><img src="../theme/eldy/img/error.png" alt="Error"></td>';
673 print '<tr><td colspan="2"><br>';
674 print $langs->trans(
"YouAskDatabaseCreationSoDolibarrNeedToConnect", $dolibarr_main_db_user, $dolibarr_main_db_host, $userroot);
676 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
677 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
688 dolibarr_install_syslog(
"step1: connection type=".$conf->db->type.
" on host=".$conf->db->host.
" port=".$conf->db->port.
" user=".$conf->db->user.
" name=".$conf->db->name);
691 $db =
getDoliDBInstance($conf->db->type, $conf->db->host, $conf->db->user, $conf->db->pass, $conf->db->name, $conf->db->port);
697 print $langs->trans(
"ServerConnection").
" (".$langs->trans(
"User").
" ".$conf->db->user.
") : ";
698 print $dolibarr_main_db_host;
700 print '<img src="../theme/eldy/img/tick.png" alt="Ok">';
704 if ($db->database_selected)
708 print $langs->trans(
"DatabaseConnection").
" (".$langs->trans(
"User").
" ".$conf->db->user.
") : ";
709 print $dolibarr_main_db_name;
711 print '<img src="../theme/eldy/img/tick.png" alt="Ok">';
716 dolibarr_install_syslog(
"step1: connection to database ".$conf->db->name.
" by user ".$conf->db->user.
" failed", LOG_ERR);
718 print $langs->trans(
"DatabaseConnection").
" (".$langs->trans(
"User").
" ".$conf->db->user.
") : ";
719 print $dolibarr_main_db_name;
721 print '<img src="../theme/eldy/img/error.png" alt="Error">';
725 print '<tr><td colspan="2"><br>';
726 print $langs->trans(
'CheckThatDatabasenameIsCorrect', $dolibarr_main_db_name).
'<br>';
727 print $langs->trans(
'IfAlreadyExistsCheckOption').
'<br>';
728 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
736 print $langs->trans(
"ServerConnection").
" (".$langs->trans(
"User").
" ".$conf->db->user.
") : ";
737 print $dolibarr_main_db_host;
739 print '<img src="../theme/eldy/img/error.png" alt="Error">';
743 print '<tr><td colspan="2"><br>';
744 print $langs->trans(
"ErrorConnection", $conf->db->host, $conf->db->name, $conf->db->user);
745 print $langs->trans(
'IfLoginDoesNotExistsCheckCreateUser').
'<br>';
746 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
759 <script
type=
"text/javascript">
766 document.getElementById(
'nextbutton').style.visibility=
"hidden";
767 document.getElementById(
'pleasewait').style.visibility=
"visible";
776 if ($error && isset($argv[1])) $ret = 1;
781 pFooter($error ? 1 : 0, $setuplang,
'jsinfo', 1);
784 if ($ret) exit($ret);
796 $fp = @fopen(
"$mainfile",
"w");
800 fputs($fp,
'<?php'.
"\n");
801 fputs($fp,
"// Wrapper to include main into htdocs\n");
802 fputs($fp,
"include_once '".$main_dir.
"/main.inc.php';\n");
817 $fp = @fopen(
"$masterfile",
"w");
821 fputs($fp,
'<?php'.
"\n");
822 fputs($fp,
"// Wrapper to include master into htdocs\n");
823 fputs($fp,
"include_once '".$main_dir.
"/master.inc.php';\n");
837 global $conf, $langs;
838 global $main_url, $main_dir, $main_data_dir, $main_force_https, $main_use_alt_dir, $main_alt_dir_name, $main_db_prefix;
839 global $dolibarr_main_url_root, $dolibarr_main_document_root, $dolibarr_main_data_root, $dolibarr_main_db_host;
840 global $dolibarr_main_db_port, $dolibarr_main_db_name, $dolibarr_main_db_user, $dolibarr_main_db_pass;
841 global $dolibarr_main_db_type, $dolibarr_main_db_character_set, $dolibarr_main_db_collation, $dolibarr_main_authentication;
842 global $dolibarr_main_distrib;
843 global $db_host, $db_port, $db_name, $db_user, $db_pass, $db_type, $db_character_set, $db_collation;
844 global $conffile, $conffiletoshow, $conffiletoshowshort;
845 global $force_dolibarr_lib_ADODB_PATH, $force_dolibarr_lib_NUSOAP_PATH;
846 global $force_dolibarr_lib_TCPDF_PATH, $force_dolibarr_lib_FPDI_PATH;
847 global $force_dolibarr_lib_GEOIP_PATH;
848 global $force_dolibarr_lib_ODTPHP_PATH, $force_dolibarr_lib_ODTPHP_PATHTOPCLZIP;
849 global $force_dolibarr_js_CKEDITOR, $force_dolibarr_js_JQUERY, $force_dolibarr_js_JQUERY_UI;
850 global $force_dolibarr_font_DOL_DEFAULT_TTF, $force_dolibarr_font_DOL_DEFAULT_TTF_BOLD;
854 $key = md5(uniqid(mt_rand(),
true));
856 $fp = fopen(
"$conffile",
"w");
861 fputs($fp,
'<?php'.
"\n");
862 fputs($fp,
'//'.
"\n");
863 fputs($fp,
'// File generated by Dolibarr installer '.DOL_VERSION.
' on '.
dol_print_date(
dol_now(),
'').
"\n");
864 fputs($fp,
'//'.
"\n");
865 fputs($fp,
'// Take a look at conf.php.example file for an example of '.$conffiletoshowshort.
' file'.
"\n");
866 fputs($fp,
'// and explanations for all possibles parameters.'.
"\n");
867 fputs($fp,
'//'.
"\n");
869 fputs($fp,
'$dolibarr_main_url_root=\''.str_replace(
"'",
"\'", trim($main_url)).
'\';
');
872 fputs($fp, '$dolibarr_main_document_root=\
''.str_replace(
"'",
"\'", trim($main_dir)).
'\';
');
875 fputs($fp, $main_use_alt_dir.'$dolibarr_main_url_root_alt=\
''.str_replace(
"'",
"\'", trim(
"/".$main_alt_dir_name)).
'\';
');
878 fputs($fp, $main_use_alt_dir.'$dolibarr_main_document_root_alt=\
''.str_replace(
"'",
"\'", trim($main_dir.
"/".$main_alt_dir_name)).
'\';
');
881 fputs($fp, '$dolibarr_main_data_root=\
''.str_replace(
"'",
"\'", trim($main_data_dir)).
'\';
');
884 fputs($fp, '$dolibarr_main_db_host=\
''.str_replace(
"'",
"\'", trim($db_host)).
'\';
');
887 fputs($fp, '$dolibarr_main_db_port=\
''.str_replace(
"'",
"\'", trim($db_port)).
'\';
');
890 fputs($fp, '$dolibarr_main_db_name=\
''.str_replace(
"'",
"\'", trim($db_name)).
'\';
');
893 fputs($fp, '$dolibarr_main_db_prefix=\
''.str_replace(
"'",
"\'", trim($main_db_prefix)).
'\';
');
896 fputs($fp, '$dolibarr_main_db_user=\
''.str_replace(
"'",
"\'", trim($db_user)).
'\';
');
898 fputs($fp, '$dolibarr_main_db_pass=\
''.str_replace(
"'",
"\'", trim($db_pass)).
'\';
');
901 fputs($fp, '$dolibarr_main_db_type=\
''.str_replace(
"'",
"\'", trim($db_type)).
'\';
');
904 fputs($fp, '$dolibarr_main_db_character_set=\
''.str_replace(
"'",
"\'", trim($db_character_set)).
'\';
');
907 fputs($fp, '$dolibarr_main_db_collation=\
''.str_replace(
"'",
"\'", trim($db_collation)).
'\';
');
914 fputs($fp,
'$dolibarr_main_authentication=\'dolibarr\';');
917 fputs($fp,
'//$dolibarr_main_demo=\'autologin,autopass\';');
920 fputs($fp,
'// Security settings');
923 fputs($fp,
'$dolibarr_main_prod=\'0\';');
926 fputs($fp,
'$dolibarr_main_force_https=\''.$main_force_https.
'\';
');
929 fputs($fp, '$dolibarr_main_restrict_os_commands=\
'mysqldump, mysql, pg_dump, pgrestore\';');
932 fputs($fp,
'$dolibarr_nocsrfcheck=\'0\';');
935 fputs($fp,
'$dolibarr_main_instance_unique_id=\''.$key.
'\';
');
938 fputs($fp, '$dolibarr_mailing_limit_sendbyweb=\
'0\';');
943 if (empty($force_dolibarr_lib_FPDF_PATH)) { fputs($fp,
'//'); $force_dolibarr_lib_FPDF_PATH =
''; }
944 fputs($fp,
'$dolibarr_lib_FPDF_PATH=\''.$force_dolibarr_lib_FPDF_PATH.
'\';
');
946 if (empty($force_dolibarr_lib_TCPDF_PATH)) { fputs($fp, '
947 fputs($fp,
'$dolibarr_lib_TCPDF_PATH=\''.$force_dolibarr_lib_TCPDF_PATH.
'\';
');
949 if (empty($force_dolibarr_lib_FPDI_PATH)) { fputs($fp, '
950 fputs($fp,
'$dolibarr_lib_FPDI_PATH=\''.$force_dolibarr_lib_FPDI_PATH.
'\';
');
952 if (empty($force_dolibarr_lib_TCPDI_PATH)) { fputs($fp, '
953 fputs($fp,
'$dolibarr_lib_TCPDI_PATH=\''.$force_dolibarr_lib_TCPDI_PATH.
'\';
');
955 if (empty($force_dolibarr_lib_ADODB_PATH)) { fputs($fp, '
956 fputs($fp,
'$dolibarr_lib_ADODB_PATH=\''.$force_dolibarr_lib_ADODB_PATH.
'\';
');
958 if (empty($force_dolibarr_lib_GEOIP_PATH)) { fputs($fp, '
959 fputs($fp,
'$dolibarr_lib_GEOIP_PATH=\''.$force_dolibarr_lib_GEOIP_PATH.
'\';
');
961 if (empty($force_dolibarr_lib_NUSOAP_PATH)) { fputs($fp, '
962 fputs($fp,
'$dolibarr_lib_NUSOAP_PATH=\''.$force_dolibarr_lib_NUSOAP_PATH.
'\';
');
964 if (empty($force_dolibarr_lib_ODTPHP_PATH)) { fputs($fp, '
965 fputs($fp,
'$dolibarr_lib_ODTPHP_PATH=\''.$force_dolibarr_lib_ODTPHP_PATH.
'\';
');
967 if (empty($force_dolibarr_lib_ODTPHP_PATHTOPCLZIP)) { fputs($fp, '
968 fputs($fp,
'$dolibarr_lib_ODTPHP_PATHTOPCLZIP=\''.$force_dolibarr_lib_ODTPHP_PATHTOPCLZIP.
'\';
');
970 if (empty($force_dolibarr_js_CKEDITOR)) { fputs($fp, '
971 fputs($fp,
'$dolibarr_js_CKEDITOR=\''.$force_dolibarr_js_CKEDITOR.
'\';
');
973 if (empty($force_dolibarr_js_JQUERY)) { fputs($fp, '
974 fputs($fp,
'$dolibarr_js_JQUERY=\''.$force_dolibarr_js_JQUERY.
'\';
');
976 if (empty($force_dolibarr_js_JQUERY_UI)) { fputs($fp, '
977 fputs($fp,
'$dolibarr_js_JQUERY_UI=\''.$force_dolibarr_js_JQUERY_UI.
'\';
');
980 // Write params to overwrites default font path
982 if (empty($force_dolibarr_font_DOL_DEFAULT_TTF)) { fputs($fp, '
983 fputs($fp,
'$dolibarr_font_DOL_DEFAULT_TTF=\''.$force_dolibarr_font_DOL_DEFAULT_TTF.
'\';
');
985 if (empty($force_dolibarr_font_DOL_DEFAULT_TTF_BOLD)) { fputs($fp, '
986 fputs($fp,
'$dolibarr_font_DOL_DEFAULT_TTF_BOLD=\''.$force_dolibarr_font_DOL_DEFAULT_TTF_BOLD.
'\';
');
990 fputs($fp, '$dolibarr_main_distrib=\
''.str_replace(
"'",
"\'", trim($dolibarr_main_distrib)).
'\';
');
995 if (file_exists("$conffile"))
997 include $conffile; // force config reload, do not put include_once
998 conf($dolibarr_main_document_root);
1001 print $langs->trans("SaveConfigurationFile");
1002 print ' <strong>
'.$conffile.'</strong>
';
1004 print '<img src=
"../theme/eldy/img/tick.png" alt=
"Ok">
';
detect_dolibarr_main_document_root()
Automatically detect Dolibarr's main document root.
GETPOST($paramname, $check= 'alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_copy($srcfile, $destfile, $newmask=0, $overwriteifexists=1)
Copy a file to another file.
dolCopyDir($srcfile, $destfile, $newmask, $overwriteifexists, $arrayreplacement=null, $excludesubdir=0)
Copy a dir to another dir.
pHeader($subtitle, $next, $action= 'set', $param= '', $forcejqueryurl= '', $csstable= 'main-inside')
Show HTML header of install pages.
getDoliDBInstance($type, $host, $user, $pass, $name, $port)
Return a DoliDB instance (database handler).
conf($dolibarr_main_document_root)
Load conf file (file must exists)
dol_now($mode= 'auto')
Return date for now.
parse_database_login($force_install_databaserootlogin)
Replaces automatic database login by actual value.
write_main_file($mainfile, $main_dir)
Create main file.
dolibarr_install_syslog($message, $level=LOG_DEBUG)
Log function for install pages.
write_master_file($masterfile, $main_dir)
Create master file.
dol_strlen($string, $stringencoding= 'UTF-8')
Make a strlen call.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename= '', $restricttologhandler= '', $logcontext=null)
Write log message into outputs.
parse_database_pass($force_install_databaserootpass)
Replaces automatic database password by actual value.
detect_dolibarr_main_url_root()
Automatically detect Dolibarr's main URL root.
print $_SERVER["PHP_SELF"]
Edit parameters.
detect_dolibarr_main_data_root($dolibarr_main_document_root)
Automatically detect Dolibarr's main data root.
pFooter($nonext=0, $setuplang= '', $jscheckfunction= '', $withpleasewait=0)
Print HTML footer of install pages.
print
Draft customers invoices.
dol_print_date($time, $format= '', $tzoutput= 'auto', $outputlangs= '', $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
write_conf_file($conffile)
Save configuration file.
if(preg_match('/crypted:/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type
dol_mkdir($dir, $dataroot= '', $newmask=null)
Creation of a directory (this can create recursive subdir)