31define(
'DONOTLOADCONF', 1);
55@phan-var-force string $dolibarr_main_db_collation
60$action =
GETPOST(
'action',
'aZ09') ?
GETPOST(
'action',
'aZ09') : (empty($argv[1]) ?
'' : $argv[1]);
61$setuplang =
GETPOST(
'selectlang',
'aZ09', 3) ?
GETPOST(
'selectlang',
'aZ09', 3) : (empty($argv[2]) ?
'auto' : $argv[2]);
62$langs->setDefaultLang($setuplang);
64$langs->loadLangs(array(
"admin",
"install",
"errors"));
67$main_dir =
GETPOST(
'main_dir') ?
GETPOST(
'main_dir') : (empty($argv[3]) ?
'' : $argv[3]);
69$main_data_dir =
GETPOST(
'main_data_dir') ?
GETPOST(
'main_data_dir') : (empty($argv[4]) ? ($main_dir.
'/documents') : $argv[4]);
71$main_url =
GETPOST(
'main_url') ?
GETPOST(
'main_url') : (empty($argv[5]) ?
'' : $argv[5]);
73$userroot =
GETPOST(
'db_user_root',
'alpha') ?
GETPOST(
'db_user_root',
'alpha') : (empty($argv[6]) ?
'' : $argv[6]);
74$passroot =
GETPOST(
'db_pass_root',
'password') ?
GETPOST(
'db_pass_root',
'password') : (empty($argv[7]) ?
'' : $argv[7]);
76$db_type =
GETPOST(
'db_type',
'aZ09') ?
GETPOST(
'db_type',
'aZ09') : (empty($argv[8]) ?
'' : $argv[8]);
77$db_host =
GETPOST(
'db_host',
'alpha') ?
GETPOST(
'db_host',
'alpha') : (empty($argv[9]) ?
'' : $argv[9]);
78$db_name =
GETPOST(
'db_name',
'aZ09') ?
GETPOST(
'db_name',
'aZ09') : (empty($argv[10]) ?
'' : $argv[10]);
79$db_user =
GETPOST(
'db_user',
'alpha') ?
GETPOST(
'db_user',
'alpha') : (empty($argv[11]) ?
'' : $argv[11]);
80$db_pass =
GETPOST(
'db_pass',
'password') ?
GETPOST(
'db_pass',
'password') : (empty($argv[12]) ?
'' : $argv[12]);
82$db_prefix =
GETPOST(
'db_prefix',
'aZ09') ?
GETPOST(
'db_prefix',
'aZ09') : (empty($argv[14]) ?
'' : $argv[14]);
83$db_create_database =
GETPOST(
'db_create_database',
'alpha') ?
GETPOST(
'db_create_database',
'alpha') : (empty($argv[15]) ?
'' : $argv[15]);
84$db_create_user =
GETPOST(
'db_create_user',
'alpha') ?
GETPOST(
'db_create_user',
'alpha') : (empty($argv[16]) ?
'' : $argv[16]);
86$main_force_https = ((
GETPOST(
"main_force_https",
'alpha') && (
GETPOST(
"main_force_https",
'alpha') ==
"on" ||
GETPOST(
"main_force_https",
'alpha') == 1)) ?
'1' :
'0');
88$main_use_alt_dir = ((
GETPOST(
"main_use_alt_dir",
'alpha') ==
'' || (
GETPOST(
"main_use_alt_dir",
'alpha') ==
"on" ||
GETPOST(
"main_use_alt_dir",
'alpha') == 1)) ?
'' :
'//');
90$main_alt_dir_name = ((
GETPOST(
"main_alt_dir_name",
'alpha') &&
GETPOST(
"main_alt_dir_name",
'alpha') !=
'') ?
GETPOST(
"main_alt_dir_name",
'alpha') :
'custom');
92$dolibarr_main_distrib =
'standard';
97$_SESSION[
'dol_save_pass'] = $db_pass;
101$useforcedwizard =
false;
102$forcedfile =
"./install.forced.php";
103if (
$conffile ==
"/etc/dolibarr/conf.php") {
104 $forcedfile =
"/etc/dolibarr/install.forced.php";
106if (@file_exists($forcedfile)) {
107 $useforcedwizard =
true;
108 include_once $forcedfile;
127 if (!empty($force_install_noedit)) {
129 if (!empty($argv[3])) {
130 $main_dir = $argv[3];
132 if (!empty($force_install_main_data_root)) {
133 $main_data_dir = $force_install_main_data_root;
137 if (!empty($argv[4])) {
138 $main_data_dir = $argv[4];
141 if ($force_install_noedit != 3) {
144 if (!empty($argv[5])) {
145 $main_url = $argv[5];
148 if (!empty($force_install_databaserootlogin)) {
151 if (!empty($argv[6])) {
152 $userroot = $argv[6];
154 if (!empty($force_install_databaserootpass)) {
157 if (!empty($argv[7])) {
158 $passroot = $argv[7];
161 if (($force_install_noedit == 2) || ($force_install_noedit == 3)) {
162 if (!empty($force_install_type)) {
163 $db_type = $force_install_type;
165 if (!empty($force_install_dbserver)) {
166 $db_host = $force_install_dbserver;
168 if (!empty($force_install_database)) {
169 $db_name = $force_install_database;
171 if (!empty($force_install_databaselogin)) {
172 $db_user = $force_install_databaselogin;
174 if (!empty($force_install_databasepass)) {
175 $db_pass = $force_install_databasepass;
177 if (!empty($force_install_port)) {
178 $db_port = $force_install_port;
180 if (!empty($force_install_prefix)) {
181 $db_prefix = $force_install_prefix;
183 if (!empty($force_install_createdatabase)) {
184 $db_create_database = $force_install_createdatabase;
186 if (!empty($force_install_createuser)) {
187 $db_create_user = $force_install_createuser;
189 if (!empty($force_install_mainforcehttps)) {
190 $main_force_https = $force_install_mainforcehttps;
194 if (!empty($force_install_distrib)) {
195 $dolibarr_main_distrib = $force_install_distrib;
216pHeader($langs->trans(
"DolibarrSetup").
' - '.$langs->trans(
"ConfigurationFile"),
"step2");
220 print $langs->trans(
"ConfFileIsNotWritable", $conffiletoshow);
221 pFooter(1, $setuplang,
'jscheckparam');
228if (empty($db_type)) {
229 print
'<div class="error">'.$langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"DatabaseType")).
'</div>';
232 $is_sqlite = ($db_type ===
'sqlite' || $db_type ===
'sqlite3');
234if (empty($db_host) && !$is_sqlite) {
235 print
'<div class="error">'.$langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"Server")).
'</div>';
238if (empty($db_name)) {
239 print
'<div class="error">'.$langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"DatabaseName")).
'</div>';
242if (empty($db_user) && !$is_sqlite) {
243 print
'<div class="error">'.$langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"Login")).
'</div>';
246if (!empty($db_port) && !is_numeric($db_port)) {
247 print
'<div class="error">'.$langs->trans(
"ErrorBadValueForParameter", $db_port, $langs->transnoentities(
"Port")).
'</div>';
250if (!empty($db_prefix) && !preg_match(
'/^[a-z0-9]+_$/i', $db_prefix)) {
251 print
'<div class="error">'.$langs->trans(
"ErrorBadValueForParameter", $db_prefix, $langs->transnoentities(
"DatabasePrefix")).
'</div>';
259if (!filter_var($main_url, FILTER_VALIDATE_URL)) {
260 print
'<div class="error">'.$langs->trans(
"ErrorBadValueForParameter", $main_url, $langs->transnoentitiesnoconv(
"URLRoot")).
'</div>';
262 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
267if (substr($main_dir,
dol_strlen($main_dir) - 1) ==
"/") {
268 $main_dir = substr($main_dir, 0,
dol_strlen($main_dir) - 1);
272if (!empty($main_url) && substr($main_url,
dol_strlen($main_url) - 1) ==
"/") {
273 $main_url = substr($main_url, 0,
dol_strlen($main_url) - 1);
277 print
'<div class="error">'.$langs->trans(
"ErrorBadValueForParameter", $main_dir, $langs->transnoentitiesnoconv(
"WebPagesDirectory")).
'</div>';
280 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
286 $result = @include_once $main_dir.
"/core/db/".$db_type.
'.class.php';
289 if (!empty($db_create_database) && !$userroot) {
290 print
'<div class="error">'.$langs->trans(
"YouAskDatabaseCreationSoDolibarrNeedToConnect", $db_name).
'</div>';
292 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
293 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
296 if (!empty($db_create_user) && !$userroot) {
297 print
'<div class="error">'.$langs->trans(
"YouAskLoginCreationSoDolibarrNeedToConnect", $db_user).
'</div>';
299 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
300 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
305 if (!$error && (!empty($db_create_database) || !empty($db_create_user))) {
306 $databasefortest = $db_name;
307 if (!empty($db_create_database)) {
308 if ($db_type ==
'mysql' || $db_type ==
'mysqli') {
309 $databasefortest =
'mysql';
310 } elseif ($db_type ==
'pgsql') {
311 $databasefortest =
'postgres';
313 $databasefortest =
'master';
317 $db =
getDoliDBInstance($db_type, $db_host, $userroot, $passroot, $databasefortest, (
int) $db_port);
319 dol_syslog(
"databasefortest=".$databasefortest.
" connected=".json_encode(
$db->connected).
" database_selected=".json_encode(
$db->database_selected), LOG_DEBUG);
321 if (empty($db_create_database) &&
$db->connected && !
$db->database_selected) {
322 print
'<div class="error">'.$langs->trans(
"ErrorConnectedButDatabaseNotFound", $db_name).
'</div>';
324 if (!
$db->connected) {
325 print $langs->trans(
"IfDatabaseNotExistsGoBackAndUncheckCreate").
'<br><br>';
327 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
329 } elseif (
$db->error && !(!empty($db_create_database) &&
$db->connected)) {
331 if (
$db->error ==
"No such file or directory") {
332 print
'<div class="error">'.$langs->trans(
"ErrorToConnectToMysqlCheckInstance").
'</div>';
334 print
'<div class="error">'.$db->error.
'</div>';
336 if (!
$db->connected) {
337 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
340 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
347 if (!$error && (empty($db_create_database) && empty($db_create_user))) {
351 print
'<div class="error">'.$db->error.
'</div>';
352 if (!
$db->connected) {
353 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
356 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
362 print
"<br>\nFailed to include_once(\"".$main_dir.
"/core/db/".$db_type.
".class.php\")<br>\n";
363 print
'<div class="error">'.$langs->trans(
"ErrorWrongValueForParameter", $langs->transnoentities(
"WebPagesDirectory")).
'</div>';
365 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
371if (!$error && $db !==
null &&
$db->connected) {
372 if (!empty($db_create_database)) {
373 $result =
$db->select_db($db_name);
375 print
'<div class="error">'.$langs->trans(
"ErrorDatabaseAlreadyExists", $db_name).
'</div>';
376 print $langs->trans(
"IfDatabaseExistsGoBackAndCheckCreate").
'<br><br>';
377 print $langs->trans(
"ErrorGoBackAndCorrectParameters");
384if (!$error && $db !==
null &&
$db->connected) {
385 if (!empty($db_create_database)) {
388 $defaultCharacterSet =
$db->forcecharset;
389 $defaultDBSortingCollation =
$db->forcecollate;
391 $defaultCharacterSet =
$db->getDefaultCharacterSetDatabase();
392 $defaultDBSortingCollation =
$db->getDefaultCollationDatabase();
396 if ($defaultCharacterSet ==
'utf8mb3' || $defaultDBSortingCollation ==
'utf8mb3_unicode_ci') {
397 $defaultCharacterSet =
'utf8';
398 $defaultDBSortingCollation =
'utf8_unicode_ci';
402 if ($defaultCharacterSet ==
'utf8mb4' || $defaultDBSortingCollation ==
'utf8mb4_unicode_ci') {
403 $defaultCharacterSet =
'utf8';
404 $defaultDBSortingCollation =
'utf8_unicode_ci';
407 print
'<input type="hidden" name="dolibarr_main_db_character_set" value="'.$defaultCharacterSet.
'">';
408 print
'<input type="hidden" name="dolibarr_main_db_collation" value="'.$defaultDBSortingCollation.
'">';
409 $db_character_set = $defaultCharacterSet;
410 $db_collation = $defaultDBSortingCollation;
416if (!$error && $db !==
null &&
$db->connected && $action ==
"set") {
418 if (is_array($_POST)) {
419 foreach ($_POST as $key => $value) {
420 if (!preg_match(
'/^db_pass/i', $key)) {
427 print
'<h3><img class="valignmiddle inline-block paddingright" src="../public/theme/common/gear.svg" width="20" alt="Configuration"> '.$langs->trans(
"ConfigurationFile").
'</h3>';
428 print
'<table cellspacing="0" class="centpercent" cellpadding="1">';
432 if (!is_dir($main_dir)) {
436 print $langs->trans(
"ErrorDirDoesNotExists", $main_dir).
'<br>';
437 print $langs->trans(
"ErrorWrongValueForParameter", $langs->transnoentitiesnoconv(
"WebPagesDirectory")).
'<br>';
438 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
440 print $langs->trans(
"Error");
454 if (!is_dir($main_data_dir)) {
458 if (!is_dir($main_data_dir)) {
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>';
468 $pathhtaccess = $main_data_dir.
'/.htaccess';
469 if (!file_exists($pathhtaccess)) {
471 $handlehtaccess = @fopen($pathhtaccess,
'w');
472 if ($handlehtaccess) {
473 fwrite($handlehtaccess,
'Order allow,deny'.
"\n");
474 fwrite($handlehtaccess,
'Deny from all'.
"\n");
476 fclose($handlehtaccess);
483 $dir[] = $main_data_dir.
"/mycompany";
484 $dir[] = $main_data_dir.
"/medias";
485 $dir[] = $main_data_dir.
"/users";
486 $dir[] = $main_data_dir.
"/facture";
487 $dir[] = $main_data_dir.
"/propale";
488 $dir[] = $main_data_dir.
"/ficheinter";
489 $dir[] = $main_data_dir.
"/produit";
490 $dir[] = $main_data_dir.
"/doctemplates";
494 for ($i = 0; $i < $num; $i++) {
495 if (is_dir($dir[$i])) {
500 print
"Failed to create directory: ".$dir[$i];
502 print $langs->trans(
"Error");
511 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
514 $srcroot = $main_dir.
'/install/medias';
515 $destroot = $main_data_dir.
'/medias';
519 print
"<tr><td>".$langs->trans(
"ErrorDirDoesNotExists", $main_data_dir);
520 print
' '.$langs->trans(
"YouMustCreateItAndAllowServerToWrite");
522 print
'<span class="error">'.$langs->trans(
"Error").
'</span>';
524 print
'<tr><td colspan="2"><br>'.$langs->trans(
"CorrectProblemAndReloadPage", $_SERVER[
'PHP_SELF'].
'?testget=ok').
'</td></tr>';
527 $srcroot = $main_dir.
'/install/doctemplates';
528 $destroot = $main_data_dir.
'/doctemplates';
530 'contracts' =>
'contract',
531 'invoices' =>
'invoice',
533 'products' =>
'product',
534 'projects' =>
'project',
535 'proposals' =>
'proposal',
536 'shipments' =>
'shipment',
537 'supplier_proposals' =>
'supplier_proposal',
538 'tasks' =>
'task_summary',
539 'thirdparties' =>
'thirdparty',
540 'usergroups' =>
'usergroups',
543 foreach ($docs as $cursordir => $cursorfile) {
544 $src = $srcroot.
'/'.$cursordir.
'/template_'.$cursorfile.
'.odt';
545 $dirodt = $destroot.
'/'.$cursordir;
546 $dest = $dirodt.
'/template_'.$cursorfile.
'.odt';
549 $result =
dol_copy($src, $dest,
'0', 0);
551 print
'<tr><td colspan="2"><br>'.$langs->trans(
'ErrorFailToCopyFile', $src, $dest).
'</td></tr>';
559 $main_db_prefix = (!empty($db_prefix) ? $db_prefix :
'llx_');
564 if (file_exists(
"$conffile")) {
577 conf($dolibarr_main_document_root);
580 print $langs->trans(
"ConfFileReload");
582 print
'<td>'.img_picto(
'OK',
'tick').
'</td></tr>';
585 if (isset($db_create_user) && ($db_create_user ==
"1" || $db_create_user ==
"on")) {
589 $databasefortest =
$conf->db->name;
590 if (
$conf->db->type ==
'mysql' ||
$conf->db->type ==
'mysqli') {
591 $databasefortest =
'mysql';
592 } elseif (
$conf->db->type ==
'pgsql') {
593 $databasefortest =
'postgres';
594 } elseif (
$conf->db->type ==
'mssql') {
595 $databasefortest =
'master';
601 if ($databasefortest ===
null) {
602 print
'<div class="error">Database name can not be empty</div>';
608 print
'<div class="error">'.$db->error.
'</div>';
613 if (!$error && $db !==
null) {
614 if (
$db->connected) {
617 if (empty($dolibarr_main_db_pass)) {
620 print $langs->trans(
"UserCreation").
' : ';
621 print $dolibarr_main_db_user;
623 print
'<td>'.$langs->trans(
"Error").
": A password for database user is mandatory.</td></tr>";
626 $result =
$db->DDLCreateUser($dolibarr_main_db_host, $dolibarr_main_db_user, $dolibarr_main_db_pass, $dolibarr_main_db_name);
629 if ($databasefortest ==
'mysql') {
630 if (!in_array($dolibarr_main_db_host, array(
'127.0.0.1',
'::1',
'localhost',
'localhost.local'))) {
631 $resultbis =
$db->DDLCreateUser(
'%', $dolibarr_main_db_user, $dolibarr_main_db_pass, $dolibarr_main_db_name);
635 if ($result > 0 && $resultbis > 0) {
637 print $langs->trans(
"UserCreation").
' : ';
638 print $dolibarr_main_db_user;
640 print
'<td>'.img_picto(
'OK',
'tick').
'</td></tr>';
642 if (
$db->errno() ==
'DB_ERROR_RECORD_ALREADY_EXISTS'
643 ||
$db->errno() ==
'DB_ERROR_KEY_NAME_ALREADY_EXISTS'
644 ||
$db->errno() ==
'DB_ERROR_USER_ALREADY_EXISTS') {
647 print $langs->trans(
"UserCreation").
' : ';
648 print $dolibarr_main_db_user;
650 print
'<td>'.$langs->trans(
"LoginAlreadyExists").
'</td></tr>';
654 print $langs->trans(
"UserCreation").
' : ';
655 print $dolibarr_main_db_user;
657 print
'<td>'.$langs->trans(
"Error").
': '.
$db->errno().
' '.
$db->error().($db->error ?
'. '.$db->error :
'').
"</td></tr>";
665 print $langs->trans(
"UserCreation").
' : ';
666 print $dolibarr_main_db_user;
668 print
'<td>'.img_picto(
'Error',
'warning',
'class="error"').
'</td>';
672 print
'<tr><td colspan="2"><br>';
673 print $langs->trans(
"YouAskDatabaseCreationSoDolibarrNeedToConnect", $dolibarr_main_db_user, $dolibarr_main_db_host, $userroot);
675 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
676 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
686 if (!$error && (isset($db_create_database) && ($db_create_database ==
"1" || $db_create_database ==
"on"))) {
687 dolibarr_install_syslog(
"step1: create database: ".$dolibarr_main_db_name.
" ".$dolibarr_main_db_character_set.
" ".$dolibarr_main_db_collation.
" ".$dolibarr_main_db_user);
691 if ($newdb->connected) {
692 $result = $newdb->DDLCreateDb($dolibarr_main_db_name, $dolibarr_main_db_character_set, $dolibarr_main_db_collation, $dolibarr_main_db_user);
696 print $langs->trans(
"DatabaseCreation").
" (".$langs->trans(
"User").
" ".$userroot.
") : ";
697 print $dolibarr_main_db_name;
699 print
'<td>'.img_picto(
'OK',
'tick').
'</td></tr>';
701 $newdb->select_db($dolibarr_main_db_name);
702 $check1 = $newdb->getDefaultCharacterSetDatabase();
703 $check2 = $newdb->getDefaultCollationDatabase();
711 print
'<tr><td colspan="2"><br>';
712 print $langs->trans(
"ErrorFailedToCreateDatabase", $dolibarr_main_db_name).
'<br>';
713 print $newdb->lasterror().
'<br>';
714 print $langs->trans(
"IfDatabaseExistsGoBackAndCheckCreate");
718 dolibarr_install_syslog(
'step1: failed to create database '.$dolibarr_main_db_name.
' '.$newdb->lasterrno().
' '.$newdb->lasterror(), LOG_ERR);
724 print $langs->trans(
"DatabaseCreation").
" (".$langs->trans(
"User").
" ".$userroot.
") : ";
725 print $dolibarr_main_db_name;
727 print
'<td>'.img_picto(
'Error',
'warning',
'class="error"').
'</td>';
731 print
'<tr><td colspan="2"><br>';
732 print $langs->trans(
"YouAskDatabaseCreationSoDolibarrNeedToConnect", $dolibarr_main_db_user, $dolibarr_main_db_host, $userroot);
734 print $langs->trans(
"BecauseConnectionFailedParametersMayBeWrong").
'<br><br>';
735 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
750 if (
$db->connected) {
753 print $langs->trans(
"ServerConnection").
" (".$langs->trans(
"User").
" ".((
string)
$conf->db->user).
") : ";
754 print $dolibarr_main_db_host;
760 if (
$db->database_selected) {
763 print $langs->trans(
"DatabaseConnection").
" (".$langs->trans(
"User").
" ".((
string)
$conf->db->user).
") : ";
764 print $dolibarr_main_db_name;
773 print $langs->trans(
"DatabaseConnection").
" (".$langs->trans(
"User").
" ".((
string)
$conf->db->user).
") : ";
774 print $dolibarr_main_db_name;
776 print
img_picto(
'Error',
'warning',
'class="error"');
780 print
'<tr><td colspan="2"><br>';
781 print $langs->trans(
'CheckThatDatabasenameIsCorrect', $dolibarr_main_db_name).
'<br>';
782 print $langs->trans(
'IfAlreadyExistsCheckOption').
'<br>';
783 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
791 print $langs->trans(
"ServerConnection").
" (".$langs->trans(
"User").
" ".((
string)
$conf->db->user).
") : ";
792 print $dolibarr_main_db_host;
794 print
img_picto(
'Error',
'warning',
'class="error"');
798 print
'<tr><td colspan="2"><br>';
799 print $langs->trans(
"ErrorConnection",
$conf->db->host,
$conf->db->name, ((
string)
$conf->db->user));
800 print $langs->trans(
'IfLoginDoesNotExistsCheckCreateUser').
'<br>';
801 print $langs->trans(
"ErrorGoBackAndCorrectParameters").
'<br><br>';
814<script
type=
"text/javascript">
821 document.getElementById(
'nextbutton').style.visibility=
"hidden";
822 document.getElementById(
'pleasewait').style.visibility=
"visible";
831if ($error && isset($argv[1])) {
838pFooter($error ? 1 : 0, $setuplang,
'jsinfo', 1);
855 $fp = @fopen(
"$mainfile",
"w");
858 fwrite($fp,
'<?php'.
"\n");
859 fwrite($fp,
"// Wrapper to include main into htdocs\n");
860 fwrite($fp,
"include_once '".$main_dir.
"/main.inc.php';\n");
875 $fp = @fopen(
"$masterfile",
"w");
878 fwrite($fp,
'<?php'.
"\n");
879 fwrite($fp,
"// Wrapper to include master into htdocs\n");
880 fwrite($fp,
"include_once '".$main_dir.
"/master.inc.php';\n");
894 global
$conf, $langs;
895 global $main_url, $main_dir, $main_data_dir, $main_force_https, $main_use_alt_dir, $main_alt_dir_name, $main_db_prefix;
896 global
$dolibarr_main_url_root, $dolibarr_main_document_root, $dolibarr_main_data_root, $dolibarr_main_db_host;
897 global $dolibarr_main_db_port, $dolibarr_main_db_name, $dolibarr_main_db_user, $dolibarr_main_db_pass;
898 global $dolibarr_main_db_type, $dolibarr_main_db_character_set, $dolibarr_main_db_collation, $dolibarr_main_authentication;
899 global $dolibarr_main_distrib;
900 global $db_host, $db_port, $db_name, $db_user, $db_pass, $db_type, $db_character_set, $db_collation;
902 global $force_dolibarr_lib_NUSOAP_PATH;
903 global $force_dolibarr_lib_FPDF_PATH, $force_dolibarr_lib_TCPDF_PATH, $force_dolibarr_lib_TCPDI_PATH, $force_dolibarr_lib_FPDI_PATH;
904 global $force_dolibarr_lib_GEOIP_PATH;
905 global $force_dolibarr_lib_ODTPHP_PATH, $force_dolibarr_lib_ODTPHP_PATHTOPCLZIP;
906 global $force_dolibarr_js_CKEDITOR, $force_dolibarr_js_JQUERY, $force_dolibarr_js_JQUERY_UI;
907 global $force_dolibarr_font_DOL_DEFAULT_TTF, $force_dolibarr_font_DOL_DEFAULT_TTF_BOLD;
911 $key = bin2hex(random_bytes(32));
913 $fp = fopen(
"$conffile",
"w");
917 fwrite($fp,
'<?php'.
"\n");
918 fwrite($fp,
'//'.
"\n");
919 fwrite($fp,
'// File generated by Dolibarr installer '.DOL_VERSION.
' on '.
dol_print_date(
dol_now(),
'').
"\n");
920 fwrite($fp,
'//'.
"\n");
921 fwrite($fp,
'// Take a look at conf.php.example file for an example of '.basename(
$conffile).
' file'.
"\n");
922 fwrite($fp,
'// and explanations for all possibles parameters.'.
"\n");
923 fwrite($fp,
'//'.
"\n");
924 fwrite($fp,
'$dolibarr_main_url_root=\''.
dol_escape_php(trim($main_url), 1).
'\';
');
927 fwrite($fp, '$dolibarr_main_document_root=
"'.dol_escape_php(dol_sanitizePathName(trim($main_dir))).'";
');
930 fwrite($fp, $main_use_alt_dir.'$dolibarr_main_url_root_alt=\
''.dol_escape_php(trim(
"/".$main_alt_dir_name), 1).
'\';
');
933 fwrite($fp, $main_use_alt_dir.'$dolibarr_main_document_root_alt=
"'.dol_escape_php(dol_sanitizePathName(trim($main_dir."/
".$main_alt_dir_name))).'";
');
936 fwrite($fp, '$dolibarr_main_data_root=
"'.dol_escape_php(dol_sanitizePathName(trim($main_data_dir))).'";
');
939 fwrite($fp, '$dolibarr_main_db_host=\
''.dol_escape_php(trim($db_host), 1).
'\';
');
942 fwrite($fp, '$dolibarr_main_db_port=\
''.((int) $db_port).
'\';
');
945 fwrite($fp, '$dolibarr_main_db_name=\
''.dol_escape_php(trim($db_name), 1).
'\';
');
948 fwrite($fp, '$dolibarr_main_db_prefix=\
''.dol_escape_php(trim($main_db_prefix), 1).
'\';
');
951 fwrite($fp, '$dolibarr_main_db_user=\
''.dol_escape_php(trim($db_user), 1).
'\';
');
953 fwrite($fp, '$dolibarr_main_db_pass=\
''.dol_escape_php(trim($db_pass), 1).
'\';
');
956 fwrite($fp, '$dolibarr_main_db_type=\
''.dol_escape_php(trim($db_type), 1).
'\';
');
959 fwrite($fp, '$dolibarr_main_db_character_set=\
''.dol_escape_php(trim($db_character_set), 1).
'\';
');
962 fwrite($fp, '$dolibarr_main_db_collation=\
''.dol_escape_php(trim($db_collation), 1).
'\';
');
969 fwrite($fp,
'$dolibarr_main_authentication=\'dolibarr\';');
972 fwrite($fp,
'//$dolibarr_main_demo=\'autologin,autopass\';');
975 fwrite($fp,
'// Security settings');
978 fwrite($fp,
'$dolibarr_main_prod=\'0\';');
981 fwrite($fp,
'$dolibarr_main_force_https=\''.
dol_escape_php($main_force_https, 1).
'\';
');
984 fwrite($fp, '$dolibarr_main_restrict_os_commands=\
'mariadb-dump, mariadb, mysqldump, mysql, pg_dump, pg_restore, clamdscan, clamdscan.exe\';');
987 fwrite($fp,
'$dolibarr_main_restrict_eval_methods=\'getDolGlobalString, getDolGlobalInt, getDolCurrency, getDolEntity, getDolDBType, fetchNoCompute, hasRight, isAdmin, isModEnabled, isStringVarMatching, abs, min, max, round, dol_now, preg_match\';');
990 fwrite($fp,
'$dolibarr_nocsrfcheck=\'0\';');
993 fwrite($fp,
'$dolibarr_main_instance_unique_id=\''.
dol_escape_php($key, 1).
'\';
');
996 fwrite($fp, '$dolibarr_mailing_limit_sendbyweb=\
'0\';');
998 fwrite($fp,
'$dolibarr_mailing_limit_sendbycli=\'0\';');
1003 if (empty($force_dolibarr_lib_FPDF_PATH)) {
1005 $force_dolibarr_lib_FPDF_PATH =
'';
1009 if (empty($force_dolibarr_lib_TCPDF_PATH)) {
1011 $force_dolibarr_lib_TCPDF_PATH =
'';
1015 if (empty($force_dolibarr_lib_FPDI_PATH)) {
1017 $force_dolibarr_lib_FPDI_PATH =
'';
1021 if (empty($force_dolibarr_lib_TCPDI_PATH)) {
1023 $force_dolibarr_lib_TCPDI_PATH =
'';
1027 if (empty($force_dolibarr_lib_GEOIP_PATH)) {
1029 $force_dolibarr_lib_GEOIP_PATH =
'';
1033 if (empty($force_dolibarr_lib_NUSOAP_PATH)) {
1035 $force_dolibarr_lib_NUSOAP_PATH =
'';
1039 if (empty($force_dolibarr_lib_ODTPHP_PATH)) {
1041 $force_dolibarr_lib_ODTPHP_PATH =
'';
1045 if (empty($force_dolibarr_lib_ODTPHP_PATHTOPCLZIP)) {
1047 $force_dolibarr_lib_ODTPHP_PATHTOPCLZIP =
'';
1051 if (empty($force_dolibarr_js_CKEDITOR)) {
1053 $force_dolibarr_js_CKEDITOR =
'';
1055 fwrite($fp,
'$dolibarr_js_CKEDITOR=\''.
dol_escape_php($force_dolibarr_js_CKEDITOR, 1).
'\';
');
1057 if (empty($force_dolibarr_js_JQUERY)) {
1059 $force_dolibarr_js_JQUERY =
'';
1061 fwrite($fp,
'$dolibarr_js_JQUERY=\''.
dol_escape_php($force_dolibarr_js_JQUERY, 1).
'\';
');
1063 if (empty($force_dolibarr_js_JQUERY_UI)) {
1065 $force_dolibarr_js_JQUERY_UI =
'';
1067 fwrite($fp,
'$dolibarr_js_JQUERY_UI=\''.
dol_escape_php($force_dolibarr_js_JQUERY_UI, 1).
'\';
');
1070 // Write params to overwrites default font path
1072 if (empty($force_dolibarr_font_DOL_DEFAULT_TTF)) {
1074 $force_dolibarr_font_DOL_DEFAULT_TTF =
'';
1076 fwrite($fp,
'$dolibarr_font_DOL_DEFAULT_TTF=\''.
dol_escape_php($force_dolibarr_font_DOL_DEFAULT_TTF, 1).
'\';
');
1078 if (empty($force_dolibarr_font_DOL_DEFAULT_TTF_BOLD)) {
1080 $force_dolibarr_font_DOL_DEFAULT_TTF_BOLD =
'';
1082 fwrite($fp,
'$dolibarr_font_DOL_DEFAULT_TTF_BOLD=\''.
dol_escape_php($force_dolibarr_font_DOL_DEFAULT_TTF_BOLD, 1).
'\';
');
1086 fwrite($fp, '$dolibarr_main_distrib=\
''.dol_escape_php(trim($dolibarr_main_distrib), 1).
'\';
');
1091 if (file_exists("$conffile")) {
1092 include $conffile; // force config reload, do not put include_once
1093 conf($dolibarr_main_document_root);
1096 print $langs->trans("SaveConfigurationFile");
1097 print ' <strong>
'.$conffile.'</strong>
';
1099 print img_picto('OK
', 'tick
');
global $dolibarr_main_url_root
dol_copy($srcfile, $destfile, $newmask='0', $overwriteifexists=1, $testvirus=0, $indexdatabase=0)
Copy a file to another file.
dolCopyDir($srcfile, $destfile, $newmask, $overwriteifexists, $arrayreplacement=null, $excludesubdir=0, $excludefileext=null, $excludearchivefiles=0)
Copy a dir to another dir.
dol_is_dir($folder)
Test if filename is a directory.
dol_now($mode='gmt')
Return date for now.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_sanitizePathName($str, $newstr='_', $unaccent=0, $allowdash=0)
Clean a string to use it as a path name.
dol_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
dol_escape_php($stringtoescape, $stringforquotes=2)
Returns text escaped for inclusion into a php string, build with double quotes " or '.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_mkdir($dir, $dataroot='', $newmask='')
Creation of a directory (this can create recursive subdir)
getDoliDBInstance($type, $host, $user, $pass, $name, $port)
Return a DoliDB instance (database handler).
conf($dolibarr_main_document_root)
Load conf file (file must exists)
pHeader($subtitle, $next, $action='set', $param='', $forcejqueryurl='', $csstable='main-inside')
Show HTML header of install pages.
detect_dolibarr_main_data_root($dolibarr_main_document_root)
Automatically detect Dolibarr's main data root.
pFooter($nonext=0, $setuplang='', $jscheckfunction='', $withpleasewait=0, $morehtml='')
Print HTML footer of install pages.
parse_database_login($force_install_databaserootlogin)
Replaces automatic database login by actual value.
parse_database_pass($force_install_databaserootpass)
Replaces automatic database password by actual value.
dolibarr_install_syslog($message, $level=LOG_DEBUG)
Log function for install pages.
detect_dolibarr_main_url_root()
Automatically detect Dolibarr's main URL root.
detect_dolibarr_main_document_root()
Automatically detect Dolibarr's main document root.
print $langs trans("Show") . '< td style="' . $timeColor . '" align="center"> s</td > badge status0 badge status4 badge status3 Error badge status8< td align="center">< span class="badge ' . $badge . '"></span ></td >< td align="center">< a href="#" class="button button-small" onclick="openLogModal(this)" data-req="' . dol_escape_htmltag($reqSafe) . '" data-res="' . dol_escape_htmltag($resSafe) . '" data-err="' . dol_escape_htmltag($errSafe) . '">< span class="fa fa-search-plus"></span ></a ></td ></tr >< tr >< td colspan="' . $colspan . '" class="opacitymedium"></td ></tr ></table ></div ></form > logModal none logModal none s a JSON string
buildzip.php
if(preg_match('/(crypted|dolcrypt):/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type
'integer', 'integer:ObjectClass:PathToClass[:AddCreateButtonOrNot[:Filter[:Sortfield]]]',...
if( $ret) write_main_file($mainfile, $main_dir)
Create main file.
write_conf_file($conffile)
Save configuration file.
write_master_file($masterfile, $main_dir)
Create master file.