=$max_steps){ //GenerateConfigFiles($output_folder); //if($config['postinstall']) PostInstall(); $webserverUser = DetermineWebserverUser(); $phpBinary = DeterminePhpBinary(); $baseDir = DetermineInstallationDir(); $cronjobStarterPath = $baseDir . '/cronjobs/starter2.php'; $cronjobLine = htmlspecialchars(sprintf('* * * * * %s %s > /dev/null 2>&1', $phpBinary, $cronjobStarterPath)); $page = HtmlTemplate( "

Setup erfolgreich beendet!

Um den Prozessstarter nutzen zu können: Tragen Sie folgendes Script in ihrer crontab ein:

php {$cronjobStarterPath}

Am besten eignet sich ein Interval von einer Minute. Wichtig ist dass der Cronjob unter dem Benutzer des Webservers läuft.


Anleitung – Crontab einrichten

  1. Nachfolgendes Kommando ausführen:

    sudo crontab -u {$webserverUser} -e
  2. Anschließend öffnet sich ein Editor. Dort folgende Zeile einfügen und die Datei speichern:

    {$cronjobLine}
  3. Nach dem Verlassen des Editors sollte diese Ausgabe als Bestätigung erscheinen:

    crontab: installing new crontab


Anmelden mit Benutzer: admin und Passwort: admin
"); }else{ $ok = true; if($step == 1) { $setup[$step]['description'] = stepMessage($step); $ok = stepFehler($step); }else $ok = stepFehler($step); $page = GenerateHtml($step, $setup); if($ok){$page = str_replace('[BUTTON]', (($step<=$max_steps)?"":""), $page);}else{$page = str_replace('[BUTTON]','',$page);} } if($submit!='') { $configfile = $_POST['_CONFIGFILE']; $action = $_POST['_ACTION']; unset($_POST['_CONFIGFILE']); unset($_POST['_ACTION']); unset($_POST['_SUBMIT']); $error = ((function_exists($action ?? '')) ? $action() : ''); if($configfile=='') $error .= "
'configfile' for this step is missing"; if($error=='') { // Convert Fields to Session foreach($_POST as $key=>$value) $_SESSION['setup'][$configfile][$key] = $value; if($step == 3)GenerateConfigFiles($output_folder); if($step == 3)CreateUserdata(); if($step == 3)PostInstall(); // execute Sql-Files $sql_prefix = "sql_"; foreach($_POST as $key=>$value) { if(strlen($key)>strlen($sql_prefix) && substr($key,0,strlen($sql_prefix))==$sql_prefix && $_SESSION['setup'][$configfile][substr($key,strlen($sql_prefix), strlen($key)-strlen($sql_prefix))]!=''){ unset($_SESSION['setup'][$configfile][$key]); if($value != '../../database/struktur.sql' && $value != '../../database/beispiel.sql')continue; if(is_file($value)){ if(is_file(__DIR__.'/../../conf/user.inc.php')) { $import = file_get_contents($value); $import = preg_replace ("%/\*(.*)\*/%Us", '', $import); $import = preg_replace ("%^--(.*)\n%mU", '', $import); $import = preg_replace ("%^$\n%mU", '', $import); $db= mysqli_connect($_SESSION['setup'][$configfile]['WFdbhost'],$_SESSION['setup'][$configfile]['WFdbuser'],$_SESSION['setup'][$configfile]['WFdbpass']); if($db) { if(mysqli_select_db($db,$_SESSION['setup'][$configfile]['WFdbname'])) { mysqli_set_charset($db,"utf8"); mysqli_query($db,"SET SESSION SQL_MODE :=''"); //mysqli_real_escape_string($db,$import); if($value == '../../database/struktur.sql') { // Clear target DB mysqli_query($db,'SET foreign_key_checks = 0'); if ($result = mysqli_query($db,"SHOW TABLES")) { while($row = $result->fetch_array(MYSQLI_NUM)) { mysqli_query($db,'DROP TABLE IF EXISTS '.$row[0]); } } mysqli_query($db,'SET foreign_key_checks = 1'); } $import = explode (";\n", $import); foreach ($import as $imp){ if ($imp != '' && $imp != ' ' && trim($imp) != ''){ mysqli_query($db,$imp); } } if(isset($_POST['BeispielTpl']) && $_POST['BeispielTpl']) mysqli_query($db, "INSERT INTO `user` (`id`, `username`, `password`, `repassword`, `description`, `settings`, `parentuser`, `activ`, `type`, `adresse`, `fehllogins`, `standarddrucker`, `firma`, `logdatei`, `startseite`, `hwtoken`, `hwkey`, `hwcounter`, `motppin`, `motpsecret`, `passwordmd5`, `externlogin`, `projekt_bevorzugen`, `email_bevorzugen`, `projekt`, `rfidtag`, `vorlage`, `kalender_passwort`, `kalender_ausblenden`, `kalender_aktiv`, `gpsstechuhr`, `standardetikett`, `standardfax`, `internebezeichnung`, `hwdatablock`) VALUES (3, 'demomitarbeiter', 'pllIX0pw7JU9c', 0, '', 'a:6:{s:16:\"pos_list_projekt\";s:1:\"0\";s:18:\"pos_list_kassierer\";s:1:\"0\";s:22:\"pos_list_kassierername\";s:1:\"0\";s:18:\"pos_list_lkadresse\";s:1:\"0\";s:18:\"lohnabrechnung_von\";s:0:\"\";s:18:\"lohnabrechnung_bis\";s:0:\"\";}', 0, 1, 'standard', 6, 0, 0, 1, '2015-10-26 16:01:23', '', 0, '', 0, '', '', '2ad71933e4b074c4671425c8e6b48021', 0, 0, 1, 0, '', '', '', 0, 0, 0, 0, 0, NULL, ''); "); $_SESSION['setup'][$value] = 1; } mysqli_close($db); } /* if(exec("mysql --user='{$_SESSION['setup'][$configfile]['WFdbuser']}' --password='{$_SESSION['setup'][$configfile]['WFdbpass']}' --host='{$_SESSION['setup'][$configfile]['WFdbhost']}' --database='{$_SESSION['setup'][$configfile]['WFdbname']}' < '$value'", $sql_out, $sql_status)==2) $error = "Konnte '$value' nicht ausführen"; }else $error .= "Konnte '$value' nicht finden"; */ } } } } // remove Readonly-Fields $ro_prefix = "ro_"; foreach($_POST as $key=>$value) { if(strlen($key)>strlen($ro_prefix) && substr($key,0,strlen($ro_prefix))==$ro_prefix){ unset($_SESSION['setup'][$configfile][substr($key,strlen($ro_prefix), strlen($key)-strlen($ro_prefix))]); unset($_SESSION['setup'][$configfile][$key]); } } if($error=='') { header('Location: ./setup.php?step='.++$step); exit; }else $page = str_replace('[MESSAGE]', "
$error
", $page); }else $page = str_replace('[MESSAGE]', "
$error
", $page); } $page = str_replace('[MESSAGE]','', $page); echo $page; if($step == 5 && stepFehler(5)) { @unlink(__DIR__ . '/setup.conf.php'); @unlink(__DIR__ . '/setup-cli.php'); @unlink(__DIR__ . '/setup.css'); @unlink(__FILE__); @rmdir(__DIR__); } function GenerateConfigFiles($output_folder) { if(!stepFehler(3)) { return false; } $fehler = true; foreach($_SESSION['setup'] as $file=>$vars) { $fehler = false; } foreach($_SESSION['setup'] as $file=>$vars) { if($file !== 'user.inc.php') { $fehler = true; continue; } if(!is_dir($output_folder)) { $fehler = true; continue; } $out = "$value) { if(in_array($key, array('WFdbhost', 'WFdbname', 'WFdbuser','WFdbpass','WFuserdata'))) { $$key = $value; } } if($WFdbname == '' || $WFdbuser == '') { return false; } $db= mysqli_connect($WFdbhost,$WFdbuser,$WFdbpass); if(!$db) { return false; } if(!mysqli_select_db($db,$WFdbname)) { return false; } foreach($vars as $key=>$value) { if(!in_array($key, array('WFdbhost', 'WFdbname', 'WFdbuser','WFdbpass','WFuserdata'))) { continue; } if($key === 'WFuserdata' && !is_dir($value)) { $fehler = true; continue; } if(strpos($key, 'WF') !== false){ if($value==='true' || $value==='false'){ $out .= '$this->' . $key . '=' . $value . ';' . "\n"; } else{ $out .= '$this->' . $key . '=\'' . (str_replace('\'', '\\\'', str_replace('\\', '\\\\', $value))) . '\';' . "\n"; } } } /*$out2 = ""; if(!file_put_contents(dirname(__FILE__).'/../../conf/user_defined.php', $out2))$fehler = true;*/ if(!file_put_contents($output_folder.$file, $out)) { $fehler = true; } } return !$fehler; } function GenerateHtml($step, $setup) { if(!array_key_exists($step, $setup)) { return "

Page doesnt exist

"; } $html = ""; if(array_key_exists('description',$setup[$step])) $html .= "

{$setup[$step]['description']}

"; if(array_key_exists('configfile',$setup[$step])) $html .= ""; if(array_key_exists('action',$setup[$step])) $html .= ""; $fields = ''; foreach($setup[$step]['fields'] as $key=>$value) { $name = $key; $text = ((array_key_exists('text',$value)) ? $value['text'] : $value); $type = ((array_key_exists('type',$value)) ? $value['type'] : "text"); $note = ((array_key_exists('note',$value)) ? $value['note'] : ""); $default = ((array_key_exists('default',$value)) ? $value['default'] : ""); $options = ((array_key_exists('options',$value)) ? $value['options'] : array()); $fvalue = ((array_key_exists('value',$value)) ? $value['value'] : ""); $readonly = ((array_key_exists('readonly',$value)) ? $value['readonly'] : ""); $sql = ((array_key_exists('sql',$value)) ? $value['sql'] : ""); $invisible = ((array_key_exists('invisible',$value)) ? $value['invisible'] : ""); if($readonly!="") $ro = ""; if($sql!="") $mysql = ""; if($invisible=="") { if($type=='text'){ $input = ""; } if($type=='password'){ $input = ""; } if($type=='checkbox'){ $input = ""; } if($type=='select') { $opt_out = ''; foreach($options as $opt_value=>$opt_text){ $selected = (($default!="" && $default==$opt_value) ? 'selected' : ''); $opt_out .= ""; } $input = ""; } $field = "
{$input}{$ro}{$mysql}
$note
\n"; }else $field = "{$ro}{$mysql}"; $fields .= $field; } $html .= "\n[MESSAGE]\n$fields\n[BUTTON]"; $page = HtmlTemplate($html, $step); return $page; } function HtmlTemplate($html) { global $step; // CSS inline einbinden; ansonsten wird die letzte Seite nicht korrekt angezeigt // Auf der letzten Seite werden alle Dateien im setup-Order gelöscht. $cssContent = file_get_contents(__DIR__ . '/setup.css'); return " OpenXE Installer

OpenXE Installer

{$html}

OpenXE is free open source software under AGPL/EGPL license, based on Xentral® by Xentral ERP Software GmbH.

"; } /** * Determine under which linux user runs the webserver * * @return string */ function DetermineWebserverUser() { $username = @getenv('USERNAME') ?: @getenv('USER'); if ($username !== false && !empty($username)) { return $username; } $username = $_SERVER['USERNAME'] ?: $_SERVER['USER']; if (!empty($username)) { return $username; } $username = trim(@shell_exec('whoami')); if (!empty($username)) { return $username; } return get_current_user(); // Eventuell falsch unter IIS } /** * Determine the full path of the php binary * * @return string */ function DeterminePhpBinary() { if (!empty(PHP_BINDIR)) { return PHP_BINDIR . '/php'; } $binary = trim(@shell_exec('which php')); if (!empty($binary)) { return $binary; } return '/usr/bin/env php'; } /** * Determine the full path of the installation directory; without trailing slash * * @return string */ function DetermineInstallationDir() { $baseDir = null; if (!empty(__FILE__)) { $offset = strpos(__FILE__, '/www/setup/setup.php'); if ($offset !== false) { $baseDir = substr_replace(__FILE__, '', $offset); } } if (!empty($baseDir)) { return $baseDir; } if (!empty($_SERVER['SCRIPT_FILENAME'])) { $offset = strpos($_SERVER['SCRIPT_FILENAME'], '/www/setup/setup.php'); if ($offset !== false) { $baseDir = substr_replace($_SERVER['SCRIPT_FILENAME'], '', $offset); } } return $baseDir; } ?>