';
+ my $switchserver = &check_switchserver($dom,$confname);
foreach my $img (@{$images}) {
$itemcount ++;
$css_class = $itemcount%2?' class="LC_odd_row"':'';
@@ -529,8 +533,8 @@ sub display_color_options {
$imgfile = $defaults->{$img};
}
if ($imgfile) {
- my $showfile;
- if ($imgfile =~ m-^(/uploaded/\Q$dom\E/\Q$configuname\E/portfolio.*)/([^/]+)$-) {
+ my ($showfile,$fullsize);
+ if ($imgfile =~ m-^(/res/\Q$dom\E/\Q$confname\E/\Q$img\E)/([^/]+)$-) {
my $urldir = $1;
my $filename = $2;
my @info = &Apache::lonnet::stat_file($designs->{$img});
@@ -554,18 +558,23 @@ sub display_color_options {
my $input = "/home/httpd/html".$imgfile;
my $output = '/home/httpd/html/'.$imgdir.'/tn-'.$filename;
if (!-e $output) {
- system("convert -sample 200x50 $input $output");
+ my ($width,$height) = &thumb_dimensions();
+ my $size = $width.'x'.$height;
+ system("convert -sample $size $input $output");
}
$showfile = '/'.$imgdir.'/tn-'.$filename;
}
}
if ($showfile) {
+ $showfile = &Apache::loncommon::lonhttpdurl($showfile);
+ $fullsize = &Apache::loncommon::lonhttpdurl($imgfile);
$datatable.= '
';
if (!$is_custom->{$img}) {
$datatable .= &mt('Default in use:').' ';
}
- $datatable.= '
';
+ $datatable.= '';
if ($is_custom->{$img}) {
$datatable.='
';
}
$itemcount ++;
$css_class = $itemcount%2?' class="LC_odd_row"':'';
@@ -894,14 +908,14 @@ sub usertype_update_row {
}
sub modify_login {
- my ($r,$dom,%domconfig) = @_;
+ my ($r,$dom,$confname,%domconfig) = @_;
my ($resulttext,$errors,$colchgtext,%changes,%colchanges);
my %title = ( coursecatalog => 'Display course catalog',
adminmail => 'Display administrator E-mail address');
my @offon = ('off','on');
my %loginhash;
- ($errors,%colchanges) = &modify_colors($r,$dom,['login'],\%domconfig,
- \%loginhash);
+ ($errors,%colchanges) = &modify_colors($r,$dom,$confname,['login'],
+ \%domconfig,\%loginhash);
$loginhash{login}{coursecatalog} = $env{'form.coursecatalog'};
$loginhash{login}{adminmail} = $env{'form.adminmail'};
if (ref($colchanges{'login'}) eq 'HASH') {
@@ -940,7 +954,7 @@ sub modify_login {
$resulttext = &mt('An error occurred: [_1]',$putresult);
}
if ($errors) {
- $resulttext .= &mt('The following errors occurred: ').'
'.
+ $resulttext .= ' '.&mt('The following errors occurred: ').'
'.
$errors.'
';
}
return $resulttext;
@@ -964,10 +978,10 @@ sub color_font_choices {
}
sub modify_rolecolors {
- my ($r,$dom,$roles,%domconfig) = @_;
+ my ($r,$dom,$confname,$roles,%domconfig) = @_;
my ($resulttext,%rolehash);
$rolehash{'rolecolors'} = {};
- my ($errors,%changes) = &modify_colors($r,$dom,$roles,
+ my ($errors,%changes) = &modify_colors($r,$dom,$confname,$roles,
$domconfig{'rolecolors'},$rolehash{'rolecolors'});
my $putresult = &Apache::lonnet::put_dom('configuration',\%rolehash,
$dom);
@@ -989,12 +1003,11 @@ sub modify_rolecolors {
}
sub modify_colors {
- my ($r,$dom,$roles,$domconfig,$confhash) = @_;
+ my ($r,$dom,$confname,$roles,$domconfig,$confhash) = @_;
my %changes;
my @bgs = ('pgbg','mainbg','sidebg');
my @links = ('link','alink','vlink');
my @images;
- my $configuname = $dom.'-domainconfig';
my $servadm = $r->dir_config('lonAdmEMail');
my $errors;
foreach my $role (@{$roles}) {
@@ -1007,38 +1020,61 @@ sub modify_colors {
foreach my $item (@bgs,@links) {
$confhash->{$role}{$item} = $env{'form.'.$role.'_'.$item};
}
+ my ($configuserok,$author_ok,$switchserver,%currroles);
+ my $uhome = &Apache::lonnet::homeserver($confname,$dom,1);
+ ($configuserok,%currroles) = &check_configuser($uhome,$dom,
+ $confname,$servadm);
+ if ($configuserok eq 'ok') {
+ $switchserver = &check_switchserver($dom,$confname);
+ if ($switchserver eq '') {
+ $author_ok = &check_authorstatus($dom,$confname,%currroles);
+ }
+ }
+ my ($width,$height) = &thumb_dimensions();
foreach my $img (@images) {
if ($env{'form.'.$role.'_'.$img.'.filename'} ne '') {
- my $configuserok;
- if (&Apache::lonnet::homeserver($configuname,$dom) eq 'no_host') {
- srand( time() ^ ($$ + ($$ << 15)) ); # Seed rand.
- my $configpass = &LONCAPA::Enrollment::create_password();
- $configuserok = &Apache::lonnet::modifyuser($dom,$configuname,'','internal',$configpass,'','','','','',undef,$servadm);
- } else {
- $configuserok = 'ok';
- }
+ my $error;
if ($configuserok eq 'ok') {
- my $result =
- &Apache::lonnet::userfileupload($role.'_'.$img,'',
- 'portfolio/'.$img,'','','',$configuname,$dom,'200','50');
- if ($result =~ m|(^/uploaded/.+)/([^/]+)$|) {
- my $urldir = $1;
- my $filename = $2;
- my $allowresult = &Apache::lonnet::make_public_indefinitely($result);
- if ($allowresult eq 'ok') {
- &Apache::lonnet::make_public_indefinitely($urldir.'/tn-'.$filename);
- $confhash->{$role}{$img} = $result;
- $changes{$role}{$img} = 1;
+ if ($switchserver) {
+ $error = &mt("Upload of image [_1] for $role page(s) is not permitted to this server: [_2]",$img,$switchserver);
+ } else {
+ if ($author_ok eq 'ok') {
+ my ($result,$logourl) =
+ &publishlogo($r,'upload',$role.'_'.$img,
+ $dom,$confname,$img,$width,$height);
+ if ($result eq 'ok') {
+ $confhash->{$role}{$img} = $logourl;
+ $changes{$role}{$img} = 1;
+ } else {
+ $error = &mt("Upload of image [_1] for $role page(s) failed because an error occurred publshing the file in RES space. Error was: [_2].",$img,$result);
+ }
+ } else {
+ $error = &mt("Upload of image [_1] for $role page(s) failed because an author role could not be assigned to a Domain Configuation user ([_2]) in domain: [_3]. Error was: [_4].",$img,$confname,$dom,$author_ok);
}
}
} else {
- my $error = &mt("Upload of image [_1] for $role page(s) failed because a Domain Configuation user ([_2]) could not be created in domain: [_3]. Error was: [_4].",$img,$configuname,$dom,$configuserok);
+ $error = &mt("Upload of image [_1] for $role page(s) failed because a Domain Configuation user ([_2]) could not be created in domain: [_3]. Error was: [_4].",$img,$confname,$dom,$configuserok);
+ }
+ if ($error) {
&Apache::lonnet::logthis($error);
$errors .= '
'.$error.'
';
}
} elsif ($domconfig->{$role}{$img} ne '') {
- if ($domconfig->{$role}{$img} !~ m|^/uploaded/\Q$dom\E/\Q$dom\E\-domainconfig/portfolio/\$img/.+|) {
- #FIXME copy file to target directory
+ if ($domconfig->{$role}{$img} !~ m-^(/res/\Q$dom\E/\Q$confname\E/\Q$img\E)/([^/]+)$-) {
+ my $error;
+ if ($configuserok eq 'ok') {
+# is confname an author?
+ if ($switchserver eq '') {
+ if ($author_ok eq 'ok') {
+ my ($result,$logourl) =
+ &publishlogo($r,'copy',$domconfig->{$role}{$img},
+ $dom,$confname,$img,$width,$height);
+ if ($result eq 'ok') {
+ $confhash->{$role}{$img} = $logourl;
+ }
+ }
+ }
+ }
}
}
}
@@ -1050,7 +1086,9 @@ sub modify_colors {
$confhash->{$role}{$img} = '';
$changes{$role}{$img} = 1;
} else {
- $confhash->{$role}{$img} = $domconfig->{$role}{$img};
+ if ($confhash->{$role}{$img} eq '') {
+ $confhash->{$role}{$img} = $domconfig->{$role}{$img};
+ }
}
} else {
if ($env{'form.'.$role.'_del_'.$img}) {
@@ -1176,6 +1214,254 @@ sub display_colorchgs {
return $resulttext;
}
+sub thumb_dimensions {
+ return ('200','50');
+}
+
+sub check_configuser {
+ my ($uhome,$dom,$confname,$servadm) = @_;
+ my ($configuserok,%currroles);
+ if ($uhome eq 'no_host') {
+ srand( time() ^ ($$ + ($$ << 15)) ); # Seed rand.
+ my $configpass = &LONCAPA::Enrollment::create_password();
+ $configuserok =
+ &Apache::lonnet::modifyuser($dom,$confname,'','internal',
+ $configpass,'','','','','',undef,$servadm);
+ } else {
+ $configuserok = 'ok';
+ %currroles =
+ &Apache::lonnet::get_my_roles($confname,$dom,'userroles');
+ }
+ return ($configuserok,%currroles);
+}
+
+sub check_authorstatus {
+ my ($dom,$confname,%currroles) = @_;
+ my $author_ok;
+ if (!$currroles{':'.$dom.':au'}) {
+ my $start = time;
+ my $end = 0;
+ $author_ok =
+ &Apache::lonnet::assignrole($dom,$confname,'/'.$dom.'/',
+ 'au',$end,$start);
+ } else {
+ $author_ok = 'ok';
+ }
+ return $author_ok;
+}
+
+sub publishlogo {
+ my ($r,$action,$formname,$dom,$confname,$subdir,$thumbwidth,$thumbheight) = @_;
+ my ($output,$fname,$logourl);
+ if ($action eq 'upload') {
+ $fname=$env{'form.'.$formname.'.filename'};
+ chop($env{'form.'.$formname});
+ } else {
+ ($fname) = ($formname =~ /([^\/]+)$/);
+ }
+ $fname=&Apache::lonnet::clean_filename($fname);
+# See if there is anything left
+ unless ($fname) { return ('error: no uploaded file'); }
+ $fname="$subdir/$fname";
+ my $filepath='/home/'.$confname.'/public_html';
+ my ($fnamepath,$file,$fetchthumb);
+ $file=$fname;
+ if ($fname=~m|/|) {
+ ($fnamepath,$file) = ($fname =~ m|^(.*)/([^/]+)$|);
+ }
+ my @parts=split(/\//,$filepath.'/'.$fnamepath);
+ my $count;
+ for ($count=4;$count<=$#parts;$count++) {
+ $filepath.="/$parts[$count]";
+ if ((-e $filepath)!=1) {
+ mkdir($filepath,02770);
+ }
+ }
+ # Check for bad extension and disallow upload
+ if ($file=~/\.(\w+)$/ &&
+ (&Apache::loncommon::fileembstyle($1) eq 'hdn')) {
+ $output =
+ &mt('Invalid file extension ([_1]) - reserved for LONCAPA use.',$1);
+ } elsif ($file=~/\.(\w+)$/ &&
+ !defined(&Apache::loncommon::fileembstyle($1))) {
+ $output = &mt('Unrecognized file extension ([_1]) - rename the file with a proper extension and re-upload.',$1);
+ } elsif ($file=~/\.(\d+)\.(\w+)$/) {
+ $output = &mt('File name not allowed a rename the file to remove the number immediately before the file extension([_1]) and re-upload.',$2);
+ } elsif (-d "$filepath/$file") {
+ $output = &mt('File name is a directory name - rename the file and re-upload');
+ } else {
+ my $source = $filepath.'/'.$file;
+ my $logfile;
+ if (!open($logfile,">>$source".'.log')) {
+ return (&mt('No write permission to Construction Space'));
+ }
+ print $logfile
+"\n================= Publish ".localtime()." ================\n".
+$env{'user.name'}.':'.$env{'user.domain'}."\n";
+# Save the file
+ if (!open(FH,'>'.$source)) {
+ &Apache::lonnet::logthis('Failed to create '.$source);
+ return (&mt('Failed to create file'));
+ }
+ if ($action eq 'upload') {
+ if (!print FH ($env{'form.'.$formname})) {
+ &Apache::lonnet::logthis('Failed to write to '.$source);
+ return (&mt('Failed to write file'));
+ }
+ } else {
+ my $original = &Apache::lonnet::filelocation('',$formname);
+ if(!copy($original,$source)) {
+ &Apache::lonnet::logthis('Failed to copy '.$original.' to '.$source);
+ return (&mt('Failed to write file'));
+ }
+ }
+ close(FH);
+ chmod(0660, $source); # Permissions to rw-rw---.
+
+ my $docroot=$r->dir_config('lonDocRoot');
+ my $targetdir=$docroot.'/res/'.$dom.'/'.$confname .'/'.$fnamepath;
+ my $copyfile=$targetdir.'/'.$file;
+
+ my @parts=split(/\//,$targetdir);
+ my $path="/$parts[1]/$parts[2]/$parts[3]/$parts[4]";
+ for (my $count=5;$count<=$#parts;$count++) {
+ $path.="/$parts[$count]";
+ if (!-e $path) {
+ print $logfile "\nCreating directory ".$path;
+ mkdir($path,02770);
+ }
+ }
+ my $versionresult;
+ if (-e $copyfile) {
+ $versionresult = &logo_versioning($targetdir,$file,$logfile);
+ } else {
+ $versionresult = 'ok';
+ }
+ if ($versionresult eq 'ok') {
+ if (copy($source,$copyfile)) {
+ print $logfile "\nCopied original source to ".$copyfile."\n";
+ $output = 'ok';
+ &write_metadata($dom,$confname,$formname,$targetdir,$file,$logfile);
+ $logourl = '/res/'.$dom.'/'.$confname.'/'.$fname;
+ } else {
+ print $logfile "\nUnable to write ".$copyfile.':'.$!."\n";
+ $output = &mt('Failed to copy file to RES space').", $!";
+ }
+ if (($thumbwidth =~ /^\d+$/) && ($thumbheight =~ /^\d+$/)) {
+ my $inputfile = $filepath.'/'.$file;
+ my $outfile = $filepath.'/'.'tn-'.$file;
+ my $thumbsize = $thumbwidth.'x'.$thumbheight;
+ system("convert -sample $thumbsize $inputfile $outfile");
+ chmod(0660, $filepath.'/tn-'.$file);
+ if (-e $outfile) {
+ my $copyfile=$targetdir.'/tn-'.$file;
+ if (copy($outfile,$copyfile)) {
+ print $logfile "\nCopied source to ".$copyfile."\n";
+ &write_metadata($dom,$confname,$formname,$targetdir,
+ 'tn-'.$file,$logfile);
+ } else {
+ print $logfile "\nUnable to write ".$copyfile.':'.$!."\n";
+ }
+ }
+ }
+ } else {
+ $output = $versionresult;
+ }
+ }
+ return ($output,$logourl);
+}
+
+sub logo_versioning {
+ my ($targetdir,$file,$logfile) = @_;
+ my $target = $targetdir.'/'.$file;
+ my ($maxversion,$fn,$extn,$output);
+ $maxversion = 0;
+ if ($file =~ /^(.+)\.(\w+)$/) {
+ $fn=$1;
+ $extn=$2;
+ }
+ opendir(DIR,$targetdir);
+ while (my $filename=readdir(DIR)) {
+ if ($filename=~/\Q$fn\E\.(\d+)\.\Q$extn\E$/) {
+ $maxversion=($1>$maxversion)?$1:$maxversion;
+ }
+ }
+ $maxversion++;
+ print $logfile "\nCreating old version ".$maxversion."\n";
+ my $copyfile=$targetdir.'/'.$fn.'.'.$maxversion.'.'.$extn;
+ if (copy($target,$copyfile)) {
+ print $logfile "Copied old target to ".$copyfile."\n";
+ $copyfile=$copyfile.'.meta';
+ if (copy($target.'.meta',$copyfile)) {
+ print $logfile "Copied old target metadata to ".$copyfile."\n";
+ $output = 'ok';
+ } else {
+ print $logfile "Unable to write metadata ".$copyfile.':'.$!."\n";
+ $output = &mt('Failed to copy old meta').", $!, ";
+ }
+ } else {
+ print $logfile "Unable to write ".$copyfile.':'.$!."\n";
+ $output = &mt('Failed to copy old target').", $!, ";
+ }
+ return $output;
+}
+
+sub write_metadata {
+ my ($dom,$confname,$formname,$targetdir,$file,$logfile) = @_;
+ my (%metadatafields,%metadatakeys,$output);
+ $metadatafields{'title'}=$formname;
+ $metadatafields{'creationdate'}=time;
+ $metadatafields{'lastrevisiondate'}=time;
+ $metadatafields{'copyright'}='public';
+ $metadatafields{'modifyinguser'}=$env{'user.name'}.':'.
+ $env{'user.domain'};
+ $metadatafields{'authorspace'}=$confname.':'.$dom;
+ $metadatafields{'domain'}=$dom;
+ {
+ print $logfile "\nWrite metadata file for ".$targetdir.'/'.$file;
+ my $mfh;
+ unless (open($mfh,'>'.$targetdir.'/'.$file.'.meta')) {
+ $output = &mt('Could not write metadata');
+ }
+ foreach (sort keys %metadatafields) {
+ unless ($_=~/\./) {
+ my $unikey=$_;
+ $unikey=~/^([A-Za-z]+)/;
+ my $tag=$1;
+ $tag=~tr/A-Z/a-z/;
+ print $mfh "\n\<$tag";
+ foreach (split(/\,/,$metadatakeys{$unikey})) {
+ my $value=$metadatafields{$unikey.'.'.$_};
+ $value=~s/\"/\'\'/g;
+ print $mfh ' '.$_.'="'.$value.'"';
+ }
+ print $mfh '>'.
+ &HTML::Entities::encode($metadatafields{$unikey},'<>&"')
+ .''.$tag.'>';
+ }
+ }
+ $output = 'ok';
+ print $logfile "\nWrote metadata";
+ close($mfh);
+ }
+}
+
+sub check_switchserver {
+ my ($dom,$confname) = @_;
+ my ($allowed,$switchserver);
+ my $home = &Apache::lonnet::homeserver($confname,$dom);
+ if ($home eq 'no_host') {
+ $home = &Apache::lonnet::domain($dom,'primary');
+ }
+ my @ids=&Apache::lonnet::current_machine_ids();
+ foreach my $id (@ids) { if ($id eq $home) { $allowed=1; }
+ if (!$allowed) {
+ $switchserver=''.&mt('Switch Server').'';
+ }
+ }
+ return $switchserver;
+}
+
sub modify_quotas {
my ($dom,%domconfig) = @_;
my ($resulttext,%changes);