diff --git a/mod.php b/mod.php
index 7e6f1f1f..5470ed87 100644
--- a/mod.php
+++ b/mod.php
@@ -296,24 +296,33 @@
'
' . _('Action') . ' | ' .
'';
while($log = $query->fetch()) {
- $log['text'] = utf8tohtml($log['text']);
- $log['text'] = preg_replace('/(\d+\.\d+\.\d+\.\d+)/', '$1', $log['text']);
+ $log_id = 'log_' . md5($log['text']);
- if(isset($boards[$log['board']])) {
- if(preg_match('/post #(\d+)/', $log['text'], $match)) {
- $post_query = prepare(sprintf("SELECT `thread` FROM `posts_%s` WHERE `id` = :id", $boards[$log['board']]));
- $post_query->bindValue(':id', $match[1], PDO::PARAM_INT);
- $post_query->execute() or error(db_error($query));
+ if($_log = cache::get($log_id))
+ $log['text'] = $_log;
+ else {
+
+ $log['text'] = utf8tohtml($log['text']);
+ $log['text'] = preg_replace('/(\d+\.\d+\.\d+\.\d+)/', '$1', $log['text']);
+
+ if(isset($boards[$log['board']])) {
+ if(preg_match('/post #(\d+)/', $log['text'], $match)) {
+ $post_query = prepare(sprintf("SELECT `thread` FROM `posts_%s` WHERE `id` = :id", $boards[$log['board']]));
+ $post_query->bindValue(':id', $match[1], PDO::PARAM_INT);
+ $post_query->execute() or error(db_error($query));
- if($post = $post_query->fetch()) {
- $log['text'] = preg_replace('/post #(\d+)/', '$0', $log['text']);
+ if($post = $post_query->fetch()) {
+ $log['text'] = preg_replace('/post #(\d+)/', '$0', $log['text']);
+
+ cache::set($log_id, $log['text']);
+ }
}
}
}