180 global $langs,
$conf;
182 dol_syslog(get_class($this).
"::load_arrays user=".$user->id.
" filter=".$filter);
186 require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions2.lib.php';
190 foreach ($modulesdir as $dir) {
192 if (!is_resource($handle)) {
197 while (($file = readdir($handle)) !==
false) {
199 if (preg_match(
'/\.back$/i', $file)) {
203 if (!preg_match(
"/^(mod.*)\.class\.php/i", $file, $reg)) {
207 $modulename = $reg[1];
211 $part = strtolower(preg_replace(
'/^mod/i',
'', $modulename));
213 if ($part ===
'propale') {
216 if (empty(
$conf->$part->enabled)) {
220 if (empty($enabled)) {
225 $file = $dir.
"/".$modulename.
".class.php";
226 $classname = $modulename;
228 $module =
new $classname($this->db);
229 '@phan-var-force DolibarrModules $module';
231 if (isset($module->import_code) && is_array($module->import_code)) {
232 foreach ($module->import_code as $r => $value) {
233 if ($filter && ($filter != $module->import_code[$r])) {
253 $langtoload = $module->getLangFilesArray();
254 if (is_array($langtoload)) {
255 foreach ($langtoload as $key) {
261 $this->array_import_perms[$i] = $user->hasRight(
'import',
'run');
263 $this->array_import_icon[$i] = (isset($module->import_icon[$r]) ? $module->import_icon[$r] : $module->picto);
265 $this->array_import_code[$i] = $module->import_code[$r];
267 $this->array_import_label[$i] = $module->getImportDatasetLabel($r);
269 $this->array_import_tables[$i] = $module->import_tables_array[$r];
271 $this->array_import_tables_creator[$i] = (isset($module->import_tables_creator_array[$r]) ? $module->import_tables_creator_array[$r] :
'');
273 $this->array_import_fields[$i] = $module->import_fields_array[$r];
275 $this->array_import_fieldshidden[$i] = (isset($module->import_fieldshidden_array[$r]) ? $module->import_fieldshidden_array[$r] :
'');
277 $this->array_import_entities[$i] = $module->import_entities_array[$r];
279 $this->array_import_regex[$i] = (isset($module->import_regex_array[$r]) ? $module->import_regex_array[$r] :
'');
281 $this->array_import_updatekeys[$i] = (isset($module->import_updatekeys_array[$r]) ? $module->import_updatekeys_array[$r] :
'');
284 $this->array_import_preselected_updatekeys[$i] = (isset($module->import_preselected_updatekeys_array[$r]) ? $module->import_preselected_updatekeys_array[$r] :
'');
286 $this->array_import_examplevalues[$i] = (isset($module->import_examplevalues_array[$r]) ? $module->import_examplevalues_array[$r] :
'');
288 $this->array_import_convertvalue[$i] = (isset($module->import_convertvalue_array[$r]) ? $module->import_convertvalue_array[$r] :
'');
290 $this->array_import_run_sql_after[$i] = (isset($module->import_run_sql_after_array[$r]) ? $module->import_run_sql_after_array[$r] :
'');
292 $this->array_import_module[$i] = array(
'position_of_profile' => ($module->module_position.
'-'.$module->import_code[$r]),
'module' => $module);
294 dol_syslog(
"Import loaded for module ".$modulename.
" with index ".$i.
", dataset=".$module->import_code[$r].
", nb of fields=".count($module->import_fields_array[$r]));
320 global
$conf, $langs;
324 dol_syslog(get_class($this).
"::build_example_file ".$model);
327 $dir = DOL_DOCUMENT_ROOT.
"/core/modules/import/";
328 $file =
"import_".$model.
".modules.php";
329 $classname =
"Import".$model;
330 require_once $dir.$file;
331 $objmodel =
new $classname($this->db, $datatoimport);
332 '@phan-var-force ModeleImports $objmodel';
334 $outputlangs = $langs;
338 $s .= $objmodel->write_header_example($outputlangs);
341 $s .= $objmodel->write_title_example($outputlangs, $headerlinefields);
344 $s .= $objmodel->write_record_example($outputlangs, $contentlinevalues);
347 $s .= $objmodel->write_footer_example($outputlangs);
363 if (empty($this->model_name)) {
364 $this->error =
'ErrorWrongParameters';
367 if (empty($this->datatoimport)) {
368 $this->error =
'ErrorWrongParameters';
371 if (empty($this->hexa)) {
372 $this->error =
'ErrorWrongParameters';
378 $sql =
'INSERT INTO '.MAIN_DB_PREFIX.
'import_model (';
385 $sql .= (isset($this->fk_user) ? (int) $this->fk_user :
'null').
",";
386 $sql .=
" '".$this->db->escape($this->model_name).
"',";
387 $sql .=
" '".$this->db->escape($this->datatoimport).
"',";
388 $sql .=
" '".$this->db->escape($this->hexa).
"'";
391 $resql = $this->db->query($sql);
396 $this->error = $this->db->lasterror();
397 $this->errno = $this->db->lasterrno();
398 $this->db->rollback();
411 $sql =
'SELECT em.rowid, em.field, em.label, em.type';
412 $sql .=
' FROM '.MAIN_DB_PREFIX.
'import_model as em';
413 $sql .=
' WHERE em.rowid = '.((int) $id);
415 dol_syslog(get_class($this).
"::fetch", LOG_DEBUG);
416 $result = $this->db->query($sql);
418 $obj = $this->db->fetch_object($result);
420 $this->
id = $obj->rowid;
421 $this->hexa = $obj->field;
422 $this->model_name = $obj->label;
423 $this->datatoimport = $obj->type;
424 $this->fk_user = $obj->fk_user;
427 $this->error =
"Model not found";