[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
Zen Cart 源代码 init_header.php

Zen Cart 源代码 init_header.php




下载文件

文件名: init_header.php
文件类型: PHP文件
文件大小: 7.39 KiB
MD5: 52b02a1091c697a3000cce674e135e00

init_header.php - 关闭高亮
  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-2013 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 GIT: $Id: Author: DrByte  Tue Jul 23 19:29:41 2013 -0400 Modified in v1.5.2 $
  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 sql cache directory not writeable
  27.  */
  28. define('WARN_SQL_CACHE_DIRECTORY_NOT_WRITEABLE', 'true');
  29. /**
  30.  * should a message be displayed if session.autostart is on in php.ini
  31.  */
  32. define('WARN_SESSION_AUTO_START', 'true');
  33. /**
  34.  * should a message be displayed if download directory not readable
  35.  */
  36. define('WARN_DOWNLOAD_DIRECTORY_NOT_READABLE', 'true');
  37. /**
  38.  * should a message be displayed if system detects version problem with the database
  39.  */
  40. define('WARN_DATABASE_VERSION_PROBLEM','true');
  41. // check if the installer directory exists, and warn of its existence
  42. if (WARN_INSTALL_EXISTENCE == 'true') {
  43.   $check_path = realpath(dirname(basename($PHP_SELF)) . '/zc_install');
  44.   if (is_dir($check_path)) {
  45.     $messageStack->add('header', sprintf(WARNING_INSTALL_DIRECTORY_EXISTS, ($check_path == '' ? '..../zc_install' : $check_path)), 'warning');
  46.   }
  47. }
  48.  
  49. // check if the configure.php file is writeable
  50. if (WARN_CONFIG_WRITEABLE == 'true') {
  51.   $check_path = realpath(dirname(basename($PHP_SELF)) . '/includes/configure.php');
  52.   if (file_exists($check_path) && is__writeable($check_path)) {
  53.     $messageStack->add('header', sprintf(WARNING_CONFIG_FILE_WRITEABLE, ($check_path == '' ? '..../includes/configure.php' : $check_path)), 'warning');
  54.   }
  55. }
  56.  
  57. // check if the sql cache folder is writeable
  58. if (WARN_SQL_CACHE_DIRECTORY_NOT_WRITEABLE == 'true' && strtolower(SQL_CACHE_METHOD) == 'file') {
  59.   if (!is_dir(DIR_FS_SQL_CACHE)) {
  60.     $messageStack->add('header', WARNING_SQL_CACHE_DIRECTORY_NON_EXISTENT, 'warning');
  61.   } elseif (!is_writeable(DIR_FS_SQL_CACHE)) {
  62.     $messageStack->add('header', WARNING_SQL_CACHE_DIRECTORY_NOT_WRITEABLE, 'warning');
  63.   }
  64. }
  65.  
  66. // give the visitors a message that the website will be down at ... time
  67. if ( (WARN_BEFORE_DOWN_FOR_MAINTENANCE == 'true') && (DOWN_FOR_MAINTENANCE == 'false') ) {
  68.   $messageStack->add('header', TEXT_BEFORE_DOWN_FOR_MAINTENANCE . PERIOD_BEFORE_DOWN_FOR_MAINTENANCE);
  69. }
  70.  
  71. // this will let the admin know that the website is DOWN FOR MAINTENANCE to the public
  72. if ( (DOWN_FOR_MAINTENANCE == 'true') && (strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR'])) ) {
  73.   $messageStack->add('header', TEXT_ADMIN_DOWN_FOR_MAINTENANCE, 'warning');
  74. }
  75.  
  76. // check session.auto_start is disabled
  77. if ( (function_exists('ini_get')) && (WARN_SESSION_AUTO_START == 'true') ) {
  78.   if (ini_get('session.auto_start') == '1') {
  79.     $messageStack->add('header', WARNING_SESSION_AUTO_START, 'warning');
  80.   }
  81. }
  82.  
  83. // to warn if the "downloads" folder is not readable (ie: not found, etc)
  84. if ( (WARN_DOWNLOAD_DIRECTORY_NOT_READABLE == 'true') && (DOWNLOAD_ENABLED == 'true') ) {
  85.   if (!is_dir(DIR_FS_DOWNLOAD)) {
  86.     $messageStack->add('header', WARNING_DOWNLOAD_DIRECTORY_NON_EXISTENT, 'warning');
  87.   }
  88. }
  89.  
  90. // check database version against source code
  91. $zv_db_patch_ok = true; // we start with true
  92. if (WARN_DATABASE_VERSION_PROBLEM != 'false') {
  93.   $result = $db->Execute("SELECT project_version_major, project_version_minor FROM " . TABLE_PROJECT_VERSION . " WHERE project_version_key = 'Zen-Cart Database'");
  94.   $zv_db_patch_level_found = $result->fields['project_version_major']. '.' . $result->fields['project_version_minor'];
  95.   $zv_db_patch_level_expected = EXPECTED_DATABASE_VERSION_MAJOR . '.' . EXPECTED_DATABASE_VERSION_MINOR;
  96.   if ($zv_db_patch_level_expected=='.' || ($zv_db_patch_level_found < $zv_db_patch_level_expected) ) {
  97.     $zv_db_patch_ok = false;
  98.     $messageStack->add('header', WARNING_DATABASE_VERSION_OUT_OF_DATE, 'warning');
  99.   }
  100. }
  101.  
  102. // Alerting about payment modules in testing/debug mode
  103.  
  104. if (defined('MODULE_PAYMENT_PAYPAL_IPN_DEBUG') && (MODULE_PAYMENT_PAYPAL_IPN_DEBUG == 'true' || MODULE_PAYMENT_PAYPAL_TESTING == 'Test')) {
  105.   $messageStack->add('header', 'PAYPAL IS IN TESTING MODE', 'warning');
  106. }
  107. 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' ) ) {
  108.   $messageStack->add('header', 'AUTHORIZENET IS IN TESTING MODE', 'warning');
  109. }
  110. if (defined('MODULE_SHIPPING_USPS_SERVER') &&   MODULE_SHIPPING_USPS_SERVER == 'test' ) {
  111.   $messageStack->add('header', 'USPS IS IN TESTING MODE', 'warning');
  112. }
  113.  
  114. // Alerts for EZ-Pages
  115. if (EZPAGES_STATUS_HEADER == '2' && (strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR']))) {
  116.   $messageStack->add('header', TEXT_EZPAGES_STATUS_HEADER_ADMIN, 'caution');
  117. }
  118. if (EZPAGES_STATUS_FOOTER == '2' && (strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR']))) {
  119.   $messageStack->add('header', TEXT_EZPAGES_STATUS_FOOTER_ADMIN, 'caution');
  120. }
  121. if (EZPAGES_STATUS_SIDEBOX == '2' && (strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR']))) {
  122.   $messageStack->add('header', TEXT_EZPAGES_STATUS_SIDEBOX_ADMIN, 'caution');
  123. }
  124. if (defined('STRICT_ERROR_REPORTING') && STRICT_ERROR_REPORTING == true) {
  125.   $messageStack->add('header', 'STRICT ERROR REPORTING IS ON', 'warning');
  126. }
  127.  
  128.  
  129. // if down for maintenance, prevent indexing
  130. if ( (DOWN_FOR_MAINTENANCE == 'true') && (!strstr(EXCLUDE_ADMIN_IP_FOR_MAINTENANCE, $_SERVER['REMOTE_ADDR'])) ) {
  131.   header("HTTP/1.1 503 Service Unavailable");
  132. }
  133.  
  134. /* Check for invalid countries in customer's address book.
  135.  * If a customer is logged in, check to see that the customers' address(es) still contain valid countries.
  136. * If not, redirect to the address-book page for changes.
  137. */
  138. if ($_SESSION['customer_id'] && $_GET['main_page'] != FILENAME_ADDRESS_BOOK_PROCESS && $_GET['main_page'] != FILENAME_LOGOFF) {
  139.   $addresses_query = "SELECT address_book_id, entry_country_id as country_id, entry_firstname as firstname, entry_lastname as lastname
  140.                      FROM   " . TABLE_ADDRESS_BOOK . "
  141.                      WHERE  customers_id = :customersID
  142.                      ORDER BY firstname, lastname";
  143.  
  144.   $addresses_query = $db->bindVars($addresses_query, ':customersID', $_SESSION['customer_id'], 'integer');
  145.   $addresses = $db->Execute($addresses_query);
  146.  
  147.   while (!$addresses->EOF) {
  148.     if (zen_get_country_name($addresses->fields['country_id'], TRUE) == '') {
  149.       $messageStack->add_session('addressbook', sprintf(ERROR_TEXT_COUNTRY_DISABLED_PLEASE_CHANGE, zen_get_country_name($addresses->fields['country_id'], FALSE)), 'error');
  150.       zen_redirect (zen_href_link(FILENAME_ADDRESS_BOOK_PROCESS, 'edit=' . $addresses->fields['address_book_id'], 'SSL'));
  151.     }
  152.     $addresses->MoveNext();
  153.   }
  154. }
  155.