104 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| class Pref_System extends Handler_Protected {
 | |
| 
 | |
| 	function before($method) {
 | |
| 		if (parent::before($method)) {
 | |
| 			if ($_SESSION["access_level"] < 10) {
 | |
| 				print __("Your access level is insufficient to open this tab.");
 | |
| 				return false;
 | |
| 			}
 | |
| 			return true;
 | |
| 		}
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	function csrf_ignore($method) {
 | |
| 		$csrf_ignored = array("index");
 | |
| 
 | |
| 		return array_search($method, $csrf_ignored) !== false;
 | |
| 	}
 | |
| 
 | |
| 	function clearLog() {
 | |
| 		$this->pdo->query("DELETE FROM ttrss_error_log");
 | |
| 	}
 | |
| 
 | |
| 	function index() {
 | |
| 
 | |
| 		print "<div dojoType=\"dijit.layout.AccordionContainer\" region=\"center\">";
 | |
| 		print "<div dojoType=\"dijit.layout.AccordionPane\" 
 | |
| 			title=\"<i class='material-icons'>report</i> ".__('Event Log')."\">";
 | |
| 
 | |
| 		if (LOG_DESTINATION == "sql") {
 | |
| 
 | |
| 			$res = $this->pdo->query("SELECT errno, errstr, filename, lineno,
 | |
| 				created_at, login, context FROM ttrss_error_log
 | |
| 				LEFT JOIN ttrss_users ON (owner_uid = ttrss_users.id)
 | |
| 				ORDER BY ttrss_error_log.id DESC
 | |
| 				LIMIT 100");
 | |
| 
 | |
| 			print "<button dojoType=\"dijit.form.Button\"
 | |
| 				onclick=\"Helpers.updateEventLog()\">".__('Refresh')."</button> ";
 | |
| 
 | |
| 			print " <button dojoType=\"dijit.form.Button\"
 | |
| 				class=\"alt-danger\" onclick=\"Helpers.clearEventLog()\">".__('Clear')."</button> ";
 | |
| 
 | |
| 			print "<p><table width=\"100%\" cellspacing=\"10\" class=\"prefErrorLog\">";
 | |
| 
 | |
| 			print "<tr class=\"title\">
 | |
| 				<td width='5%'>".__("Error")."</td>
 | |
| 				<td>".__("Filename")."</td>
 | |
| 				<td>".__("Message")."</td>
 | |
| 				<td width='5%'>".__("User")."</td>
 | |
| 				<td width='5%'>".__("Date")."</td>
 | |
| 				</tr>";
 | |
| 
 | |
| 			while ($line = $res->fetch()) {
 | |
| 				print "<tr class=\"errrow\">";
 | |
| 
 | |
| 				foreach ($line as $k => $v) {
 | |
| 					$line[$k] = htmlspecialchars($v);
 | |
| 				}
 | |
| 
 | |
| 				print "<td class='errno'>" . Logger::$errornames[$line["errno"]] . " (" . $line["errno"] . ")</td>";
 | |
| 				print "<td class='filename'>" . $line["filename"] . ":" . $line["lineno"] . "</td>";
 | |
| 				print "<td class='errstr'>" . $line["errstr"] . "<hr/>" . nl2br($line["context"]) . "</td>";
 | |
| 				print "<td class='login'>" . $line["login"] . "</td>";
 | |
| 
 | |
| 				print "<td class='timestamp'>" .
 | |
| 					make_local_datetime(
 | |
| 					$line["created_at"], false) . "</td>";
 | |
| 
 | |
| 				print "</tr>";
 | |
| 			}
 | |
| 
 | |
| 			print "</table>";
 | |
| 		} else {
 | |
| 
 | |
| 			print_notice("Please set LOG_DESTINATION to 'sql' in config.php to enable database logging.");
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		print "</div>";
 | |
| 
 | |
| 		print "<div dojoType=\"dijit.layout.AccordionPane\" 
 | |
| 			title=\"<i class='material-icons'>info</i> ".__('PHP Information')."\">";
 | |
| 
 | |
| 		ob_start();
 | |
| 		phpinfo();
 | |
| 		$info = ob_get_contents();
 | |
| 		ob_end_clean();
 | |
| 
 | |
| 		print "<div class='phpinfo'>";
 | |
| 		print preg_replace( '%^.*<body>(.*)</body>.*$%ms','$1', $info);
 | |
| 		print "</div>";
 | |
| 
 | |
| 		print "</div>";
 | |
| 
 | |
| 		PluginHost::getInstance()->run_hooks(PluginHost::HOOK_PREFS_TAB,
 | |
| 			"hook_prefs_tab", "prefSystem");
 | |
| 
 | |
| 		print "</div>"; #container
 | |
| 	}
 | |
| 
 | |
| }
 | 
