dolibarr 20.0.0
doc_generic_supplier_order_odt.modules.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2010-2012 Laurent Destailleur <eldy@users.sourceforge.net>
3 * Copyright (C) 2012 Juanjo Menent <jmenent@2byte.es>
4 * Copyright (C) 2014 Marcos García <marcosgdf@gmail.com>
5 * Copyright (C) 2016 Charlie Benke <charlie@patas-monkey.com>
6 * Copyright (C) 2018-2019 Philippe Grand <philippe.grand@atoo-net.com>
7 * Copyright (C) 2018-2024 Frédéric France <frederic.france@free.fr>
8 * Copyright (C) 2019 Tim Otte <otte@meuser.it>
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 3 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 * or see https://www.gnu.org/
23 */
24
31require_once DOL_DOCUMENT_ROOT.'/core/modules/supplier_order/modules_commandefournisseur.php';
32require_once DOL_DOCUMENT_ROOT.'/product/class/product.class.php';
33require_once DOL_DOCUMENT_ROOT.'/core/lib/company.lib.php';
34require_once DOL_DOCUMENT_ROOT.'/core/lib/functions2.lib.php';
35require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
36require_once DOL_DOCUMENT_ROOT.'/core/lib/doc.lib.php';
37
38
43{
48 public $issuer;
49
53 public $version = 'dolibarr';
54
55
61 public function __construct($db)
62 {
63 global $conf, $langs, $mysoc;
64
65 // Load translation files required by the page
66 $langs->loadLangs(array("main", "companies"));
67
68 $this->db = $db;
69 $this->name = "ODT templates";
70 $this->description = $langs->trans("DocumentModelOdt");
71 $this->scandir = 'SUPPLIER_ORDER_ADDON_PDF_ODT_PATH'; // Name of constant that is used to save list of directories to scan
72
73 // Page size for A4 format
74 $this->type = 'odt';
75 $this->page_largeur = 0;
76 $this->page_hauteur = 0;
77 $this->format = array($this->page_largeur, $this->page_hauteur);
78 $this->marge_gauche = 0;
79 $this->marge_droite = 0;
80 $this->marge_haute = 0;
81 $this->marge_basse = 0;
82
83 $this->option_logo = 1; // Display logo
84 $this->option_tva = 0; // Manage the vat option COMMANDE_TVAOPTION
85 $this->option_modereg = 0; // Display payment mode
86 $this->option_condreg = 0; // Display payment terms
87 $this->option_escompte = 0; // Displays if there has been a discount
88 $this->option_credit_note = 0; // Support credit notes
89 $this->option_freetext = 1; // Support add of a personalised text
90 $this->option_draft_watermark = 0; // Support add of a watermark on drafts
91
92 // Recupere issuer
93 $this->issuer = $mysoc;
94 if (!$this->issuer->country_code) {
95 $this->issuer->country_code = substr($langs->defaultlang, -2); // By default if not defined
96 }
97 }
98
99
106 public function info($langs)
107 {
108 global $conf, $langs;
109
110 // Load translation files required by the page
111 $langs->loadLangs(array("errors", "companies"));
112
113 $form = new Form($this->db);
114
115 $texte = $this->description.".<br>\n";
116 $texte .= '<form action="'.$_SERVER["PHP_SELF"].'" method="POST" enctype="multipart/form-data">';
117 $texte .= '<input type="hidden" name="token" value="'.newToken().'">';
118 $texte .= '<input type="hidden" name="page_y" value="">';
119 $texte .= '<input type="hidden" name="action" value="setModuleOptions">';
120 $texte .= '<input type="hidden" name="param1" value="SUPPLIER_ORDER_ADDON_PDF_ODT_PATH">';
121 $texte .= '<table class="nobordernopadding" width="100%">';
122
123 // List of directories area
124 $texte .= '<tr><td>';
125 $texttitle = $langs->trans("ListOfDirectories");
126 $listofdir = explode(',', preg_replace('/[\r\n]+/', ',', trim(getDolGlobalString('SUPPLIER_ORDER_ADDON_PDF_ODT_PATH'))));
127 $listoffiles = array();
128 foreach ($listofdir as $key => $tmpdir) {
129 $tmpdir = trim($tmpdir);
130 $tmpdir = preg_replace('/DOL_DATA_ROOT/', DOL_DATA_ROOT, $tmpdir);
131 if (!$tmpdir) {
132 unset($listofdir[$key]);
133 continue;
134 }
135 if (!is_dir($tmpdir)) {
136 $texttitle .= img_warning($langs->trans("ErrorDirNotFound", $tmpdir), 0);
137 } else {
138 $tmpfiles = dol_dir_list($tmpdir, 'files', 0, '\.(ods|odt)');
139 if (count($tmpfiles)) {
140 $listoffiles = array_merge($listoffiles, $tmpfiles);
141 }
142 }
143 }
144 $texthelp = $langs->trans("ListOfDirectoriesForModelGenODT");
145 $texthelp .= '<br><br><span class="opacitymedium">'.$langs->trans("ExampleOfDirectoriesForModelGen").'</span>';
146 // Add list of substitution keys
147 $texthelp .= '<br>'.$langs->trans("FollowingSubstitutionKeysCanBeUsed").'<br>';
148 $texthelp .= $langs->transnoentitiesnoconv("FullListOnOnlineDocumentation"); // This contains an url, we don't modify it
149
150 $texte .= $form->textwithpicto($texttitle, $texthelp, 1, 'help', '', 1, 3, $this->name);
151 $texte .= '<div><div style="display: inline-block; min-width: 100px; vertical-align: middle;">';
152 $texte .= '<textarea class="flat" cols="60" name="value1">';
153 $texte .= getDolGlobalString('SUPPLIER_ORDER_ADDON_PDF_ODT_PATH');
154 $texte .= '</textarea>';
155 $texte .= '</div><div style="display: inline-block; vertical-align: middle;">';
156 $texte .= '<input type="submit" class="button button-edit reposition smallpaddingimp" name="modify" value="'.dol_escape_htmltag($langs->trans("Modify")).'">';
157 $texte .= '<br></div></div>';
158
159 // Scan directories
160 $nbofiles = count($listoffiles);
161 if (getDolGlobalString('SUPPLIER_ORDER_ADDON_PDF_ODT_PATH')) {
162 $texte .= $langs->trans("NumberOfModelFilesFound").': <b>';
163 //$texte.=$nbofiles?'<a id="a_'.get_class($this).'" href="#">':'';
164 $texte .= count($listoffiles);
165 //$texte.=$nbofiles?'</a>':'';
166 $texte .= '</b>';
167 }
168
169 if ($nbofiles) {
170 $texte .= '<div id="div_'.get_class($this).'" class="hiddenx">';
171 // Show list of found files
172 foreach ($listoffiles as $file) {
173 $texte .= '- '.$file['name'].' <a href="'.DOL_URL_ROOT.'/document.php?modulepart=doctemplates&file=supplier_orders/'.urlencode(basename($file['name'])).'">'.img_picto('', 'listlight').'</a>';
174 $texte .= ' &nbsp; <a class="reposition" href="'.$_SERVER["PHP_SELF"].'?modulepart=doctemplates&keyforuploaddir=SUPPLIER_ORDER_ADDON_PDF_ODT_PATH&action=deletefile&token='.newToken().'&file='.urlencode(basename($file['name'])).'">'.img_picto('', 'delete').'</a>';
175 $texte .= '<br>';
176 }
177 $texte .= '</div>';
178 }
179 // Add input to upload a new template file.
180 $texte .= '<div>'.$langs->trans("UploadNewTemplate").' <input type="file" name="uploadfile">';
181 $texte .= '<input type="hidden" value="SUPPLIER_ORDER_ADDON_PDF_ODT_PATH" name="keyforuploaddir">';
182 $texte .= '<input type="submit" class="button reposition smallpaddingimp" value="'.dol_escape_htmltag($langs->trans("Upload")).'" name="upload">';
183 $texte .= '</div>';
184 $texte .= '</td>';
185
186 $texte .= '</tr>';
187
188 $texte .= '</table>';
189 $texte .= '</form>';
190
191 return $texte;
192 }
193
194 // phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
206 public function write_file($object, $outputlangs, $srctemplatepath, $hidedetails = 0, $hidedesc = 0, $hideref = 0)
207 {
208 // phpcs:enable
209 global $user, $langs, $conf, $mysoc, $hookmanager;
210
211 if (empty($srctemplatepath)) {
212 dol_syslog("doc_generic_odt::write_file parameter srctemplatepath empty", LOG_WARNING);
213 return -1;
214 }
215
216 // Add odtgeneration hook
217 if (!is_object($hookmanager)) {
218 include_once DOL_DOCUMENT_ROOT.'/core/class/hookmanager.class.php';
219 $hookmanager = new HookManager($this->db);
220 }
221 $hookmanager->initHooks(array('odtgeneration'));
222 global $action;
223
224 if (!is_object($outputlangs)) {
225 $outputlangs = $langs;
226 }
227 $sav_charset_output = $outputlangs->charset_output;
228 $outputlangs->charset_output = 'UTF-8';
229
230 $outputlangs->loadLangs(array("main", "dict", "companies", "bills"));
231
232 if ($conf->fournisseur->commande->dir_output) {
233 $object->fetch_thirdparty();
234
235 if ($object->specimen) {
236 $dir = $conf->fournisseur->commande->dir_output;
237 $file = $dir."/SPECIMEN.pdf";
238 } else {
239 $objectref = dol_sanitizeFileName($object->ref);
240 $objectrefsupplier = dol_sanitizeFileName($object->ref_supplier);
241 $dir = $conf->fournisseur->commande->dir_output.'/'.$objectref;
242 $file = $dir."/".$objectref.".pdf";
243 if (getDolGlobalString('SUPPLIER_REF_IN_NAME')) {
244 $file = $dir."/".$objectref.($objectrefsupplier ? "_".$objectrefsupplier : "").".pdf";
245 }
246 }
247
248 if (!file_exists($dir)) {
249 if (dol_mkdir($dir) < 0) {
250 $this->error = $langs->transnoentities("ErrorCanNotCreateDir", $dir);
251 return -1;
252 }
253 }
254
255 if (file_exists($dir)) {
256 //print "srctemplatepath=".$srctemplatepath; // Src filename
257 $newfile = basename($srctemplatepath);
258 $newfiletmp = preg_replace('/\.od[ts]/i', '', $newfile);
259 $newfiletmp = preg_replace('/template_/i', '', $newfiletmp);
260 $newfiletmp = preg_replace('/modele_/i', '', $newfiletmp);
261 $newfiletmp = $objectref . '_' . $newfiletmp;
262 //$file=$dir.'/'.$newfiletmp.'.'.dol_print_date(dol_now(),'%Y%m%d%H%M%S').'.odt';
263 // Get extension (ods or odt)
264 $newfileformat = substr($newfile, strrpos($newfile, '.') + 1);
265 if (getDolGlobalString('MAIN_DOC_USE_TIMING')) {
266 $format = getDolGlobalString('MAIN_DOC_USE_TIMING');
267 if ($format == '1') {
268 $format = '%Y%m%d%H%M%S';
269 }
270 $filename = $newfiletmp . '-' . dol_print_date(dol_now(), $format) . '.' . $newfileformat;
271 } else {
272 $filename = $newfiletmp . '.' . $newfileformat;
273 }
274 $file = $dir . '/' . $filename;
275 //print "newdir=".$dir;
276 //print "newfile=".$newfile;
277 //print "file=".$file;
278 //print "conf->societe->dir_temp=".$conf->societe->dir_temp;
279
280 dol_mkdir($conf->fournisseur->commande->dir_temp);
281 if (!is_writable($conf->fournisseur->commande->dir_temp)) {
282 $this->error = $langs->transnoentities("ErrorFailedToWriteInTempDirectory", $conf->fournisseur->commande->dir_temp);
283 dol_syslog('Error in write_file: ' . $this->error, LOG_ERR);
284 return -1;
285 }
286
287 // If CUSTOMER contact defined on order, we use it
288 $usecontact = false;
289 $arrayidcontact = $object->getIdContact('external', 'CUSTOMER');
290 if (count($arrayidcontact) > 0) {
291 $usecontact = true;
292 $result = $object->fetch_contact($arrayidcontact[0]);
293 }
294
295 // Recipient name
296 $contactobject = null;
297 if (!empty($usecontact)) {
298 // We can use the company of contact instead of thirdparty company
299 if ($object->contact->socid != $object->thirdparty->id && (!isset($conf->global->MAIN_USE_COMPANY_NAME_OF_CONTACT) || getDolGlobalString('MAIN_USE_COMPANY_NAME_OF_CONTACT'))) {
300 $object->contact->fetch_thirdparty();
301 $socobject = $object->contact->thirdparty;
302 $contactobject = $object->contact;
303 } else {
304 $socobject = $object->thirdparty;
305 // if we have a CUSTOMER contact and we don't use it as thirdparty recipient we store the contact object for later use
306 $contactobject = $object->contact;
307 }
308 } else {
309 $socobject = $object->thirdparty;
310 }
311
312 // Make substitution
313 $substitutionarray = array(
314 '__FROM_NAME__' => $this->issuer->name,
315 '__FROM_EMAIL__' => $this->issuer->email,
316 '__TOTAL_TTC__' => $object->total_ttc,
317 '__TOTAL_HT__' => $object->total_ht,
318 '__TOTAL_VAT__' => $object->total_tva
319 );
320 complete_substitutions_array($substitutionarray, $langs, $object);
321 // Call the ODTSubstitution hook
322 $parameters = array('file'=>$file, 'object'=>$object, 'outputlangs'=>$outputlangs, 'substitutionarray'=>&$substitutionarray);
323 $reshook = $hookmanager->executeHooks('ODTSubstitution', $parameters, $this, $action); // Note that $action and $object may have been modified by some hooks
324 // Line of free text
325 $newfreetext = '';
326 $paramfreetext = 'ORDER_FREE_TEXT';
327 if (!empty($conf->global->$paramfreetext)) {
328 $newfreetext = make_substitutions(getDolGlobalString($paramfreetext), $substitutionarray);
329 }
330
331 // Open and load template
332 require_once ODTPHP_PATH.'odf.php';
333 try {
334 $odfHandler = new Odf(
335 $srctemplatepath,
336 array(
337 'PATH_TO_TMP' => $conf->fournisseur->dir_temp,
338 'ZIP_PROXY' => 'PclZipProxy', // PhpZipProxy or PclZipProxy. Got "bad compression method" error when using PhpZipProxy.
339 'DELIMITER_LEFT' => '{',
340 'DELIMITER_RIGHT' => '}'
341 )
342 );
343 } catch (Exception $e) {
344 $this->error = $e->getMessage();
345 dol_syslog($e->getMessage(), LOG_INFO);
346 return -1;
347 }
348 // After construction $odfHandler->contentXml contains content and
349 // [!-- BEGIN row.lines --]*[!-- END row.lines --] has been replaced by
350 // [!-- BEGIN lines --]*[!-- END lines --]
351
352 // Make substitutions into odt of freetext
353 try {
354 $odfHandler->setVars('free_text', $newfreetext, true, 'UTF-8');
355 } catch (OdfException $e) {
356 dol_syslog($e->getMessage(), LOG_INFO);
357 }
358
359 // Define substitution array
360 $substitutionarray = getCommonSubstitutionArray($outputlangs, 0, null, $object);
361 $array_object_from_properties = $this->get_substitutionarray_each_var_object($object, $outputlangs);
362 $array_objet = $this->get_substitutionarray_object($object, $outputlangs);
363 $array_user = $this->get_substitutionarray_user($user, $outputlangs);
364 $array_soc = $this->get_substitutionarray_mysoc($mysoc, $outputlangs);
365 $array_thirdparty = $this->get_substitutionarray_thirdparty($socobject, $outputlangs);
366 $array_other = $this->get_substitutionarray_other($outputlangs);
367 // retrieve contact information for use in object as contact_xxx tags
368 $array_thirdparty_contact = array();
369 if ($usecontact && is_object($contactobject)) {
370 $array_thirdparty_contact = $this->get_substitutionarray_contact($contactobject, $outputlangs, 'contact');
371 }
372
373 $tmparray = array_merge($substitutionarray, $array_object_from_properties, $array_user, $array_soc, $array_thirdparty, $array_objet, $array_other, $array_thirdparty_contact);
374 complete_substitutions_array($tmparray, $outputlangs, $object);
375
376 // Call the ODTSubstitution hook
377 $parameters = array('odfHandler'=>&$odfHandler, 'file'=>$file, 'object'=>$object, 'outputlangs'=>$outputlangs, 'substitutionarray'=>&$tmparray);
378 $reshook = $hookmanager->executeHooks('ODTSubstitution', $parameters, $this, $action); // Note that $action and $object may have been modified by some hooks
379
380 foreach ($tmparray as $key => $value) {
381 try {
382 if (preg_match('/logo$/', $key)) { // Image
383 if (file_exists($value)) {
384 $odfHandler->setImage($key, $value);
385 } else {
386 $odfHandler->setVars($key, 'ErrorFileNotFound', true, 'UTF-8');
387 }
388 } else { // Text
389 $odfHandler->setVars($key, $value, true, 'UTF-8');
390 }
391 } catch (OdfException $e) {
392 dol_syslog($e->getMessage(), LOG_INFO);
393 }
394 }
395 // Replace tags of lines
396 $foundtagforlines = 1;
397 try {
398 $listlines = $odfHandler->setSegment('lines');
399 } catch (OdfExceptionSegmentNotFound $e) {
400 // We may arrive here if tags for lines not present into template
401 $foundtagforlines = 0;
402 dol_syslog($e->getMessage(), LOG_INFO);
403 }
404 if ($foundtagforlines) {
405 $linenumber = 0;
406 foreach ($object->lines as $line) {
407 $linenumber++;
408 $tmparray = $this->get_substitutionarray_lines($line, $outputlangs, $linenumber);
409 complete_substitutions_array($tmparray, $outputlangs, $object, $line, "completesubstitutionarray_lines");
410 // Call the ODTSubstitutionLine hook
411 $parameters = array('odfHandler'=>&$odfHandler, 'file'=>$file, 'object'=>$object, 'outputlangs'=>$outputlangs, 'substitutionarray'=>&$tmparray, 'line'=>$line);
412 $reshook = $hookmanager->executeHooks('ODTSubstitutionLine', $parameters, $this, $action); // Note that $action and $object may have been modified by some hooks
413 foreach ($tmparray as $key => $val) {
414 try {
415 $listlines->setVars($key, $val, true, 'UTF-8');
416 } catch (SegmentException $e) {
417 dol_syslog($e->getMessage(), LOG_INFO);
418 }
419 }
420 $listlines->merge();
421 }
422 try {
423 $odfHandler->mergeSegment($listlines);
424 } catch (OdfException $e) {
425 $this->error = $e->getMessage();
426 dol_syslog($this->error, LOG_WARNING);
427 return -1;
428 }
429 }
430
431 // Replace labels translated
432 $tmparray = $outputlangs->get_translations_for_substitutions();
433 foreach ($tmparray as $key => $value) {
434 try {
435 $odfHandler->setVars($key, $value, true, 'UTF-8');
436 } catch (OdfException $e) {
437 dol_syslog($e->getMessage(), LOG_INFO);
438 }
439 }
440
441 // Call the beforeODTSave hook
442
443 $parameters = array('odfHandler'=>&$odfHandler, 'file'=>$file, 'object'=>$object, 'outputlangs'=>$outputlangs, 'substitutionarray'=>&$tmparray);
444 $reshook = $hookmanager->executeHooks('beforeODTSave', $parameters, $this, $action); // Note that $action and $object may have been modified by some hooks
445
446 // Write new file
447 if (getDolGlobalString('MAIN_ODT_AS_PDF')) {
448 try {
449 $odfHandler->exportAsAttachedPDF($file);
450 } catch (Exception $e) {
451 $this->error = $e->getMessage();
452 dol_syslog($e->getMessage(), LOG_INFO);
453 return -1;
454 }
455 } else {
456 try {
457 $odfHandler->saveToDisk($file);
458 } catch (Exception $e) {
459 $this->error = $e->getMessage();
460 dol_syslog($e->getMessage(), LOG_INFO);
461 return -1;
462 }
463 }
464
465 $parameters = array('odfHandler'=>&$odfHandler, 'file'=>$file, 'object'=>$object, 'outputlangs'=>$outputlangs, 'substitutionarray'=>&$tmparray);
466 $reshook = $hookmanager->executeHooks('afterODTCreation', $parameters, $this, $action); // Note that $action and $object may have been modified by some hooks
467
468 dolChmod($file);
469
470 $odfHandler = null; // Destroy object
471
472 $this->result = array('fullpath'=>$file);
473
474 return 1; // Success
475 } else {
476 $this->error = $langs->transnoentities("ErrorCanNotCreateDir", $dir);
477 return -1;
478 }
479 }
480
481 return -1;
482 }
483}
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
Definition card.php:58
get_substitutionarray_each_var_object(&$object, $outputlangs, $recursive=1)
Define array with couple substitution key => substitution value.
get_substitutionarray_mysoc($mysoc, $outputlangs)
Define array with couple substitution key => substitution value.
get_substitutionarray_contact($object, $outputlangs, $array_key='object')
Define array with couple substitution key => substitution value.
get_substitutionarray_other($outputlangs)
Define array with couple substitution key => substitution value.
get_substitutionarray_lines($line, $outputlangs, $linenumber=0)
Define array with couple substitution key => substitution value Note that vars into substitutions arr...
get_substitutionarray_thirdparty($object, $outputlangs, $array_key='company')
Define array with couple substitution key => substitution value For example {company_name}...
get_substitutionarray_user($user, $outputlangs)
Define array with couple substitution key => substitution value.
Class to manage generation of HTML components Only common components must be here.
Class to manage hooks.
Parent class for supplier orders models.
Class to build documents using ODF templates generator.
info($langs)
Return description of a module.
write_file($object, $outputlangs, $srctemplatepath, $hidedetails=0, $hidedesc=0, $hideref=0)
Function to build a document on disk using the generic odt module.
print $script_file $mode $langs defaultlang(is_numeric($duration_value) ? " delay=". $duration_value :"").(is_numeric($duration_value2) ? " after cd cd cd description as description
Only used if Module[ID]Desc translation string is not found.
dol_dir_list($utf8_path, $types="all", $recursive=0, $filter="", $excludefilter=null, $sortcriteria="name", $sortorder=SORT_ASC, $mode=0, $nohook=0, $relativename="", $donotfollowsymlinks=0, $nbsecondsold=0)
Scan a directory and return a list of files/directories.
Definition files.lib.php:63
img_warning($titlealt='default', $moreatt='', $morecss='pictowarning')
Show warning logo.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
dolChmod($filepath, $newmask='')
Change mod of a file.
dol_now($mode='auto')
Return date for now.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
newToken()
Return the value of token currently saved into session with name 'newtoken'.
complete_substitutions_array(&$substitutionarray, $outputlangs, $object=null, $parameters=null, $callfunc="completesubstitutionarray")
Complete the $substitutionarray with more entries coming from external module that had set the "subst...
make_substitutions($text, $substitutionarray, $outputlangs=null, $converttextinhtmlifnecessary=0)
Make substitution into a text string, replacing keys with vals from $substitutionarray (oldval=>newva...
dol_sanitizeFileName($str, $newstr='_', $unaccent=1)
Clean a string to use it as a file name.
getCommonSubstitutionArray($outputlangs, $onlykey=0, $exclude=null, $object=null, $include=null)
Return array of possible common substitutions.
getDolGlobalString($key, $default='')
Return dolibarr global constant string value.
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)
if(preg_match('/crypted:/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type
Definition repair.php:137
$conf db name
Only used if Module[ID]Name translation string is not found.
Definition repair.php:140