logString .= $errorString; } if ((!defined('IGNORE_LOG_LEVEL_WRITE')) && ($logno <= LOG_LEVEL_WRITE)) { global $config; $filename = $config['log_file']; //XXX: Trying to write to a file that a the file cannot be opened // what could possible go wrong //Check if the file can be opened if (!$handle = fopen($filename, 'a+')) { define('IGNORE_LOG_LEVEL_WRITE', true); trigger_log(SYSLOG_EMERG, 'Cannot open file "' . $filename . '"', __FILE__, __LINE__); exit; } // Write $errorString to file. if (fwrite($handle, $errorString) === FALSE) { define('LOG_LEVEL_WRITE', LOG_LEVEL_NONE); trigger_log(SYSLOG_EMERG, 'Cannot write to "' . $filename . '"', __FILE__, __LINE__); exit; } fclose($handle); } /* XXX: Sends email out for every line, instead of all the lines of the current output */ if ($logno <= LOG_LEVEL_MAIL) { global $config; @mail($config['mail'], 'Nodemap error', $errorString); } } function __destruct() { echo ''; } } $LOG_HANDLER = new LogHandler(); /* * Function: trigger_log * Parameters: int $logno, string $logstr, string $logfile, int $logline * Function: Handling with log entries, forwarding them to our $LOG_HANDLER object. */ function trigger_log($logno, $logstr, $logfile, $logline) { global $LOG_HANDLER; $LOG_HANDLER->logEntry($logno, $logstr, $logfile, $logline); } ?>