#!/usr/bin/perl $basepath = './'; # # csNews - v2.35 - 060906 ##################################################################### # # # Copyright © 1999-2001 CGISCRIPT.NET - All Rights Reserved # # # ##################################################################### # # # THIS COPYRIGHT INFORMATION MUST REMAIN INTACT # # AND MAY NOT BE MODIFIED IN ANY WAY # # # ##################################################################### # # When you downloaded this script you agreed to accept the terms # of this Agreement. This Agreement is a legal contract, which # specifies the terms of the license and warranty limitation between # you and CGISCRIPT.NET. You should carefully read the following # terms and conditions before installing or using this software. # Unless you have a different license agreement obtained from # CGISCRIPT.NET, installation or use of this software indicates # your acceptance of the license and warranty limitation terms # contained in this Agreement. If you do not agree to the terms of this # Agreement, promptly delete and destroy all copies of the Software. # # Versions of the Software # Only one copy of the registered version of CGISCRIPT.NET # may used on one web site. # # License to Redistribute # Distributing the software and/or documentation with other products # (commercial or otherwise) or by other than electronic means without # CGISCRIPT.NET's prior written permission is forbidden. # All rights to the CGISCRIPT.NET software and documentation not expressly # granted under this Agreement are reserved to CGISCRIPT.NET. # # Disclaimer of Warranty # THIS SOFTWARE AND ACCOMPANYING DOCUMENTATION ARE PROVIDED "AS IS" AND # WITHOUT WARRANTIES AS TO PERFORMANCE OF MERCHANTABILITY OR ANY OTHER # WARRANTIES WHETHER EXPRESSED OR IMPLIED. BECAUSE OF THE VARIOUS HARDWARE # AND SOFTWARE ENVIRONMENTS INTO WHICH CGISCRIPT.NET MAY BE USED, NO WARRANTY # OF FITNESS FOR A PARTICULAR PURPOSE IS OFFERED. THE USER MUST ASSUME THE # ENTIRE RISK OF USING THIS PROGRAM. ANY LIABILITY OF CGISCRIPT.NET WILL BE # LIMITED EXCLUSIVELY TO PRODUCT REPLACEMENT OR REFUND OF PURCHASE PRICE. # IN NO CASE SHALL CGISCRIPT.NET BE LIABLE FOR ANY INCIDENTAL, SPECIAL OR # CONSEQUENTIAL DAMAGES OR LOSS, INCLUDING, WITHOUT LIMITATION, LOST PROFITS # OR THE INABILITY TO USE EQUIPMENT OR ACCESS DATA, WHETHER SUCH DAMAGES ARE # BASED UPON A BREACH OF EXPRESS OR IMPLIED WARRANTIES, BREACH OF CONTRACT, # NEGLIGENCE, STRICT TORT, OR ANY OTHER LEGAL THEORY. THIS IS TRUE EVEN IF # CGISCRIPT.NET IS ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. IN NO CASE WILL # CGISCRIPT.NET' LIABILITY EXCEED THE AMOUNT OF THE LICENSE FEE ACTUALLY PAID # BY LICENSEE TO CGISCRIPT.NET. # # Credits: # Andy Angrick - Programmer - angrick@cgiscript.net # Mike Barone - Design - mbarone@cgiscript.net # # For information about this script or other scripts see # http://www.cgiscript.net # # Thank you for trying out our script. # If you have any suggestions or ideas for a new innovative script # please direct them to suggest@cgiscript.net. Thanks. # ######################################################################## # Misc Options # ######################################################################## #path to sendmail $sendmail = '/usr/sbin/sendmail'; ### date format. Default MM-DD-YYYY. Change 'US' to 'E' for DD-MM-YYYY format. $df = 'US'; ### target for URL articles on listings. $urltarget = '_blank'; ### target for URL articles on searches $searchtarget = '_blank'; ### number of records perl page in the management screen $epp = 25; ### enter database names here comma separated to search through particular databases ### leave blank for all databases $searchdb = ''; ######################################################################## # Config Variables # ######################################################################## (! -e "$basepath/setup.cgi")?($nosetup=1):(require("$basepath/setup.cgi")); (!$htmlpath)&&($htmlpath=$cgipath); (!$htmlurl)&&($htmlurl=$cgiurl); $in{'htmlurl'} = $htmlurl; $in{'cgiurl'} = $cgiurl."/csNews.cgi"; $flock = 1; ######################################################################## # End Config Variables # ######################################################################## require("$basepath/libs.cgi"); $edd = "default%2edb"; $dd="default"; $in{'cinfo'} = qq|

