PageRenderTime 50ms CodeModel.GetById 23ms RepoModel.GetById 1ms app.codeStats 0ms

/includes/init_includes/init_header.php

http://daocart.googlecode.com/
PHP | 142 lines | 87 code | 11 blank | 44 comment | 72 complexity | 54d0a1b4b4a742615b36c2d802f8c5f9 MD5 | raw file
Possible License(s): AGPL-1.0, GPL-2.0, BSD-3-Clause
  1. <?php
  2. /**
  3. * header code, mainly concerned with adding to messagestack when certain warnings are applicable
  4. *
  5. * @package templateStructure
  6. * @copyright Copyright 2003-2007 Zen Cart Development Team
  7. * @copyright Portions Copyright 2003 osCommerce
  8. * @license http://www.zen-cart.com/license/2_0.txt GNU Public License V2.0
  9. * @version $Id: init_header.php 6990 2007-09-12 21:45:57Z drbyte $
  10. */
  11. if (!defined('IS_ADMIN_FLAG')) {
  12. die('Illegal Access');
  13. }
  14. /**
  15. * set which precautions should be checked
  16. */
  17. /**
  18. * should a message be displayed if install directory exists
  19. */
  20. define('WARN_INSTALL_EXISTENCE', 'true');
  21. /**
  22. * should a message be displayed if config directory is writeable
  23. */
  24. define('WARN_CONFIG_WRITEABLE', 'true');
  25. /**
  26. * should a message be displayed if session directory not writeable
  27. */
  28. define('WARN_SESSION_DIRECTORY_NOT_WRITEABLE', 'true');
  29. /**
  30. * should a message be displayed if sql cache directory not writeable
  31. */
  32. define('WARN_SQL_CACHE_DIRECTORY_NOT_WRITEABLE', 'true');
  33. /**
  34. * should a message be displayed if session.autostart is on in php.ini
  35. */
  36. define('WARN_SESSION_AUTO_START', 'true');
  37. /**
  38. * should a message be displayed if download directory not readable
  39. */
  40. define('WARN_DOWNLOAD_DIRECTORY_NOT_READABLE', 'true');
  41. /**
  42. * should a message be displayed if system detects version problem with the database
  43. */
  44. define('WARN_DATABASE_VERSION_PROBLEM','true');
  45. // check if the installer directory exists, and warn of its existence
  46. if (WARN_INSTALL_EXISTENCE == 'true') {
  47. $check_path = realpath(dirname(basename($PHP_SELF)) . '/zc_install');
  48. if (is_dir($check_path)) {
  49. $messageStack->add('header', sprintf(WARNING_INSTALL_DIRECTORY_EXISTS, ($check_path == '' ? '..../zc_install' : $check_path)), 'warning');
  50. }
  51. }
  52. // check if the configure.php file is writeable
  53. if (WARN_CONFIG_WRITEABLE == 'true') {
  54. $check_path = realpath(dirname(basename($PHP_SELF)) . '/includes/configure.php');
  55. if (file_exists($check_path) && is__writeable($check_path)) {
  56. $messageStack->add('header', sprintf(WARNING_CONFIG_FILE_WRITEABLE, ($check_path == '' ? '..../includes/configure.php' : $check_path)), 'warning');
  57. }
  58. }
  59. // check if the session folder is writeable
  60. if (WARN_SESSION_DIRECTORY_NOT_WRITEABLE == 'true') {
  61. if (STORE_SESSIONS == '') {
  62. if (!is_dir(zen_session_save_path())) {
  63. $messageStack->add('header', WARNING_SESSION_DIRECTORY_NON_EXISTENT, 'warning');
  64. } elseif (!is_writeable(zen_session_save_path())) {
  65. $messageStack->add('header', WARNING_SESSION_DIRECTORY_NOT_WRITEABLE, 'warning');
  66. }
  67. }
  68. }
  69. // check if the sql cache folder is writeable
  70. if (WARN_SQL_CACHE_DIRECTORY_NOT_WRITEABLE == 'true' && strtolower(SQL_CACHE_METHOD) == 'file') {
  71. if (!is_dir(DIR_FS_SQL_CACHE)) {
  72. $messageStack->add('header', WARNING_SQL_CACHE_DIRECTORY_NON_EXISTENT, 'warning');
  73. } elseif (!is_writeable(DIR_FS_SQL_CACHE)) {
  74. $messageStack->add('header', WARNING_SQL_CACHE_DIRECTORY_NOT_WRITEABLE, 'warning');
  75. }
  76. }
  77. // give the visitors a message that the website will be down at ... time
  78. if ( (WARN_BEFORE_DOWN_FOR_MAINTENANCE == 'true') && (DOWN_FOR_MAINTENANCE == 'false') ) {
  79. $messageStack->add('header', TEXT_BEFORE_DOWN_FOR_MAINTENANCE . PERIOD_BEFORE_DOWN_FOR_MAINTENANCE);
  80. }
  81. // this will let the admin know that the website is DOWN FOR MAINTENANCE to the public
  82. if ( (DOWN_FOR_MAINTENANCE == 'true') && (strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR'])) ) {
  83. $messageStack->add('header', TEXT_ADMIN_DOWN_FOR_MAINTENANCE, 'warning');
  84. }
  85. // check session.auto_start is disabled
  86. if ( (function_exists('ini_get')) && (WARN_SESSION_AUTO_START == 'true') ) {
  87. if (ini_get('session.auto_start') == '1') {
  88. $messageStack->add('header', WARNING_SESSION_AUTO_START, 'warning');
  89. }
  90. }
  91. // to warn if the "downloads" folder is not readable (ie: not found, etc)
  92. if ( (WARN_DOWNLOAD_DIRECTORY_NOT_READABLE == 'true') && (DOWNLOAD_ENABLED == 'true') ) {
  93. if (!is_dir(DIR_FS_DOWNLOAD)) {
  94. $messageStack->add('header', WARNING_DOWNLOAD_DIRECTORY_NON_EXISTENT, 'warning');
  95. }
  96. }
  97. // check database version against source code
  98. $zv_db_patch_ok = true; // we start with true
  99. if (WARN_DATABASE_VERSION_PROBLEM != 'false') {
  100. $result = $db->Execute("SELECT project_version_major, project_version_minor FROM " . TABLE_PROJECT_VERSION . " WHERE project_version_key = 'Zen-Cart Database'");
  101. $zv_db_patch_level_found = $result->fields['project_version_major']. '.' . $result->fields['project_version_minor'];
  102. $zv_db_patch_level_expected = EXPECTED_DATABASE_VERSION_MAJOR . '.' . EXPECTED_DATABASE_VERSION_MINOR;
  103. if ($zv_db_patch_level_expected=='.' || ($zv_db_patch_level_found < $zv_db_patch_level_expected) ) {
  104. $zv_db_patch_ok = false;
  105. $messageStack->add('header', WARNING_DATABASE_VERSION_OUT_OF_DATE, 'warning');
  106. }
  107. }
  108. // Alerting about payment modules in testing/debug mode
  109. if (defined('MODULE_PAYMENT_PAYPAL_IPN_DEBUG') && (MODULE_PAYMENT_PAYPAL_IPN_DEBUG == 'true' || MODULE_PAYMENT_PAYPAL_TESTING == 'Test')) {
  110. $messageStack->add('header', 'PAYPAL IS IN TESTING MODE', 'warning');
  111. }
  112. if ((defined('MODULE_PAYMENT_AUTHORIZENET_AIM_STATUS') && MODULE_PAYMENT_AUTHORIZENET_AIM_STATUS == 'True' && defined('MODULE_PAYMENT_AUTHORIZENET_AIM_TESTMODE') && MODULE_PAYMENT_AUTHORIZENET_AIM_TESTMODE == 'Test') || (defined('MODULE_PAYMENT_AUTHORIZENET_STATUS') && MODULE_PAYMENT_AUTHORIZENET_STATUS == 'True' && defined('MODULE_PAYMENT_AUTHORIZENET_TESTMODE') && MODULE_PAYMENT_AUTHORIZENET_TESTMODE =='Test' ) ) {
  113. $messageStack->add('header', 'AUTHORIZENET IS IN TESTING MODE', 'warning');
  114. }
  115. if (defined('MODULE_SHIPPING_USPS_SERVER') && MODULE_SHIPPING_USPS_SERVER == 'test' ) {
  116. $messageStack->add('header', 'USPS IS IN TESTING MODE', 'warning');
  117. }
  118. // Alerts for EZ-Pages
  119. if (EZPAGES_STATUS_HEADER == '2' && (strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR']))) {
  120. $messageStack->add('header', TEXT_EZPAGES_STATUS_HEADER_ADMIN, 'caution');
  121. }
  122. if (EZPAGES_STATUS_FOOTER == '2' && (strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR']))) {
  123. $messageStack->add('header', TEXT_EZPAGES_STATUS_FOOTER_ADMIN, 'caution');
  124. }
  125. if (EZPAGES_STATUS_SIDEBOX == '2' && (strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR']))) {
  126. $messageStack->add('header', TEXT_EZPAGES_STATUS_SIDEBOX_ADMIN, 'caution');
  127. }
  128. if (defined('STRICT_ERROR_REPORTING') && STRICT_ERROR_REPORTING == true) {
  129. $messageStack->add('header', 'STRICT ERROR REPORTING IS ON', 'warning');
  130. }
  131. ?>