Save attachment temp files to /tmp, not 'upload' to avoid breaking display when using files.php.

This commit is contained in:
Retro_Guy 2023-07-17 10:01:05 -07:00
parent 2937368252
commit 3fdae1cf95
1 changed files with 8 additions and 4 deletions

View File

@ -199,6 +199,10 @@ function message_post($subject,$from,$newsgroups,$ref,$body,$encryptthis=null,$e
global $www_charset,$config_dir,$spooldir; global $www_charset,$config_dir,$spooldir;
global $msgid_generate,$msgid_fqdn,$rslight_version; global $msgid_generate,$msgid_fqdn,$rslight_version;
flush(); flush();
$attachment_temp_dir = $spooldir."/tmp/";
if(!is_dir($attachment_temp_dir)) {
mkdir($attachment_temp_dir);
}
$myconfig = false; $myconfig = false;
if(file_exists($config_dir.'/userconfig/'.$authname.'.config')) { if(file_exists($config_dir.'/userconfig/'.$authname.'.config')) {
$userconfig = unserialize(file_get_contents($config_dir.'/userconfig/'.$authname.'.config')); $userconfig = unserialize(file_get_contents($config_dir.'/userconfig/'.$authname.'.config'));
@ -227,7 +231,7 @@ function message_post($subject,$from,$newsgroups,$ref,$body,$encryptthis=null,$e
$spam_fail = $spam_result_array['spam_fail']; $spam_fail = $spam_result_array['spam_fail'];
} }
if($do_attach) { if($do_attach) {
move_uploaded_file($_FILES["photo"]["tmp_name"], $spooldir."/upload/" . $_FILES["photo"]["name"]); move_uploaded_file($_FILES["photo"]["tmp_name"], $attachment_temp_dir . $_FILES["photo"]["name"]);
} }
$ns=nntp_open($server,$port); $ns=nntp_open($server,$port);
if ($ns != false) { if ($ns != false) {
@ -313,9 +317,9 @@ function message_post($subject,$from,$newsgroups,$ref,$body,$encryptthis=null,$e
if($do_attach) { if($do_attach) {
fputs($ns,'Content-Type: multipart/mixed;boundary="------------'.$boundary.'"'); fputs($ns,'Content-Type: multipart/mixed;boundary="------------'.$boundary.'"');
fputs($ns,"\r\n"); fputs($ns,"\r\n");
$contenttype = shell_exec('file -b --mime-type '.$spooldir.'/upload/'.$_FILES['photo']['name']); $contenttype = shell_exec('file -b --mime-type '.$attachment_temp_dir.$_FILES['photo']['name']);
$contenttype = rtrim($contenttype); $contenttype = rtrim($contenttype);
$b64file = shell_exec('uuencode -m '.$spooldir.'/upload/'.$_FILES['photo']['name'].' '.$_FILES['photo']['name'].' | grep -v \'begin-base64\|====\''); $b64file = shell_exec('uuencode -m '.$attachment_temp_dir.$_FILES['photo']['name'].' '.$_FILES['photo']['name'].' | grep -v \'begin-base64\|====\'');
$body.='Content-Type: '.$contenttype.';'; $body.='Content-Type: '.$contenttype.';';
$body.="\r\n name=".$_FILES['photo']['name']; $body.="\r\n name=".$_FILES['photo']['name'];
$body.="\r\nContent-Transfer-Encoding: base64"; $body.="\r\nContent-Transfer-Encoding: base64";
@ -348,7 +352,7 @@ function message_post($subject,$from,$newsgroups,$ref,$body,$encryptthis=null,$e
nntp_close($ns); nntp_close($ns);
if($do_attach) { if($do_attach) {
// clean up attachment file // clean up attachment file
unlink($spooldir.'/upload/'.$_FILES["photo"]["name"]); unlink($attachment_temp_dir.$_FILES["photo"]["name"]);
} }
} else { } else {
$message=$text_error["post_failed"]; $message=$text_error["post_failed"];