function exception(Exception $e) { logger::emerg("Unhandled exception: (%s) %s in %s:%d", get_class($e), $e->getMessage(), str_replace(BASE_PATH, '', $e->getFile()), $e->getLine()); Console::debugEx(0, get_class($e), "Unhandled exception: (%s) %s in %s:%d", get_class($e), $e->getMessage(), str_replace(BASE_PATH, '', $e->getFile()), $e->getLine()); $f = file($e->getFile()); foreach ($f as $i => $line) { $mark = $i + 1 == $e->getLine() ? '=> ' : ' '; $f[$i] = sprintf(' %05d. %s', $i + 1, $mark) . $f[$i]; $f[$i] = str_replace("\n", "", $f[$i]); } $first = $e->getLine() - 4; if ($first < 0) { $first = 0; } $last = $e->getLine() + 3; if ($last >= count($f)) { $last = count($f) - 1; } $source = join("\n", array_slice($f, $first, $last - $first)); Console::debugEx(0, get_class($e), Console::backtrace(0, $e->getTrace(), true)); Console::debugEx(LOG_LOG, "Exception", "Source dump of %s:\n%s", str_replace(BASE_PATH, '', $e->getFile()), $source); $rv = 1; logger::emerg("Exiting with return code %d after exception.", $rv); Console::debugEx(LOG_BASIC, __CLASS__, "Exiting with return code %d after exception.", $rv); }
function exception(Exception $e) { if (ob_get_length() != false) { @ob_end_clean(); } $et = typeOf($e); if ($et == 'FileNotFoundException' || $et == 'NavigationException') { response::setStatus(404); header('HTTP/1.1 404 Not Found', true); printf("<h1>404: Not Found</h1>"); return; } if ($et == 'HttpException') { response::setStatus($e->getCode()); $code = $e->getMessage(); list($code) = explode(':', $code); $code = str_replace('Error ', '', $code); $msg = HttpException::getHttpMessage($code); header('HTTP/1.1 ' . $code . ' ' . $msg . ' ' . $msg); printf("<h1>%s: %s</h1>\n<pre>%s</pre>", $code, $msg, $msg); return; } response::setStatus(500); logger::emerg("Unhandled exception: (%s) %s in %s:%d", get_class($e), $e->getMessage(), str_replace(BASE_PATH, '', $e->getFile()), $e->getLine()); header('HTTP/1.1 501 Server Error', true); $id = uniqid(); $dbg = sprintf("Unhandled exception: (%s) %s\n in %s:%d", get_class($e), $e->getMessage(), str_replace(SYS_PATH, '', $e->getFile()), $e->getLine()) . Console::backtrace(0, $e->getTrace(), true) . "\n" . "Loaded modules:\n" . ModuleManager::debug() . "\n" . request::getDebugInformation(); logger::emerg($dbg); if (config::get('lepton.mvc.exception.log', false) == true) { $logfile = config::get('lepton.mvc.exception.logfile', "/tmp/" . $_SERVER['HTTP_HOST'] . "-debug.log"); $log = "=== Unhandled Exception ===\n\n" . $dbg . "\n"; $lf = @fopen($logfile, "a+"); if ($lf) { fputs($lf, $log); fclose($lf); } } $ico_error = resource::get('warning.png'); header('content-type: text/html; charset=utf-8'); echo '<html><head><title>Unhandled Exception</title>' . self::$css . self::$js . '</head><body>' . '<div id="box"><div id="left"><img src="' . $ico_error . '" width="32" height="32"></div><div id="main">' . '<h1>An Unhandled Exception Occured</h1>' . '<hr noshade>' . '<p>This means that something didn\'t go quite go as planned. This could be ' . 'caused by one of several reasons, so please be patient and try ' . 'again in a little while.</p>'; if (config::get('lepton.mvc.exception.feedback', false) == true) { echo '<p>The administrator of the website has been notified about this error. You ' . 'can help us find and fix the problem by writing a line or two about what you were doing when this ' . 'error occured.</p>'; echo '<p id="feedbacklink"><a href="javascript:doFeedback();">If you would like to assist us with more information, please click here</a>.</p>'; echo '<div id="feedback" style="display:none;"><p>Describe in a few short lines what you were doing right before you encountered this error:</p><form action="/errorevent.feedback/' . $id . '" method="post"><div><textarea name="text" style="width:100%; height:50px;"></textarea></div><div style="padding-top:5px; text-align:right;"><input type="button" value=" Close " onclick="closeFeedback();"> <input type="submit" value=" Submit Feedback "></div></form></div>'; } if (config::get('lepton.mvc.exception.showdebug', false) == true) { echo '<hr noshade>' . '<a href="javascript:toggleAdvanced();">Details »</a>' . '<pre id="advanced" style="display:none; height:300px;">' . $dbg . '</pre>'; } echo '<div>' . '</body></html>'; }
protected function addField($field, $meta) { // TODO: Verify the meta format $md = explode(' ', $meta); $mi = 0; $mo = array(); // Console::debugEx(LOG_DEBUG2,__CLASS__,"Parsing quotes in array for %s", $meta); // Console::debugEx(LOG_DEBUG2,__CLASS__," \$md = {'%s'}", join("','", $md)); while ($mi < count($md)) { // Console::debugEx(LOG_DEBUG2,__CLASS__,"Current token: %s", $md[$mi]); if ($md[$mi][0] == '"') { $buf = array(); while ($mi < count($md)) { $str = $md[$mi]; $buf[] = $md[$mi++]; // Console::debugEx(LOG_DEBUG2,__CLASS__," -- Quoted token: %s (%s)", $str, $str[strlen($str)-1]); if ($str[strlen($str) - 2] == '"') { break; } } $bufstr = join(' ', $buf); $bufstr = substr($bufstr, 1, strlen($bufstr) - 2); $mo[] = $bufstr; Console::debugEx(LOG_DEBUG2, __CLASS__, "Joined quoted statement: %s", $bufstr); } else { $mo[] = $md[$mi++]; } } $md = $mo; // Console::debugEx(LOG_DEBUG2,__CLASS__," \$md = {'%s'}", join("','", $md)); $ftype = null; $fdef = null; $freq = false; $fprot = false; $mi = 0; while ($mi < count($md)) { // Console::debugEx(LOG_DEBUG1,__CLASS__,'Parsing abstract model field %s: %s', $field, $md[$mi]); switch (strtolower($md[$mi])) { case 'string': $ftype = 'STRING'; break; case 'int': $ftype = 'INT'; break; case 'bool': $ftype = 'BOOL'; break; case 'set': $ftype = 'SET'; break; case 'enum': $ftype = 'STRING'; break; case 'required': $freq = true; break; case 'protected': $fprot = true; break; case 'index': $this->_index = $field; break; case 'default': $fdef = $md[++$mi]; break; case 'like': $flike = $md[++$mi]; break; case 'in': case 'of': $fin = $md[++$mi]; break; case 'format': if ($ftype == 'INT' || $ftype == 'STRING') { // Check format } else { Console::warn('Format declaration for key %s ignored', $field); } break; case 'auto': if ($ftype == 'INT') { } else { Console::warn('Only INT can be auto fields'); } $fauto = true; break; } $mi++; } if ($ftype != null) { $this->_fields[$field] = array('type' => $ftype, 'required' => $freq, 'default' => $fdef, 'protected' => $fprot); return true; } else { Console::warn('Bad type specified for field %s in AbstractModel implementation', $field); Console::backtrace(); } return false; }