#!/usr/bin/perl -wT
#
# TWiki WikiClone (see wiki.pm for $wikiversion and other info)
#
# Based on parts of Ward Cunninghams original Wiki and JosWiki.
# Copyright (C) 1998 Markus Peter - SPiN GmbH (warpi@spin.de)
# Some changes by Dave Harris (drh@bhresearch.co.uk) incorporated
# Copyright (C) 1999-2000 Peter Thoeny, peter@thoeny.com
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details, published at
# http://www.gnu.org/copyleft/gpl.html
#This is a hack to the standard "save" script until Plugins are allowed
#to handle form processing
# It still needs to do the same kind of general checks that "save" does.
use CGI::Carp qw(fatalsToBrowser);
use CGI;
use lib ( '.' );
use lib ( '../lib' );
use TWiki;
$query= new CGI;
&main();
sub main
{
my $thePathInfo = $query->path_info();
my $theRemoteUser = $query->remote_user();
my $theTopic = $query->param( 'topic' );
my $theUrl = $query->url;
my $mode = $query->param( 'mode' );
( $topic, $webName, $dummy, $userName ) =
&TWiki::initialize( $thePathInfo, $theRemoteUser, $theTopic, $theUrl, $query );
$dummy = ""; # to suppress warning
my $wikiUserName = &TWiki::userToWikiName( $userName );
if( ! &TWiki::Store::webExists( $webName ) ) {
my $url = &TWiki::getOopsUrl( $webName, $topic, "oopsnoweb" );
TWiki::redirect( $query, $url );
return;
}
my( $mirrorSiteName, $mirrorViewURL ) = &TWiki::readOnlyMirrorWeb( $webName );
if( $mirrorSiteName ) {
my $url = &TWiki::getOopsUrl( $webName, $topic, "oopsmirror", $mirrorSiteName, $mirrorViewURL );
print $query->redirect( $url );
return;
}
#AS changed to use the POST access condition (instead than CHANGE)
# check access permission
if( ! &TWiki::Access::checkAccessPermission( "post", $wikiUserName, "", $topic, $webName ) ) {
my $url = &TWiki::getOopsUrl( $webName, $topic, "oopsaccesschange" );
TWiki::redirect( $query, $url );
return;
}
# get text and other parameters
my $qptext = $query->param( "qptext" );
my $errMsg = '(attempt to change authorization settings detected)';
#AS remove unwanted (ALLOW|DENY)(TOPIC|WEB)(CHANGE|POST|RENAME)...
$qptext =~ s/\s*\*\s+Set\s+(ALLOW|DENY)(TOPIC|WEB)(CHANGE|RENAME|POST)\s*=.*/$errMsg/go;
#/AS
my $unlock = "on";
my $dontNotify = "";
my $saveCmd = "";
my $formattedPost = "----\n\n$qptext\n\n";
my $timeStamp = TWiki::getLocaldate();
$formattedPost .= "-- QuickPosted by $wikiUserName at $timeStamp\n\n";
#now just read in the topic file, modify it, and save
my ($meta, $text) = &TWiki::Store::readTopic( $webName, $topic );
if ($mode eq "after") {
$text =~ s/%QUICKPOST(.*?)%/%QUICKPOST$1%\n$formattedPost/g;
} else {
$text =~ s/%QUICKPOST/$formattedPost%QUICKPOST/g;
}
my $error = &TWiki::Store::saveTopic( $webName, $topic, $text, $meta, $saveCmd, $unlock, $dontNotify );
if( $error ) {
# S. Knutson 30 Nov 2000: error happened (probably from RCS), show it
my $url = &TWiki::getOopsUrl( $webName, $topic, "oopssaveerr", $error );
TWiki::redirect( $query, $url );
} else {
TWiki::redirect( $query, &TWiki::getViewUrl( "", $topic ) );
}
}