--- loncom/publisher/lonretrieve.pm 2001/04/03 22:03:55 1.4 +++ loncom/publisher/lonretrieve.pm 2001/05/02 20:34:34 1.7 @@ -31,10 +31,11 @@ sub phaseone { my $resdir=$resfn; $resdir=~s/\/[^\/]+$/\//; - $fn=~/^\/(.+)\.(\w+)$/; + $fn=~/\/([^\/]+)\.(\w+)$/; my $main=$1; my $suffix=$2; - + + if (-e $resfn) { $r->print('
'. ''. ''. @@ -69,6 +70,9 @@ sub phaseone { 'Retrieval of an old version will '. 'overwrite the file currently in construction space

'. '

'); +} else { + $r->print('

No previous versions published.

'); +} } sub phasetwo { @@ -82,14 +86,29 @@ sub phasetwo { } my $logfile; my $ctarget='/home/'.$uname.'/public_html'.$fn; + my $vfn=$fn; + if ($version ne 'new') { + $vfn=~s/\.(\w+)$/\.$version\.$1/; + } + my $csource=$r->dir_config('lonDocRoot').'/res/'.$udom.'/'.$uname.$vfn; unless ($logfile=Apache::File->new('>>'.$ctarget.'.log')) { $r->print( 'No write permission to user directory, FAIL'); } print $logfile "\n\n================= Retrieve ".localtime()." ================\n". -"Version $version\n\n"; - +"Version: $version\nSource: $csource\nTarget: $ctarget\n"; + $r->print('

Copying file: '); + if (copy($csource,$ctarget)) { + $r->print('ok

'); + print $logfile "Copied sucessfully.\n\n"; + } else { + my $error=$!; + $r->print('fail, '.$error.'

'); + print $logfile "Copy failed: $error\n\n"; + } + $r->print('Back to '.$fn.''); } else { $r->print( 'Please pick a version to retrieve

'); @@ -143,3 +162,6 @@ sub handler { $r->print(''); return OK; } + +1; +__END__