dolibarr 24.0.0-beta
step1.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2004-2007 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3 * Copyright (C) 2004-2016 Laurent Destailleur <eldy@users.sourceforge.net>
4 * Copyright (C) 2004 Benoit Mortier <benoit.mortier@opensides.be>
5 * Copyright (C) 2004 Sebastien Di Cintio <sdicintio@ressource-toi.org>
6 * Copyright (C) 2005-2011 Regis Houssin <regis.houssin@inodbox.com>
7 * Copyright (C) 2015-2016 Raphaël Doursenaud <rdoursenaud@gpcsolutions.fr>
8 * Copyright (C) 2024-2026 MDW <mdeweerd@users.noreply.github.com>
9 * Copyright (C) 2024 Frédéric France <frederic.france@free.fr>
10 *
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 3 of the License, or
14 * (at your option) any later version.
15 *
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with this program. If not, see <https://www.gnu.org/licenses/>.
23 */
24
31define('DONOTLOADCONF', 1); // To avoid loading conf by file inc.php
32
33include 'inc.php';
54'
55@phan-var-force string $dolibarr_main_db_collation
56';
57
58global $langs;
59
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);
63
64$langs->loadLangs(array("admin", "install", "errors"));
65
66// Dolibarr pages directory
67$main_dir = GETPOST('main_dir') ? GETPOST('main_dir') : (empty($argv[3]) ? '' : $argv[3]);
68// Directory for generated documents (invoices, orders, ecm, etc...)
69$main_data_dir = GETPOST('main_data_dir') ? GETPOST('main_data_dir') : (empty($argv[4]) ? ($main_dir.'/documents') : $argv[4]);
70// Dolibarr root URL
71$main_url = GETPOST('main_url') ? GETPOST('main_url') : (empty($argv[5]) ? '' : $argv[5]);
72// Database login information
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]);
75// Database server
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]);
81$db_port = GETPOSTINT('db_port') ? GETPOSTINT('db_port') : (empty($argv[13]) ? '' : $argv[13]);
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]);
85// Force https
86$main_force_https = ((GETPOST("main_force_https", 'alpha') && (GETPOST("main_force_https", 'alpha') == "on" || GETPOST("main_force_https", 'alpha') == 1)) ? '1' : '0');
87// Use alternative directory
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)) ? '' : '//');
89// Alternative root directory name
90$main_alt_dir_name = ((GETPOST("main_alt_dir_name", 'alpha') && GETPOST("main_alt_dir_name", 'alpha') != '') ? GETPOST("main_alt_dir_name", 'alpha') : 'custom');
91
92$dolibarr_main_distrib = 'standard';
93
94session_start(); // To be able to keep info into session (used for not losing password during navigation. The password must not transit through parameters)
95
96// Save a flag to tell to restore input value if we go back
97$_SESSION['dol_save_pass'] = $db_pass;
98//$_SESSION['dol_save_passroot']=$passroot;
99
100// Now we load forced values from install.forced.php file.
101$useforcedwizard = false;
102$forcedfile = "./install.forced.php";
103if ($conffile == "/etc/dolibarr/conf.php") {
104 $forcedfile = "/etc/dolibarr/install.forced.php";
105}
106if (@file_exists($forcedfile)) {
107 $useforcedwizard = true;
108 include_once $forcedfile;
126 // If forced install is enabled, replace the post values. These are empty because form fields are disabled.
127 if (!empty($force_install_noedit)) {
129 if (!empty($argv[3])) {
130 $main_dir = $argv[3]; // override when executing the script in command line
131 }
132 if (!empty($force_install_main_data_root)) {
133 $main_data_dir = $force_install_main_data_root;
134 } else {
135 $main_data_dir = detect_dolibarr_main_data_root($main_dir);
136 }
137 if (!empty($argv[4])) {
138 $main_data_dir = $argv[4]; // override when executing the script in command line
139 }
140 // In mode 3 the main_url is custom
141 if ($force_install_noedit != 3) {
142 $main_url = detect_dolibarr_main_url_root();
143 }
144 if (!empty($argv[5])) {
145 $main_url = $argv[5]; // override when executing the script in command line
146 }
147
148 if (!empty($force_install_databaserootlogin)) {
149 $userroot = parse_database_login($force_install_databaserootlogin);
150 }
151 if (!empty($argv[6])) {
152 $userroot = $argv[6]; // override when executing the script in command line
153 }
154 if (!empty($force_install_databaserootpass)) {
155 $passroot = parse_database_pass($force_install_databaserootpass);
156 }
157 if (!empty($argv[7])) {
158 $passroot = $argv[7]; // override when executing the script in command line
159 }
160 }
161 if (($force_install_noedit == 2) || ($force_install_noedit == 3)) {
162 if (!empty($force_install_type)) {
163 $db_type = $force_install_type;
164 }
165 if (!empty($force_install_dbserver)) {
166 $db_host = $force_install_dbserver;
167 }
168 if (!empty($force_install_database)) {
169 $db_name = $force_install_database;
170 }
171 if (!empty($force_install_databaselogin)) {
172 $db_user = $force_install_databaselogin;
173 }
174 if (!empty($force_install_databasepass)) {
175 $db_pass = $force_install_databasepass;
176 }
177 if (!empty($force_install_port)) {
178 $db_port = $force_install_port;
179 }
180 if (!empty($force_install_prefix)) {
181 $db_prefix = $force_install_prefix;
182 }
183 if (!empty($force_install_createdatabase)) {
184 $db_create_database = $force_install_createdatabase;
185 }
186 if (!empty($force_install_createuser)) {
187 $db_create_user = $force_install_createuser;
188 }
189 if (!empty($force_install_mainforcehttps)) {
190 $main_force_https = $force_install_mainforcehttps;
191 }
192 }
193
194 if (!empty($force_install_distrib)) {
195 $dolibarr_main_distrib = $force_install_distrib;
196 }
197}
198
199
200$error = 0;
201
202
203/*
204 * Actions
205 */
206
207// None
208
209
210/*
211 * View
212 */
213
214dolibarr_install_syslog("--- step1: entering step1.php page");
215
216pHeader($langs->trans("DolibarrSetup").' - '.$langs->trans("ConfigurationFile"), "step2");
217
218// Test if we can run a first install process
219if (!is_writable($conffile)) {
220 print $langs->trans("ConfFileIsNotWritable", $conffiletoshow);
221 pFooter(1, $setuplang, 'jscheckparam');
222 exit;
223}
224
225
226// Check parameters
227$is_sqlite = false;
228if (empty($db_type)) {
229 print '<div class="error">'.$langs->trans("ErrorFieldRequired", $langs->transnoentities("DatabaseType")).'</div>';
230 $error++;
231} else {
232 $is_sqlite = ($db_type === 'sqlite' || $db_type === 'sqlite3');
233}
234if (empty($db_host) && !$is_sqlite) {
235 print '<div class="error">'.$langs->trans("ErrorFieldRequired", $langs->transnoentities("Server")).'</div>';
236 $error++;
237}
238if (empty($db_name)) {
239 print '<div class="error">'.$langs->trans("ErrorFieldRequired", $langs->transnoentities("DatabaseName")).'</div>';
240 $error++;
241}
242if (empty($db_user) && !$is_sqlite) {
243 print '<div class="error">'.$langs->trans("ErrorFieldRequired", $langs->transnoentities("Login")).'</div>';
244 $error++;
245}
246if (!empty($db_port) && !is_numeric($db_port)) {
247 print '<div class="error">'.$langs->trans("ErrorBadValueForParameter", $db_port, $langs->transnoentities("Port")).'</div>';
248 $error++;
249}
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>';
252 $error++;
253}
254
255$db = null;
256$main_dir = dol_sanitizePathName($main_dir);
257$main_data_dir = dol_sanitizePathName($main_data_dir);
258
259if (!filter_var($main_url, FILTER_VALIDATE_URL)) {
260 print '<div class="error">'.$langs->trans("ErrorBadValueForParameter", $main_url, $langs->transnoentitiesnoconv("URLRoot")).'</div>';
261 print '<br>';
262 print $langs->trans("ErrorGoBackAndCorrectParameters");
263 $error++;
264}
265
266// Remove last / into dans main_dir
267if (substr($main_dir, dol_strlen($main_dir) - 1) == "/") {
268 $main_dir = substr($main_dir, 0, dol_strlen($main_dir) - 1);
269}
270
271// Remove last / into dans main_url
272if (!empty($main_url) && substr($main_url, dol_strlen($main_url) - 1) == "/") {
273 $main_url = substr($main_url, 0, dol_strlen($main_url) - 1);
274}
275
276if (!dol_is_dir($main_dir.'/core/db/')) {
277 print '<div class="error">'.$langs->trans("ErrorBadValueForParameter", $main_dir, $langs->transnoentitiesnoconv("WebPagesDirectory")).'</div>';
278 print '<br>';
279 //print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
280 print $langs->trans("ErrorGoBackAndCorrectParameters");
281 $error++;
282}
283
284// Test database connection
285if (!$error) {
286 $result = @include_once $main_dir."/core/db/".$db_type.'.class.php';
287 if ($result) {
288 // If we require database or user creation we need to connect as root, so we need root login credentials
289 if (!empty($db_create_database) && !$userroot) {
290 print '<div class="error">'.$langs->trans("YouAskDatabaseCreationSoDolibarrNeedToConnect", $db_name).'</div>';
291 print '<br>';
292 print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
293 print $langs->trans("ErrorGoBackAndCorrectParameters");
294 $error++;
295 }
296 if (!empty($db_create_user) && !$userroot) {
297 print '<div class="error">'.$langs->trans("YouAskLoginCreationSoDolibarrNeedToConnect", $db_user).'</div>';
298 print '<br>';
299 print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
300 print $langs->trans("ErrorGoBackAndCorrectParameters");
301 $error++;
302 }
303
304 // If we need root access
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';
312 } else {
313 $databasefortest = 'master';
314 }
315 }
316
317 $db = getDoliDBInstance($db_type, $db_host, $userroot, $passroot, $databasefortest, (int) $db_port);
318
319 dol_syslog("databasefortest=".$databasefortest." connected=".json_encode($db->connected)." database_selected=".json_encode($db->database_selected), LOG_DEBUG);
320
321 if (empty($db_create_database) && $db->connected && !$db->database_selected) {
322 print '<div class="error">'.$langs->trans("ErrorConnectedButDatabaseNotFound", $db_name).'</div>';
323 print '<br>';
324 if (!$db->connected) {
325 print $langs->trans("IfDatabaseNotExistsGoBackAndUncheckCreate").'<br><br>';
326 }
327 print $langs->trans("ErrorGoBackAndCorrectParameters");
328 $error++;
329 } elseif ($db->error && !(!empty($db_create_database) && $db->connected)) {
330 // Note: you may experience error here with message "No such file or directory" when mysql was installed for the first time but not yet launched.
331 if ($db->error == "No such file or directory") {
332 print '<div class="error">'.$langs->trans("ErrorToConnectToMysqlCheckInstance").'</div>';
333 } else {
334 print '<div class="error">'.$db->error.'</div>';
335 }
336 if (!$db->connected) {
337 print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
338 }
339 //print '<a href="#" onClick="javascript: history.back();">';
340 print $langs->trans("ErrorGoBackAndCorrectParameters");
341 //print '</a>';
342 $error++;
343 }
344 }
345
346 // If we need simple access
347 if (!$error && (empty($db_create_database) && empty($db_create_user))) {
348 $db = getDoliDBInstance($db_type, $db_host, $db_user, $db_pass, $db_name, (int) $db_port);
349
350 if ($db->error) {
351 print '<div class="error">'.$db->error.'</div>';
352 if (!$db->connected) {
353 print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
354 }
355 //print '<a href="#" onClick="javascript: history.back();">';
356 print $langs->trans("ErrorGoBackAndCorrectParameters");
357 //print '</a>';
358 $error++;
359 }
360 }
361 } else {
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>';
364 //print '<a href="#" onClick="javascript: history.back();">';
365 print $langs->trans("ErrorGoBackAndCorrectParameters");
366 //print '</a>';
367 $error++;
368 }
369}
370
371if (!$error && $db !== null && $db->connected) {
372 if (!empty($db_create_database)) {
373 $result = $db->select_db($db_name);
374 if ($result) {
375 print '<div class="error">'.$langs->trans("ErrorDatabaseAlreadyExists", $db_name).'</div>';
376 print $langs->trans("IfDatabaseExistsGoBackAndCheckCreate").'<br><br>';
377 print $langs->trans("ErrorGoBackAndCorrectParameters");
378 $error++;
379 }
380 }
381}
382
383// Define $defaultCharacterSet and $defaultDBSortingCollation
384if (!$error && $db !== null && $db->connected) {
385 if (!empty($db_create_database)) { // If we create database, we force default value
386 // Default values come from the database handler
387
388 $defaultCharacterSet = $db->forcecharset;
389 $defaultDBSortingCollation = $db->forcecollate;
390 } else { // If already created, we take current value
391 $defaultCharacterSet = $db->getDefaultCharacterSetDatabase();
392 $defaultDBSortingCollation = $db->getDefaultCollationDatabase();
393 }
394
395 // It seems some PHP driver mysqli does not support utf8mb3
396 if ($defaultCharacterSet == 'utf8mb3' || $defaultDBSortingCollation == 'utf8mb3_unicode_ci') {
397 $defaultCharacterSet = 'utf8';
398 $defaultDBSortingCollation = 'utf8_unicode_ci';
399 }
400 // Force to avoid utf8mb4 because index on field char 255 reach limit of 767 char for indexes (example with mysql 5.6.34 = mariadb 10.0.29)
401 // TODO Remove this when utf8mb4 is supported
402 if ($defaultCharacterSet == 'utf8mb4' || $defaultDBSortingCollation == 'utf8mb4_unicode_ci') {
403 $defaultCharacterSet = 'utf8';
404 $defaultDBSortingCollation = 'utf8_unicode_ci';
405 }
406
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;
411 dolibarr_install_syslog("step1: db_character_set=".$db_character_set." db_collation=".$db_collation);
412}
413
414
415// Create config file
416if (!$error && $db !== null && $db->connected && $action == "set") { // Test on permission not required here
417 umask(0);
418 if (is_array($_POST)) {
419 foreach ($_POST as $key => $value) {
420 if (!preg_match('/^db_pass/i', $key)) {
421 dolibarr_install_syslog("step1: choice for ".$key." = ".$value);
422 }
423 }
424 }
425
426 // Show title of step
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">';
429
430 // Check parameter main_dir
431 if (!$error) {
432 if (!is_dir($main_dir)) {
433 dolibarr_install_syslog("step1: directory '".$main_dir."' is unavailable or can't be accessed");
434
435 print "<tr><td>";
436 print $langs->trans("ErrorDirDoesNotExists", $main_dir).'<br>';
437 print $langs->trans("ErrorWrongValueForParameter", $langs->transnoentitiesnoconv("WebPagesDirectory")).'<br>';
438 print $langs->trans("ErrorGoBackAndCorrectParameters").'<br><br>';
439 print '</td><td>';
440 print $langs->trans("Error");
441 print "</td></tr>";
442 $error++;
443 }
444 }
445
446 if (!$error) {
447 dolibarr_install_syslog("step1: directory '".$main_dir."' exists");
448 }
449
450
451 // Create subdirectory main_data_dir
452 if (!$error) {
453 // Create directory for documents
454 if (!is_dir($main_data_dir)) {
455 dol_mkdir($main_data_dir);
456 }
457
458 if (!is_dir($main_data_dir)) {
459 print "<tr><td>".$langs->trans("ErrorDirDoesNotExists", $main_data_dir);
460 print ' '.$langs->trans("YouMustCreateItAndAllowServerToWrite");
461 print '</td><td>';
462 print '<span class="error">'.$langs->trans("Error").'</span>';
463 print "</td></tr>";
464 print '<tr><td colspan="2"><br>'.$langs->trans("CorrectProblemAndReloadPage", $_SERVER['PHP_SELF'].'?testget=ok').'</td></tr>';
465 $error++;
466 } else {
467 // Create .htaccess file in document directory
468 $pathhtaccess = $main_data_dir.'/.htaccess';
469 if (!file_exists($pathhtaccess)) {
470 dolibarr_install_syslog("step1: .htaccess file did not exist, we created it in '".$main_data_dir."'");
471 $handlehtaccess = @fopen($pathhtaccess, 'w');
472 if ($handlehtaccess) {
473 fwrite($handlehtaccess, 'Order allow,deny'."\n");
474 fwrite($handlehtaccess, 'Deny from all'."\n");
475
476 fclose($handlehtaccess);
477 dolibarr_install_syslog("step1: .htaccess file created");
478 }
479 }
480
481 // Documents are stored above the web pages root to prevent being downloaded without authentication
482 $dir = array();
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";
491
492 // Loop on each directory of dir [] to create them if they do not exist
493 $num = count($dir);
494 for ($i = 0; $i < $num; $i++) {
495 if (is_dir($dir[$i])) {
496 dolibarr_install_syslog("step1: directory '".$dir[$i]."' exists");
497 } else {
498 if (dol_mkdir($dir[$i]) < 0) {
499 print "<tr><td>";
500 print "Failed to create directory: ".$dir[$i];
501 print '</td><td>';
502 print $langs->trans("Error");
503 print "</td></tr>";
504 $error++;
505 } else {
506 dolibarr_install_syslog("step1: directory '".$dir[$i]."' created");
507 }
508 }
509 }
510
511 require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
512
513 // Copy directory medias
514 $srcroot = $main_dir.'/install/medias';
515 $destroot = $main_data_dir.'/medias';
516 dolCopyDir($srcroot, $destroot, '0', 0);
517
518 if ($error) {
519 print "<tr><td>".$langs->trans("ErrorDirDoesNotExists", $main_data_dir);
520 print ' '.$langs->trans("YouMustCreateItAndAllowServerToWrite");
521 print '</td><td>';
522 print '<span class="error">'.$langs->trans("Error").'</span>';
523 print "</td></tr>";
524 print '<tr><td colspan="2"><br>'.$langs->trans("CorrectProblemAndReloadPage", $_SERVER['PHP_SELF'].'?testget=ok').'</td></tr>';
525 } else {
526 //ODT templates
527 $srcroot = $main_dir.'/install/doctemplates';
528 $destroot = $main_data_dir.'/doctemplates';
529 $docs = array(
530 'contracts' => 'contract',
531 'invoices' => 'invoice',
532 'orders' => 'order',
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',
541 'users' => 'user',
542 );
543 foreach ($docs as $cursordir => $cursorfile) {
544 $src = $srcroot.'/'.$cursordir.'/template_'.$cursorfile.'.odt';
545 $dirodt = $destroot.'/'.$cursordir;
546 $dest = $dirodt.'/template_'.$cursorfile.'.odt';
547
548 dol_mkdir($dirodt);
549 $result = dol_copy($src, $dest, '0', 0);
550 if ($result < 0) {
551 print '<tr><td colspan="2"><br>'.$langs->trans('ErrorFailToCopyFile', $src, $dest).'</td></tr>';
552 }
553 }
554 }
555 }
556 }
557
558 // Table prefix
559 $main_db_prefix = (!empty($db_prefix) ? $db_prefix : 'llx_');
560
561 // Write conf file on disk
562 if (!$error) {
563 // Save old conf file on disk
564 if (file_exists("$conffile")) {
565 // We must ignore errors as an existing old file may already exist and not be replaceable or
566 // the installer (like for ubuntu) may not have permission to create another file than conf.php.
567 // Also no other process must be able to read file or we expose the new file, so content with password.
568 @dol_copy($conffile, $conffile.'.old', '0400');
569 }
570
571 $error += write_conf_file($conffile);
572 }
573
574 // Create database and admin user database
575 if (!$error) {
576 // We reload configuration file
577 conf($dolibarr_main_document_root);
578
579 print '<tr><td>';
580 print $langs->trans("ConfFileReload");
581 print '</td>';
582 print '<td>'.img_picto('OK', 'tick').'</td></tr>';
583
584 // Create database user if requested
585 if (isset($db_create_user) && ($db_create_user == "1" || $db_create_user == "on")) {
586 dolibarr_install_syslog("step1: create database user: ".$dolibarr_main_db_user);
587
588 //print $conf->db->host." , ".$conf->db->name." , ".$conf->db->user." , ".$conf->db->port;
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';
596 }
597
598 // Check database connection
599
600 $db = null;
601 if ($databasefortest === null) {
602 print '<div class="error">Database name can not be empty</div>';
603 $error++;
604 } else {
605 $db = getDoliDBInstance($conf->db->type, $conf->db->host, $userroot, $passroot, $databasefortest, (int) $conf->db->port);
606
607 if ($db->error) {
608 print '<div class="error">'.$db->error.'</div>';
609 $error++;
610 }
611 }
612
613 if (!$error && $db !== null) {
614 if ($db->connected) {
615 $resultbis = 1;
616
617 if (empty($dolibarr_main_db_pass)) {
618 dolibarr_install_syslog("step1: failed to create user, password is empty", LOG_ERR);
619 print '<tr><td>';
620 print $langs->trans("UserCreation").' : ';
621 print $dolibarr_main_db_user;
622 print '</td>';
623 print '<td>'.$langs->trans("Error").": A password for database user is mandatory.</td></tr>";
624 } else {
625 // Create user
626 $result = $db->DDLCreateUser($dolibarr_main_db_host, $dolibarr_main_db_user, $dolibarr_main_db_pass, $dolibarr_main_db_name);
627
628 // Create user bis
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);
632 }
633 }
634
635 if ($result > 0 && $resultbis > 0) {
636 print '<tr><td>';
637 print $langs->trans("UserCreation").' : ';
638 print $dolibarr_main_db_user;
639 print '</td>';
640 print '<td>'.img_picto('OK', 'tick').'</td></tr>';
641 } else {
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') {
645 dolibarr_install_syslog("step1: user already exists");
646 print '<tr><td>';
647 print $langs->trans("UserCreation").' : ';
648 print $dolibarr_main_db_user;
649 print '</td>';
650 print '<td>'.$langs->trans("LoginAlreadyExists").'</td></tr>';
651 } else {
652 dolibarr_install_syslog("step1: failed to create user", LOG_ERR);
653 print '<tr><td>';
654 print $langs->trans("UserCreation").' : ';
655 print $dolibarr_main_db_user;
656 print '</td>';
657 print '<td>'.$langs->trans("Error").': '.$db->errno().' '.$db->error().($db->error ? '. '.$db->error : '')."</td></tr>";
658 }
659 }
660 }
661
662 $db->close();
663 } else {
664 print '<tr><td>';
665 print $langs->trans("UserCreation").' : ';
666 print $dolibarr_main_db_user;
667 print '</td>';
668 print '<td>'.img_picto('Error', 'warning', 'class="error"').'</td>';
669 print '</tr>';
670
671 // warning message due to connection failure
672 print '<tr><td colspan="2"><br>';
673 print $langs->trans("YouAskDatabaseCreationSoDolibarrNeedToConnect", $dolibarr_main_db_user, $dolibarr_main_db_host, $userroot);
674 print '<br>';
675 print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
676 print $langs->trans("ErrorGoBackAndCorrectParameters").'<br><br>';
677 print '</td></tr>';
678
679 $error++;
680 }
681 }
682 } // end of user account creation
683
684
685 // If database creation was asked, we create it
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);
688 $newdb = getDoliDBInstance($conf->db->type, $conf->db->host, $userroot, $passroot, '', (int) $conf->db->port);
689 //print 'eee'.$conf->db->type." ".$conf->db->host." ".$userroot." ".$passroot." ".$conf->db->port." ".$newdb->connected." ".$newdb->forcecharset;exit;
690
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);
693
694 if ($result) {
695 print '<tr><td>';
696 print $langs->trans("DatabaseCreation")." (".$langs->trans("User")." ".$userroot.") : ";
697 print $dolibarr_main_db_name;
698 print '</td>';
699 print '<td>'.img_picto('OK', 'tick').'</td></tr>';
700
701 $newdb->select_db($dolibarr_main_db_name);
702 $check1 = $newdb->getDefaultCharacterSetDatabase();
703 $check2 = $newdb->getDefaultCollationDatabase();
704 dolibarr_install_syslog('step1: new database is using charset='.$check1.' collation='.$check2);
705
706 // If values differs, we save conf file again
707 //if ($check1 != $dolibarr_main_db_character_set) dolibarr_install_syslog('step1: value for character_set is not the one asked for database creation', LOG_WARNING);
708 //if ($check2 != $dolibarr_main_db_collation) dolibarr_install_syslog('step1: value for collation is not the one asked for database creation', LOG_WARNING);
709 } else {
710 // warning message
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");
715 print '<br>';
716 print '</td></tr>';
717
718 dolibarr_install_syslog('step1: failed to create database '.$dolibarr_main_db_name.' '.$newdb->lasterrno().' '.$newdb->lasterror(), LOG_ERR);
719 $error++;
720 }
721 $newdb->close();
722 } else {
723 print '<tr><td>';
724 print $langs->trans("DatabaseCreation")." (".$langs->trans("User")." ".$userroot.") : ";
725 print $dolibarr_main_db_name;
726 print '</td>';
727 print '<td>'.img_picto('Error', 'warning', 'class="error"').'</td>';
728 print '</tr>';
729
730 // warning message
731 print '<tr><td colspan="2"><br>';
732 print $langs->trans("YouAskDatabaseCreationSoDolibarrNeedToConnect", $dolibarr_main_db_user, $dolibarr_main_db_host, $userroot);
733 print '<br>';
734 print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
735 print $langs->trans("ErrorGoBackAndCorrectParameters").'<br><br>';
736 print '</td></tr>';
737
738 $error++;
739 }
740 } // end of create database
741
742
743 // We test access with dolibarr database user (not admin)
744 if (!$error) {
745 dolibarr_install_syslog("step1: connection type=".$conf->db->type." on host=".$conf->db->host." port=".$conf->db->port." user=".((string) $conf->db->user)." name=".((string) $conf->db->name));
746 //print "connection de type=".$conf->db->type." sur host=".$conf->db->host." port=".$conf->db->port." user=".$conf->db->user." name=".$conf->db->name;
747
748 $db = getDoliDBInstance($conf->db->type, $conf->db->host, (string) $conf->db->user, $conf->db->pass, $conf->db->name, (int) $conf->db->port);
749
750 if ($db->connected) {
751 dolibarr_install_syslog("step1: connection to server by user ".((string) $conf->db->user)." ok");
752 print "<tr><td>";
753 print $langs->trans("ServerConnection")." (".$langs->trans("User")." ".((string) $conf->db->user).") : ";
754 print $dolibarr_main_db_host;
755 print "</td><td>";
756 print img_picto('OK', 'tick');
757 print "</td></tr>";
758
759 // server access ok, basic access ok
760 if ($db->database_selected) {
761 dolibarr_install_syslog("step1: connection to database ".$conf->db->name." by user ".((string) $conf->db->user)." ok");
762 print "<tr><td>";
763 print $langs->trans("DatabaseConnection")." (".$langs->trans("User")." ".((string) $conf->db->user).") : ";
764 print $dolibarr_main_db_name;
765 print "</td><td>";
766 print img_picto('OK', 'tick');
767 print "</td></tr>";
768
769 $error = 0;
770 } else {
771 dolibarr_install_syslog("step1: connection to database ".$conf->db->name." by user ".((string) $conf->db->user)." failed", LOG_ERR);
772 print "<tr><td>";
773 print $langs->trans("DatabaseConnection")." (".$langs->trans("User")." ".((string) $conf->db->user).") : ";
774 print $dolibarr_main_db_name;
775 print '</td><td>';
776 print img_picto('Error', 'warning', 'class="error"');
777 print "</td></tr>";
778
779 // warning message
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>';
784 print '</td></tr>';
785
786 $error++;
787 }
788 } else {
789 dolibarr_install_syslog("step1: connection to server by user ".((string) $conf->db->user)." failed", LOG_ERR);
790 print "<tr><td>";
791 print $langs->trans("ServerConnection")." (".$langs->trans("User")." ".((string) $conf->db->user).") : ";
792 print $dolibarr_main_db_host;
793 print '</td><td>';
794 print img_picto('Error', 'warning', 'class="error"');
795 print "</td></tr>";
796
797 // warning message
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>';
802 print '</td></tr>';
803
804 $error++;
805 }
806 }
807 }
808
809 print '</table>';
810}
811
812?>
813
814<script type="text/javascript">
815function jsinfo()
816{
817 ok=true;
818
819 //alert('<?php echo dol_escape_js($langs->transnoentities("NextStepMightLastALongTime")); ?>');
820
821 document.getElementById('nextbutton').style.visibility="hidden";
822 document.getElementById('pleasewait').style.visibility="visible";
823
824 return ok;
825}
826</script>
827
828<?php
829
830$ret = 0;
831if ($error && isset($argv[1])) {
832 $ret = 1;
833}
834dolibarr_install_syslog("Exit ".$ret);
835
836dolibarr_install_syslog("--- step1: end");
837
838pFooter($error ? 1 : 0, $setuplang, 'jsinfo', 1);
839
840// Return code if ran from command line
841if ($ret) {
842 exit($ret);
843}
844
845
853function write_main_file($mainfile, $main_dir)
854{
855 $fp = @fopen("$mainfile", "w");
856 if ($fp) {
857 clearstatcache();
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");
861 fclose($fp);
862 }
863}
864
865
873function write_master_file($masterfile, $main_dir)
874{
875 $fp = @fopen("$masterfile", "w");
876 if ($fp) {
877 clearstatcache();
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");
881 fclose($fp);
882 }
883}
884
885
893{
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;
901 global $conffile, $conffiletoshow;
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;
908
909 $error = 0;
910
911 $key = bin2hex(random_bytes(32)); // Generate a random hash (64 hex chars)
912
913 $fp = fopen("$conffile", "w");
914 if ($fp) {
915 clearstatcache();
916
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).'\';');
925 fwrite($fp, "\n");
926
927 fwrite($fp, '$dolibarr_main_document_root="'.dol_escape_php(dol_sanitizePathName(trim($main_dir))).'";');
928 fwrite($fp, "\n");
929
930 fwrite($fp, $main_use_alt_dir.'$dolibarr_main_url_root_alt=\''.dol_escape_php(trim("/".$main_alt_dir_name), 1).'\';');
931 fwrite($fp, "\n");
932
933 fwrite($fp, $main_use_alt_dir.'$dolibarr_main_document_root_alt="'.dol_escape_php(dol_sanitizePathName(trim($main_dir."/".$main_alt_dir_name))).'";');
934 fwrite($fp, "\n");
935
936 fwrite($fp, '$dolibarr_main_data_root="'.dol_escape_php(dol_sanitizePathName(trim($main_data_dir))).'";');
937 fwrite($fp, "\n");
938
939 fwrite($fp, '$dolibarr_main_db_host=\''.dol_escape_php(trim($db_host), 1).'\';');
940 fwrite($fp, "\n");
941
942 fwrite($fp, '$dolibarr_main_db_port=\''.((int) $db_port).'\';');
943 fwrite($fp, "\n");
944
945 fwrite($fp, '$dolibarr_main_db_name=\''.dol_escape_php(trim($db_name), 1).'\';');
946 fwrite($fp, "\n");
947
948 fwrite($fp, '$dolibarr_main_db_prefix=\''.dol_escape_php(trim($main_db_prefix), 1).'\';');
949 fwrite($fp, "\n");
950
951 fwrite($fp, '$dolibarr_main_db_user=\''.dol_escape_php(trim($db_user), 1).'\';');
952 fwrite($fp, "\n");
953 fwrite($fp, '$dolibarr_main_db_pass=\''.dol_escape_php(trim($db_pass), 1).'\';');
954 fwrite($fp, "\n");
955
956 fwrite($fp, '$dolibarr_main_db_type=\''.dol_escape_php(trim($db_type), 1).'\';');
957 fwrite($fp, "\n");
958
959 fwrite($fp, '$dolibarr_main_db_character_set=\''.dol_escape_php(trim($db_character_set), 1).'\';');
960 fwrite($fp, "\n");
961
962 fwrite($fp, '$dolibarr_main_db_collation=\''.dol_escape_php(trim($db_collation), 1).'\';');
963 fwrite($fp, "\n");
964
965 // Authentication
966 fwrite($fp, '// Authentication settings');
967 fwrite($fp, "\n");
968
969 fwrite($fp, '$dolibarr_main_authentication=\'dolibarr\';');
970 fwrite($fp, "\n\n");
971
972 fwrite($fp, '//$dolibarr_main_demo=\'autologin,autopass\';');
973 fwrite($fp, "\n");
974
975 fwrite($fp, '// Security settings');
976 fwrite($fp, "\n");
977
978 fwrite($fp, '$dolibarr_main_prod=\'0\';');
979 fwrite($fp, "\n");
980
981 fwrite($fp, '$dolibarr_main_force_https=\''.dol_escape_php($main_force_https, 1).'\';');
982 fwrite($fp, "\n");
983
984 fwrite($fp, '$dolibarr_main_restrict_os_commands=\'mariadb-dump, mariadb, mysqldump, mysql, pg_dump, pg_restore, clamdscan, clamdscan.exe\';');
985 fwrite($fp, "\n");
986
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\';');
988 fwrite($fp, "\n");
989
990 fwrite($fp, '$dolibarr_nocsrfcheck=\'0\';');
991 fwrite($fp, "\n");
992
993 fwrite($fp, '$dolibarr_main_instance_unique_id=\''.dol_escape_php($key, 1).'\';');
994 fwrite($fp, "\n");
995
996 fwrite($fp, '$dolibarr_mailing_limit_sendbyweb=\'0\';');
997 fwrite($fp, "\n");
998 fwrite($fp, '$dolibarr_mailing_limit_sendbycli=\'0\';');
999 fwrite($fp, "\n");
1000
1001 // Write params to overwrites default lib path
1002 fwrite($fp, "\n");
1003 if (empty($force_dolibarr_lib_FPDF_PATH)) {
1004 fwrite($fp, '//');
1005 $force_dolibarr_lib_FPDF_PATH = '';
1006 }
1007 fwrite($fp, '$dolibarr_lib_FPDF_PATH="'.dol_escape_php(dol_sanitizePathName($force_dolibarr_lib_FPDF_PATH)).'";');
1008 fwrite($fp, "\n");
1009 if (empty($force_dolibarr_lib_TCPDF_PATH)) {
1010 fwrite($fp, '//');
1011 $force_dolibarr_lib_TCPDF_PATH = '';
1012 }
1013 fwrite($fp, '$dolibarr_lib_TCPDF_PATH="'.dol_escape_php(dol_sanitizePathName($force_dolibarr_lib_TCPDF_PATH)).'";');
1014 fwrite($fp, "\n");
1015 if (empty($force_dolibarr_lib_FPDI_PATH)) {
1016 fwrite($fp, '//');
1017 $force_dolibarr_lib_FPDI_PATH = '';
1018 }
1019 fwrite($fp, '$dolibarr_lib_FPDI_PATH="'.dol_escape_php(dol_sanitizePathName($force_dolibarr_lib_FPDI_PATH)).'";');
1020 fwrite($fp, "\n");
1021 if (empty($force_dolibarr_lib_TCPDI_PATH)) {
1022 fwrite($fp, '//');
1023 $force_dolibarr_lib_TCPDI_PATH = '';
1024 }
1025 fwrite($fp, '$dolibarr_lib_TCPDI_PATH="'.dol_escape_php(dol_sanitizePathName($force_dolibarr_lib_TCPDI_PATH)).'";');
1026 fwrite($fp, "\n");
1027 if (empty($force_dolibarr_lib_GEOIP_PATH)) {
1028 fwrite($fp, '//');
1029 $force_dolibarr_lib_GEOIP_PATH = '';
1030 }
1031 fwrite($fp, '$dolibarr_lib_GEOIP_PATH="'.dol_escape_php(dol_sanitizePathName($force_dolibarr_lib_GEOIP_PATH)).'";');
1032 fwrite($fp, "\n");
1033 if (empty($force_dolibarr_lib_NUSOAP_PATH)) {
1034 fwrite($fp, '//');
1035 $force_dolibarr_lib_NUSOAP_PATH = '';
1036 }
1037 fwrite($fp, '$dolibarr_lib_NUSOAP_PATH="'.dol_escape_php(dol_sanitizePathName($force_dolibarr_lib_NUSOAP_PATH)).'";');
1038 fwrite($fp, "\n");
1039 if (empty($force_dolibarr_lib_ODTPHP_PATH)) {
1040 fwrite($fp, '//');
1041 $force_dolibarr_lib_ODTPHP_PATH = '';
1042 }
1043 fwrite($fp, '$dolibarr_lib_ODTPHP_PATH="'.dol_escape_php(dol_sanitizePathName($force_dolibarr_lib_ODTPHP_PATH)).'";');
1044 fwrite($fp, "\n");
1045 if (empty($force_dolibarr_lib_ODTPHP_PATHTOPCLZIP)) {
1046 fwrite($fp, '//');
1047 $force_dolibarr_lib_ODTPHP_PATHTOPCLZIP = '';
1048 }
1049 fwrite($fp, '$dolibarr_lib_ODTPHP_PATHTOPCLZIP="'.dol_escape_php(dol_sanitizePathName($force_dolibarr_lib_ODTPHP_PATHTOPCLZIP)).'";');
1050 fwrite($fp, "\n");
1051 if (empty($force_dolibarr_js_CKEDITOR)) {
1052 fwrite($fp, '//');
1053 $force_dolibarr_js_CKEDITOR = '';
1054 }
1055 fwrite($fp, '$dolibarr_js_CKEDITOR=\''.dol_escape_php($force_dolibarr_js_CKEDITOR, 1).'\';');
1056 fwrite($fp, "\n");
1057 if (empty($force_dolibarr_js_JQUERY)) {
1058 fwrite($fp, '//');
1059 $force_dolibarr_js_JQUERY = '';
1060 }
1061 fwrite($fp, '$dolibarr_js_JQUERY=\''.dol_escape_php($force_dolibarr_js_JQUERY, 1).'\';');
1062 fwrite($fp, "\n");
1063 if (empty($force_dolibarr_js_JQUERY_UI)) {
1064 fwrite($fp, '//');
1065 $force_dolibarr_js_JQUERY_UI = '';
1066 }
1067 fwrite($fp, '$dolibarr_js_JQUERY_UI=\''.dol_escape_php($force_dolibarr_js_JQUERY_UI, 1).'\';');
1068 fwrite($fp, "\n");
1069
1070 // Write params to overwrites default font path
1071 fwrite($fp, "\n");
1072 if (empty($force_dolibarr_font_DOL_DEFAULT_TTF)) {
1073 fwrite($fp, '//');
1074 $force_dolibarr_font_DOL_DEFAULT_TTF = '';
1075 }
1076 fwrite($fp, '$dolibarr_font_DOL_DEFAULT_TTF=\''.dol_escape_php($force_dolibarr_font_DOL_DEFAULT_TTF, 1).'\';');
1077 fwrite($fp, "\n");
1078 if (empty($force_dolibarr_font_DOL_DEFAULT_TTF_BOLD)) {
1079 fwrite($fp, '//');
1080 $force_dolibarr_font_DOL_DEFAULT_TTF_BOLD = '';
1081 }
1082 fwrite($fp, '$dolibarr_font_DOL_DEFAULT_TTF_BOLD=\''.dol_escape_php($force_dolibarr_font_DOL_DEFAULT_TTF_BOLD, 1).'\';');
1083 fwrite($fp, "\n");
1084
1085 // Other
1086 fwrite($fp, '$dolibarr_main_distrib=\''.dol_escape_php(trim($dolibarr_main_distrib), 1).'\';');
1087 fwrite($fp, "\n");
1088
1089 fclose($fp);
1090
1091 if (file_exists("$conffile")) {
1092 include $conffile; // force config reload, do not put include_once
1093 conf($dolibarr_main_document_root);
1094
1095 print "<tr><td>";
1096 print $langs->trans("SaveConfigurationFile");
1097 print ' <strong>'.$conffile.'</strong>';
1098 print "</td><td>";
1099 print img_picto('OK', 'tick');
1100 print "</td></tr>";
1101 } else {
1102 $error++;
1103 }
1104 }
1105
1106 return $error;
1107}
global $dolibarr_main_url_root
if(!isModEnabled('ai')||!getDolGlobalString('AI_ASSISTANT_ENABLED')) global $conf
The main.inc.php has been included so the following variable are now defined:
if(!isModEnabled('ai')||!getDolGlobalString('AI_ASSISTANT_ENABLED')) global $db
API class for accounts.
$conffile
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)
Definition inc.php:426
pHeader($subtitle, $next, $action='set', $param='', $forcejqueryurl='', $csstable='main-inside')
Show HTML header of install pages.
Definition inc.php:541
detect_dolibarr_main_data_root($dolibarr_main_document_root)
Automatically detect Dolibarr's main data root.
Definition inc.php:736
pFooter($nonext=0, $setuplang='', $jscheckfunction='', $withpleasewait=0, $morehtml='')
Print HTML footer of install pages.
Definition inc.php:635
parse_database_login($force_install_databaserootlogin)
Replaces automatic database login by actual value.
Definition inc.php:780
parse_database_pass($force_install_databaserootpass)
Replaces automatic database password by actual value.
Definition inc.php:791
dolibarr_install_syslog($message, $level=LOG_DEBUG)
Log function for install pages.
Definition inc.php:699
detect_dolibarr_main_url_root()
Automatically detect Dolibarr's main URL root.
Definition inc.php:747
detect_dolibarr_main_document_root()
Automatically detect Dolibarr's main document root.
Definition inc.php:712
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]]]',...
Definition repair.php:130
if( $ret) write_main_file($mainfile, $main_dir)
Create main file.
Definition step1.php:853
write_conf_file($conffile)
Save configuration file.
Definition step1.php:892
write_master_file($masterfile, $main_dir)
Create master file.
Definition step1.php:873