if (!defined('SITE')) exit('No direct script access allowed'); // nagging date thing if (phpversion() >= '5.1.2') date_default_timezone_set('GMT'); // this is a little redundant function load_path($type) { switch ($type) { case 'lib': return LIBPATH; break; case 'db': return DBPATH; break; case 'help': return HELPATH; break; case 'mod': return MODPATH; break; case 'lang': return LANGPATH; break; } } // can't return direct references (weird bug) function &get_instance() { global $OBJ, $INDX; if (is_object($INDX)) { $reference = $INDX; return $reference; } else { $reference = $OBJ; return $reference; } } // this is a little ugly but it works function &load_class($class, $instantiate = TRUE, $type, $internal = FALSE) { global $indx; static $objects = array(); $path = load_path($type); $file = $class; // exceptions if ($type == 'db') $file = 'db.' . $indx['sql']; if ($type == 'lang') $file = 'index'; if (!isset($objects[$class])) { if ($internal == FALSE) { if (file_exists(DIRNAME . BASENAME . '/' . $path . '/' . $file . '.php')) { require_once(DIRNAME . BASENAME . '/' . $path . '/' . $file . '.php'); } else { show_error('class not found'); } if ($instantiate == TRUE) { $objects[$class] = new $class(); } else { $objects[$class] = TRUE; } } else // TRUE { if (file_exists(DIRNAME . BASENAME . '/' . $path . '/' . $file . '/index.php')) { require_once(DIRNAME . BASENAME . '/' . $path . '/' . $file . '/index.php'); } else { show_error('class not found'); } if ($instantiate == TRUE) { $objects[$class] = new $class(); } else { $objects[$class] = TRUE; } } } return $objects[$class]; } // from the helper folder function load_helper($file) { if ($file == '') return; if (file_exists(DIRNAME . BASENAME . '/' . HELPATH . '/' . $file . '.php')) { require_once(DIRNAME . BASENAME . '/' . HELPATH . '/' . $file . '.php'); } } // load multiple helpers function load_helpers($files) { if (!is_array($files)) return; foreach ($files as $file) load_helper($file); } // loading helpers for a module (located in module folder) function load_module_helper($file, $section) { if ($file == '') return; if (file_exists(DIRNAME . BASENAME . '/' . MODPATH . '/' . $section . '/' . $file . '.php')) require_once(DIRNAME . BASENAME . '/' . MODPATH . '/' . $section . '/' . $file . '.php'); } function show_error($message='') { // we'll use the default language for this //$lang =& load_class('lang', TRUE, 'lib'); $lang =& load_class('lang', TRUE, 'lang'); $lang->setlang(); // get the default strings $message = $lang->word($message); $error =& load_class('error', TRUE, 'lib'); header('Status: 503 Service Unavailable'); // change to right error note echo $error->show_error($message); exit; } // could use refinement - rethink function show_login($message='') { // we'll use the default language for this //$lang =& load_class('lang',TRUE,'lib'); $lang =& load_class('lang', TRUE, 'lang'); $lang->setlang(); // get the default strings $login = "

Indexhibit


".$lang->word('login').": (".$lang->word('number chars').")

".$lang->word('password').": (".$lang->word('number chars').")

".$lang->word($message)." 

"; $error =& load_class('error',TRUE,'lib'); echo $error->show_login($login); exit; } /* system_redirect("?a=$go[a]&q=note&id=$last"); */ function system_redirect($params='') { // do we need to put some validators on this? // don't want the extra slash $self = (dirname($_SERVER['PHP_SELF']) == '/') ? '' : dirname($_SERVER['PHP_SELF']); header('Location: http://' . $_SERVER['HTTP_HOST'] . $self . '/' . $params); return; } function sanitize_uri($server_uri) { // remove any illegal chars first ' " $ * @ // remove non alpha chars (a-zA-Z0-9-/?# only) // all urls are lowercase $server_uri = str_replace("'", '', $server_uri); return preg_replace( array("/[^a-zA-Z0-9?=#-\/]/", '/\/+/'), array('','/'), $server_uri); } // revise this later... function entry_uri($uri='', $server_uri) { $url = $server_uri; $url = str_replace("'", '', $url); // remove any illegal chars first ' " $ * @ // remove non alpha chars (a-zA-Z0-9-/?# only) // all urls are lowercase $url = preg_replace( array("/[^a-zA-Z0-9?=#-\/]/", '/\/+/'), array('','/'), $url); $url = strtolower($url); // we need to remove the references (they can be found when necessary) $url = preg_replace("/\?(.*)$/", '', $url); $url = explode('/', $url); if (is_array($url)) array_shift($url); // if we aren't in the root we need to deal with it // allows our site to be more portable $uri = preg_replace(array("/^\//","/\/$/"), array('', ''), $uri); if ($uri != '') { $delete_dir = explode('/', $uri); // we need to pop off the default root if it's set if (is_array($delete_dir)) { foreach ($delete_dir as $dir) { if ($url[0] == $dir) { array_shift($url); } } } } // always must have / at the beginning for the db $url = '/'.implode('/', $url); // ouch, needs thought // trailing slash if ((substr($url,-1) != '/') && (substr($url,-3) != 'php')) $url = $url . '/'; return $url; } // fore dealing with mod_rewrite issues function ndxz_rewriter($url='') { if (MODREWRITE == false) { if ($url == '/') { return '/'; } else { return '/index.php?' . $url; } } else { return $url; } } function shutDownCheck() { global $indx; if (!isset($indx['db'])) { echo "Database is not installed."; exit; } } ?>
Fatal error: Call to undefined function shutdowncheck() in /home/madebygypsy/madebygypsy.com/index.php on line 25