X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/timetracker.git/blobdiff_plain/fcb4a368c1de2e4c086e64064c00f404efaef617..55e76bcb802e12987d7afa9a79fcf37eaec0d746:/dbinstall.php diff --git a/dbinstall.php b/dbinstall.php index a6aab22e..9f579947 100755 --- a/dbinstall.php +++ b/dbinstall.php @@ -55,6 +55,16 @@ if ($request->isGet()) { // Require the configuration file with application settings. if (file_exists(APP_DIR."/WEB-INF/config.php")) { echo('WEB-INF/config.php file exists.
'); + + // Config file must start with the PHP opening tag. We are checking this because + // a Unicode editor may insert a byte order mark (BOM) before it. This is not good as it will + // spit white space before output in some situations such as in PDF reports. + $file = fopen(APP_DIR.'/WEB-INF/config.php', 'r'); + $line = fgets($file); + if (strcmp('Error: WEB-INF/config.php file does not start with PHP opening tag.
'); + } + fclose($file); } else { echo('Error: WEB-INF/config.php file does not exist.
'); } @@ -67,6 +77,14 @@ if ($request->isGet()) { echo('Error: DSN value is not defined. Check your config.php file.
'); } + // Check if PHP version is good enough. + $required_version = '5.2.1'; // Something in TCPDF library does not work below this one. + if (version_compare(phpversion(), $required_version, '>=')) { + echo('PHP version: '.phpversion().', good enough.
'); + } else { + echo('Error: PHP version is not high enough: '.phpversion().'. Required: '.$required_version.'.
'); + } + // Depending on DSN, require either mysqli or mysql extensions. if (strrpos(DSN, 'mysqli://', -strlen(DSN)) !== FALSE) { if (extension_loaded('mysqli')) { @@ -587,7 +605,18 @@ if ($_POST) { setChange("ALTER TABLE tt_fav_reports ADD COLUMN `show_client` tinyint(4) NOT NULL default '0'"); setChange("ALTER TABLE tt_fav_reports ADD COLUMN `show_invoice` tinyint(4) NOT NULL default '0'"); setChange("ALTER TABLE tt_fav_reports ADD COLUMN `group_by` varchar(20) default NULL"); - setChange("CREATE TABLE `tt_expense_items` (`id` bigint NOT NULL auto_increment, `date` date NOT NULL, `user_id` int(11) NOT NULL, `client_id` int(11) default NULL, `project_id` int(11) default NULL, `name` varchar(255) NOT NULL, `cost` decimal(10,2) default '0.00', `invoice_id` int(11) default NULL, PRIMARY KEY (`id`))"); + + setChange("CREATE TABLE `tt_expense_items` (`id` bigint NOT NULL auto_increment, `date` date NOT NULL, + `user_id` int(11) NOT NULL, `client_id` int(11) default NULL, `project_id` int(11) default NULL, + + /* Kimberly Keown suggested revision to increase character length of expenses.php and expense_edit.php $cl_item_name textarea. + Updated mysql.sql also. + Original: `name` varchar(255) NOT NULL, */ + `name` text NOT NULL, + + `cost` decimal(10,2) default '0.00', `invoice_id` int(11) default NULL, + PRIMARY KEY (`id`))"); + setChange("create index date_idx on tt_expense_items(date)"); setChange("create index user_idx on tt_expense_items(user_id)"); setChange("create index client_idx on tt_expense_items(client_id)"); @@ -614,8 +643,7 @@ if ($_POST) { setChange("CREATE TABLE `tt_monthly_quota` (`team_id` int(11) NOT NULL, `year` smallint(5) UNSIGNED NOT NULL, `month` tinyint(3) UNSIGNED NOT NULL, `quota` smallint(5) UNSIGNED NOT NULL, PRIMARY KEY (`year`,`month`,`team_id`))"); setChange("ALTER TABLE `tt_monthly_quota` ADD CONSTRAINT `FK_TT_TEAM_CONSTRAING` FOREIGN KEY (`team_id`) REFERENCES `tt_teams` (`id`) ON DELETE CASCADE ON UPDATE CASCADE"); setChange("ALTER TABLE `tt_teams` ADD `workday_hours` SMALLINT NULL DEFAULT '8' AFTER `lock_spec`"); - setChange("UPDATE `tt_teams` SET `workday_hours` = 8"); - setChange("ALTER TABLE tt_teams DROP daily_working_hours"); + setChange("RENAME TABLE tt_monthly_quota TO tt_monthly_quotas"); } // The update_clients function updates projects field in tt_clients table. @@ -701,7 +729,7 @@ if ($_POST) { setChange("OPTIMIZE TABLE tt_fav_reports"); setChange("OPTIMIZE TABLE tt_invoices"); setChange("OPTIMIZE TABLE tt_log"); - setChange("OPTIMIZE TABLE tt_monthly_quota"); + setChange("OPTIMIZE TABLE tt_monthly_quotas"); setChange("OPTIMIZE TABLE tt_project_task_binds"); setChange("OPTIMIZE TABLE tt_projects"); setChange("OPTIMIZE TABLE tt_tasks"); @@ -768,4 +796,4 @@ if ($_POST) { - \ No newline at end of file +