From 95f1b1c1495e6b1e012e2339b887684a0cc4861d Mon Sep 17 00:00:00 2001 From: Retro_Guy Date: Mon, 20 May 2024 03:59:30 -0700 Subject: [PATCH] Avoid retrieving articles multiple times for display_full_headers. --- Rocksolid_Light/rocksolid/lib/message.inc.php | 34 ++++++++++++------- 1 file changed, 21 insertions(+), 13 deletions(-) diff --git a/Rocksolid_Light/rocksolid/lib/message.inc.php b/Rocksolid_Light/rocksolid/lib/message.inc.php index 5036df0..5ab31b4 100644 --- a/Rocksolid_Light/rocksolid/lib/message.inc.php +++ b/Rocksolid_Light/rocksolid/lib/message.inc.php @@ -185,7 +185,7 @@ function message_parse($rawmessage) */ function message_read($id, $bodynum = 0, $group = "") { - global $CONFIG, $config_name, $cache_articles, $spooldir, $spoolpath, $logdir, $text_error, $ns; + global $CONFIG, $config_name, $cache_articles, $spooldir, $spoolpath, $logdir, $text_error, $ns, $current_article; $logfile = $logdir . '/newsportal.log'; if (! testGroup($group)) { echo $text_error["read_access_denied"]; @@ -227,6 +227,7 @@ function message_read($id, $bodynum = 0, $group = "") unset($rawmessage); if ($CONFIG['article_database'] == '1') { $rawmessage = np_get_db_article($id, $group, 1); + $current_article = $rawmessage; } else { $articlepath = $spoolpath . preg_replace('/\./', '/', $group) . "/" . $id; if (file_exists($articlepath)) { @@ -601,15 +602,19 @@ function copy_messageid() function display_full_headers($article, $group, $name, $from, $getface = false) { - global $spoolpath, $CONFIG; - if ($CONFIG['article_database'] == '1') { - $message = np_get_db_article($article, $group, 1); - } else { - $thisgroup = $spoolpath . "/" . preg_replace('/\./', '/', $group); - if (! file_exists($group . "/" . $article)) { - // Return something useful + global $spoolpath, $CONFIG, $current_message; + if (! isset($current_message)) { + if ($CONFIG['article_database'] == '1') { + $message = np_get_db_article($article, $group, 1); + } else { + $thisgroup = $spoolpath . "/" . preg_replace('/\./', '/', $group); + if (! file_exists($group . "/" . $article)) { + // Return something useful + } + $message = file($thisgroup . "/" . $article, FILE_IGNORE_NEW_LINES); } - $message = file($thisgroup . "/" . $article, FILE_IGNORE_NEW_LINES); + } else { + $message = $current_message; } if (isset($sendface)) { unlink($sendface); @@ -762,7 +767,10 @@ function message_show($group, $id, $attachment = 0, $article_data = false, $maxl global $file_article, $file_article_full, $OVERRIDES, $spooldir; global $text_header, $text_article, $article_showthread, $file_attachment, $attachment_show; global $block_xnoarchive, $article_graphicquotes; - global $CONFIG; + global $CONFIG, $current_message; + if (! isset($current_message)) { + $current_message = np_get_db_article($id, $group, 1); + } if ($article_data == false) $article_data = message_read($id, $attachment, $group); $head = $article_data->header; @@ -785,14 +793,14 @@ function message_show($group, $id, $attachment = 0, $article_data = false, $maxl } } $block = false; - foreach($blocked_user_config as $key => $value) { - $blockme = '/'.addslashes($key).'/'; + foreach ($blocked_user_config as $key => $value) { + $blockme = '/' . addslashes($key) . '/'; if (preg_match($blockme, $head->from)) { $block = true; break; } } - + if ($block == true) { echo '

(message #' . $head->number . ' hidden by your blocklist)


'; return "blocked";