Powered by csNewsPro - © 2000-2003 CGIScript.net |; $| = 1; eval { &main; }; if ($@) { &cgierr("fatal error: $@"); } exit; sub main{ print "Content-type: text/html\n\n"; ($ENV{'CONTENT_TYPE'} =~ /multipart\/form-data/i)?(&getdata(1)):(&getdata()); $in{'database'} =~ s/%(..)/pack("c",hex($1))/ge; $in{'database'} =~ s/([^\w])/'%'.sprintf("%.2x",ord($1))/ge; $in{'database'} =~ s/%2earchive/\.archive/g; ($in{'command'} eq '')&&($nosetup)&&(&Setup); ($in{'command'} eq '')&&(!$nosetup)&&(&ShowIndex); ($in{'command'} eq "viewnews")&&(&ShowListPub); ($in{'command'} eq "viewone")&&(&ViewOne); ($in{'command'} eq "login")&&(&Login); ($in{'command'} eq 'savesetup')&&(($nosetup)?(&SaveSetup):(&PError("Error. Permission denied."))); ($in{'command'} eq 'emailarticle')&&(&EmailArticle); ($in{'command'} eq 'dosearch')&&(&DoSearch); ($in{'command'} eq 'showsearchform')&&(&ShowSearchForm); &SaveVars; &GetLogin; &GetVars; ($in{'command'} eq "setstyles")&&(&SetStyles); ($in{'command'} eq "showadd")&&(&ShowAdd); ($in{'command'} eq "reorder")&&(&Reorder); ($in{'command'} eq "moveto")&&(&Moveto); ($in{'command'} eq "add")&&(&Add); ($in{'command'} eq "showedit")&&(&ShowEdit); ($in{'command'} eq "savechanges")&&(&SaveChanges); ($in{'command'} eq "deleteitems")&&(&DeleteItems); ($in{'command'} eq "copyitem")&&(&CopyItem); ($in{'command'} eq "manage")&&(&ShowList); ($in{'command'} eq "view")&&(&ViewOne); ($in{'command'} eq "showadv")&&(&ShowAdv); ($in{'command'} eq "deletedb")&&(&DeleteDB); ($in{'command'} eq "showadddb")&&(&ShowAddDB); ($in{'command'} eq "addnewsdb")&&(&AddNewsDB); ($in{'command'} eq "showlinks")&&(&ShowLinks); ($in{'command'} eq "showupload")&&(&ShowUpload); ($in{'command'} eq "upload")&&(&Upload); ($in{'command'} eq "refresh")&&(&Refresh); ($in{'command'} eq 'showeditor')&&(&ShowEditor); ($in{'command'} eq 'uploadEditor')&&(&UploadEditor); ($in{'command'} eq 'showuploadEditor')&&(&ShowUploadEditor); ($in{'command'} eq 'rendb')&&(&CopyDB(1)); ($in{'command'} eq 'copydb')&&(&CopyDB(2)); ($in{'command'} eq 'viewsaved')&&(&ViewSaved); } sub ShowSearchForm{ if($in{'js'} ne 'Y'){ &PageOut("$htmlpath/t_searchform.htm"); } else{ &PageOutJS("$htmlpath/t_searchform.htm"); } exit; } sub DoSearch{ $tmpdb = $in{'database'}; (!$searchdb)&&($searchdb = 'all'); (!$in{'query'})&&(&PError("Error. Please enter something to search for.")); (-e "$cgipath/$searchdb.style.cgi")?(require "$cgipath/$searchdb.style.cgi"):(require "$cgipath/styles.cgi"); if($searchdb eq 'all'){ opendir(IMG,"$htmlpath/"); @dbfiles = grep(/db$/,readdir(IMG)); closedir(IMG); foreach $i (sort @dbfiles){ push(@sd,$i); } $in{'ilink'} = qq|[Back to Index]|; } else{ (@sd) = split(/\s*,\s*/,$searchdb); $in{'ilink'} = qq|[Back to Index]|; } #loop through for search foreach $i (@sd){ open(DB,"$htmlpath/$i")||print "$htmlpath/$i
"; while($line=){ chop $line; (@fields) = split(/\~/,$line); next if ($fields[21] eq 'N'); ##get news html file $in{'database'} = $i; open(HTML,"$htmlpath/newsdir/$in{'database'}$fields[0].htm")||print "$!: $htmlpath/newsdir/$in{'database'}$fields[0].htm
"; $body=''; while(){ $body .= $_; } close HTML; $line = $line .' '. $body; if($line =~ /$in{'query'}/i){ $fields[3] = &reverseHTML($fields[3]); $fields[1] = &reverseHTML($fields[1]); $fields[3] =~ s/\\n/\n/g; if($fields[19] eq "U"){ $viewlink = ""; } elsif($fields[19] eq "I"){ $viewlink = ""; } else{ $viewlink = ""; } $cat=$i; $cat =~ s/%(..)/pack("c",hex($1))/ge; $cat =~ s/\.db//g; $cat = "$cat » "; $in{'searchresults'} .= "


\n"; } } close DB; } (!$in{'searchresults'})&&($in{'searchresults'} = 'No results found.'); &PageOut("$htmlpath/t_search_results.htm"); exit; } sub ViewSaved{ print "
";
open(DB,"$htmlpath/$in{'database'}.savedemail.cgi");
while(){
  $found=1;
  print;
  }
if(!$found){
  print "No email addresses saved
"; } exit; } sub EmailArticle{ (!$in{'te'})&&(&PError("Error. Please enter an email address to send the article to.")); (!$in{'ye'})&&(&PError("Error. Please enter your email address")); ($in{'te'} =~ /[^A-Za-z0-9\.\@]/)&&(&PError("Permission denied")); ($in{'ye'} =~ /[^A-Za-z0-9\.\@]/)&&(&PError("Permission denied")); my $sc=0; if(! -f "$htmlpath/$in{'database'}"){ &PError("Permission denied."); exit; } else{ open(DB,"<$htmlpath/$in{'database'}.savedemail.cgi"); while(){ chomp; my($ra,$te,$ye) = split(":",$_); ($ra eq $ENV{'REMOTE_ADDR'})&&($sc++); } close DB; } if($sc > 3){ &PError("Permission denied."); exit; } open(MAIL,"|$sendmail -t"); print MAIL <<"EOF"; To: $in{'te'} From: $in{'ye'} Subject: $in{'title'} This email was sent from: $in{'cgiurl'} $in{'comments'} $in{'url'} EOF close MAIL; open(DB,">>$htmlpath/$in{'database'}.savedemail.cgi"); ($flock)&&(flock(DB,2)); print DB "$ENV{'REMOTE_ADDR'}:$in{'te'}:$in{'ye'}\n"; close DB; ($flock)&&(flock(DB,8)); print <<"EOF"; EOF exit; } sub CopyDB{ local($type) = @_; $in{'nm'} = $in{'nm'} . ".db"; $in{'nm'} =~ s/([^\w])/'%'.sprintf("%.2x",ord($1))/ge; (-e "$in{'nm'}")&&(&PError("Error. Category already exists")); if($type == 1){ rename("$htmlpath/$in{'database'}","$htmlpath/$in{'nm'}"); rename("$cgipath/$in{'database'}.style.cgi","$cgipath/$in{'nm'}.style.cgi"); rename("$htmlpath/$in{'database'}.evenrow","$htmlpath/$in{'nm'}.evenrow"); rename("$htmlpath/$in{'database'}.oddrow","$htmlpath/$in{'nm'}.oddrow"); rename("$htmlpath/$in{'database'}.list","$htmlpath/$in{'nm'}.list"); rename("$htmlpath/$in{'database'}.full","$htmlpath/$in{'nm'}.full"); } else{ &CopyFile("$htmlpath/$in{'database'}","$htmlpath/$in{'nm'}"); &CopyFile("$cgipath/$in{'database'}.style.cgi","$cgipathpath/$in{'nm'}.style.cgi"); &CopyFile("$htmlpath/$in{'database'}.evenrow","$htmlpath/$in{'nm'}.evenrow"); &CopyFile("$htmlpath/$in{'database'}.oddrow","$htmlpath/$in{'nm'}.oddrow"); &CopyFile("$htmlpath/$in{'database'}.list","$htmlpath/$in{'nm'}.list"); &CopyFile("$htmlpath/$in{'database'}.full","$htmlpath/$in{'nm'}.full"); } opendir(TDIR,"$htmlpath/newsdir"); @allfiles = readdir(TDIR); closedir TDIR; $db = $in{'database'}; foreach $i (@allfiles){ if($i =~ /$db(\d+)\.htm/){ &CopyFile("$htmlpath/newsdir/$i","$htmlpath/newsdir/$in{'nm'}$1.htm"); ($type == 1)&&(unlink("$htmlpath/newsdir/$i")); } } ($type==1)?($m = 'category rename'):($m = 'category copied'); ($type==1)&&($in{'database'} = $in{'nm'}); print <<"EOF"; EOF exit; } sub Moveto{ (!$in{'moveto'})&&(&PError("Error. Please select an item to move.")); ($in{'movedatabase'} eq $in{'database'})&&(&PError("Error. The item already exists in this category")); @moves = split(/\\0/,$in{'moveto'}); foreach $i (@moves){ $m{$i} = 1; } ##get highest ID in DB for unique ID. open(DB,"$htmlpath/$in{'movedatabase'}"); $id = 0; while(){ ($idt,@rest) = split("~",$_); ($idt > $id)&&($id = $idt); } close DB; $id++; open(ODB,"$htmlpath/$in{'database'}"); ($flock)&&(flock(ODB,2)); open(ODBT,">$htmlpath/$in{'database'}.tmp"); ($flock)&&(flock(ODBT,2)); open(MDB,">>$htmlpath/$in{'movedatabase'}"); ($flock)&&(flock(MDB,2)); while($line = ){ $count++; ($mid,@fields) = split(/\~/,$line); if($m{$mid}){ $all = join("~",@fields); print MDB "$id~$all"; rename("$htmlpath/newsdir/$in{'database'}${mid}.htm","$htmlpath/newsdir/$in{'movedatabase'}${id}.htm"); $id++; } else{ print ODBT $line; } } close ODB; close ODBT; close MDB; rename("$htmlpath/$in{'database'}.tmp","$htmlpath/$in{'database'}"); ($flock)&&(flock(ODB,8)); ($flock)&&(flock(ODBT,8)); ($flock)&&(flock(MDB,8)); ##rename bodies foreach $i (@moves){ rename("$htmlpath/newsdir/$in{'database'}${i}.htm","$htmlpath/newsdir/$in{'movedatabase'}${i}.htm"); } print <<"EOF"; EOF exit; } sub GetLogin{ $in{'mpage'} = ''; &GetCookies; $in{'UserName'} = $cookie{'UserName'}; $in{'PassWord'} = $cookie{'PassWord'}; if(!$in{'UserName'}){ &GetDatabases; &PageOut("$htmlpath/t_login.htm"); exit; } else{ ##if master...let it go if(($in{'UserName'} eq $username)&&($in{'PassWord'} eq $password)){ #good to go. $in{'mpage'} = 'manager'; return; } else{ (-e "$cgipath/$in{'database'}.style.cgi")?($dbs = "$cgipath/$in{'database'}.style.cgi"):($dbs = "${cgipath}/styles.cgi"); require($dbs); $in{'mpage'} = 'nonadmin'; ##anonymous access ($in{'security'} eq "anon")&&(return); ##password access ($in{'security'} ne 'password')&&(&PError("Error. Invalid username or password")); ##find out what database we are in and match up user. ##get users @users = split(/\r?\n/,$in{'userpass'}); foreach $i (@users){ ($username,$password)=split(":",$i); ##good to go ($in{'UserName'} eq $username)&&($in{'PassWord'} eq $password)&&(return); } } } &PError("Error. Invalid username or password"); } sub Login{ &GetDatabases; &PageOut("$htmlpath/t_login.htm"); exit; } sub ShowIndex{ opendir(IMG,"$htmlpath/"); @dbfiles = grep(/db$/,readdir(IMG)); closedir(IMG); $dfound=0; foreach $i (sort @dbfiles){ $dfound=1; $seldb=''; $dbo = $i; $dbo =~ s/%(..)/pack("c",hex($1))/ge; $dbo =~ s/\.db//g; $in{'newsitems'} .= "
  • $dbo
  • "; } (!$dfound)&&($in{'newsitems'} = "No news categories configured."); &PageOut("$htmlpath/t_index.htm"); exit; } sub Refresh{ &SetStyle; &ShowAdv; exit; } sub AddNewsDB{ (!$in{'newsdb'})&&(&PError("Error. Please Enter a Database Name.")); $in{'newsdb'} .= '.db'; $in{'newsdb'} =~ s/([^\w])/'%'.sprintf("%.2x",ord($1))/ge; (-e "$htmlpath/$in{'newsdb'}")&&(&PError("Error. Database already exists. Please use another name.")); open(NEWS,">${htmlpath}/$in{'newsdb'}"); close NEWS; print <<"EOF"; EOF } sub ShowAddDB{ &PageOut("${htmlpath}/t_adddb.htm"); exit; } sub DeleteDB{ unlink("$htmlpath/$in{'database'}"); unlink("$cgipath/$in{'database'}.style.cgi"); unlink("$htmlpath/$in{'database'}.evenrow"); unlink("$htmlpath/$in{'database'}.oddrow"); unlink("$htmlpath/$in{'database'}.list"); unlink("$htmlpath/$in{'database'}.full"); #delete the bodies opendir(DIR,"$htmlpath/newsdir"); @files = readdir(DIR); close DIR; foreach $i (@files){ if($i =~ /$in{'database'}\d+\.htm/){ unlink("$htmlpath/newsdir/$i"); } } print <<"EOF"; EOF } sub ViewOne{ (-e "$cgipath/$in{'database'}.style.cgi")?(require "$cgipath/$in{'database'}.style.cgi"):(require "$cgipath/styles.cgi"); (-e "$htmlpath/$in{'database'}.full")?($po = "$htmlpath/$in{'database'}.full"):($po = "$htmlpath/t_view.htm"); open(DB,"$htmlpath/$in{'database'}"); $found = 0; while(){ chop; (@fields) = split(/\~/,$_); ($fields[0] eq $in{'id'})&&($found = 1)&&(last); } if($found){ $in{'id'} = $fields[0]; $in{'title'} = $fields[1]; $in{'ptitle'} = $in{'title'}; $in{'date'} = $fields[2]; if($df ne 'US'){ my($m,$d,$y) = $in{'date'} =~ /(\d\d)-(\d\d)-(\d\d\d\d)/; $in{'date'} = "$d-$m-$y"; } $in{'description'} = $fields[3]; $in{'location'} = $fields[4]; foreach $i (keys %in){ $in{$i} = &reverseHTML($in{$i}); } $in{'description'} =~ s/\\n/
    /g; $display = $fields[19]; $authorization = $fields[21]; $bodyname = "$in{'database'}$fields[0].htm"; ##get news html file open(HTML,"$htmlpath/newsdir/$bodyname"); while(){ $in{'body'} .= $_; } close HTML; if($fields[22] eq 'checked'){ $in{'body'} =~ s/([\<\>])/'&#'.ord($1).';'/ge; $in{'body'} =~ s/\n/
    /g; $in{'title'} =~ s/([\<\>])/'&#'.ord($1).';'/ge; $in{'date'} =~ s/([\<\>])/'&#'.ord($1).';'/ge; $in{'location'} =~ s/([\<\>])/'&#'.ord($1).';'/ge; } if($in{'displaysendemail'}){ open(HTML,"$htmlpath/t_email.htm"); while(){ $_ =~ s/in\((\w+)\)/$in{$1}/g; $in{'body'} .= $_; } close HTML; } ($fields[6] eq 'checked')&&($in{'date'}=''); ($fields[7] eq 'checked')&&($in{'location'}=''); ($in{'date'})&&($in{'location'})&&($in{'location'}=" -- $in{'location'}"); (!$in{'op'})&&($in{'op'} = 't'); (!$in{'ct'})&&($in{'ct'} = 'd'); if(($in{'ct'} ne 'j')&&($in{'op'} eq 't')){ &PageOut("$po"); } elsif(($in{'ct'} eq 'j')&&($in{'op'} eq 't')){ &PageOutJS("$po"); } elsif(($in{'ct'} ne 'j')&&($in{'op'} ne 't')){ &PageOut("$htmlpath/newsdir/$bodyname"); } else{ &PageOutJS("$htmlpath/newsdir/$bodyname"); } } else{ print "Error. No Record Found!
    "; } close DB; exit; } sub SetStyle{ #save templates $in{'EvenRowTemplate'} = &reverseHTML($in{'EvenRowTemplate'}); $in{'OddRowTemplate'} = &reverseHTML($in{'OddRowTemplate'}); $in{'MainListingTemplate'} = &reverseHTML($in{'MainListingTemplate'}); $in{'FullViewTemplate'} = &reverseHTML($in{'FullViewTemplate'}); if($in{'EvenRowTemplate'}){ open(TMP,">$htmlpath/$in{'database'}.evenrow"); print TMP $in{'EvenRowTemplate'}; close TMP; delete($in{'EvenRowTemplate'}); } if($in{'OddRowTemplate'}){ open(TMP,">$htmlpath/$in{'database'}.oddrow"); print TMP $in{'OddRowTemplate'}; close TMP; delete($in{'OddRowTemplate'}); } if($in{'MainListingTemplate'}){ open(TMP,">$htmlpath/$in{'database'}.list"); print TMP $in{'MainListingTemplate'}; close TMP; delete($in{'MainListingTemplate'}); } if($in{'FullViewTemplate'}){ open(TMP,">$htmlpath/$in{'database'}.full"); print TMP $in{'FullViewTemplate'}; close TMP; delete($in{'FullViewTemplate'}); } open(STYLE,">$cgipath/$in{'database'}.style.cgi"); foreach $i (sort keys(%in)){ $in{$i} = &reverseHTML($in{$i}); next if (($i eq 'command')||($i eq 'cgiurl')); next if (($i eq 'basemanageurl')||($i eq 'cinfo')); next if (($i eq 'database')||($i eq 'imagedir')); next if (($i eq 'imagerealdir')||($i eq 'images2')); next if (($i eq 'format')||($i eq 'managementname')); next if (($i eq 'managementuser')||($i eq 'managementemail')); next if (($i eq 'UserName')||($i eq 'PassWord')); $in{$i} =~ s/\\//g; $in{$i} =~ s/@/\\@/g; $in{$i} =~ s/"/\\"/g; print STYLE "\$in{'$i'}=\"$in{$i}\";\n"; } print STYLE "1;\n"; close STYLE; } sub SetStyles{ &SetStyle; print <<"EOF"; EOF exit; } sub ShowAd{ (-e "$cgipath/$in{'database'}.style.cgi")?(require "$cgipath/$in{'database'}.style.cgi"):(require "$cgipath/styles.cgi"); (-e "$htmlpath/$in{'database'}.evenrow")?($evenrow = "$htmlpath/$in{'database'}.evenrow"):($evenrow = "$htmlpath/t_news_line_even.htm"); (-e "$htmlpath/$in{'database'}.oddrow")?($oddrow = "$htmlpath/$in{'database'}.oddrow"):($oddrow = "$htmlpath/t_news_line_odd.htm"); (-e "$htmlpath/$in{'database'}.list")?($list = "$htmlpath/$in{'database'}.list"):($list = "$htmlpath/t_news_body.htm"); (-e "$htmlpath/$in{'database'}.full")?($full = "$htmlpath/$in{'database'}.full"):($full = "$htmlpath/t_view.htm"); (!$in{'security'})&&($in{'securitynone'} = 'checked'); $in{"security$in{'security'}"}='checked'; ($in{'security'} ne 'password')&&($in{'securepass'} = ''); (!$in{'position'})&&($in{'positioncenter'} = 'checked'); $in{'position'.$in{'position'}} = 'checked'; foreach $i (keys %in){ $in{$i} =~ s/([<>"])/'&#'.ord($1).';'/ge; } ##get even row open(TMP,"$evenrow"); while(){ $in{'EvenRowTemplate'} .= $_; } close TMP; ##get odd row open(TMP,"$oddrow"); while(){ $in{'OddRowTemplate'} .= $_; } close TMP; ##get list body open(TMP,"$list"); while(){ $in{'MainListingTemplate'} .= $_; } close TMP; ##get full listing open(TMP,"$full"); while(){ $in{'FullViewTemplate'} .= $_; } close TMP; $in{'EvenRowTemplate'} = &htmlspecialchars($in{'EvenRowTemplate'}); $in{'OddRowTemplate'} = &htmlspecialchars($in{'OddRowTemplate'}); $in{'MainListingTemplate'} = &htmlspecialchars($in{'MainListingTemplate'}); $in{'FullViewTemplate'} = &htmlspecialchars($in{'FullViewTemplate'}); } sub ShowAdv{ ($in{'mpage'} ne 'manager')&&(&PError("Error. Access denied for advanced settings")); &ShowAd; &PageOut("$htmlpath/t_news_advanced_settings.htm"); exit; } sub ShowList{ $flip=1; &GetDatabases; $dbo = $in{'database'}; $dbo =~ s/%(..)/pack("c",hex($1))/ge; $dbo =~ s/\.db//g; if($dbo =~ /\.archive$/){ $dbo =~ s/\.archive$//; $dbo = "$dbo Archive"; } $in{'alabel'} = "Current Category: $dbo"; ##get total count open(DB,"$htmlpath/$in{'database'}"); while($line=){ $tc++; } close DB; (!$in{'page'})&&($in{'page'} = 1); $start = ($in{'page'}*$epp)-$epp; $end = $start + $epp; open(DB,"$htmlpath/$in{'database'}"); while($line=){ $count++; if(($count > $start) & ($count <= $end)){ chomp $line; (@fields) = split(/\~/,$line); foreach $i (0..$#fields){ $fields[$i] = &reverseHTML($fields[$i]); ($fields[22] eq 'checked')&&($fields[$i] =~ s/([<>"])/'&#'.ord($1).';'/ge); $fields[$i] =~ s/\\n/\n/g; } ($fields[2])&&($fields[2] .= ' -- '); if($df ne 'US'){ my($m,$d,$y) = $fields[2] =~ /(\d\d)-(\d\d)-(\d\d\d\d)/; $fields[2] = "$d-$m-$y"; } $in{'viewlink'}=''; ##create the link ($fields[19] eq "S")&&($in{'viewlink'} = ""); ($fields[19] eq "P")&&($in{'viewlink'} = ""); ($fields[19] eq "I")&&($in{'viewlink'} = ""); if($fields[19] eq "U"){ open(HTML,"$htmlpath/newsdir/$in{'database'}$fields[0].htm"); $url = ; close HTML; $in{'viewlink'} = ""; } ##make select for $i (1..$tc){ ($i == $count)?($sel = 'selected'):($sel=''); $in{'rowsel'} .= ""; } ($flip==1)?($bgc='#CCCCCC'):($bgc='#FFFFFF'); $flip=$flip * -1; $fields[1] =~ s/<\/*form>//g; $fields[2] =~ s/<\/*form>//g; $fields[3] =~ s/<\/*form.*?>//gi; $in{'line'} .= "    $in{'viewlink'}$fields[1]
    $fields[2]$fields[4]
    $fields[3]
    "; $in{'rowsel'}=''; } } close DB; &GetNlinks; (!$in{'line'})&&($in{'line'}="No news items configured"); ($in{'mpage'} eq 'manager')?(&PageOut("$htmlpath/t_show_list.htm")):(&PageOut("$htmlpath/t_show_list_pub.htm")); exit; } sub GetDatabases{ opendir(IMG,"$htmlpath/"); @dbfiles = grep(/db$/,readdir(IMG)); closedir(IMG); $dfound=0; foreach $i (sort @dbfiles){ $seldb=''; $dbo = $i; $dbo =~ s/%(..)/pack("c",hex($1))/ge; $dbo =~ s/\.db//g; (!$in{'database'})&&($seldb='selected')&&($in{'database'} = $i)&&($dfound=1); ($i eq $in{'database'})?($seldb = 'selected'):($seldb = ''); ("$i.archive" eq $in{'database'})?($sela = 'selected'):($sela = ''); $in{'databases'} .= "\n"; $in{'databasesa'} .= "\n"; } ###get saved archives opendir(IMG,"$htmlpath/"); @dbfiles = grep(/archive$/,readdir(IMG)); closedir(IMG); $dfound=0; foreach $i (sort @dbfiles){ $seldb=''; $dbo = $i; $dbo =~ s/%(..)/pack("c",hex($1))/ge; $dbo =~ s/\.db.archive//g; $dfound=1; ($i eq $in{'database'})?($sela = 'selected'):($sela = ''); $in{'databasesb'} .= "\n"; } (!$dfound)&&(!$in{'databases'})&&($in{'database'} = $edd)&&($in{'databases'} = ""); } sub CopyItem{ ##get highest ID in DB for unique ID. open(DB,"$htmlpath/$in{'database'}"); $id = 0; while(){ ($idt,@rest) = split("~",$_); ($idt > $id)&&($id = $idt); } close DB; $id++; open(DB,"$htmlpath/$in{'database'}"); open(TMP,">$htmlpath/$in{'database'}.tmp"); ($flock)&&(flock(TMP,2)); while($line = ){ $count++; ($mid,@fields) = split(/\~/,$line); print TMP $line; if($mid eq $in{'id'}){ $tmp = join("~",$id,@fields); print TMP $tmp; } } close DB; close TMP; ($flock)&&(flock(TMP,8)); @fi = stat("$htmlpath/$in{'database'}.tmp"); ##only write over the file if greater than 1 byte in size. rename("$htmlpath/$in{'database'}.tmp","$htmlpath/$in{'database'}") unless (($fi[7] < 1)&&($count > 1)); #copy body open(BODY,"$htmlpath/newsdir/$in{'database'}$in{'id'}.htm"); open(BODYNEW,">$htmlpath/newsdir/$in{'database'}$id.htm"); ($flock)&&(flock(BODYNEW,2)); while(){ print BODYNEW; } close BODY; close BODYNEW; ($flock)&&(flock(BODYNEW,8)); print <<"EOF"; EOF exit; } sub DeleteItems{ @moves = split(/\\0/,$in{'moveto'}); foreach $i (@moves){ $m{$i} = 1; } open(DB,"$htmlpath/$in{'database'}"); ($flock)&&(flock(DB,2)); open(TMP,">$htmlpath/$in{'database'}.tmp"); ($flock)&&(flock(TMP,2)); while($line = ){ $count++; (@fields) = split(/\~/,$line); print TMP $line unless ($m{$fields[0]}); } close DB; close TMP; rename("$htmlpath/$in{'database'}.tmp","$htmlpath/$in{'database'}"); ($flock)&&(flock(TMP,8)); ($flock)&&(flock(DB,8)); #delete bodies foreach $i (@moves){ unlink("$htmlpath/newsdir/$in{'database'}$i.htm"); } print <<"EOF"; EOF exit; } sub SaveChanges{ if($in{'file'}){ $rn = &GetRealName($in{'file'}); $trn = $in{'database'}; $trn =~ s/\%/\_/g; &SaveFile($in{'file'},"$htmlpath/news_upload/$trn.$rn"); $in{'uploaded'} = "$trn.$rn"; } $id = $in{'id'}; foreach $i (keys(%in)){ $in{$i} =~ s/<//g; } $in{'datemodified'} = time; &GetOutVars; open(DB,"$htmlpath/$in{'database'}"); open(TMP,">$htmlpath/$in{'database'}.tmp"); ($flock)&&(flock(TMP,2)); while($line = ){ $count++; (@fields) = split(/\~/,$line); ($fields[0] eq $id)?(print TMP "$newentry\n"):(print TMP $line); } close DB; close TMP; ($flock)&&(flock(TMP,8)); @fi = stat("$htmlpath/$in{'database'}.tmp"); ##only write over the file if greater than 1 byte in size. rename("$htmlpath/$in{'database'}.tmp","$htmlpath/$in{'database'}") unless (($fi[7] < 1)&&($count > 1)); print <<"EOF"; EOF exit; } sub ShowEdit{ open(DB,"$htmlpath/$in{'database'}"); $found = 0; while(){ chop; (@fields) = split(/\~/,$_); ($fields[0] eq $in{'id'})&&($found = 1)&&(last); } if($found){ foreach $i (0..$#fields){ $fields[$i] = &reverseHTML($fields[$i]); $fields[$i] =~ s/\\n/\n/g; } foreach $i (0..$#fields){ $fields[$i] =~ s/([<>"])/'&#'.ord($1).';'/ge; } $in{'id'} = $fields[0]; $in{'title'} = $fields[1]; ($in{'month'},$in{'day'},$in{'year'}) = split(/[\.\-\/]/,$fields[2]); $in{'description'} = $fields[3]; $in{'description'} =~ s/<(\/*textarea)>/<$1>/gi; $in{'location'} = $fields[4]; $in{'hidedate'} = $fields[6]; $in{'hidelocation'} = $fields[7]; $in{'dateentered'} = $fields[8]; $in{'datemodified'} = $fields[9]; $in{'uploaded'} = $fields[10]; $display = $fields[19]; if($display eq 'I'){ $in{'cf'} = "
    Current File: $in{'uploaded'}"; } $in{"d$display"} = 'checked'; $in{'noparsehtml'} = $fields[22]; $authorization = $fields[21]; $in{"a$authorization"} = 'checked'; $bodyname = "$in{'database'}$fields[0].htm"; $in{'title1'} = "Edit News Item"; $in{'sbutton'} = ' Save Changes '; $in{'command'} = 'savechanges'; (!$display)&&($in{'dS'} = 'checked'); (!$authorization)&&($in{'aY'} = 'checked'); ##get news html file open(HTML,"$htmlpath/newsdir/$bodyname"); while(){ $in{'body'} .= $_; } $in{'body'} =~ s/<(\/*textarea)>/<$1>/gi; ($display eq "U")&&($in{'url'} = $in{'body'})&&($in{'body'} = ''); (!$in{'url'})&&($in{'url'} = 'http://'); close HTML; &PageOut("$htmlpath/t_add_news.htm"); } else{ print "Error. No record found."; } exit; } sub Add{ if($in{'file'}){ $rn = &GetRealName($in{'file'}); $trn = $in{'database'}; $trn =~ s/\%/\_/g; &SaveFile($in{'file'},"$htmlpath/news_upload/$trn.$rn"); $in{'uploaded'} = "$trn.$rn"; } (-e "$cgipath/$in{'database'}.style.cgi")?(require "$cgipath/$in{'database'}.style.cgi"):(require "$cgipath/styles.cgi"); ##get highest ID in DB for unique ID. open(DB,"$htmlpath/$in{'database'}"); $id = 0; while(){ ($idt,@rest) = split("~",$_); ($idt > $id)&&($id = $idt); } close DB; $id++; &GetOutVars; open(DB,"$htmlpath/$in{'database'}"); open(DBT,">$htmlpath/$in{'database'}.tmp"); ($flock)&&(flock(DBT,2)); print DBT "$newentry\n"; while(){ print DBT $_; } close DB; close DBT; ($flock)&&(flock(DBT,8)); @s = stat("$htmlpath/$in{'database'}.tmp"); ($s[7]>0)&&(rename("$htmlpath/$in{'database'}.tmp","$htmlpath/$in{'database'}")); print <<"EOF"; EOF exit; } sub GetOutVars{ $display = $in{'display'}; $url = $in{'url'}; if($display eq "U"){ $body = $url; } else{ $body = $in{'body'}; } &GetBodyName; $body =~ s/\r\n/\n/g; open(HTML,">$htmlpath/newsdir/$bodyname"); ($flock)&&(flock(HTML,2)); print HTML $body; close HTML; ($flock)&&(flock(HTML,8)); #escape all variables foreach $i (keys (%in)){ $in{$i} = &htmlspecialchars($in{$i}); } $title = $in{'title'}; $date = "$in{'month'}-$in{'day'}-$in{'year'}"; $description = $in{'description'}; $location = $in{'location'}; $hidedate = $in{'hidedate'}; $hidelocation = $in{'hidelocation'}; ($in{'dateentered'})?($dateentered = $in{'dateentered'}):($dateentered = time); ($in{'datemodified'})?($datemodified = $in{'datemodified'}):($datemodified = time); $uploaded = $in{'uploaded'}; $authorization = $in{'authorization'}; #unescape all variables foreach $i (keys (%in)){ $in{$i} = &reverseHTML($in{$i}); } $newentry = "$id~$title~$date~$description~$location~$bodyname~$hidedate~$hidelocation~$dateentered~$datemodified~$uploaded~$t3~$p1~$p2~$p3~$e1~$e2~$e3~$header~$display~$MsgIcon~$authorization~$in{'noparsehtml'}"; $newentry =~ s/\r\n/\\n/g; $newentry =~ s/\n/\\n/g; } sub GetBodyName{ $bodyname = "$in{'database'}$id.htm"; } sub ShowAdd{ $in{'title1'} = "Add News Item"; $date = &ctime(time); ($in{'month'},$in{'day'},$in{'year'}) = split(/[\.\-\/]/,$date); $in{'sbutton'} = ' Add News '; $in{'command'} = 'add'; $in{'dP'} = 'checked'; $in{'aY'} = 'checked'; $in{'url'} = 'http://'; $in{'htmlNO'} = 'checked'; &PageOut("$htmlpath/t_add_news.htm"); exit; } sub Reorder{ ##get total count open(DB,"$htmlpath/$in{'database'}"); while($line=){ $tc++; @f=split("~",$line); (!$in{'order_'.$tc})&&($in{'order_'.$tc} = $tc); ($in{'order_'.$tc} > $tc)&&($pre='2'); ($in{'order_'.$tc} < $tc)&&($pre='0'); ($in{'order_'.$tc} == $tc)&&($pre='1'); $o = sprintf("%.3d",$in{'order_'.$tc}); $l{$o.$pre.'-'.$f[0]} = $line; } close DB; open(OUT,">$htmlpath/~$in{'database'}"); ($flock)&&(flock(OUT,2)); for $i (sort keys %l){ print OUT $l{$i}; } close OUT; ($flock)&&(flock(OUT,8)); $tc=0; $in{'w'} = 'lowform'; @s = stat("$htmlpath/~$in{'database'}"); ($s[7]>0)&&(rename("$htmlpath/~$in{'database'}","$htmlpath/$in{'database'}")); &ShowList; } sub ShowLinks{ open(DB,"$htmlpath/$in{'database'}")||die print "$htmlpath/$in{'database'}
    "; while($line=){ chop $line; (@fields) = split(/\~/,$line); $in{'titles'} .= qq||; } &GetDatabases; $in{'ssiurl'} = $in{'cgiurl'}; $in{'ssiurl'} =~ s/http:\/\/.*?\//\//i; &PageOut("$htmlpath/link_wizard.htm"); exit; } sub GetRealName{ local($filename) = @_; if ($filename =~ /\//) { @array = split(/\//, $filename); $real_name = pop(@array); } elsif ($filename =~ /\\/) { @array = split(/\\/, $filename); $real_name = pop(@array); } else { $real_name = "$filename"; } return $real_name; } sub SaveFile { local($filename,$outfile)=@_; if (!open(OUTFILE, ">$outfile")) { &PError("Error. There was an error saving your attachment."); } binmode(OUTFILE); while ($bytesread = read($filename,$buffer,1024)) { $totalbytes += $bytesread; print OUTFILE $buffer; } close($filename); close(OUTFILE); } sub SaveVars{ foreach $i (keys %in){ $tmp{$i} = $in{$i}; } } sub GetVars{ foreach $i (keys %tmp){ $in{$i} = $tmp{$i}; } } sub Setup{ $cgipath = `pwd`;chomp $cgipath; $cgiurl = "$ENV{'HTTP_HOST'}/$ENV{'SCRIPT_NAME'}"; $cgiurl =~ s/\/csNews\.cgi//i; $cgiurl =~ s/\/\//\//g; $cgiurl = "http://".$cgiurl; $setup = "\$cgiurl = '$cgiurl'; \$cgipath = '$cgipath'; \$username='demo'; \$password='demo'; 1; "; print <<"EOF"; csNews Setup csNews Setup
    Current contents of your setup.cgi file
    Please verify the information and modify if needed:

    Definitions:

    \$cgiurl = Full URL to the csNews directory
    \$cgipath = Full PATH to the csNews directory.
    \$username = username to enter management screens
    \$password = password to enter management screens

    Normal Installation Instructions:

    In most cases, the script is already configured. Change the \$username and \$password variables to your liking and click 'Save'. If the setup portion of the script cannot find your site variables automatically, you will have to enter those in the above text area. If you click 'save' and you come back to this setup page, then your server doesn't have write access to your directories. You can solve this problem by chmod'ing the csNews directory to 777.

    WinNT installations:
    The script has been tested and works on an NT IIS webserver. You will, however, have to manually enter the cgipath and rootpath variables. For example, your rootpath might look something like 'c:/inetpub/wwwroot' (Note: the back-slashes '\' normally associated with Window's file paths has been changed to a forward-slash '/')

    CGI-BIN Installation Instructions:

    The preferred method is to install csNews in a directory outside your cgi-bin directory, however, if your hosting service will not let you run scripts outside your cgi-bin directory, then follow these procedures:

    Copy all the *.cgi files to a directory in your cgi-bin directory, making sure they are chmod'd to 755. For example, you could create a /cgi-bin/csNews/ directory and place csNews.cgi, libs.cgi, styles.cgi and setup.cgi (if this file exists) in this direcory.

    Create a directory outside your cgi-bin directory and copy all the remaining files and subdirectories there. For example, you could create a /cgi-script/csNews and place the files there.

    Edit the above variables (or manually edit setup.cgi) to the following:
    \$cgiurl = URL to the csNews directory INSIDE your cgi-bin directory (where the script is installed).
    \$cgipath = FULL PATH to the csNews directory INSIDE your cgi-bin directory (where the script is installed).
    ADD THE FOLLOWING VARIABLES TO THE ABOVE CONFIGURATION OR MANUALLY EDIT setup.cgi:
    \$htmlurl =  FULL URL to the csNews directory OUTSIDE your cgi-bin directory (where the rem
    aining files where installed)
    \$htmlpath = FULL PATH to the csNews directory OUTSIDE your cgi-bin directory (where the
    remaining files where installed)
    For Example, your new setup.cgi file might look something like this:
    \$cgiurl='http://www.cgiscript.net/cgi-bin/csNews';
    \$cgipath='/www/vhosts/cgiscript.net/cgi-bin/csNews';
    \$htmlurl='http://www.cgiscript.net/cgi-script/csNews';
    \$htmlpath='/www/vhosts/cgiscript.net/cgi-script/csNews';
    \$username='myusername';
    \$password=',mypassword';
    1;

    (note: the '1' at the end is to prevent errors from perl if \$password was left empty)

    EOF exit; } sub SaveSetup{ (-e "$basepath/setup.cgi")&&(&PError("Error. Access Denied")); $in{'setup'} =~ s/\r*\n/\n/g; open(SETUP,">./setup.cgi"); ($flock)&&(flock(SETUP,2)); print SETUP $in{'setup'}; print SETUP "\n"; close SETUP; ($flock)&&(flock(SETUP,8)); print <<"EOF"; EOF exit; } sub ShowListPub{ &GetRange; (!$in{'o'})&&($in{'o'} = 'n'); (!$in{'od'})&&($in{'od'} = 'a'); ##override to create all encompassing db if($in{'database'} eq 'all'){ &CreateFullDB; } elsif($in{'database'} =~ /\%5c0/){ &CreateFullDB; } else{ open(DB,"$htmlpath/$in{'database'}"); while(){ chomp; push(@tmp,$_); } close DB; } foreach $line (@tmp){ #chop $line; $count ++; (@fields) = split(/\~/,$line); next if ($fields[21] eq 'N'); #order number $count = sprintf("%.6d",$count); ($in{'o'} eq 'n')&&($sort{$count} = $line); #order date if($in{'o'} eq 'd'){ $fields[2] = &reverseHTML($fields[2]); ($m,$d,$y) = split(/[\-\/\.]/,$fields[2]); $m = sprintf("%.2d",$m); $d = sprintf("%.2d",$d); $y = sprintf("%.4d",$y); $myd = "$y$m$d-$fields[0]-$fields[23]"; $sort{$myd} = $line; } #order description if($in{'o'} eq 'a'){ $fields[1] = &reverseHTML($fields[1]); $myt = "$fields[1]-$fields[0]-$fields[23]"; $myt =~ tr/A-Z/a-z/; $sort{$myt} = $line; } } if($in{'od'} eq 'a'){ foreach $line (sort {$a cmp $b} keys(%sort)){ (&CheckRange)&&(next); push(@vals,$sort{$line}); } } else{ foreach $line (sort {$b cmp $a} keys(%sort)){ (&CheckRange)&&(next); push(@vals,$sort{$line}); } } &ShowListPub2; } sub GetRange{ if(($in{'range'} eq 's')&&($in{'o'} eq 'd')){ ($m,$d,$y) = split(/[\-\/\.]/,$in{'rangestart'}); $m = sprintf("%.2d",$m); $d = sprintf("%.2d",$d); $y = sprintf("%.4d",$y); $in{'rangestart'} = "$y$m$d"; ($m,$d,$y) = split(/[\-\/\.]/,$in{'rangeend'}); $m = sprintf("%.2d",$m); $d = sprintf("%.2d",$d); $y = sprintf("%.4d",$y); $in{'rangeend'} = "$y$m$d"; } } sub CheckRange{ (($in{'range'} eq '')||($in{'range'} eq 'a'))&&(return 0); if(($in{'range'} eq 's')&&($in{'o'} eq 'n')){ if($in{'pt'} ne 'c'){ $mycount++; (($mycount >= $in{'rangestart'})&&($mycount <= $in{'rangeend'}))?(return 0):(return 1); } else{ @f = split("~",$sort{$line}); $mycount{$f[23]}++; (($mycount{$f[23]} >= $in{'rangestart'})&&($mycount{$f[23]} <= $in{'rangeend'}))?(return 0):(return 1); } } if(($in{'range'} eq 's')&&($in{'o'} eq 'a')){ $x = substr($line,0,length($in{'rangestart'})); $y = substr($line,0,length($in{'rangeend'})); (($x ge $in{'rangestart'})&&($y le $in{'rangeend'}))?(return 0):(return 1); } if(($in{'range'} eq 's')&&($in{'o'} eq 'd')){ ($x,$i) = split(/[\-\/\.]/,$line); (($x ge $in{'rangestart'})&&($x le $in{'rangeend'}))?(return 0):(return 1); } } sub ShowListPub2{ srand(time|$$); $rand = int(rand(1000)); $tid=$in{'id'}; #&GetDatabases; (-e "$cgipath/$in{'database'}.style.cgi")?(require "$cgipath/$in{'database'}.style.cgi"):(require "$cgipath/styles.cgi"); (-e "$htmlpath/$in{'database'}.evenrow")?($evenrow = "$htmlpath/$in{'database'}.evenrow"):($evenrow = "$htmlpath/t_news_line_even.htm"); (-e "$htmlpath/$in{'database'}.oddrow")?($oddrow = "$htmlpath/$in{'database'}.oddrow"):($oddrow = "$htmlpath/t_news_line_odd.htm"); (-e "$htmlpath/$in{'database'}.list")?($list = "$htmlpath/$in{'database'}.list"):($list = "$htmlpath/t_news_body.htm"); $jsfn = $in{'database'}; $jsfn =~ s/\W//g; $jsfn .= $rand; $flip=1; #get even row open(NEWS,"$evenrow"); while(){ $tmpeven .= $_ } close NEWS; #get odd row open(NEWS,"$oddrow"); while(){ $tmpodd .= $_ } close NEWS; foreach $line (@vals){ $count ++; (@fields) = split(/\~/,$line); ## if other type of database... give it to them if($fields[23]){ $in{'database'} = $fields[23]; } next if ($fields[21] eq 'N'); foreach $i (0..$#fields){ $fields[$i] = &reverseHTML($fields[$i]); ($fields[22] eq 'checked')&&($fields[$i] =~ s/([<>"])/'&#'.ord($1).';'/ge); $fields[$i] =~ s/\\n/\n/g; } $in{'viewlink'}=''; ##create the link ($in{'link'})&&($fields[19] = $in{'link'}); ($fields[19] eq "S")&&($viewlink = ""); if($fields[19] eq "P"){ $in{'database'} =~ s/\%27/\\'/g; $viewlink = ""; $in{'database'} =~ s/\\'/\%27/g; } ($fields[19] eq "I")&&($viewlink = ""); (!$viewlink)&&($viewlink = ""); ($fields[19] eq "N")&&($viewlink = ""); if($fields[19] eq "U"){ open(HTML,"$htmlpath/newsdir/$in{'database'}$fields[0].htm"); $url = ; close HTML; $viewlink = ""; } $flip = $flip * -1; if($in{'sc'} eq 'y'){ $cat = $in{'database'}; $cat =~ s/%(..)/pack("c",hex($1))/ge; $cat =~ s/\.db//g; $cat = "$cat » "; $in{'title'} = "$viewlink$cat$fields[1]"; } else{ $in{'title'} = "$viewlink$fields[1]"; } ($fields[6] ne 'checked')?($in{'date'} = $fields[2]):($in{'date'} = ''); ($fields[7] ne 'checked')?($in{'location'} = $fields[4]):($in{'location'}=''); $in{'description'} = $fields[3]; if($df ne 'US'){ my($m,$d,$y) = $in{'date'} =~ /(\d\d)-(\d\d)-(\d\d\d\d)/; $in{'date'} = "$d-$m-$y"; } ($in{'sd'} eq 'n')&&($in{'description'} = ''); ($in{'st'} eq 'n')&&($in{'date'} = ''); ($in{'st'} eq 'n')&&($in{'location'} = ''); #limit description ($in{'dlimit'})&&($in{'description'} = substr($in{'description'},0,$in{'dlimit'}).'...'); #add bodies to description if($in{'nb'} eq 'y'){ $body=''; $in{'title'} = "$cat$fields[1]"; open(HTML,"$htmlpath/newsdir/$in{'database'}$fields[0].htm"); while(){ $body .= $_; } close HTML; $in{'description'} = "$in{'description'}

    $body

    "; } ($flip == -1)?($newsline = $tmpeven):($newsline = $tmpodd); ($in{'op'} eq 'r')&&($br='
    '); ($in{'date'})&&($in{'date'} = "$br$in{'date'}"); ($in{'description'})&&($in{'description'} = "$br$in{'description'}"); ($in{'date'})&&($in{'location'})&&($in{'location'} = " - $in{'location'}"); (!$in{'date'})&&($in{'location'})&&($in{'location'} = "$br$in{'location'}"); $newsline =~ s/in\((\w+)\)/$in{$1}/g; $in{'newslines'} .= $newsline; ($in{'op'} eq 'r')&&($raw .= "

    $in{'title'}$in{'date'}$in{'location'}$in{'description'}

    "); } ($in{'locationbar'} eq 'checked')?($in{'locationbar'} = 'yes'):($in{'locationbar'} = 'no'); ($in{'directories'} eq 'checked')?($in{'directories'} = 'yes'):($in{'directories'} = 'no'); ($in{'statusbar'} eq 'checked')?($in{'status'} = 'yes'):($in{'status'} = 'no'); ($in{'menubar'} eq 'checked')?($in{'menubar'} = 'yes'):($in{'menubar'} = 'no'); ($in{'toolbar'} eq 'checked')?($in{'toolbar'} = 'yes'):($in{'toolbar'} = 'no'); ($in{'resizable'} eq 'checked')?($in{'resizable'} = 'yes'):($in{'resizable'} = 'no'); ($in{'scrollbar'} eq 'checked')?($in{'scrollbar'} = 'yes'):($in{'scrollbar'} = 'no'); (!$in{'ptop'})&&($in{'ptop'} = '0'); (!$in{'pleft'})&&($in{'pleft'} = '0'); $newsjs = qq~ ~; if($in{'op'} eq 'r'){ $raw .= $newsjs; if($in{'ct'} eq 'j'){ $raw =~ s/\"/\\"/g; $raw =~ s/script/scr\"\+\"ipt/gsi; @mylines = split(/\r*\n/,$raw); foreach $q (@mylines){ print qq| document.write("$q"); |; } } else{ print $raw; } } else{ $in{'newslines'} .= $newsjs; ($in{'ct'} eq 'j')?(&PageOutJS("$list")):(&PageOut("$list")); } exit; } sub ShowUploadEditor{ &PageOut("$htmlpath/t_upload_imageEditor.htm"); exit; } sub UploadEditor{ $rn = &GetRealName($in{'file'}); &CheckExt($rn); $trn = $in{'database'}; $trn =~ s/\%/\_/g; &SaveFile($in{'file'},"$htmlpath/image_upload/$trn.$rn"); (!$in{'align'})&&($in{'align'}='left'); (!$in{'border'})&&($in{'border'}='0'); (!$in{'hspace'})&&($in{'hspace'}='0'); (!$in{'vspace'})&&($in{'vspace'}='0'); print <<"EOF"; EOF exit; } sub ShowEditor{ &PageOut("$htmlpath/editor.cgi"); exit; } sub CheckExt{ local($rn) = @_; #check file extension. $in{'fta'} = "gif,jpg"; if($in{'fta'}){ ($ext) = $rn =~ /.*\.(\w*)$/; (@fx) = split(",",$in{'fta'}); foreach $i (@fx){ ($i =~ /$ext/i)&&($found=1); } (!$found)&&(&PError("Error. Only $in{'fta'} types are permitted")); } if($in{'ftr'}){ ($ext) = $rn =~ /.*\.(\w*)$/; (@fx) = split(",",$in{'ftr'}); foreach $i (@fx){ ($i !~ /$ext/i)&&($found=1); } (!$found)&&(&PError("Error. $in{'ftr'} types are NOT permitted")); } } sub CopyFile{ local($old,$new)=@_; return if ((! -e "$old")||(-d "$old")); open(DB,"$old"); open(DBT,">$new"); ($flock)&&(flock(DBT,2)); while(){ print DBT; } close DB; close DBT; ($flock)&&(flock(DBT,8)); } sub PageOutJS{ local($file) = @_; open(OUT,"$file")||print "$!: $file
    "; while(){ $o = $_; $o =~ s/in\((\w+)\)/$in{$1}/g; $o =~ s/\"/\\"/g; $o =~ s/\\n/\\\\n/g; #$o =~ s/script/scr\"\+\"ipt/gsi; $o =~ s/(scr)(ipt)/$1\"\+\"$2/gsi; @mylines = split(/\r*\n/,$o); foreach $q (@mylines){ print qq|document.write("$q\\n");\n|; } } close OUT; } 1; sub CreateFullDB{ if($in{'database'} eq 'all'){ opendir(IMG,"$htmlpath/"); @dbfiles = grep(/db$/,readdir(IMG)); closedir(IMG); opendir(IMG,"$htmlpath/"); @dbfilesb = grep(/archive$/,readdir(IMG)); closedir(IMG); push(@dbfiles,@dbfilesb); } else{ @dbfiles = split(/\%5c0/,$in{'database'}); $in{'database'} = $dbfiles[0]; } foreach $x (@dbfiles){ open(DB,"$htmlpath/$x"); while(){ chomp; @f = split("~",$_); $f[9] = sprintf("%.20d",$f[9]); if($in{'gc'} eq 'y'){ $tmp = $x; $tmp =~ s/\W//g; $tmp =~ tr/a-z/A-Z/; $mydb{"$tmp$f[9]\t$f[0]\t$x"} = $_; } else{ $mydb{"$f[9]\t$f[0]\t$x"} = $_; } } close DB; } foreach $x (sort {$b cmp $a} keys(%mydb)){ if($in{'gc'} eq 'y'){ ($dm,$id,$db) = split("\t",$x); } else{ ($dm,$id,$db) = split("\t",$x); } push(@tmp,"$mydb{$x}~$db"); } close TMP; } sub GetNlinks{ ((!$in{'page'})||($in{'lpage'} < 0))&&($in{'lpage'} = 1); $nstart = ($in{'lpage'}+10)-10; $nend = $nstart + 10; #$sstring =~ s/([^\w&=])/'%'.sprintf("%.2x",ord($1))/ge; my $db = $in{'database'}; $db =~ s/([^\w&=])/'%'.sprintf("%.2x",ord($1))/ge; $sstring = "command=manage&database=$db"; $npages = int($count/$epp); (($count/$epp) > $npages)&&($npages++); #print "S: $nstart E: $nend Total # pages: $npages $count/$epp
    "; for $i (1..$npages){ if(($i > $nstart) & ($i <= $nend)){ ($i eq $in{'page'})?($link .= " $i "):($link .= " $i "); } } $nend; $pend = $nend - 20; ($npages > $nend)&&($link .= " [Next] "); ($nend > 11)&&($link = " [Prev] " . $link); (!$link)&&($link='0'); $link .= ""; $link = "Result Pages:" . $link; $in{'link'} = $link; } sub htmlspecialchars{ my($buffer) =@_; $buffer =~ s/\&/\&/g; $buffer =~ s/\/\>/g; $buffer =~ s/\"/\"/g; return $buffer; } sub reverseHTML{ my($text) = @_; $text =~ s/&#(\d+);/pack("c",$1)/ge; $text =~ s/\&/\&/g; $text =~ s/\</\/g; $text =~ s/\"/\"/g; return $text; }