X-Git-Url: https://git.p6c8.net/selfforum.git/blobdiff_plain/cd70ccb79697cf5a16df1dda1063e0c0a36e17cb..d8a1fb31ed6883aef6a7ba78a117269218966a10:/selfforum-cgi/shared/Posting/Handle.pm?ds=sidebyside diff --git a/selfforum-cgi/shared/Posting/Handle.pm b/selfforum-cgi/shared/Posting/Handle.pm index 11ec9aa..9d2a94a 100644 --- a/selfforum-cgi/shared/Posting/Handle.pm +++ b/selfforum-cgi/shared/Posting/Handle.pm @@ -15,9 +15,10 @@ use strict; use vars qw(@EXPORT); use base qw(Exporter); -@EXPORT = qw(hide_posting recover_posting); +@EXPORT = qw(hide_posting recover_posting modify_posting); -use Posting::_lib qw(get_message_node); +use Posting::_lib qw(get_message_node save_file get_all_threads + create_forum_xml_string); use XML::DOM; @@ -25,21 +26,41 @@ use XML::DOM; # # Hide a posting: set 'invisible' flag # -# Params: $forum Path and filename of forum -# $tpath Path to thread files -# \%hashref Reference: 'thread', 'posting', 'indexFile' +# Params: $forum Path and filename of forum +# $tpath Path to thread files +# \%info Hash reference: 'thread', 'posting', 'indexFile' # Return: -none- # sub hide_posting($$$) { my ($forum, $tpath, $info) = @_; - my ($tid, $mid, $indexFile) = ('t' . $info->{'thread'}, - 'm' . $info->{'posting'}, + my ($tid, $mid, $indexFile) = ($info->{'thread'}, + $info->{'posting'}, $info->{'indexFile'}); - my $tfile = $tpath . '/' . $tid . '.xml'; - change_posting_visibility($tfile, $tid, $mid, 1); - change_posting_visibility($forum, $tid, $mid, 1); + # Thread + my $tfile = $tpath . '/t' . $tid . '.xml'; + change_posting_visibility($tfile, 't'.$tid, 'm'.$mid, 1); + + # Forum + #change_posting_visibility($forum, 't'.$tid, 'm'.$mid, 1); # OBSOLETE + + my ($f, $lthread, $lmsg, $dtd, $zlev) = get_all_threads($forum, 1, 0); + + for (@{$f->{$tid}}) + { + if ($_->{'mid'} == $mid) + { + $_->{'deleted'} = 1; + } + } + + my %cfxs = ( + 'dtd' => $dtd, + 'lastMessage' => $lmsg, + 'lastThread' => $lthread + ); + create_forum_xml_string($f, \%cfxs); } ### recover_posting() ########################################################## @@ -54,13 +75,33 @@ sub hide_posting($$$) sub recover_posting($$$) { my ($forum, $tpath, $info) = @_; - my ($tid, $mid, $indexFile) = ('t' . $info->{'thread'}, - 'm' . $info->{'posting'}, + my ($tid, $mid, $indexFile) = ($info->{'thread'}, + $info->{'posting'}, $info->{'indexFile'}); - my $tfile = $tpath . '/' . $tid . '.xml'; - change_posting_visibility($tfile, $tid, $mid, 0); - change_posting_visibility($forum, $tid, $mid, 0); + # Thread + my $tfile = $tpath . '/t' . $tid . '.xml'; + change_posting_visibility($tfile, 't'.$tid, 'm'.$mid, 0); + + # Forum + #change_posting_visibility($forum, 't'.$tid, 'm'.$mid, 0); # OBSOLETE + + my ($f, $lthread, $lmsg, $dtd, $zlev) = get_all_threads($forum, 1, 0); + + for (@{$f->{$tid}}) + { + if ($_->{'mid'} == $mid) + { + $_->{'deleted'} = 0; + } + } + + my %cfxs = ( + 'dtd' => $dtd, + 'lastMessage' => $lmsg, + 'lastThread' => $lthread + ); + create_forum_xml_string($f, \%cfxs); } ### change_posting_visibility () ############################################### @@ -71,9 +112,9 @@ sub recover_posting($$$) # $tid Thread ID # $mid Message ID # $invisible 1 - invisible, 0 - visible -# Return: -none- +# Return: Status code # -sub change_posting_visibility($$$) +sub change_posting_visibility($$$$) { my ($fname, $tid, $mid, $invisible) = @_; @@ -90,9 +131,70 @@ sub change_posting_visibility($$$) $_->setAttribute('invisible', $invisible); } - $xml->printToFile($fname.'.temp'); - rename $fname.'.temp', $fname; + return save_file($fname, \$xml->toString); +} + +### modify_posting () ########################################################## +# +# Modify a posting (only subject and category until now!) +# +# Params: $forum Path and filename of forum +# $tpath Path to thread files +# \%info Reference: 'thread', 'posting', 'indexFile', 'data' +# (\%hashref: 'subject', 'category', 'body') +# Return: -none- +# +sub modify_posting($$$) +{ + my ($forum, $tpath, $info) = @_; + my ($tid, $mid, $indexFile, $data) = ('t' . $info->{'thread'}, + 'm' . $info->{'posting'}, + $info->{'indexFile'}, + $info->{'data'}); + my ($subject, $category, $body) = ($data->{'subject'}, $data->{'category'}, $data->{'body'}); + + my %msgdata; + + # These values may be changed by change_posting_value() + $subject && $msgdata{'Subject'} = $subject; + $category && $msgdata{'Category'} = $category; + + # + my $tfile = $tpath . '/' . $tid . '.xml'; + change_posting_value($tfile, $tid, $mid, \$msgdata); + change_posting_value($forum, $tid, $mid, \$msgdata); +} + +### change_posting_value () #################################################### +# +# Change specific values of a posting +# +# Params: $fname Filename +# $tid Thread ID +# $mid Message ID +# \%values New values +# Return: Status code +# +sub change_posting_value($$$$) +{ + my ($fname, $tid, $mid, $values) = @_; + + my $parser = new XML::DOM::Parser; + my $xml = $parser->parsefile($fname); + + my $mnode = get_message_node($xml, $tid, $mid); + + for (keys %$values) + { + # Find first direct child node with name $_ + my $nodes = $mnode->getElementsByTagName($_, 0); + my $node = $nodes->item(0); + $node->setValue($values->{$_}); + } + + return save_file($fname, \$xml->toString); } +# Let it be true 1;