From: Nik Okuntseff Date: Mon, 18 Jul 2016 17:26:45 +0000 (+0000) Subject: Merge branch 'master' of https://github.com/avidenic/timetracker into avidenic-master X-Git-Tag: timetracker_1.19-1~1702^2 X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/timetracker.git/commitdiff_plain/0afb05f8218082cb068f17a0f16f5bcb5c32131e?hp=61d8edb3db70bd197ed6b988727394633b0cecf9 Merge branch 'master' of https://github.com/avidenic/timetracker into avidenic-master Conflicts: .gitignore WEB-INF/templates/footer.tpl --- diff --git a/.gitignore b/.gitignore index c1b019f7..8f4d2699 100644 --- a/.gitignore +++ b/.gitignore @@ -4,4 +4,4 @@ WEB-INF/templates_c/*.png WEB-INF/lib/tcpdf/ nbproject/ upload/ -.vscode/ \ No newline at end of file +.vscode/ diff --git a/dbinstall.php b/dbinstall.php index 1009f519..a511617b 100755 --- a/dbinstall.php +++ b/dbinstall.php @@ -42,6 +42,99 @@ function setChange($sql) { print "successful update
\n"; } +if (!$request->isPost()) { + echo('

Environment check

'); + + // Check if WEB-INF/templates_c dir is writable. + if (is_writable(APP_DIR.'/WEB-INF/templates_c/')) { + echo('WEB-INF/templates_c/ directory is writable.
'); + } else { + echo('Error: WEB-INF/templates_c/ directory is not writable.
'); + } + + // Require the configuration file with application settings. + if (file_exists(APP_DIR."/WEB-INF/config.php")) { + echo('WEB-INF/config.php file exists.
'); + } else { + echo('Error: WEB-INF/config.php file does not exist.
'); + } + + // Check whether DSN is defined. + if (defined('DSN')) { + // echo('DSN is defined as '.DSN.'
'); + echo('DSN is defined.
'); + } else { + echo('Error: DSN value is not defined. Check your config.php file.
'); + } + + // Depending on DSN, require either mysqli or mysql extensions. + if (strrpos(DSN, 'mysqli://', -strlen(DSN)) !== FALSE) { + if (extension_loaded('mysqli')) { + echo('mysqli PHP extension is loaded.
'); + } else { + echo('Error: mysqli PHP extension is required but is not loaded.
'); + } + } + if (strrpos(DSN, 'mysql://', -strlen(DSN)) !== FALSE) { + if (extension_loaded('mysql')) { + echo('mysql PHP extension is loaded.
'); + } else { + echo('Error: mysql PHP extension is required but is not loaded.
'); + } + } + + // Check mbstring extension. + if (extension_loaded('mbstring')) { + echo('mbstring PHP extension is loaded.
'); + } else { + echo('Error: mbstring PHP extension is not loaded.
'); + } + + // Check gd extension. + if (extension_loaded('gd')) { + echo('gd PHP extension is loaded.
'); + } else { + echo('Error: gd PHP extension is not loaded. It is required for charts plugin.
'); + } + + // Check ldap extension. + if (AUTH_MODULE == 'ldap') { + if (extension_loaded('ldap_')) { + echo('ldap PHP extension is loaded.
'); + } else { + echo('Error: ldap PHP extension is not loaded. It is required for LDAP authentication.
'); + } + } + + // Check database access. + require_once('MDB2.php'); + $conn = MDB2::connect(DSN); + if (!is_a($conn, 'MDB2_Error')) { + echo('Connection to database successful.
'); + } else { + die('Error: connection to database failed. '.$conn->getMessage().'
'); + } + + $conn->setOption('debug', true); + $conn->setFetchMode(MDB2_FETCHMODE_ASSOC); + + $sql = "show tables"; + $res = $conn->query($sql); + if (is_a($res, 'MDB2_Error')) { + die('Error: show tables returned an error. '.$res->getMessage().'
'); + } + $tblCnt = 0; + while ($val = $res->fetchRow()) { + $tblCnt++; + } + if ($tblCnt > 0) { + echo("There are $tblCnt tables in database.
"); + } else { + echo('There are no tables in database. Execute step 1 - Create database structure.
'); + } + $conn->disconnect(); +} + if ($_POST) { print "Processing...
\n";