X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Fmysql-connect.php;h=d3c8afd80de9953d1bb5d211368738cba41b7527;hp=82e55ff7195d9c9de1c474ded915104adbdf9398;hb=48affba7561e342c1f5691793dd96edadf4085d4;hpb=fc162164725588cf75969f707faead9c9cd8e68b diff --git a/inc/mysql-connect.php b/inc/mysql-connect.php index 82e55ff719..d3c8afd80d 100644 --- a/inc/mysql-connect.php +++ b/inc/mysql-connect.php @@ -10,16 +10,9 @@ * -------------------------------------------------------------------- * * Kurzbeschreibung : Verbindet zu Ihrer Datenbank * * -------------------------------------------------------------------- * - * $Revision:: $ * - * $Date:: $ * - * $Tag:: 0.2.1-FINAL $ * - * $Author:: $ * - * Needs to be in all Files and every File needs "svn propset * - * svn:keywords Date Revision" (autoprobset!) at least!!!!!! * - * -------------------------------------------------------------------- * * Copyright (c) 2003 - 2009 by Roland Haeder * - * Copyright (c) 2009, 2010 by Mailer Developer Team * - * For more information visit: http://www.mxchange.org * + * Copyright (c) 2009 - 2013 by Mailer Developer Team * + * For more information visit: http://mxchange.org * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -42,17 +35,44 @@ if (!defined('__SECURITY')) { die(); } // END - if +// Init array +$__functions = array(); + +// Init include file array as it follows same naming scheme +foreach ( array( + 'stats', + 'xml', + 'callback', + 'referral', + 'email', + 'request', + 'session', + 'code', + 'pool', + 'language', + 'sql', + 'expression', + 'filter', + 'extensions') as $lib) { + + // Add it + array_push($__functions, $lib . '-functions'); +} // END - foreach + // Load more function libraries or includes -foreach (array('request-functions', 'session-functions', 'code-functions', 'language-functions', 'sql-functions', 'expression-functions', 'filter-functions','revision-functions', 'filters', 'mysql-manager', 'extensions-functions', 'handler') as $lib) { +foreach (array_merge($__functions, array('filters', 'mysql-manager', 'handler')) as $lib) { // Load special functions loadIncludeOnce('inc/' . $lib . '.php'); } // END - foreach +// Remove array +unset($__functions); + // Set error handler set_error_handler('__errorHandler'); // Disable block-mode by default -enableBlockMode(false); +enableBlockMode(FALSE); // Init error handler initErrorHandler(); @@ -64,105 +84,72 @@ initRequest(); initMemberId(); // Set important header_sent -if (!isset($GLOBALS['header_sent'])) $GLOBALS['header_sent'] = '0'; +if (!isset($GLOBALS['__header_sent'])) { + $GLOBALS['__header_sent'] = '0'; +} // END - if // Init fatal messages initFatalMessages(); -// Init message system -initMessages(); - // Enable HTML templates by default enableTemplateHtml(); // Are we in installation phase? -if ((!isInstalling()) && (!isInstallationPhase())) { +if ((!isInstaller()) && (isInstalled())) { // Load configuration file(s) here loadIncludeOnce('inc/load_config.php'); // Load database layer here loadIncludeOnce('inc/db/lib.php'); + // Init message system + initMessages(); + // CSS array initExtensionCssFiles(); - if ((!empty($GLOBALS['mysql']['host'])) && (!empty($GLOBALS['mysql']['login'])) && (!empty($GLOBALS['mysql']['dbase']))) { - // Connect to DB - SQL_CONNECT($GLOBALS['mysql']['host'], $GLOBALS['mysql']['login'], $GLOBALS['mysql']['password'], __FILE__, __LINE__); - - // Is the link valid? - if (SQL_IS_LINK_UP()) { - // Enable exit on error - enableExitOnError(); - - // Is it a valid resource? - if (SQL_SELECT_DB($GLOBALS['mysql']['dbase'], __FILE__, __LINE__) === true) { - // This is required for extension 'optimize' to work - setConfigEntry('__DB_NAME', $GLOBALS['mysql']['dbase']); - - // Remove MySQL array from namespace - unset($GLOBALS['mysql']); - - // Load cache - loadIncludeOnce('inc/load_cache.php'); - - // Check module for permissions - $checkModule = checkModulePermissions(); - - // Admin module should be accessable by guests to login - if ((getModule() == 'admin') && ($checkModule == 'admin_only')) { - // This is fine and can be ignored - } elseif ($checkModule != 'done') { - // Not fine! - logDebugMessage(__FILE__, __LINE__, sprintf("Check of module %s results in unexpected value: %s", - getModule(), - $checkModule - )); - } - } else { - // Wrong database? - addFatalMessage(__FILE__, __LINE__, '{--WRONG_DB_SELECTED--}'); - } - } else { - // No link to database! - addFatalMessage(__FILE__, __LINE__, '{--NO_DB_LINK--}'); - } - } else { - // Maybe you forgot to enter your MySQL data? - addFatalMessage(__FILE__, __LINE__, '{--MYSQL_DATA_MISSING--}'); - } -} else { - /////////////////////////////////////////////////// - // Include neccessary functions for installation // - /////////////////////////////////////////////////// + // Initialize SQL link + initSqlLink(); + // Init session + initSession(); +} else { // Default output is 'direct' for HTML output setConfigEntry('OUTPUT_MODE', 'direct'); // This hack prevents a backtrace in CSS output - if (getOutputMode() == 1) { + if (isCssOutputMode()) { // Problem with config so set output mode setConfigEntry('OUTPUT_MODE', 'render'); } // END - if // CFG: DATABASE-TYPE - setConfigEntry('_DB_TYPE', 'mysql3'); + setConfigEntry('_DB_TYPE', 'mysql'); + + // Set link as down + unsetSqlLinkUp(__FILE__, __LINE__); + + // Load database layer here + loadIncludeOnce('inc/db/lib.php'); + + // Init message system + initMessages(); + + // Init session + initSession(); // Include more - foreach (array('inc/db/lib.php','inc/databases.php','inc/session.php','inc/versions.php','inc/install-functions.php','inc/load_config.php') as $inc) { - // Load the include - loadIncludeOnce($inc); + foreach (array('databases', 'install-functions', 'load_config', 'load_cache') as $inc) { + // Load include file + loadIncludeOnce('inc/' . $inc . '.php'); } // END - foreach - // Load cache - loadIncludeOnce('inc/load_cache.php'); - - // Run the init filter chain - runFilterChain('init'); + // Init installer + initInstaller(); - // Are we installation routine? - if ((!isInstalling()) && (getOutputMode() != 1) && (getOutputMode() != -1)) { - // You have to install first! + // Check whether we are in installation routine + if ((!isInstalling()) && (!isCssOutputMode()) && (!isRawOutputMode())) { + // Redirect to the URL redirectToUrl('install.php'); } // END - if }