step1.php 43 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043
  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@capnetworks.com>
  7. * Copyright (C) 2015-2016 Raphaël Doursenaud <rdoursenaud@gpcsolutions.fr>
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; either version 3 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. */
  22. /**
  23. * \file htdocs/install/step1.php
  24. * \ingroup install
  25. * \brief Build conf file on disk
  26. */
  27. define('DONOTLOADCONF',1); // To avoid loading conf by file inc.php
  28. include 'inc.php';
  29. global $langs;
  30. $action=GETPOST('action','aZ09')?GETPOST('action','aZ09'):(empty($argv[1])?'':$argv[1]);
  31. $setuplang=GETPOST('selectlang','aZ09',3)?GETPOST('selectlang','aZ09',3):(empty($argv[2])?'auto':$argv[2]);
  32. $langs->setDefaultLang($setuplang);
  33. $langs->load("admin");
  34. $langs->load("install");
  35. $langs->load("errors");
  36. // Dolibarr pages directory
  37. $main_dir = GETPOST('main_dir')?GETPOST('main_dir'):(empty($argv[3])?'':$argv[3]);
  38. // Directory for generated documents (invoices, orders, ecm, etc...)
  39. $main_data_dir = GETPOST('main_data_dir') ? GETPOST('main_data_dir') : (empty($argv[4])? ($main_dir . '/documents') :$argv[4]);
  40. // Dolibarr root URL
  41. $main_url = GETPOST('main_url')?GETPOST('main_url'):(empty($argv[5])?'':$argv[5]);
  42. // Database login information
  43. $userroot=GETPOST('db_user_root','alpha')?GETPOST('db_user_root','alpha'):(empty($argv[6])?'':$argv[6]);
  44. $passroot=GETPOST('db_pass_root','none')?GETPOST('db_pass_root','none'):(empty($argv[7])?'':$argv[7]);
  45. // Database server
  46. $db_type=GETPOST('db_type','aZ09')?GETPOST('db_type','aZ09'):(empty($argv[8])?'':$argv[8]);
  47. $db_host=GETPOST('db_host','alpha')?GETPOST('db_host','alpha'):(empty($argv[9])?'':$argv[9]);
  48. $db_name=GETPOST('db_name','aZ09')?GETPOST('db_name','aZ09'):(empty($argv[10])?'':$argv[10]);
  49. $db_user=GETPOST('db_user','alpha')?GETPOST('db_user','alpha'):(empty($argv[11])?'':$argv[11]);
  50. $db_pass=GETPOST('db_pass','none')?GETPOST('db_pass','none'):(empty($argv[12])?'':$argv[12]);
  51. $db_port=GETPOST('db_port','int')?GETPOST('db_port','int'):(empty($argv[13])?'':$argv[13]);
  52. $db_prefix=GETPOST('db_prefix','aZ09')?GETPOST('db_prefix','aZ09'):(empty($argv[14])?'':$argv[14]);
  53. $db_create_database = GETPOST('db_create_database','none')?GETPOST('db_create_database','none'):(empty($argv[15])?'':$argv[15]);
  54. $db_create_user = GETPOST('db_create_user','none')?GETPOST('db_create_user','none'):(empty($argv[16])?'':$argv[16]);
  55. // Force https
  56. $main_force_https = ((GETPOST("main_force_https",'alpha') && (GETPOST("main_force_https",'alpha') == "on" || GETPOST("main_force_https",'alpha') == 1)) ? '1' : '0');
  57. // Use alternative directory
  58. $main_use_alt_dir = ((GETPOST("main_use_alt_dir",'alpha') == '' || (GETPOST("main_use_alt_dir",'alpha') == "on" || GETPOST("main_use_alt_dir",'alpha') == 1)) ? '' : '//');
  59. // Alternative root directory name
  60. $main_alt_dir_name = ((GETPOST("main_alt_dir_name",'alpha') && GETPOST("main_alt_dir_name",'alpha') != '') ? GETPOST("main_alt_dir_name",'alpha') : 'custom');
  61. session_start(); // To be able to keep info into session (used for not losing password during navigation. The password must not transit through parameters)
  62. // Save a flag to tell to restore input value if we go back
  63. $_SESSION['dol_save_pass']=$db_pass;
  64. //$_SESSION['dol_save_passroot']=$passroot;
  65. // Now we load forced values from install.forced.php file.
  66. $useforcedwizard=false;
  67. $forcedfile="./install.forced.php";
  68. if ($conffile == "/etc/dolibarr/conf.php") $forcedfile="/etc/dolibarr/install.forced.php";
  69. if (@file_exists($forcedfile)) {
  70. $useforcedwizard = true;
  71. include_once $forcedfile;
  72. // If forced install is enabled, replace the post values. These are empty because form fields are disabled.
  73. if ($force_install_noedit) {
  74. $main_dir = detect_dolibarr_main_document_root();
  75. if (!empty($force_install_main_data_root)) {
  76. $main_data_dir = $force_install_main_data_root;
  77. } else {
  78. $main_data_dir = detect_dolibarr_main_data_root($main_dir);
  79. }
  80. $main_url = detect_dolibarr_main_url_root();
  81. if (!empty($force_install_databaserootlogin)) {
  82. $userroot = parse_database_login($force_install_databaserootlogin);
  83. }
  84. if (!empty($force_install_databaserootpass)) {
  85. $passroot = parse_database_pass($force_install_databaserootpass);
  86. }
  87. }
  88. if ($force_install_noedit == 2) {
  89. if (!empty($force_install_type)) {
  90. $db_type = $force_install_type;
  91. }
  92. if (!empty($force_install_dbserver)) {
  93. $db_host = $force_install_dbserver;
  94. }
  95. if (!empty($force_install_database)) {
  96. $db_name = $force_install_database;
  97. }
  98. if (!empty($force_install_databaselogin)) {
  99. $db_user = $force_install_databaselogin;
  100. }
  101. if (!empty($force_install_databasepass)) {
  102. $db_pass = $force_install_databasepass;
  103. }
  104. if (!empty($force_install_port)) {
  105. $db_port = $force_install_port;
  106. }
  107. if (!empty($force_install_prefix)) {
  108. $db_prefix = $force_install_prefix;
  109. }
  110. if (!empty($force_install_createdatabase)) {
  111. $db_create_database = $force_install_createdatabase;
  112. }
  113. if (!empty($force_install_createuser)) {
  114. $db_create_user = $force_install_createuser;
  115. }
  116. if (!empty($force_install_mainforcehttps)) {
  117. $main_force_https = $force_install_mainforcehttps;
  118. }
  119. }
  120. }
  121. $error = 0;
  122. /*
  123. * View
  124. */
  125. dolibarr_install_syslog("--- step1: entering step1.php page");
  126. pHeader($langs->trans("ConfigurationFile"),"step2");
  127. // Test if we can run a first install process
  128. if (! is_writable($conffile))
  129. {
  130. print $langs->trans("ConfFileIsNotWritable",$conffiletoshow);
  131. pFooter(1,$setuplang,'jscheckparam');
  132. exit;
  133. }
  134. // Check parameters
  135. $is_sqlite = false;
  136. if (empty($db_type))
  137. {
  138. print '<div class="error">'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("DatabaseType")).'</div>';
  139. $error++;
  140. } else {
  141. $is_sqlite = ($db_type === 'sqlite' || $db_type === 'sqlite3' );
  142. }
  143. if (empty($db_host) && ! $is_sqlite)
  144. {
  145. print '<div class="error">'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("Server")).'</div>';
  146. $error++;
  147. }
  148. if (empty($db_name))
  149. {
  150. print '<div class="error">'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("DatabaseName")).'</div>';
  151. $error++;
  152. }
  153. if (empty($db_user) && ! $is_sqlite)
  154. {
  155. print '<div class="error">'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("Login")).'</div>';
  156. $error++;
  157. }
  158. if (! empty($db_port) && ! is_numeric($db_port))
  159. {
  160. print '<div class="error">'.$langs->trans("ErrorBadValueForParameter",$db_port,$langs->transnoentities("Port")).'</div>';
  161. $error++;
  162. }
  163. if (! empty($db_prefix) && ! preg_match('/^[a-z0-9]+_$/i', $db_prefix))
  164. {
  165. print '<div class="error">'.$langs->trans("ErrorBadValueForParameter",$db_prefix,$langs->transnoentities("DatabasePrefix")).'</div>';
  166. $error++;
  167. }
  168. // Remove last / into dans main_dir
  169. if (substr($main_dir, dol_strlen($main_dir) -1) == "/")
  170. {
  171. $main_dir = substr($main_dir, 0, dol_strlen($main_dir)-1);
  172. }
  173. // Remove last / into dans main_url
  174. if (! empty($main_url) && substr($main_url, dol_strlen($main_url) -1) == "/")
  175. {
  176. $main_url = substr($main_url, 0, dol_strlen($main_url)-1);
  177. }
  178. // Test database connection
  179. if (! $error) {
  180. $result=@include_once $main_dir."/core/db/".$db_type.'.class.php';
  181. if ($result)
  182. {
  183. // If we require database or user creation we need to connect as root, so we need root login credentials
  184. if (!empty($db_create_database) && !$userroot) {
  185. print '<div class="error">'.$langs->trans("YouAskDatabaseCreationSoDolibarrNeedToConnect",$db_name).'</div>';
  186. print '<br>';
  187. print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
  188. print $langs->trans("ErrorGoBackAndCorrectParameters");
  189. $error++;
  190. }
  191. if (!empty($db_create_user) && !$userroot) {
  192. print '<div class="error">'.$langs->trans("YouAskLoginCreationSoDolibarrNeedToConnect",$db_user).'</div>';
  193. print '<br>';
  194. print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
  195. print $langs->trans("ErrorGoBackAndCorrectParameters");
  196. $error++;
  197. }
  198. // If we need root access
  199. if (!$error && (!empty($db_create_database) || !empty($db_create_user))) {
  200. $databasefortest=$db_name;
  201. if (!empty($db_create_database)) {
  202. if ($db_type == 'mysql' || $db_type == 'mysqli')
  203. {
  204. $databasefortest='mysql';
  205. }
  206. elseif ($db_type == 'pgsql')
  207. {
  208. $databasefortest='postgres';
  209. }
  210. else
  211. {
  212. $databasefortest='master';
  213. }
  214. }
  215. //print $_POST["db_type"].",".$_POST["db_host"].",$userroot,$passroot,$databasefortest,".$_POST["db_port"];
  216. $db=getDoliDBInstance($db_type, $db_host, $userroot, $passroot, $databasefortest, $db_port);
  217. dol_syslog("databasefortest=" . $databasefortest . " connected=" . $db->connected . " database_selected=" . $db->database_selected, LOG_DEBUG);
  218. //print "databasefortest=".$databasefortest." connected=".$db->connected." database_selected=".$db->database_selected;
  219. if (empty($db_create_database) && $db->connected && !$db->database_selected) {
  220. print '<div class="error">'.$langs->trans("ErrorConnectedButDatabaseNotFound",$db_name).'</div>';
  221. print '<br>';
  222. if (! $db->connected) print $langs->trans("IfDatabaseNotExistsGoBackAndUncheckCreate").'<br><br>';
  223. print $langs->trans("ErrorGoBackAndCorrectParameters");
  224. $error++;
  225. } elseif ($db->error && ! (! empty($db_create_database) && $db->connected)) {
  226. // 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.
  227. if ($db->error == "No such file or directory") print '<div class="error">'.$langs->trans("ErrorToConnectToMysqlCheckInstance").'</div>';
  228. else print '<div class="error">'.$db->error.'</div>';
  229. if (! $db->connected) print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
  230. //print '<a href="#" onClick="javascript: history.back();">';
  231. print $langs->trans("ErrorGoBackAndCorrectParameters");
  232. //print '</a>';
  233. $error++;
  234. }
  235. }
  236. // If we need simple access
  237. if (!$error && (empty($db_create_database) && empty($db_create_user))) {
  238. $db=getDoliDBInstance($db_type, $db_host, $db_user, $db_pass, $db_name, $db_port);
  239. if ($db->error)
  240. {
  241. print '<div class="error">'.$db->error.'</div>';
  242. if (! $db->connected) print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
  243. //print '<a href="#" onClick="javascript: history.back();">';
  244. print $langs->trans("ErrorGoBackAndCorrectParameters");
  245. //print '</a>';
  246. $error++;
  247. }
  248. }
  249. }
  250. else
  251. {
  252. print "<br>\nFailed to include_once(\"".$main_dir."/core/db/".$db_type.".class.php\")<br>\n";
  253. print '<div class="error">'.$langs->trans("ErrorWrongValueForParameter",$langs->transnoentities("WebPagesDirectory")).'</div>';
  254. //print '<a href="#" onClick="javascript: history.back();">';
  255. print $langs->trans("ErrorGoBackAndCorrectParameters");
  256. //print '</a>';
  257. $error++;
  258. }
  259. }
  260. else
  261. {
  262. if (isset($db)) print $db->lasterror();
  263. if (isset($db) && ! $db->connected) print '<br>'.$langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
  264. print $langs->trans("ErrorGoBackAndCorrectParameters");
  265. $error++;
  266. }
  267. if (! $error && $db->connected)
  268. {
  269. if (! empty($db_create_database)) {
  270. $result=$db->select_db($db_name);
  271. if ($result)
  272. {
  273. print '<div class="error">'.$langs->trans("ErrorDatabaseAlreadyExists", $db_name).'</div>';
  274. print $langs->trans("IfDatabaseExistsGoBackAndCheckCreate").'<br><br>';
  275. print $langs->trans("ErrorGoBackAndCorrectParameters");
  276. $error++;
  277. }
  278. }
  279. }
  280. // Define $defaultCharacterSet and $defaultDBSortingCollation
  281. if (! $error && $db->connected)
  282. {
  283. if (!empty($db_create_database)) // If we create database, we force default value
  284. {
  285. // Default values come from the database handler
  286. $defaultCharacterSet=$db->forcecharset;
  287. $defaultDBSortingCollation=$db->forcecollate;
  288. }
  289. else // If already created, we take current value
  290. {
  291. $defaultCharacterSet=$db->getDefaultCharacterSetDatabase();
  292. $defaultDBSortingCollation=$db->getDefaultCollationDatabase();
  293. }
  294. // 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)
  295. // TODO Remove this when utf8mb4 is supported
  296. if ($defaultCharacterSet == 'utf8mb4' || $defaultDBSortingCollation == 'utf8mb4_unicode_ci')
  297. {
  298. $defaultCharacterSet = 'utf8';
  299. $defaultDBSortingCollation = 'utf8_unicode_ci';
  300. }
  301. print '<input type="hidden" name="dolibarr_main_db_character_set" value="'.$defaultCharacterSet.'">';
  302. print '<input type="hidden" name="dolibarr_main_db_collation" value="'.$defaultDBSortingCollation.'">';
  303. $db_character_set=$defaultCharacterSet;
  304. $db_collation=$defaultDBSortingCollation;
  305. dolibarr_install_syslog("step1: db_character_set=" . $db_character_set . " db_collation=" . $db_collation);
  306. }
  307. // Create config file
  308. if (! $error && $db->connected && $action == "set")
  309. {
  310. umask(0);
  311. if (is_array($_POST))
  312. {
  313. foreach($_POST as $key => $value)
  314. {
  315. if (! preg_match('/^db_pass/i', $key)) {
  316. dolibarr_install_syslog("step1: choice for " . $key . " = " . $value);
  317. }
  318. }
  319. }
  320. // Show title of step
  321. print '<h3><img class="valigntextbottom" src="../theme/common/octicons/build/svg/gear.svg" width="20" alt="Configuration"> '.$langs->trans("ConfigurationFile").'</h3>';
  322. print '<table cellspacing="0" width="100%" cellpadding="1" border="0">';
  323. // Check parameter main_dir
  324. if (! $error)
  325. {
  326. if (! is_dir($main_dir))
  327. {
  328. dolibarr_install_syslog("step1: directory '" . $main_dir . "' is unavailable or can't be accessed");
  329. print "<tr><td>";
  330. print $langs->trans("ErrorDirDoesNotExists",$main_dir).'<br>';
  331. print $langs->trans("ErrorWrongValueForParameter",$langs->trans("WebPagesDirectory")).'<br>';
  332. print $langs->trans("ErrorGoBackAndCorrectParameters").'<br><br>';
  333. print '</td><td>';
  334. print $langs->trans("Error");
  335. print "</td></tr>";
  336. $error++;
  337. }
  338. }
  339. if (! $error)
  340. {
  341. dolibarr_install_syslog("step1: directory '" . $main_dir . "' exists");
  342. }
  343. // Create subdirectory main_data_dir
  344. if (! $error)
  345. {
  346. // Create directory for documents
  347. if (! is_dir($main_data_dir))
  348. {
  349. dol_mkdir($main_data_dir);
  350. }
  351. if (! is_dir($main_data_dir))
  352. {
  353. print "<tr><td>".$langs->trans("ErrorDirDoesNotExists",$main_data_dir);
  354. print ' '.$langs->trans("YouMustCreateItAndAllowServerToWrite");
  355. print '</td><td>';
  356. print '<span class="error">'.$langs->trans("Error").'</span>';
  357. print "</td></tr>";
  358. print '<tr><td colspan="2"><br>'.$langs->trans("CorrectProblemAndReloadPage",$_SERVER['PHP_SELF'].'?testget=ok').'</td></tr>';
  359. $error++;
  360. }
  361. else
  362. {
  363. // Create .htaccess file in document directory
  364. $pathhtaccess=$main_data_dir.'/.htaccess';
  365. if (! file_exists($pathhtaccess))
  366. {
  367. dolibarr_install_syslog("step1: .htaccess file did not exist, we created it in '" . $main_data_dir . "'");
  368. $handlehtaccess=@fopen($pathhtaccess,'w');
  369. if ($handlehtaccess)
  370. {
  371. fwrite($handlehtaccess,'Order allow,deny'."\n");
  372. fwrite($handlehtaccess,'Deny from all'."\n");
  373. fclose($handlehtaccess);
  374. dolibarr_install_syslog("step1: .htaccess file created");
  375. }
  376. }
  377. // Documents are stored above the web pages root to prevent being downloaded without authentification
  378. $dir=array();
  379. $dir[] = $main_data_dir."/mycompany";
  380. $dir[] = $main_data_dir."/medias";
  381. $dir[] = $main_data_dir."/users";
  382. $dir[] = $main_data_dir."/facture";
  383. $dir[] = $main_data_dir."/propale";
  384. $dir[] = $main_data_dir."/ficheinter";
  385. $dir[] = $main_data_dir."/produit";
  386. $dir[] = $main_data_dir."/doctemplates";
  387. // Loop on each directory of dir [] to create them if they do not exist
  388. $num=count($dir);
  389. for ($i = 0; $i < $num; $i++)
  390. {
  391. if (is_dir($dir[$i]))
  392. {
  393. dolibarr_install_syslog("step1: directory '" . $dir[$i] . "' exists");
  394. }
  395. else
  396. {
  397. if (dol_mkdir($dir[$i]) < 0)
  398. {
  399. print "<tr><td>";
  400. print "Failed to create directory: ".$dir[$i];
  401. print '</td><td>';
  402. print $langs->trans("Error");
  403. print "</td></tr>";
  404. $error++;
  405. }
  406. else
  407. {
  408. dolibarr_install_syslog("step1: directory '" . $dir[$i] . "' created");
  409. }
  410. }
  411. }
  412. require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
  413. // Copy directory medias
  414. $srcroot=$main_dir.'/install/medias';
  415. $destroot=$main_data_dir.'/medias';
  416. dolCopyDir($srcroot, $destroot, 0, 0);
  417. if ($error)
  418. {
  419. print "<tr><td>".$langs->trans("ErrorDirDoesNotExists",$main_data_dir);
  420. print ' '.$langs->trans("YouMustCreateItAndAllowServerToWrite");
  421. print '</td><td>';
  422. print '<span class="error">'.$langs->trans("Error").'</span>';
  423. print "</td></tr>";
  424. print '<tr><td colspan="2"><br>'.$langs->trans("CorrectProblemAndReloadPage",$_SERVER['PHP_SELF'].'?testget=ok').'</td></tr>';
  425. }
  426. else
  427. {
  428. //ODT templates
  429. $srcroot=$main_dir.'/install/doctemplates';
  430. $destroot=$main_data_dir.'/doctemplates';
  431. $docs=array(
  432. 'contracts' => 'contract',
  433. 'invoices' => 'invoice',
  434. 'orders' => 'order',
  435. 'products' => 'product',
  436. 'projects' => 'project',
  437. 'proposals' => 'proposal',
  438. 'shipments' => 'shipment',
  439. 'supplier_proposals' => 'supplier_proposal',
  440. 'tasks' => 'task_summary',
  441. 'thirdparties' => 'thirdparty',
  442. 'usergroups' => 'usergroups',
  443. 'users' => 'user',
  444. 'usergroups' => 'usergroups',
  445. );
  446. foreach($docs as $cursordir => $cursorfile)
  447. {
  448. $src=$srcroot.'/'.$cursordir.'/template_'.$cursorfile.'.odt';
  449. $dirodt=$destroot.'/'.$cursordir;
  450. $dest=$dirodt.'/template_'.$cursorfile.'.odt';
  451. dol_mkdir($dirodt);
  452. $result=dol_copy($src,$dest,0,0);
  453. if ($result < 0)
  454. {
  455. print '<tr><td colspan="2"><br>'.$langs->trans('ErrorFailToCopyFile',$src,$dest).'</td></tr>';
  456. }
  457. }
  458. }
  459. }
  460. }
  461. // Table prefix
  462. $main_db_prefix = (! empty($db_prefix) ? $db_prefix : 'llx_');
  463. // Write conf file on disk
  464. if (! $error)
  465. {
  466. // Save old conf file on disk
  467. if (file_exists("$conffile"))
  468. {
  469. // We must ignore errors as an existing old file may already exist and not be replaceable or
  470. // the installer (like for ubuntu) may not have permission to create another file than conf.php.
  471. // Also no other process must be able to read file or we expose the new file, so content with password.
  472. @dol_copy($conffile, $conffile.'.old', '0400');
  473. }
  474. $error+=write_conf_file($conffile);
  475. }
  476. // Create database and admin user database
  477. if (! $error)
  478. {
  479. // We reload configuration file
  480. conf($dolibarr_main_document_root);
  481. print '<tr><td>';
  482. print $langs->trans("ConfFileReload");
  483. print '</td>';
  484. print '<td><img src="../theme/eldy/img/tick.png" alt="Ok"></td></tr>';
  485. // Create database user if requested
  486. if (isset($db_create_user) && ($db_create_user == "1" || $db_create_user == "on")) {
  487. dolibarr_install_syslog("step1: create database user: " . $dolibarr_main_db_user);
  488. //print $conf->db->host." , ".$conf->db->name." , ".$conf->db->user." , ".$conf->db->port;
  489. $databasefortest=$conf->db->name;
  490. if ($conf->db->type == 'mysql' || $conf->db->type == 'mysqli')
  491. {
  492. $databasefortest='mysql';
  493. }
  494. else if ($conf->db->type == 'pgsql')
  495. {
  496. $databasefortest='postgres';
  497. }
  498. else if ($conf->db->type == 'mssql')
  499. {
  500. $databasefortest='master';
  501. }
  502. // Check database connection
  503. $db=getDoliDBInstance($conf->db->type,$conf->db->host,$userroot,$passroot,$databasefortest,$conf->db->port);
  504. if ($db->error)
  505. {
  506. print '<div class="error">'.$db->error.'</div>';
  507. $error++;
  508. }
  509. if (! $error)
  510. {
  511. if ($db->connected)
  512. {
  513. $resultbis = 1;
  514. // Create user
  515. $result=$db->DDLCreateUser($dolibarr_main_db_host, $dolibarr_main_db_user, $dolibarr_main_db_pass, $dolibarr_main_db_name);
  516. // Create user bis
  517. if ($databasefortest == 'mysql')
  518. {
  519. if (! in_array($dolibarr_main_db_host, array('127.0.0.1', '::1', 'localhost', 'localhost.local')))
  520. {
  521. $resultbis=$db->DDLCreateUser('%', $dolibarr_main_db_user, $dolibarr_main_db_pass, $dolibarr_main_db_name);
  522. }
  523. }
  524. if ($result > 0 && $resultbis > 0)
  525. {
  526. print '<tr><td>';
  527. print $langs->trans("UserCreation").' : ';
  528. print $dolibarr_main_db_user;
  529. print '</td>';
  530. print '<td><img src="../theme/eldy/img/tick.png" alt="Ok"></td></tr>';
  531. }
  532. else
  533. {
  534. if ($db->errno() == 'DB_ERROR_RECORD_ALREADY_EXISTS'
  535. || $db->errno() == 'DB_ERROR_KEY_NAME_ALREADY_EXISTS'
  536. || $db->errno() == 'DB_ERROR_USER_ALREADY_EXISTS')
  537. {
  538. dolibarr_install_syslog("step1: user already exists");
  539. print '<tr><td>';
  540. print $langs->trans("UserCreation").' : ';
  541. print $dolibarr_main_db_user;
  542. print '</td>';
  543. print '<td>'.$langs->trans("LoginAlreadyExists").'</td></tr>';
  544. }
  545. else
  546. {
  547. dolibarr_install_syslog("step1: failed to create user", LOG_ERR);
  548. print '<tr><td>';
  549. print $langs->trans("UserCreation").' : ';
  550. print $dolibarr_main_db_user;
  551. print '</td>';
  552. print '<td>'.$langs->trans("Error").': '.$db->errno().' '.$db->error()."</td></tr>";
  553. }
  554. }
  555. $db->close();
  556. }
  557. else
  558. {
  559. print '<tr><td>';
  560. print $langs->trans("UserCreation").' : ';
  561. print $dolibarr_main_db_user;
  562. print '</td>';
  563. print '<td><img src="../theme/eldy/img/error.png" alt="Error"></td>';
  564. print '</tr>';
  565. // warning message due to connection failure
  566. print '<tr><td colspan="2"><br>';
  567. print $langs->trans("YouAskDatabaseCreationSoDolibarrNeedToConnect",$dolibarr_main_db_user,$dolibarr_main_db_host,$userroot);
  568. print '<br>';
  569. print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
  570. print $langs->trans("ErrorGoBackAndCorrectParameters").'<br><br>';
  571. print '</td></tr>';
  572. $error++;
  573. }
  574. }
  575. } // end of user account creation
  576. // If database creation was asked, we create it
  577. if (!$error && (isset($db_create_database) && ($db_create_database == "1" || $db_create_database == "on"))) {
  578. dolibarr_install_syslog("step1: create database: " . $dolibarr_main_db_name . " " . $dolibarr_main_db_character_set . " " . $dolibarr_main_db_collation . " " . $dolibarr_main_db_user);
  579. $newdb=getDoliDBInstance($conf->db->type,$conf->db->host,$userroot,$passroot,'',$conf->db->port);
  580. //print 'eee'.$conf->db->type." ".$conf->db->host." ".$userroot." ".$passroot." ".$conf->db->port." ".$newdb->connected." ".$newdb->forcecharset;exit;
  581. if ($newdb->connected)
  582. {
  583. $result=$newdb->DDLCreateDb($dolibarr_main_db_name, $dolibarr_main_db_character_set, $dolibarr_main_db_collation, $dolibarr_main_db_user);
  584. if ($result)
  585. {
  586. print '<tr><td>';
  587. print $langs->trans("DatabaseCreation")." (".$langs->trans("User")." ".$userroot.") : ";
  588. print $dolibarr_main_db_name;
  589. print '</td>';
  590. print '<td><img src="../theme/eldy/img/tick.png" alt="Ok"></td></tr>';
  591. $newdb->select_db($dolibarr_main_db_name);
  592. $check1=$newdb->getDefaultCharacterSetDatabase();
  593. $check2=$newdb->getDefaultCollationDatabase();
  594. dolibarr_install_syslog('step1: new database is using charset=' . $check1 . ' collation=' . $check2);
  595. // If values differs, we save conf file again
  596. //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);
  597. //if ($check2 != $dolibarr_main_db_collation) dolibarr_install_syslog('step1: value for collation is not the one asked for database creation', LOG_WARNING);
  598. }
  599. else
  600. {
  601. // warning message
  602. print '<tr><td colspan="2"><br>';
  603. print $langs->trans("ErrorFailedToCreateDatabase",$dolibarr_main_db_name).'<br>';
  604. print $newdb->lasterror().'<br>';
  605. print $langs->trans("IfDatabaseExistsGoBackAndCheckCreate");
  606. print '<br>';
  607. print '</td></tr>';
  608. dolibarr_install_syslog('step1: failed to create database ' . $dolibarr_main_db_name . ' ' . $newdb->lasterrno() . ' ' . $newdb->lasterror(), LOG_ERR);
  609. $error++;
  610. }
  611. $newdb->close();
  612. }
  613. else {
  614. print '<tr><td>';
  615. print $langs->trans("DatabaseCreation")." (".$langs->trans("User")." ".$userroot.") : ";
  616. print $dolibarr_main_db_name;
  617. print '</td>';
  618. print '<td><img src="../theme/eldy/img/error.png" alt="Error"></td>';
  619. print '</tr>';
  620. // warning message
  621. print '<tr><td colspan="2"><br>';
  622. print $langs->trans("YouAskDatabaseCreationSoDolibarrNeedToConnect",$dolibarr_main_db_user,$dolibarr_main_db_host,$userroot);
  623. print '<br>';
  624. print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'<br><br>';
  625. print $langs->trans("ErrorGoBackAndCorrectParameters").'<br><br>';
  626. print '</td></tr>';
  627. $error++;
  628. }
  629. } // end of create database
  630. // We test access with dolibarr database user (not admin)
  631. if (! $error)
  632. {
  633. 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);
  634. //print "connexion de type=".$conf->db->type." sur host=".$conf->db->host." port=".$conf->db->port." user=".$conf->db->user." name=".$conf->db->name;
  635. $db=getDoliDBInstance($conf->db->type,$conf->db->host,$conf->db->user,$conf->db->pass,$conf->db->name,$conf->db->port);
  636. if ($db->connected)
  637. {
  638. dolibarr_install_syslog("step1: connection to server by user " . $conf->db->user . " ok");
  639. print "<tr><td>";
  640. print $langs->trans("ServerConnection")." (".$langs->trans("User")." ".$conf->db->user.") : ";
  641. print $dolibarr_main_db_host;
  642. print "</td><td>";
  643. print '<img src="../theme/eldy/img/tick.png" alt="Ok">';
  644. print "</td></tr>";
  645. // server access ok, basic access ok
  646. if ($db->database_selected)
  647. {
  648. dolibarr_install_syslog("step1: connection to database " . $conf->db->name . " by user " . $conf->db->user . " ok");
  649. print "<tr><td>";
  650. print $langs->trans("DatabaseConnection")." (".$langs->trans("User")." ".$conf->db->user.") : ";
  651. print $dolibarr_main_db_name;
  652. print "</td><td>";
  653. print '<img src="../theme/eldy/img/tick.png" alt="Ok">';
  654. print "</td></tr>";
  655. $error = 0;
  656. }
  657. else
  658. {
  659. dolibarr_install_syslog("step1: connection to database " . $conf->db->name . " by user " . $conf->db->user . " failed", LOG_ERR);
  660. print "<tr><td>";
  661. print $langs->trans("DatabaseConnection")." (".$langs->trans("User")." ".$conf->db->user.") : ";
  662. print $dolibarr_main_db_name;
  663. print '</td><td>';
  664. print '<img src="../theme/eldy/img/error.png" alt="Error">';
  665. print "</td></tr>";
  666. // warning message
  667. print '<tr><td colspan="2"><br>';
  668. print $langs->trans('CheckThatDatabasenameIsCorrect',$dolibarr_main_db_name).'<br>';
  669. print $langs->trans('IfAlreadyExistsCheckOption').'<br>';
  670. print $langs->trans("ErrorGoBackAndCorrectParameters").'<br><br>';
  671. print '</td></tr>';
  672. $error++;
  673. }
  674. }
  675. else
  676. {
  677. dolibarr_install_syslog("step1: connection to server by user " . $conf->db->user . " failed", LOG_ERR);
  678. print "<tr><td>";
  679. print $langs->trans("ServerConnection")." (".$langs->trans("User")." ".$conf->db->user.") : ";
  680. print $dolibarr_main_db_host;
  681. print '</td><td>';
  682. print '<img src="../theme/eldy/img/error.png" alt="Error">';
  683. print "</td></tr>";
  684. // warning message
  685. print '<tr><td colspan="2"><br>';
  686. print $langs->trans("ErrorConnection",$conf->db->host,$conf->db->name,$conf->db->user);
  687. print $langs->trans('IfLoginDoesNotExistsCheckCreateUser').'<br>';
  688. print $langs->trans("ErrorGoBackAndCorrectParameters").'<br><br>';
  689. print '</td></tr>';
  690. $error++;
  691. }
  692. }
  693. }
  694. print '</table>';
  695. }
  696. ?>
  697. <script type="text/javascript">
  698. function jsinfo()
  699. {
  700. ok=true;
  701. //alert('<?php echo dol_escape_js($langs->transnoentities("NextStepMightLastALongTime")); ?>');
  702. document.getElementById('nextbutton').style.visibility="hidden";
  703. document.getElementById('pleasewait').style.visibility="visible";
  704. return ok;
  705. }
  706. </script>
  707. <?php
  708. $ret=0;
  709. if ($error && isset($argv[1])) $ret=1;
  710. dolibarr_install_syslog("Exit ".$ret);
  711. dolibarr_install_syslog("--- step1: end");
  712. pFooter($error?1:0,$setuplang,'jsinfo',1);
  713. // Return code if ran from command line
  714. if ($ret) exit($ret);
  715. /**
  716. * Create main file. No particular permissions are set by installer.
  717. *
  718. * @param string $mainfile Full path name of main file to generate/update
  719. * @param string $main_dir Full path name to main.inc.php file
  720. * @return void
  721. */
  722. function write_main_file($mainfile,$main_dir)
  723. {
  724. $fp = @fopen("$mainfile", "w");
  725. if($fp)
  726. {
  727. clearstatcache();
  728. fputs($fp, '<?php'."\n");
  729. fputs($fp, "// Wrapper to include main into htdocs\n");
  730. fputs($fp, "include_once '".$main_dir."/main.inc.php';\n");
  731. fclose($fp);
  732. }
  733. }
  734. /**
  735. * Create master file. No particular permissions are set by installer.
  736. *
  737. * @param string $masterfile Full path name of master file to generate/update
  738. * @param string $main_dir Full path name to master.inc.php file
  739. * @return void
  740. */
  741. function write_master_file($masterfile,$main_dir)
  742. {
  743. $fp = @fopen("$masterfile", "w");
  744. if($fp)
  745. {
  746. clearstatcache();
  747. fputs($fp, '<?php'."\n");
  748. fputs($fp, "// Wrapper to include master into htdocs\n");
  749. fputs($fp, "include_once '".$main_dir."/master.inc.php';\n");
  750. fclose($fp);
  751. }
  752. }
  753. /**
  754. * Save configuration file. No particular permissions are set by installer.
  755. *
  756. * @param string $conffile Path to conf file to generate/update
  757. * @return integer
  758. */
  759. function write_conf_file($conffile)
  760. {
  761. global $conf,$langs;
  762. global $main_url,$main_dir,$main_data_dir,$main_force_https,$main_use_alt_dir,$main_alt_dir_name,$main_db_prefix;
  763. global $dolibarr_main_url_root,$dolibarr_main_document_root,$dolibarr_main_data_root,$dolibarr_main_db_host;
  764. global $dolibarr_main_db_port,$dolibarr_main_db_name,$dolibarr_main_db_user,$dolibarr_main_db_pass;
  765. global $dolibarr_main_db_type,$dolibarr_main_db_character_set,$dolibarr_main_db_collation,$dolibarr_main_authentication;
  766. global $db_host,$db_port,$db_name,$db_user,$db_pass,$db_type,$db_character_set,$db_collation;
  767. global $conffile,$conffiletoshow,$conffiletoshowshort;
  768. global $force_dolibarr_lib_ADODB_PATH, $force_dolibarr_lib_NUSOAP_PATH;
  769. global $force_dolibarr_lib_TCPDF_PATH, $force_dolibarr_lib_FPDI_PATH;
  770. global $force_dolibarr_lib_PHPEXCEL_PATH, $force_dolibarr_lib_GEOIP_PATH;
  771. global $force_dolibarr_lib_ODTPHP_PATH, $force_dolibarr_lib_ODTPHP_PATHTOPCLZIP;
  772. global $force_dolibarr_js_CKEDITOR, $force_dolibarr_js_JQUERY, $force_dolibarr_js_JQUERY_UI, $force_dolibarr_js_JQUERY_FLOT;
  773. global $force_dolibarr_font_DOL_DEFAULT_TTF, $force_dolibarr_font_DOL_DEFAULT_TTF_BOLD;
  774. $error=0;
  775. $key = md5(uniqid(mt_rand(), true)); // Generate random hash
  776. $fp = fopen("$conffile", "w");
  777. if($fp)
  778. {
  779. clearstatcache();
  780. fputs($fp,'<?php'."\n");
  781. fputs($fp,'//'."\n");
  782. fputs($fp,'// File generated by Dolibarr installer '.DOL_VERSION.' on '.dol_print_date(dol_now(),'')."\n");
  783. fputs($fp,'//'."\n");
  784. fputs($fp,'// Take a look at conf.php.example file for an example of '.$conffiletoshowshort.' file'."\n");
  785. fputs($fp,'// and explanations for all possibles parameters.'."\n");
  786. fputs($fp,'//'."\n");
  787. fputs($fp, '$dolibarr_main_url_root=\''.str_replace("'","\'",trim($main_url)).'\';');
  788. fputs($fp,"\n");
  789. fputs($fp, '$dolibarr_main_document_root=\''.str_replace("'","\'",trim($main_dir)).'\';');
  790. fputs($fp,"\n");
  791. fputs($fp, $main_use_alt_dir.'$dolibarr_main_url_root_alt=\''.str_replace("'","\'",trim("/".$main_alt_dir_name)).'\';');
  792. fputs($fp,"\n");
  793. fputs($fp, $main_use_alt_dir.'$dolibarr_main_document_root_alt=\''.str_replace("'","\'",trim($main_dir."/".$main_alt_dir_name)).'\';');
  794. fputs($fp,"\n");
  795. fputs($fp, '$dolibarr_main_data_root=\''.str_replace("'","\'",trim($main_data_dir)).'\';');
  796. fputs($fp,"\n");
  797. fputs($fp, '$dolibarr_main_db_host=\''.str_replace("'","\'",trim($db_host)).'\';');
  798. fputs($fp,"\n");
  799. fputs($fp, '$dolibarr_main_db_port=\''.str_replace("'","\'",trim($db_port)).'\';');
  800. fputs($fp,"\n");
  801. fputs($fp, '$dolibarr_main_db_name=\''.str_replace("'","\'",trim($db_name)).'\';');
  802. fputs($fp,"\n");
  803. fputs($fp, '$dolibarr_main_db_prefix=\''.str_replace("'","\'",trim($main_db_prefix)).'\';');
  804. fputs($fp,"\n");
  805. fputs($fp, '$dolibarr_main_db_user=\''.str_replace("'","\'",trim($db_user)).'\';');
  806. fputs($fp,"\n");
  807. fputs($fp, '$dolibarr_main_db_pass=\''.str_replace("'","\'",trim($db_pass)).'\';');
  808. fputs($fp,"\n");
  809. fputs($fp, '$dolibarr_main_db_type=\''.str_replace("'","\'",trim($db_type)).'\';');
  810. fputs($fp,"\n");
  811. fputs($fp, '$dolibarr_main_db_character_set=\''.str_replace("'","\'",trim($db_character_set)).'\';');
  812. fputs($fp,"\n");
  813. fputs($fp, '$dolibarr_main_db_collation=\''.str_replace("'","\'",trim($db_collation)).'\';');
  814. fputs($fp,"\n");
  815. /* Authentication */
  816. fputs($fp, '// Authentication settings');
  817. fputs($fp,"\n");
  818. fputs($fp, '$dolibarr_main_authentication=\'dolibarr\';');
  819. fputs($fp,"\n\n");
  820. fputs($fp, '//$dolibarr_main_demo=\'autologin,autopass\';');
  821. fputs($fp,"\n");
  822. fputs($fp, '// Security settings');
  823. fputs($fp,"\n");
  824. fputs($fp, '$dolibarr_main_prod=\'0\';');
  825. fputs($fp,"\n");
  826. fputs($fp, '$dolibarr_main_force_https=\''.$main_force_https.'\';');
  827. fputs($fp,"\n");
  828. fputs($fp, '$dolibarr_main_restrict_os_commands=\'mysqldump, mysql, pg_dump, pgrestore\';');
  829. fputs($fp,"\n");
  830. fputs($fp, '$dolibarr_nocsrfcheck=\'0\';');
  831. fputs($fp,"\n");
  832. fputs($fp, '$dolibarr_main_cookie_cryptkey=\''.$key.'\';');
  833. fputs($fp,"\n");
  834. fputs($fp, '$dolibarr_mailing_limit_sendbyweb=\'0\';');
  835. fputs($fp,"\n");
  836. // Write params to overwrites default lib path
  837. fputs($fp,"\n");
  838. if (empty($force_dolibarr_lib_FPDF_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_FPDF_PATH=''; }
  839. fputs($fp, '$dolibarr_lib_FPDF_PATH=\''.$force_dolibarr_lib_FPDF_PATH.'\';');
  840. fputs($fp,"\n");
  841. if (empty($force_dolibarr_lib_TCPDF_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_TCPDF_PATH=''; }
  842. fputs($fp, '$dolibarr_lib_TCPDF_PATH=\''.$force_dolibarr_lib_TCPDF_PATH.'\';');
  843. fputs($fp,"\n");
  844. if (empty($force_dolibarr_lib_FPDI_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_FPDI_PATH=''; }
  845. fputs($fp, '$dolibarr_lib_FPDI_PATH=\''.$force_dolibarr_lib_FPDI_PATH.'\';');
  846. fputs($fp,"\n");
  847. if (empty($force_dolibarr_lib_TCPDI_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_TCPDI_PATH=''; }
  848. fputs($fp, '$dolibarr_lib_TCPDI_PATH=\''.$force_dolibarr_lib_TCPDI_PATH.'\';');
  849. fputs($fp,"\n");
  850. if (empty($force_dolibarr_lib_ADODB_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_ADODB_PATH=''; }
  851. fputs($fp, '$dolibarr_lib_ADODB_PATH=\''.$force_dolibarr_lib_ADODB_PATH.'\';');
  852. fputs($fp,"\n");
  853. if (empty($force_dolibarr_lib_GEOIP_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_GEOIP_PATH=''; }
  854. fputs($fp, '$dolibarr_lib_GEOIP_PATH=\''.$force_dolibarr_lib_GEOIP_PATH.'\';');
  855. fputs($fp,"\n");
  856. if (empty($force_dolibarr_lib_NUSOAP_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_NUSOAP_PATH=''; }
  857. fputs($fp, '$dolibarr_lib_NUSOAP_PATH=\''.$force_dolibarr_lib_NUSOAP_PATH.'\';');
  858. fputs($fp,"\n");
  859. if (empty($force_dolibarr_lib_PHPEXCEL_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_PHPEXCEL_PATH=''; }
  860. fputs($fp, '$dolibarr_lib_PHPEXCEL_PATH=\''.$force_dolibarr_lib_PHPEXCEL_PATH.'\';');
  861. fputs($fp,"\n");
  862. if (empty($force_dolibarr_lib_ODTPHP_PATH)) { fputs($fp, '//'); $force_dolibarr_lib_ODTPHP_PATH=''; }
  863. fputs($fp, '$dolibarr_lib_ODTPHP_PATH=\''.$force_dolibarr_lib_ODTPHP_PATH.'\';');
  864. fputs($fp,"\n");
  865. if (empty($force_dolibarr_lib_ODTPHP_PATHTOPCLZIP)) { fputs($fp, '//'); $force_dolibarr_lib_ODTPHP_PATHTOPCLZIP=''; }
  866. fputs($fp, '$dolibarr_lib_ODTPHP_PATHTOPCLZIP=\''.$force_dolibarr_lib_ODTPHP_PATHTOPCLZIP.'\';');
  867. fputs($fp,"\n");
  868. if (empty($force_dolibarr_js_CKEDITOR)) { fputs($fp, '//'); $force_dolibarr_js_CKEDITOR=''; }
  869. fputs($fp, '$dolibarr_js_CKEDITOR=\''.$force_dolibarr_js_CKEDITOR.'\';');
  870. fputs($fp,"\n");
  871. if (empty($force_dolibarr_js_JQUERY)) { fputs($fp, '//'); $force_dolibarr_js_JQUERY=''; }
  872. fputs($fp, '$dolibarr_js_JQUERY=\''.$force_dolibarr_js_JQUERY.'\';');
  873. fputs($fp,"\n");
  874. if (empty($force_dolibarr_js_JQUERY_UI)) { fputs($fp, '//'); $force_dolibarr_js_JQUERY_UI=''; }
  875. fputs($fp, '$dolibarr_js_JQUERY_UI=\''.$force_dolibarr_js_JQUERY_UI.'\';');
  876. fputs($fp,"\n");
  877. if (empty($force_dolibarr_js_JQUERY_FLOT)) { fputs($fp, '//'); $force_dolibarr_js_JQUERY_FLOT=''; }
  878. fputs($fp, '$dolibarr_js_JQUERY_FLOT=\''.$force_dolibarr_js_JQUERY_FLOT.'\';');
  879. fputs($fp,"\n");
  880. // Write params to overwrites default font path
  881. fputs($fp,"\n");
  882. if (empty($force_dolibarr_font_DOL_DEFAULT_TTF)) { fputs($fp, '//'); $force_dolibarr_font_DOL_DEFAULT_TTF=''; }
  883. fputs($fp, '$dolibarr_font_DOL_DEFAULT_TTF=\''.$force_dolibarr_font_DOL_DEFAULT_TTF.'\';');
  884. fputs($fp,"\n");
  885. if (empty($force_dolibarr_font_DOL_DEFAULT_TTF_BOLD)) { fputs($fp, '//'); $force_dolibarr_font_DOL_DEFAULT_TTF_BOLD=''; }
  886. fputs($fp, '$dolibarr_font_DOL_DEFAULT_TTF_BOLD=\''.$force_dolibarr_font_DOL_DEFAULT_TTF_BOLD.'\';');
  887. fputs($fp,"\n");
  888. fclose($fp);
  889. if (file_exists("$conffile"))
  890. {
  891. include $conffile; // force config reload, do not put include_once
  892. conf($dolibarr_main_document_root);
  893. print "<tr><td>";
  894. print $langs->trans("SaveConfigurationFile");
  895. print ' <strong>'.$conffile.'</strong>';
  896. print "</td><td>";
  897. print '<img src="../theme/eldy/img/tick.png" alt="Ok">';
  898. print "</td></tr>";
  899. }
  900. else
  901. {
  902. $error++;
  903. }
  904. }
  905. return $error;
  906. }