--- loncom/publisher/lonpublisher.pm 2001/08/17 21:25:36 1.41
+++ loncom/publisher/lonpublisher.pm 2001/10/16 18:46:10 1.49
@@ -11,7 +11,8 @@
# 04/16/2001 Scott Harrison
# 05/03,05/05,05/07 Gerd Kortemeyer
# 05/28/2001 Scott Harrison
-# 06/23,08/07,08/11,8/13,8/17 Gerd Kortemeyer
+# 06/23,08/07,08/11,8/13,8/17,8/18,8/24,9/26 Gerd Kortemeyer
+# 10/3,10/8 Scott Harrison
package Apache::lonpublisher;
@@ -154,7 +155,6 @@ sub urlfixup {
}
sub publish {
-
my ($source,$target,$style)=@_;
my $logfile;
my $scrout='';
@@ -259,7 +259,7 @@ sub publish {
}
$allow{$newurl}=1;
}
- } ('src','href');
+ } ('src','href','background');
if ($tag eq 'applet') {
my $codebase='';
@@ -317,9 +317,18 @@ sub publish {
}
# ------------------------------------------------------------ Construct Allows
unless ($style eq 'rat') {
+ $scrout.='
Dependencies
';
my $allowstr="\n";
map {
$allowstr.=''."\n";
+ $scrout.='
';
+ unless ($_=~/\*/) {
+ $scrout.='';
+ }
+ $scrout.=''.$_.'';
+ unless ($_=~/\*/) {
+ $scrout.='';
+ }
} keys %allow;
$outstring=~s/(\<\/[^\>]+\>\s*)$/$allowstr$1/s;
}
@@ -352,6 +361,8 @@ sub publish {
%metadatakeys=();
my %oldparmstores=();
+
+ $scrout.='Metadata Information
';
# ------------------------------------------------ First, check out environment
unless (-e $source.'.meta') {
@@ -402,7 +413,11 @@ sub publish {
# -------------------------------------------------- Parse content for metadata
if ($style eq 'ssi') {
+ my $oldenv=$ENV{'request.uri'};
+
+ $ENV{'request.uri'}=$target;
$allmeta=Apache::lonxml::xmlparse('meta',$content);
+ $ENV{'request.uri'}=$oldenv;
&metaeval($allmeta);
}
@@ -465,12 +480,29 @@ sub publish {
$textonly=~s/[^a-z\s]//g;
my %keywords=();
- map {
- unless ($nokey{$_}) {
- $keywords{$_}=1;
- }
- } ($textonly=~m/(\w+)/g);
+ my $j=0;
+ my $word;
+ for (my $i=0; $i\n";
$colcount=0;
}
- $colcount++;
+ else {
+ $colcount++;
+ }
} sort keys %keywords;
$keywordout.='
';
}
-
$scrout.=$keywordout;
$scrout.=&textfield('Additional Keywords','addkey','');
@@ -518,6 +551,13 @@ sub publish {
$scrout.=&textfield('Publisher/Owner','owner',
$metadatafields{'owner'});
+# --------------------------------------------------- Correct copyright for rat
+ if ($style eq 'rat') {
+ if ($metadatafields{'copyright'} eq 'public') {
+ delete $metadatafields{'copyright'};
+ }
+ delete $cprtag{'public'};
+ }
$scrout.=&selectbox('Copyright/Distribution','copyright',
$metadatafields{'copyright'},%cprtag);
@@ -833,6 +873,20 @@ sub handler {
return OK;
}
+# Get query string for limited number of parameters
+
+ map {
+ my ($name, $value) = split(/=/,$_);
+ $value =~ tr/+/ /;
+ $value =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;
+ if ($name eq 'filename') {
+ unless ($ENV{'form.'.$name}) {
+ $ENV{'form.'.$name}=$value;
+ }
+ }
+ } (split(/&/,$ENV{'QUERY_STRING'}));
+
+
# -------------------------------------------------------------- Check filename
my $fn=$ENV{'form.filename'};
@@ -864,7 +918,8 @@ sub handler {
return HTTP_NOT_ACCEPTABLE;
}
- $fn=~s/^http\:\/\/[^\/]+\/\~(\w+)/\/home\/$1\/public_html/;
+ $fn=~s/^http\:\/\/[^\/]+//;
+ $fn=~s/^\/\~(\w+)/\/home\/$1\/public_html/;
my $targetdir='';
$docroot=$r->dir_config('lonDocRoot');