--- loncom/imspackages/imsimport.pm 2004/02/10 23:36:32 1.1 +++ loncom/imspackages/imsimport.pm 2004/04/08 09:19:39 1.6 @@ -1,42 +1,21 @@ package Apache::imsimport; - use strict; - use Apache::Constants qw(:common :http :methods); - use Apache::loncacc; - use Apache::loncommon(); - use Apache::Log(); - use Apache::lonnet; - use HTML::Parser; - use HTML::Entities(); - use Apache::lonlocal; - use Apache::lonupload; - use File::Basename(); -# ---------------------------------------------------------------- Display Control -sub display_control { -# figure out what page we're on and where we're heading. - my $page = $ENV{'form.page'}; - my $command = $ENV{'form.go'}; - my $current_page = &calculate_page($page,$command); - return $current_page; -} - -# CALCULATE THE CURRENT PAGE -sub calculate_page($$) { - my ($prev,$dir) = @_; - return 0 if $prev eq ''; # start with first page - return $prev + 1 if $dir eq 'NextPage'; - return $prev - 1 if $dir eq 'PreviousPage'; - return $prev if $dir eq 'ExitPage'; - return 0 if $dir eq 'BackToStart'; -} - -# ---------------------------------------------------------------- Jscript Zero -sub jscript_zero { +use strict; +use Apache::Constants qw(:common :http :methods); +use Apache::loncacc; +use Apache::loncommon(); +use Apache::Log(); +use Apache::lonnet; +use Apache::imsprocessor; +use HTML::Parser; +use HTML::Entities(); +use Apache::lonlocal; +use Apache::lonupload; +use File::Basename(); + +# ---------------------------------------------------------------- Jscript One +sub jscript_one { my ($fullpath,$jsref) = @_; - my $source = ''; - if (exists($ENV{'form.go'}) ) { - $source = $ENV{'form.go'}; - } $$jsref = <<"END_OF_ONE"; function verify() { if ((document.forms.dataForm.newdir.value == '') || (!document.forms.dataForm.newdir.value)) { @@ -46,15 +25,14 @@ function verify() { if (document.forms.dataForm.source.selectedIndex == 0) { alert("You must choose the Course Management System from which the IMS package was exported"); return false - } + } return true } - + function nextPage() { - if (verify()) { - document.forms.dataForm.go.value="NextPage" - document.forms.dataForm.submit() - } + if (verify()) { + document.forms.dataForm.submit() + } } function createWin() { @@ -80,16 +58,191 @@ function createWin() { newWindow.document.close() newWindow.focus() } + END_OF_ONE } -# ---------------------------------------------------------------- Display Zero -sub display_zero { - my ($r,$uname,$fn,$page) = @_; +# ---------------------------------------------------------------- Jscript Two +sub jscript_two { + my ($javascript,$user,$dom,$numcrs) = @_; + my %crsentry = (); + my $course_list; + my $title_list; + my @crslist = (); + &get_ccroles($user,$dom,\%crsentry,\@crslist); + if (@crslist > 0) { + $crsentry{$crslist[0]} =~ s/("|,)//g; + $title_list = '"'.$crsentry{$crslist[0]}.'"'; + if (@crslist > 1) { + for (my $i=1; $i<@crslist; $i++) { + $crsentry{$crslist[$i]} =~ s/("|,)//g; + $title_list .= ',"'.$crsentry{$crslist[$i]}.'"'; + } + } + } + $course_list = '"'.join('","',@crslist).'"'; + $$numcrs = @crslist; + + $$javascript = qq# + +function checkCourse() { + courseID_array = new Array($course_list) + courseTitle_array = new Array($title_list) + var step2Form = document.forms.pickoptions + var conditionType = step2Form.conditions.value + var curVal = step2Form.targetcourse.options[step2Form.targetcourse.selectedIndex].value + if (curVal == -1) { + if ( conditionType == 'both' ) { + if ( step2Form.board.checked == true || step2Form.users.checked == true ) { + setCourse(step2Form,'add') + } + } + if ( conditionType == 'users' ) { + if ( step2Form.users.checked == true ) { + setCourse(step2Form,'add') + } + } + if ( conditionType == 'board' ) { + if ( step2Form.board.checked == true ) { + setCourse(step2Form,'add') + } + } + } + else { + if ( conditionType == 'both' ) { + if ( step2Form.board.checked == false && step2Form.users.checked == false ) { + setCourse(step2Form,'clear') + } + } + if ( conditionType == 'users' ) { + if ( step2Form.users.checked == false ) { + setCourse(step2Form,'clear') + } + } + if ( conditionType == 'board' ) { + if ( step2Form.board.checked == false ) { + setCourse(step2Form,'clear') + } + } + } +} + +function setCourse(step2Form,call) { + step2Form.targetcourse.length = 0 + if (call == 'add') { + step2Form.targetcourse.length = 0 + step2Form.targetcourse.options[0] = new Option("Please Select","0",true,true) + for (var i=0; i 0) { + checkCourse() + } +} + +function verify(caller) { + var numCrs = $$numcrs + var opForm = document.forms.pickoptions + var totcheck = 0; + var totchg = 0; + for (var i=0; iprint(<<"END_OF_ONE"); -

Step 1: Selection of IMS package type and destination directory for the package contents 

@@ -100,10 +253,11 @@ sub display_zero { - @@ -113,66 +267,47 @@ sub display_zero { - - - - - - - - + + + - + Create a directory where you will unpack your IMS package.   - - + - - - - - - - - + @@ -183,10 +318,11 @@ Please choose a destination LON-CAPA dir
  +      - Specify the Course Management system used to create the package. + Specify the Course Management system used to create the package.   +
  -Please choose the CMS used to create your IMS content package. -
 
  - +Please choose the CMS used to create your IMS content package.   +
 
 
  +    - Create a directory where you will unpack your IMS package. -
 
  -Please choose a destination LON-CAPA directory in which to store the contents of the IMS package file +Please choose a destination LON-CAPA directory in which to store the contents of the IMS package file.
  

 
 
 If you have created a destination directory you should use the "Next Page" button to complete the process of unpacking your IMS package.If you have selected the CMS used to create the IMS package, and have created a destination directory, click the 'Proceed' button to continue the IMS package upload process.
- -
-
  + + - +
@@ -200,1455 +336,416 @@ Please choose a destination LON-CAPA dir END_OF_ONE } -# ---------------------------------------------------------------- Display One - -sub expand_bb5 { - my ($r,$uname,$udom,$fn,$page) = @_; - my @state = (); - my @seq = "Top"; - my $lastitem; - my %resnum = (); - my %title = (); - my %filepath = (); - my %contentscount = ('Top' => 0); - my %contents = (); - my %parentseq = (); - my %base = (); - my %file = (); - my %type = (); - my %href = (); - my $identifier = ''; +# ---------------------------------------------------------------- Display Two +sub display_two { + my ($r,$zipupload,$areas,$areaname,$cmsmap,$uname,$newdir,$numcrs,$fullpath) = @_; + &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['folder','source']); + my $cms = $ENV{'form.source'}; + my $dirname = $ENV{'form.newdir'}; + my $tempdir = &Apache::imsprocessor::create_tempdir('CSTR',$dirname,''); + my $fname = &Apache::imsprocessor::uploadzip('CSTR',$tempdir,$zipupload); + my $unzip_result = ''; + my $manifest_result = ''; + unless ($tempdir eq '') { + $unzip_result = &Apache::imsprocessor::expand_zip($tempdir,$fname); + } + my %resources = (); + my %items = (); + my %hrefs = (); my %resinfo = (); - my $numfolders = 0; - my $numpages = 0; - my $docroot = $ENV{'form.newdir'}; - if (!-e "$docroot/temp") { - mkdir "$docroot/temp"; - } - my $newdir = ''; - if ($docroot =~ m|public_html/(.+)$|) { - $newdir = $1; - } - my $dirname = "/res/$udom/$uname/$newdir"; - my $zipfile = '/home/'.$uname.'/public_html'.$fn; - if ($fn =~ m|\.zip$|i) { - open(OUTPUT, "unzip -o $zipfile -d $docroot/temp 2> /dev/null |"); - while () { - print "$_
"; - } - close(OUTPUT); - } + my %count = (); + my @bgcolors = ("#eeeeee","#dddddd"); - my $xmlfile = $docroot.'/temp/imsmanifest.xml'; -# print STDERR "XML file is $xmlfile\n"; - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - my $num = @state - 3; - my $start = $num; - my $statestr = ''; - foreach (@state) { - $statestr .= "$_ "; - } - if ( ($state[0] eq "manifest") && ($state[1] eq "organizations") && ($state[2] eq "tableofcontents") ) { - my $searchstr = "manifest organizations tableofcontents"; - while ($num > 0) { - $searchstr .= " item"; - $num --; - } - if (("@state" eq $searchstr) && (@state > 3)) { - my $itm = $attr->{identifier}; - $resnum{$itm} = $attr->{identifierref}; - $title{$itm} = $attr->{title}; - if ($start > @seq) { - unless ($lastitem eq '') { - push @seq, $lastitem; - unless ( defined($contents{$seq[-1]}) ) { - @{$contents{$seq[-1]}} = (); - } - push @{$contents{$seq[-1]}},$itm; - $parentseq{$itm} = $seq[-1]; + my $counter = 0; + my $iter = 0; + my %count = ( + announce => 0, + board => 0, + doc => 0, + extlink => 0, + msg => 0, + pool => 0, + quiz => 0, + staff => 0, + survey => 0, + users => 0, + ); + my $conditions; + + if ($unzip_result eq 'ok') { + $manifest_result = &Apache::imsprocessor::process_manifest($cms,$tempdir,\%resources,\%items,\%hrefs,\%resinfo); + if ($manifest_result eq 'ok') { + foreach my $res (sort keys %resources) { + if ($cms eq 'bb5') { + foreach my $area (keys %{$$cmsmap{$cms}}) { + if ($resources{$res}{type} eq $$cmsmap{$cms}{$area}) { + $count{$area} ++; } } - elsif ($start < @seq) { - my $diff = @seq - $start; - while ($diff > 0) { - pop @seq; - $diff --; - } - if (@seq) { - push @{$contents{$seq[-1]}}, $itm; - } - } else { - push @{$contents{$seq[-1]}}, $itm; - } - my $path; - if (@seq > 1) { - $path = join(',',@seq); - } elsif (@seq > 0) { - $path = $seq[0]; + } elsif ($cms eq 'angel') { + foreach my $area (keys %{$$cmsmap{$cms}}) { + if ($area eq 'doc') { + if (grep/^$resources{$res}{type}$/,@{$$cmsmap{$cms}{doc}}) { + $count{$area} ++; + } + } elsif ($resources{$res}{type} eq $$cmsmap{$cms}{$area}) { + $count{$area} ++; + } } - $filepath{$itm} = $path; - $contentscount{$seq[-1]} ++; - $lastitem = $itm; - } - } elsif ("@state" eq "manifest resources resource" ) { - $identifier = $attr->{identifier}; - $base{$identifier} = $attr->{baseurl}; - $file{$identifier} = $attr->{file}; - $type{$identifier} = $attr->{type}; - } elsif ("@state" eq "manifest resources resource file") { - push@{$href{$identifier}},$attr->{href}; - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - pop @state; - }, "tagname"], - ); - - $p->parse_file($xmlfile); - $p->eof; - - my $topnum = 0; - my $destdir = $docroot; -# print STDERR "Destdir is $destdir\n"; - if (!-e "$destdir") { - mkdir("$destdir",0755); - } - if (!-e "$destdir/sequences") { - mkdir("$destdir/sequences",0755); - } - if (!-e "$destdir/resfiles") { - mkdir("$destdir/resfiles",0755); - } - if (!-e "$destdir/pages") { - mkdir("$destdir/pages",0755); - } - if (!-e "$destdir/problems") { - mkdir("$destdir/problems",0755); - } - open(FILE,">$destdir/sequences/ims_import.sequence"); - print FILE "\n"; - - foreach my $key (sort keys %href) { - foreach my $file (@{$href{$key}}) { - my $filepath = $file; - if (!-e "$destdir/resfiles/$key") { - mkdir("$destdir/resfiles/$key",0755); - } - while ($filepath =~ m-(\w+)/(.+)-) { - $filepath = $2; - if (!-e "$destdir/resfiles/$key/$1") { - mkdir("$destdir/resfiles/$key/$1",0755); } } - system("cp $docroot/temp/$key/$file $destdir/resfiles/$key/$file"); - } - } - - foreach my $key (sort keys %type) { - if ($type{$key} eq "resource/x-bb-document") { - %{$resinfo{$key}} = (); - &process_content($key,$docroot,$destdir,\%{$resinfo{$key}},$udom,$uname); - } elsif ($type{$key} eq "resource/x-bb-staffinfo") { - %{$resinfo{$key}} = (); - &process_staff($key,$docroot,$destdir,\%{$resinfo{$key}}); - } elsif ($type{$key} eq "resource/x-bb-externallink") { - %{$resinfo{$key}} = (); - &process_link($key,$docroot,$destdir,\%{$resinfo{$key}}); - } elsif ($type{$key} eq "resource/x-bb-discussionboard") { - %{$resinfo{$key}} = (); - &process_db($key,$docroot,$destdir,\%{$resinfo{$key}}); - } elsif ($type{$key} eq "resource/x-bb-announcement") { - %{$resinfo{$key}} = (); - &process_announce($key,$docroot,$destdir,\%{$resinfo{$key}}); - } elsif ($type{$key} eq "assessment/x-bb-pool") { - %{$resinfo{$key}} = (); - &process_assessment($key,$docroot,'pool',$dirname,$destdir,\%{$resinfo{$key}}); - } elsif ($type{$key} eq "assessment/x-bb-quiz") { - %{$resinfo{$key}} = (); - &process_assessment($key,$docroot,'quiz',$dirname,$destdir,\%{$resinfo{$key}}); - } elsif ($type{$key} eq "assessment/x-bb-survey") { - %{$resinfo{$key}} = (); - &process_assessment($key,$docroot,'survey',$dirname,$destdir,\%{$resinfo{$key}}); - } elsif ($type{$key} eq "assessment/x-bb-group") { - %{$resinfo{$key}} = (); - &process_group($key,$docroot,$destdir,\%{$resinfo{$key}}); - } elsif ($type{$key} eq "resource/x-bb-user") { - %{$resinfo{$key}} = (); - &process_user($key,$docroot,$destdir,\%{$resinfo{$key}}); - } - } - - my $nextnum = 0; - open(TOPFILE,">$destdir/sequences/ims_import.sequence"); - print TOPFILE "\n"; - my $fileopen = 0; - my $areakey; - my $areacount = 0; - my $lastentry = ''; - my $notlastentry = ''; - my %pagecount = (); - my %pagecontents = (); - my %pageflag = (); - my %seqflag = (); - my %seqcount = (); - - foreach my $key (sort keys %resnum) { -# print STDERR "$key $filepath{$key} $resnum{$key} $title{$key}\n"; - $pageflag{$key} = 0; - $seqflag{$key} = 0; - $seqcount{$key} = 0; - $pagecount{$key} = -1; - if ($filepath{$key} eq 'Top') { - $topnum ++; - $nextnum = $topnum +1; - print TOPFILE qq| -\n|; - if ($topnum == $contentscount{'Top'}) { - print TOPFILE qq|\n|; - } - } else { - if ($topnum == $contentscount{'Top'}) { - print TOPFILE qq| type="finish">\n|; - } else { - print TOPFILE qq|> -\n|; - } - } - my $seqname = $title{$key}; - $seqname =~ s/\s//g; - $seqname =~ tr/A-Z/a-z/; - if ($fileopen) { - if ($areacount == 0) { - print AREAFILE qq| - -\n|; - } elsif ($areacount == 1) { - print AREAFILE qq|\n|; + if ($count{board} > 0) { + if ($count{users} > 0) { + $conditions = 'both'; } else { - print AREAFILE qq|$lastentry\n|; + $conditions = 'board'; } - print AREAFILE "\n"; - close(AREAFILE); - $fileopen = 0; + } elsif ($count{users} > 0) { + $conditions = 'users'; + } else { + $conditions = 'none'; } - $areakey = $key; - @{$pagecontents{$areakey}} = (); - open(AREAFILE,">$destdir/sequences/$key.sequence"); - print AREAFILE "\n"; - $fileopen = 1; - $areacount = 0; - } else { - if ($filepath{$key} eq "Top,$areakey") { -# print STDERR "$key $filepath{$key} $resnum{$key} $title{$key}\n"; - my $src = ''; - if ($areacount == 0) { - if ($resinfo{$resnum{$key}}{'isfolder'} eq "true") { - $src = 'sequences/'.$key.".sequence"; - $pageflag{$areakey} = 0; - $seqflag{$areakey} = 1; - } else { - if ($pageflag{$areakey}) { - push @{$pagecontents{$areakey}[$pagecount{$areakey}]},$key; - } else { - $pagecount{$areakey} ++; - $src = 'pages/'.$areakey.'_'.$pagecount{$areakey}.'.page'; - @{$pagecontents{$areakey}[$pagecount{$areakey}]} = ("$key"); - $seqflag{$areakey} = 0; - } - } - unless ($pageflag{$areakey}) { - print AREAFILE qq| -\n|; - $areacount ++; - $notlastentry = ""; - unless ($seqflag{$areakey}) { - $pageflag{$areakey} = 1; - } - } - } else { - my $id = $areacount +1; - my $nextid = $id +1; - $areacount ++; - if ($resinfo{$resnum{$key}}{'isfolder'} eq "true") { - $src = 'sequences/'.$key.".sequence"; - $pageflag{$areakey} = 0; - $seqflag{$areakey} = 1; + + $r->print(< + + + + +
+ + + + + + + + + + + + + + + + + + +ENDBLOCKTWO + if ($count{board} + $count{users} > 0) { + $r->print(" + + + + + + + + "); + if ($$numcrs > 0) { + $r->print(" + + + +"); } else { - if ($resinfo{$resnum{$contents{$key}[0]}}{'isfolder'} eq "true") { - $src = 'sequences/'.$contents{$key}[0].".sequence"; - $pageflag{$key} = 0; - $seqflag{$key} = 1; - $seqcount{$key} ++; - } else { - if ($pageflag{$key}) { - push @{$pagecontents{$key}[$pagecount{$key}]},$contents{$key}[0]; - } else { - $pagecount{$key} ++; - $src = 'pages/'.$key.'_'.$pagecount{$key}.'.page'; - @{$pagecontents{$key}[$pagecount{$key}]} = ("$contents{$key}[0]"); - $seqflag{$key} = 0; - } - } - unless ($pageflag{$key}) { - print LOCFILE qq| - -\n|; - } else { - if ($contentscount{$key} > 2 ) { - for (my $i=1; $i<$contentscount{$key}-1; $i++) { - if ($resinfo{$resnum{$contents{$key}[$i]}}{'isfolder'} eq "true") { - $src = 'sequences/'.$contents{$key}[$i].".sequence"; - $pageflag{$key} = 0; - $seqflag{$key} = 1; - $seqcount{$key} ++; - } else { - if ($pageflag{$key}) { - push @{$pagecontents{$key}[$pagecount{$key}]},$contents{$key}[$i]; - } else { - $pagecount{$key} ++; - $src = 'pages/'.$key.'_'.$pagecount{$key}.'.page'; - @{$pagecontents{$key}[$pagecount{$key}]} = ("$contents{$key}[$i]"); - $seqflag{$key} = 0; - } - } - unless ($pageflag{$key}) { - $curr_id ++; - $next_id ++; - print LOCFILE qq|> - - - -\n|; - } else { - print LOCFILE qq| type="finish">\n|; - } - print STDERR "seqcount is $seqcount{$key}, pagecount is $pagecount{$key} for $key\n"; - } else { - $curr_id ++; - $next_id ++; - print LOCFILE qq|> - -\n|; - } - } + $r->print(" + + + + + + + + + + + + +
  +
+    + Choose which content types you wish to import +
 
  + + + + +
+ + + + +
+ + + + + + +ENDBLOCK + foreach my $area (@{$areas}) { + if ($count{$area} > 0) { + my $count_tag = 'flag_'.$counter; + $r->print(" + + "); + if ($area eq 'board') { + $r->print(" "); + } elsif ($area eq 'users') { + $r->print(" "); } else { - if ($pageflag{$areakey}) { - push @{$pagecontents{$areakey}[$pagecount{$areakey}]},$key; - } else { - $pagecount{$areakey} ++ ; - $src = 'pages/'.$areakey.'_'.$pagecount{$areakey}.'.page'; - @{$pagecontents{$areakey}[$pagecount{$areakey}]} = ("$key"); - $seqflag{$areakey} = 0; - } + $r->print(" "); } - unless ($pageflag{$areakey}) { - print AREAFILE $notlastentry.qq||; - $notlastentry = qq|> -\n|; + $counter ++; + $iter = $counter%2; } } - my $src =""; - my $next_id = 1; - my $curr_id = 0; - if ( (($type{$resnum{$key}} eq "resource/x-bb-document") || ($type{$resnum{$key}} eq "resource/x-bb-staffinfo") || ($type{$resnum{$key}} eq "resource/x-bb-externallink")) && ($resinfo{$resnum{$key}}{'isfolder'} eq "true") ) { -# if ( ($type{$resnum{$key}} eq "resource/x-bb-staffinfo") && ($resinfo{$resnum{$key}}{'isfolder'} eq "true") ) { -# print "$key $filepath{$key} $resnum{$key} $title{$key}\n"; -# print "Folder for item - $key - res - $resnum{$key}\n"; -# print "$key, $contentscount{$key}\n"; -# foreach (@{$contents{$key}}) { -# print "$key, $_\n"; -# } -# print STDERR "Contents Count for $key is $contentscount{$key}\n"; - open(LOCFILE,">$destdir/sequences/$key.sequence"); - print LOCFILE "\n"; - if ($contentscount{$key} == 0) { - print LOCFILE qq| - -\n|; + $r->print(< +
Import?Content typeAdditional options
print(qq|onClick='javascript:setOptions("$area","$counter")'|); + } + $r->print("/>  $$areaname{$area}   - $count{$area} item(s)   + +    + + +   None
+
+
+
  +
+    + Choose a course to receive bulletin boards and user enrollment. +
 
 A listing of possible course targets will be displayed if import of bulletin boards and/or enrollment is checked above (step 3). If you do not plan to import either of these content types, there is no need to specify a course. +

+Choose course:   +
+
 You do not have active course coordinator status in any LON-CAPA courses currently, so bulletin boards and enrollment information included in your IMS package will be discarded, regardless of your import choice for these two items above (step 3). If you wish to import bulletin boards and/or user information into LON-CAPA please click 'Exit now' to quit the current IMS import process, and contact your domain coordinator and request a course coordinator role in a LON-CAPA course into which you can upload bulletin boards and/or enroll users. + "); } - print LOCFILE "\n"; - close(LOCFILE); } - } - } - print TOPFILE ""; - close(TOPFILE); - foreach my $key (sort keys %pagecontents) { - for (my $i=0; $i<@{$pagecontents{$key}}; $i++) { - my $filestem = "/res/$udom/$uname/$newdir"; - my $filename = $destdir.'/pages/'.$key.'_'.$i.'.page'; - open(PAGEFILE,">$filename"); - print PAGEFILE qq| - -\n|; - if (@{$pagecontents{$key}[$i]} == 1) { - print PAGEFILE qq||; - } elsif (@{$pagecontents{$key}[$i]} == 2) { - print PAGEFILE qq||; - } else { - for (my $j=1; $j<@{$pagecontents{$key}[$i]}-1; $j++) { - my $curr_id = $j+1; - my $next_id = $j+2; - my $resource = $filestem.'/resfiles/'.$resnum{$pagecontents{$key}[$i][$j]}.'.html'; - print PAGEFILE qq| -\n|; - } - my $final_id = @{$pagecontents{$key}[$i]}; - print PAGEFILE qq|\n|; + $r->print(< +  

 Once you have checked the checkboxes for all areas you wish to import from the IMS package, and selected additional options (if available) you should click the 'Import package' button.
  + + + + + + + +ENDBLOCK + if ($count{board} == 0) { + $r->print(' '."\n"); } - print PAGEFILE ""; - close(PAGEFILE); + if ($count{users} == 0) { + $r->print(' '."\n"); + } + $r->print(< +
+ + + + + +
+ + + +
+
+
+ENDDOCUMENT + } else { + $r->print("Unpacking of your IMS package failed because an IMS manifest file was not located in the package\n"); } + } else { + $r->print("Processing of your IMS package failed because the file you uploaded could not be unzipped\n"); } - system(" rm -r $docroot/temp"); } -sub process_user { - my ($res,$docroot,$destdir,$settings) = @_; - my $xmlfile = $docroot."/temp/".$res.".dat"; - my $filecount = 0; - my @state; - my $userid = ''; - my $linknum = 0; - - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - if (@state eq " USERS USER") { - $userid = $attr->{value}; - %{$$$settings{$userid}} = (); - @{$$settings{$userid}{links}} = (); - } elsif (@state eq "USERS USER LOGINID") { - $$settings{$userid}{loginid} = $attr->{value}; - } elsif (@state eq "USERS USER PASSPHRASE") { - $$settings{$userid}{passphrase} = $attr->{value}; - } elsif ("@state" eq "USERS USER STUDENTID" ) { - $$settings{$userid}{studentid} = $attr->{value}; - } elsif ("@state" eq "USERS USER NAMES FAMILY" ) { - $$settings{$userid}{family} = $attr->{value}; - } elsif ("@state" eq "USERS USER NAMES GIVEN" ) { - $$settings{$userid}{given} = $attr->{value}; - } elsif ("@state" eq "USERS USER ADDRESSES BUSINESS DATA EMAIL") { - $$settings{$userid}{email} = $attr->{value}; - } elsif ("@state" eq "USERS USER USER_ROLE") { - $$settings{$userid}{user_role} = $attr->{value}; - } elsif ("@state" eq "USERS USER FLAGS ISAVAILABLE") { - $$settings{$userid}{isavailable} = $attr->{value}; - } elsif ("@state" eq "USERS USER PERSONALPAGE FILELIST IMAGE") { - $$settings{$userid}{image} = $attr->{value}; - } elsif ( ($state[-2] eq "LINKLIST") && ($state[-1] eq "LINK") ) { - %{$$settings{$userid}{links}[$linknum]} = (); - $$settings{$userid}{links}[$linknum]{url} = $attr->{value}; - $linknum ++; - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - if ("@state" eq "USERS USER PERSONALPAGE TITLE") { - $$settings{$userid}{title} = $text; - } elsif ("@state" eq "USERS USER PERSONALPAGE DESCRIPTION") { - $$settings{$userid}{description} = $text; - } elsif (($state[-2] eq "LINK") && ($state[-1] eq "TITLE")) { - $$settings{$userid}{links}[$linknum]{title} = $text; - } elsif (($state[-3] eq "LINK") && ($state[-2] eq "DESCRIPTION") && ($state[-1] eq "TEXT")) { - $$settings{$userid}{links}[$linknum]{text} = $text; - } - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - if (@state eq "USERS USER") { - $linknum = 0; - } - pop @state; - }, "tagname"], - ); - $p->unbroken_text(1); - $p->parse_file($xmlfile); - $p->eof; -} - -sub process_group { - my ($res,$docroot,$destdir,$settings) = @_; - my $xmlfile = $docroot."/".$res.".dat"; - my $filecount = 0; - my @state; - my $grp; - - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - if (@state eq "GROUPS GROUP") { - $grp = $attr->{id}; - } - if (@state eq "GROUPS GROUP TITLE") { - $$settings{$grp}{title} = $attr->{value}; - } elsif (@state eq "GROUPS GROUP FLAGS ISAVAILABLE") { - $$settings{$grp}{isavailable} = $attr->{value}; - } elsif (@state eq "GROUPS GROUP FLAGS HASCHATROOM") { - $$settings{$grp}{chat} = $attr->{value}; - } elsif ("@state" eq "GROUPS GROUP FLAGS HASDISCUSSIONBOARD") { - $$settings{$grp}{discussion} = $attr->{value}; - } elsif ("@state" eq "GROUPS GROUP FLAGS HASTRANSFERAREA") { - $$settings{$grp}{transfer} = $attr->{value}; - } elsif ("@state" eq "GROUPS GROUP FLAGS ISPUBLIC") { - $$settings{$grp}{public} = $attr->{value}; - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - if ("@state" eq "GROUPS DESCRIPTION") { - $$settings{$grp}{description} = $text; -# print "Staff text is $text\n"; - } - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - pop @state; - }, "tagname"], - ); - $p->unbroken_text(1); - $p->parse_file($xmlfile); - $p->eof; -} - -sub process_staff { - my ($res,$docroot,$destdir,$settings) = @_; - my $xmlfile = $docroot."/temp/".$res.".dat"; - my $filecount = 0; - my @state; - %{$$settings{name}} = (); - %{$$settings{office}} = (); - - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - if (@state eq "STAFFINFO TITLE") { - $$settings{title} = $attr->{value}; - } elsif (@state eq "STAFFINFO BIOGRAPHY TEXTCOLOR") { - $$settings{textcolor} = $attr->{value}; - } elsif (@state eq "STAFFINFO BIOGRAPHY FLAGS ISHTML") { - $$settings{ishtml} = $attr->{value}; - } elsif ("@state" eq "STAFFINFO FLAGS ISAVAILABLE" ) { - $$settings{isavailable} = $attr->{value}; - } elsif ("@state" eq "STAFFINFO FLAGS ISFOLDER" ) { - $$settings{isfolder} = $attr->{value}; - } elsif ("@state" eq "STAFFINFO POSITION" ) { - $$settings{position} = $attr->{value}; - } elsif ("@state" eq "STAFFINFO HOMEPAGE" ) { - $$settings{homepage} = $attr->{value}; - } elsif ("@state" eq "STAFFINFO IMAGE") { - $$settings{image} = $attr->{value}; - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - if ("@state" eq "STAFFINFO BIOGRAPHY TEXT") { - $$settings{text} = $text; -# print "Staff text is $text\n"; - } elsif ("@state" eq "STAFFINFO CONTACT PHONE") { - $$settings{phone} = $text; - } elsif ("@state" eq "STAFFINFO CONTACT EMAIL") { - $$settings{email} = $text; - } elsif ("@state" eq "STAFFINFO CONTACT NAME FORMALTITLE") { - $$settings{name}{formaltitle} = $text; - } elsif ("@state" eq "STAFFINFO CONTACT NAME FAMILY") { - $$settings{name}{family} = $text; - } elsif ("@state" eq "STAFFINFO CONTACT NAME GIVEN") { - $$settings{name}{given} = $text; - } elsif ("@state" eq "STAFFINFO CONTACT OFFICE HOURS") { - $$settings{office}{hours} = $text; - } elsif ("@state" eq "STAFFINFO CONTACT OFFICE ADDRESS") { - $$settings{office}{address} = $text; - } - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - pop @state; - }, "tagname"], - ); - $p->unbroken_text(1); - $p->parse_file($xmlfile); - $p->eof; -} - -sub process_link { - my ($res,$docroot,$destdir,$settings) = @_; - my $xmlfile = $docroot."/temp/".$res.".dat"; - my @state = (); - %{$$settings{name}} = (); - %{$$settings{office}} = (); - - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - if (@state eq "EXTERNALLINK TITLE") { - $$settings{title} = $attr->{value}; - } elsif (@state eq "EXTERNALLINK TEXTCOLOR") { - $$settings{textcolor} = $attr->{value}; - } elsif (@state eq "EXTERNALLINK DESCRIPTION FLAGS ISHTML") { - $$settings{ishtml} = $attr->{value}; - } elsif ("@state" eq "EXTERNALLINKS FLAGS ISAVAILABLE" ) { - $$settings{isavailable} = $attr->{value}; - } elsif ("@state" eq "EXTERNALLINKS FLAGS LAUNCHINNEWWINDOW" ) { - $$settings{newwindow} = $attr->{value}; - } elsif ("@state" eq "EXTERNALLINKS FLAGS ISFOLDER" ) { - $$settings{isfolder} = $attr->{value}; - } elsif ("@state" eq "EXTERNALLINKS POSITION" ) { - $$settings{position} = $attr->{value}; - } elsif ("@state" eq "EXTERNALLINKS URL" ) { - $$settings{url} = $attr->{value}; - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - if ("@state" eq "EXTERNALLINKS DESCRIPTION TEXT") { - $$settings{text} = $text; - } - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - pop @state; - }, "tagname"], +# ---------------------------------------------------------------- Display Three +sub display_three { + my ($r,$uname,$udom,$areas,$areaname,$cmsmap,$destdir,$newdir) = @_; + my $crs = ''; + my $cdom = ''; + my $chome = ''; + my $db_handling = ''; + my $timenow = time; + my $announce_handling = 'ok'; + my $cms = $ENV{'form.source'}; + if ( defined($ENV{'form.bb_crs'}) ) { + ($cdom,$crs) = split/\//,$ENV{'form.bb_crs'}; + $chome = &Apache::lonnet::homeserver($crs,$cdom); + } + if ( defined($ENV{'form.bb_handling'}) ) { + $db_handling = $ENV{'form.bb_handling'}; + } + my $user_crs = ''; + my $user_cdom = ''; + my $user_handling = ''; + if ( defined($ENV{'form.user_crs'}) ) { + ($user_cdom,$user_crs) = split/\//,$ENV{'form.user_crs'}; + } + if ( defined($ENV{'form.user_handling'}) ) { + $user_handling = $ENV{'form.user_handling'}; + } + my $seqstem = "/res/$udom/$uname/$newdir"; + my %imports = (); + my @targets = (); + my %resources = (); + my %items = (); + my %hrefs = (); + my %urls = (); + my %resinfo = (); + my %total = ( + page => 0, + prob => 0, + seq => 0, + board => 0, + quiz => 0, + surv => 0, ); - $p->unbroken_text(1); - $p->parse_file($xmlfile); - $p->eof; -} -sub process_db { - my ($res,$docroot,$destdir,$settings) = @_; - my $xmlfile = $docroot."/temp/".$res.".dat"; - my @state = (); - my %threads; # all quotes, keyed by message ID - my $msg_id; # the current message ID - my %message; # the current message being accumulated for $msg_id - - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - my $depth = 0; - my @seq = (); - if (@state eq "FORUM TITLE") { - $$settings{title} = $attr->{value}; - } elsif (@state eq "STAFFINFO BIOGRAPHY TEXTCOLOR") { - $$settings{textcolor} = $attr->{value}; - } elsif (@state eq "FORUM DESCRIPTION FLAGS ISHTML") { - $$settings{ishtml} = $attr->{value}; - } elsif (@state eq "FORUM DESCRIPTION FLAGS ISNEWLINELITERAL") { - $$settings{newline} = $attr->{value}; - } elsif ("@state" eq "FORUM POSITION" ) { - $$settings{position} = $attr->{value}; - } elsif ("@state" eq "FORUM FLAGS ISREADONLY") { - $$settings{isavailable} = $attr->{value}; - } elsif ("@state" eq "FORUM FLAGS ISAVAILABLE" ) { - $$settings{isavailable} = $attr->{value}; - } elsif ("@state" eq "FORUM FLAGS ALLOWANONYMOUSPOSTINGS" ) { - $$settings{isfolder} = $attr->{value}; - } elsif ( ($state[0] eq "FORUM") && ($state[1] eq "MESSAGETHREADS") && ($state[2] eq "MSG") ) { - if ($state[@state-1] eq "MSG") { - $depth = @state - 3; - if ($depth > @seq) { - unless ($msg_id eq '') { - push @seq, $msg_id; - } + my @pages = (); + my @sequences = (); + my @resrcfiles = (); + + my $tempdir = $ENV{'form.tempdir'}; + + foreach my $area (@{$areas}) { + if (defined($ENV{"form.$area"}) ) { + if ($cms eq 'angel' && $area eq 'doc') { + foreach (@{$$cmsmap{$cms}{$area}}) { + $imports{$_} = 1; } - if ($depth < @seq) { - pop @seq; - } - $msg_id = $attr->{value}; - %message = (); - $message{depth} = $depth; - if ($depth > 0) { - $message{parent} = $seq[-1]; - } else { - $message{parent} = "None"; - } - } elsif ($state[@state-1] eq "TITLE") { - $message{title} = $attr->{value}; - } elsif ( ( $state[@state-3] eq "MESSAGETEXT" ) && ( $state[@state-2] eq "FLAGS" ) && ( $state[@state-1] eq "ISHTML" ) ) { - $message{ishtml} = $attr->{value}; - } elsif ( ( $state[@state-3] eq "MESSAGETEXT" ) && ( $state[@state-2] eq "FLAGS" ) && ( $state[@state-1] eq "ISNEWLINELITERAL" ) ) { - $message{newline} = $attr->{value}; - } elsif ( ( $state[@state-2] eq "DATES" ) && ( $state[@state-1] eq "CREATED" ) ) { - $message{created} = $attr->{value}; - } elsif ( $state[@state-2] eq "FLAGS") { - if ($state[@state-1] eq "ISANONYMOUS") { - $message{isanonymous} = $attr->{value}; - } - } elsif ( $state[@state-2] eq "USER" ) { - if ($state[@state-1] eq "USERID") { - $message{userid} = $attr->{value}; - } elsif ($state[@state-1] eq "USERNAME") { - $message{username} = $attr->{value}; - } elsif ($state[@state-1] eq "EMAIL") { - $message{email} = $attr->{value}; - } - } elsif ( ($state[@state-2] eq "FILELIST") && ($state[@state-2] eq "IMAGE") ) { - $message{attachment} = $attr->{value}; - } - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - if ("@state" eq "FORUM DESCRIPTION TEXT") { - $$settings{text} = $text; - } elsif ( ($state[0] eq "FORUM") && ($state[1] eq "MESSAGETHREADS") && ($state[2] eq "MSG") ) { - if ( ($state[@state-2] eq "MESSAGETEXT") && ($state[@state-1] eq "TEXT") ){ - $message{text} = $text; - } - } - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - if ( ($state[0] eq "FORUM") && ($state[1] eq "MESSAGETHREADS") && ($state[2] eq "MSG") ) { - if ($state[@state-1] eq "MSG") { - push @{$threads{$msg_id}}, { %message }; - } - } - pop @state; - }, "tagname"], - ); - $p->unbroken_text(1); - $p->parse_file($xmlfile); - $p->eof; -} - -sub process_assessment { - my ($res,$docroot,$container,$dirname,$destdir,$settings) = @_; - my $xmlfile = $docroot."/temp/".$res.".dat"; -# print "XML file is $xmlfile\n"; - my @state = (); - my @allids = (); - my %allanswers = (); - my %allchoices = (); - my $id; # the current question ID - my $answer_id; # the current answer ID - my %toptag = ( pool => 'POOL', - quiz => 'ASSESSMENT', - survey => 'ASSESSMENT' - ); -# print "process_assessment is called, incoming: $res,$docroot,$container,$destdir\n"; - - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - my $depth = 0; - my @seq = (); - my $class; - my $state_str = join(" ",@state); -# print "Current state is $state_str\n"; - if ($container eq "pool") { - if ("@state" eq "POOL TITLE") { - $$settings{title} = $attr->{value}; -# print "Title is $attr->{value}\n"; - } - } else { - if ("@state" eq "ASSESSMENT TITLE") { - $$settings{title} = $attr->{value}; - } elsif ("@state" eq "ASSESSMENT FLAG" ) { - $$settings{isnewline} = $attr->{value}; - } elsif ("@state" eq "ASSESSMENT FLAGS ISAVAILABLE") { - $$settings{isavailable} = $attr->{value}; - } elsif ("@state" eq "ASSESSMENT FLAGS ISANONYMOUS" ) { - $$settings{isanonymous} = $attr->{id}; - } elsif ("@state" eq "ASSESSMENT FLAGS GIVE FEEDBACK" ) { - $$settings{feedback} = $attr->{id}; - } elsif ("@state" eq "ASSESSMENT FLAGS SHOWCORRECT" ) { - $$settings{showcorrect} = $attr->{id}; - } elsif ("@state" eq "ASSESSMENT FLAGS SHOWRESULTS" ) { - $$settings{showresults} = $attr->{id}; - } elsif ("@state" eq "ASSESSMENT FLAGS ALLOWMULTIPLE" ) { - $$settings{allowmultiple} = $attr->{id}; - } elsif ("@state" eq "ASSESSMENT ASSESSMENTTYPE" ) { - $$settings{type} = $attr->{id}; - } - } - if ("@state" eq "$toptag{$container} QUESTIONLIST QUESTION") { - $id = $attr->{id}; - push @allids, $id; - %{$$settings{$id}} = (); - @{$allanswers{$id}} = (); - $$settings{$id}{class} = $attr->{class}; - unless ($container eq "pool") { - $$settings{$id}{points} = $attr->{points}; - } - @{$$settings{$id}{correctanswer}} = (); - } elsif ( ($state[0] eq $toptag{$container}) && ($state[-1] =~ m/^QUESTION_(\w+)$/) ) { - $id = $attr->{id}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "BODY") && ($state[3] eq "FLAGS") && ($state[4] eq "ISHTML") ) { - $$settings{$id}{html} = $attr->{value}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "BODY") && ($state[3] eq "FLAGS") && ($state[4] eq "ISNEWLINELITERAL") ) { - $$settings{$id}{newline} = $attr->{value}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "IMAGE") ) { - $$settings{$id}{image} = $attr->{value}; - $$settings{$id}{style} = $attr->{style}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "URL") ) { - $$settings{$id}{url} = $attr->{value}; - $$settings{$id}{name} = $attr->{name}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[-1] eq "ANSWER") ) { - $answer_id = $attr->{id}; - push @{$allanswers{$id}},$answer_id; - %{$$settings{$id}{$answer_id}} = (); - $$settings{$id}{$answer_id}{position} = $attr->{position}; - if ($$settings{$id}{class} eq 'QUESTION_MATCH') { - $$settings{$id}{$answer_id}{placement} = $attr->{placement}; - $$settings{$id}{$answer_id}{type} = 'answer'; - } - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[-1] eq "CHOICE") ) { - $answer_id = $attr->{id}; - push @{$allchoices{$id}},$answer_id; - %{$$settings{$id}{$answer_id}} = (); - $$settings{$id}{$answer_id}{position} = $attr->{position}; - $$settings{$id}{$answer_id}{placement} = $attr->{placement}; - $$settings{$id}{$answer_id}{type} = 'choice'; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "ANSWER") && ($state[3] eq "IMAGE") ) { - $$settings{$id}{$answer_id}{image} = $attr->{value}; - $$settings{$id}{$answer_id}{style} = $attr->{style}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "ANSWER") && ($state[3] eq "URL") ) { - $$settings{$id}{$answer_id}{url} = $attr->{value}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "CHOICE") && ($state[3] eq "IMAGE") ) { - $$settings{$id}{$answer_id}{image} = $attr->{value}; - $$settings{$id}{$answer_id}{style} = $attr->{style}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "CHOICE") && ($state[3] eq "URL") ) { - $$settings{$id}{$answer_id}{url} = $attr->{value}; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "GRADABLE") && ($state[3] eq "CORRECTANSWER") ) { - my $corr_answer = $attr->{answer_id}; - push @{$$settings{$id}{correctanswer}}, $corr_answer; -# print "Answer $corr_answer for question $id is correct\n"; - my $type = $1; - if ($type eq 'TRUEFALSE') { - $$settings{$id}{$corr_answer}{answer_position} = $attr->{position}; - } elsif ($type eq 'ORDER') { - $$settings{$id}{$corr_answer}{order} = $attr->{order}; - } elsif ($type eq 'MATCH') { - $$settings{$id}{$corr_answer}{choice_id} = $attr->{choice_id}; - } - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - unless ($container eq "pool") { - if ("@state" eq "ASSESSMENT DESCRIPTION TEXT") { - $$settings{description} = $text; - } elsif ("@state" eq "ASSESSMENT INSTRUCTIONS ") { - $$settings{instructions}{text} = $text; - } - } - if ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "BODY") && ($state[3] eq "TEXT") ) { - $$settings{$id}{text} = $text; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "ANSWER") && ($state[3] eq "TEXT") ) { - $$settings{$id}{$answer_id}{text} = $text; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "CHOICE") && ($state[3] eq "TEXT") ) { - $$settings{$id}{$answer_id}{text} = $text; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "GRADABLE") && ($state[3] eq "FEEDBACK_WHEN_CORRECT") ) { - $$settings{$id}{feedback_corr} = $text; - } elsif ( ($state[0] eq $toptag{$container}) && ($state[1] =~ m/^QUESTION_(\w+)$/) && ($state[2] eq "GRADABLE") && ($state[3] eq "FEEDBACK_WHEN_INCORRECT") ) { - $$settings{$id}{feedback_incorr} = $text; - } - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - pop @state; - }, "tagname"], - ); - $p->unbroken_text(1); - $p->parse_file($xmlfile); - $p->eof; - - my $dirtitle = $$settings{'title'}; - $dirtitle =~ s/\W//g; - $dirtitle .= '_'.$res; - if (!-e "$destdir/problems/$dirtitle") { - mkdir("$destdir/problems/$dirtitle",0755); - } - my $newdir = "$destdir/problems/$dirtitle"; - foreach my $id (@allids) { -# print "Current ID is $id, type is $$settings{$id}{class} \n"; - if ($$settings{$id}{class} eq "QUESTION_ESSAY") { - my $output; - if ($container eq 'pool') { - $output = qq| - $$settings{$id}{text} -|; - } else { - $output = qq| - $$settings{$id}{text} -|; - } - $output .= qq| - - - - - $$settings{$id}{feedbackcorr} - -|; - if ($container eq 'pool') { - $output .= qq| - |; - open(PROB,">$newdir/$id.problem"); - print PROB $output; - close PROB; - } else { - $output .= qq| - |; - open(PROB,">$newdir/$id.problem"); - print PROB $output; - close PROB; - } - } else { - my $output; - if ($container eq 'pool') { - $output = qq| -|; - } else { - $output = qq| -|; - } - $output .= qq|$$settings{$id}{text}\n|; - if ( defined($$settings{$id}{image}) ) { - if ( $$settings{$id}{style} eq 'embed' ) { - $output .= qq|

|; - } else { - $output .= qq|
Link to file
|; - } - } - if ( defined($$settings{$id}{url}) ) { - $output .= qq|
$$settings{$id}{name}
|; - } - $output .= qq| -|; - if ($$settings{$id}{class} eq 'QUESTION_MULTIPLECHOICE') { - my $numfoils = @{$allanswers{$id}}; - $output .= qq| - - - |; - for (my $k=0; $k<@{$allanswers{$id}}; $k++) { - $output .= "
|; + if ($area eq 'board') { + $db_handling = $ENV{'form.db_handling'}; + } elsif ($area eq 'users') { + $user_handling = $ENV{'form.user_handling'}; + } + } + } + my $manifest_result = &Apache::imsprocessor::process_manifest($cms,$tempdir,\%resources,\%items,\%hrefs,\%resinfo); + if ($manifest_result eq 'ok') { + &Apache::imsprocessor::target_resources(\%resources,\%imports,\@targets); + my $copy_result = &Apache::imsprocessor::copy_resources('CSTR',$cms,\%hrefs,$tempdir,\@targets,\%urls,$crs,$cdom,$chome,$destdir,$timenow); + + my @boards = (); + my @announcements = (); + my @quizzes = (); + my @surveys = (); + my @groups = (); + my %messages = (); + my @timestamp = (); + my %boardnum = (); + my @topurls = (); + my @topnames = (); + + &Apache::imsprocessor::process_resinfo($cms,'CSTR',$tempdir,$destdir,\%items,\%resources,\@boards,\@announcements,\@quizzes,\@surveys,\@groups,\%messages,\@timestamp,\%boardnum,\%resinfo,$udom,$uname,$cdom,$crs,$db_handling,$user_handling,\%total,$newdir,$seqstem,\@resrcfiles); + + &Apache::imsprocessor::build_structure($cms,'CSTR',$destdir,\%items,\%resinfo,\%resources,\%hrefs,$udom,$uname,$newdir,$timenow,$cdom,$crs,\@timestamp,\%total,\@boards,\@announcements,\@quizzes,\@surveys,\%boardnum,\@pages,\@sequences,\@topurls,\@topnames); + + $r->print("

Step 3: Publish your new LON-CAPA materials

"); + + if ($cms eq 'bb5') { + $r->print("Your IMS package has been processed successfully. A total of $total{seq} sequences, $total{page} pages, $total{board} bulletin boards, $total{quiz} quizzes, $total{surv} surveys and $total{prob} problems have been created.

\n"); + } elsif ($cms eq 'angel') { + $r->print("Your IMS package has been processed successfully. A total of $total{seq} sequences, $total{page} pages, and $total{board} bulletin boards have been created.

\n"); + } +# system (" rm -r -f $destdir/temp"); + } elsif ($manifest_result eq 'nomanifest') { + $r->print("Processing of your IMS package failed, because the IMS content package did not contain an IMS manifest file ."); + } +} + +# ---------------------------------------------------------------- Get LON-CAPA Course Coordinator roles for this user +sub get_ccroles { + my ($user,$dom,$crsentry,$crslist) = @_; + my %roles = (); + unless ($user eq '') { + %roles = &Apache::lonnet::dump('roles',$dom,$user); + } + my $iter = 0; + my @codes = (); + my %courses = (); + my @crslist = (); + my %descrip =(); + foreach my $key (keys %roles ) { + if ($key =~ m/^\/(\w+)\/(\w+)_cc$/) { + my $cdom = $1; + my $crs = $2; + my $role_end = 0; + my $role_start = 0; + my $active_chk = 1; + if ( $roles{$key} =~ m/^cc_(\d+)/ ) { + $role_end = $1; + if ( $roles{$key} =~ m/^cc_($role_end)_(\d+)$/ ) + { + $role_start = $2; + } + } + if ($role_start > 0) { + if (time < $role_start) { + $active_chk = 0; + } + } + if ($role_end > 0) { + if (time > $role_end) { + $active_chk = 0; + } + } + if ($active_chk) { + my $currcode = ''; + my %settings = &Apache::lonnet::get('environment',['internal.coursecode','description'],$cdom,$crs); + if (defined($settings{'description'}) ) { + $descrip{$crs} = $settings{'description'}; } else { - $output .= qq|
Link to file
|; + $descrip{$crs} = 'Unknown'; } - } - $output .= qq|
\n|; - } - chomp($output); - $output .= qq| -
-
- |; - } elsif ($$settings{$id}{class} eq 'QUESTION_TRUEFALSE') { - my $numfoils = @{$allanswers{$id}}; -# print "Number of foils is $numfoils\n"; - $output .= qq| - - - |; - for (my $k=0; $k<@{$allanswers{$id}}; $k++) { - $output .= " \n"; - } - chomp($output); - $output .= qq| - - - |; - } elsif ($$settings{$id}{class} eq 'QUESTION_MULTIPLEANSWER') { - my $numfoils = @{$allanswers{$id}}; -# print "Number of foils is $numfoils\n"; - $output .= qq| - - - |; - for (my $k=0; $k<@{$allanswers{$id}}; $k++) { - $output .= " \n"; - } - chomp($output); - $output .= qq| - - - |; - } elsif ($$settings{$id}{class} eq 'QUESTION_ORDER') { - my $numfoils = @{$allanswers{$id}}; - $output .= qq| - - - |; - for (my $k=0; $k<@{$allanswers{$id}}; $k++) { - $output .= " ".$$settings{$id}{$allanswers{$id}[$k]}{text}."\n"; - } - chomp($output); - $output .= qq| - - - |; - } elsif ($$settings{$id}{class} eq 'QUESTION_FILLINBLANK') { - my $numerical = 1; - for (my $k=0; $k<@{$allanswers{$id}}; $k++) { - unless ($$settings{$id}{$allanswers{$id}[$k]}{text} =~ m/^\d+\.?\d*$/) { - $numerical = 0; - } - } - if ($numerical) { - my $numans; - my $tol; - if (@{$allanswers{$id}} == 1) { - $tol = 5; - $numans = $$settings{$id}{$allanswers{$id}[0]}{text}; - } else { - my $min = $$settings{$id}{$allanswers{$id}[0]}{text}; - my $max = $$settings{$id}{$allanswers{$id}[0]}{text}; - for (my $k=1; $k<@{$allanswers{$id}}; $k++) { - if ($$settings{$id}{$allanswers{$id}[$k]}{text} <= $min) { - $min = $$settings{$id}{$allanswers{$id}[$k]}{text}; - } - if ($$settings{$id}{$allanswers{$id}[$k]}{text} >= $max) { - $max = $$settings{$id}{$allanswers{$id}[$k]}{text}; + if (defined($settings{'internal.coursecode'}) ) { + $currcode = $settings{'internal.coursecode'}; + if ($currcode eq '') { + $currcode = "____".$iter; + $iter ++; } + } else { + $currcode = "____".$iter; + $iter ++; } - $numans = ($max + $min)/2; - $tol = 100*($max - $min)/($numans*2); - } - $output .= qq| - - - - - - |; - } else { - if (@{$allanswers{$id}} == 1) { - $output .= qq| - - - - - |; - } else { - my @answertext = (); - for (my $k=0; $k<@{$allanswers{$id}}; $k++) { - $$settings{$id}{$allanswers{$id}[$k]}{text} =~ s/\|/\|/g; - push @answertext, $$settings{$id}{$allanswers{$id}[$k]}{text}; + unless (grep/^$currcode$/,@codes) { + push @codes,$currcode; + @{$courses{$currcode}} = (); } - my $regexpans = join('|',@answertext); - $regexpans = '/^('.$regexpans.')\b/'; - $output .= qq| - - - - - |; + push @{$courses{$currcode}}, $cdom.'/'.$crs; } } - } elsif ($$settings{$id}{class} eq "QUESTION_MATCH") { - $output .= qq| - - - -|; - for (my $k=0; $k<@{$allchoices{$id}}; $k++) { - $output .= qq| - -$$settings{$id}{$allchoices{$id}[$k]}{text} - - |; - } - $output .= qq| - -|; - for (my $k=0; $k<@{$allanswers{$id}}; $k++) { - $output .= qq| - -$$settings{$id}{$allanswers{$id}[$k]}{text} - - |; - } - $output .= qq| - - - |; - } - if ($container eq 'pool') { - $output .= qq|
- |; - open(PROB,">$newdir/$id.problem"); - print PROB $output; - close PROB; - } else { - $output .= qq|
- |; - open(PROB,">$newdir/$id.problem"); - print PROB $output; - close PROB; } - - } - } -} - - -sub create_ess { - my ($newdir,$qnid,$qsettings,$container) = @_; - my $output; - if ($container eq 'pool') { - $output = qq| - $$qsettings{text} -|; - } else { - $output = qq| - $$qsettings{text} -|; - } - $output .= qq| - - - - - $$qsettings{feedbackcorr} - -|; - if ($container eq 'pool') { - $output .= qq| - |; - open(PROB,">$newdir/$qnid.problem"); - print PROB $output; - close PROB; - } else { - $output .= qq| - |; - open(PROB,">$newdir/$qnid.problem"); - print PROB $output; - close PROB; + foreach my $code (sort @codes) { + foreach my $crsdom (@{$courses{$code}}) { + my ($cdom,$crs) = split/\//,$crsdom; + my $showcode = ''; + unless ($code =~m/^____\d+$/) { $showcode = $code; } + $$crsentry{$crsdom} = $showcode.':'.$descrip{$crs}; + push @{$crslist}, $crsdom; + } } return; } -sub process_announce { - my ($res,$docroot,$destdir,$settings) = @_; - my $xmlfile = $docroot."/temp/".$res.".dat"; - my @state = (); - my $id; - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - if ("@state" eq "ANNOUNCEMENT TITLE") { - $$settings{title} = $attr->{value}; - $$settings{startassessment} = (); -# print "Title is $$settings{title}\n"; - } elsif (@state eq "ANNOUNCEMENT DESCRIPTION FLAGS ISHTML") { - $$settings{ishtml} = $attr->{value}; - } elsif ("@state" eq "ANNOUNCEMENT DESCRIPTION FLAGS ISNEWLINELITERAL" ) { - $$settings{isnewline} = $attr->{value}; - } elsif ("@state" eq "CONTENT ISPERMANENT" ) { - $$settings{ispermanent} = $attr->{value}; - } elsif ("@state" eq "ANNOUNCEMENT FILES STARTASSESSMENT" ) { - $id = $attr->{id}; - $$settings{startassessment}{$id} = (); - } elsif ("@state" eq "ANNOUNCEMENT FILES STARTASSESSMENT ATTRIB" ) { - my $key = $attr->{key}; - $$settings{startassessment}{$id}{$key} = $attr->{value}; - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - if ("@state" eq "ANNOUNCEMENT DESCRIPTION TEXT") { - $$settings{maindata}{text} = $text; -# print "TEXT $text\n"; - } - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - pop @state; - }, "tagname"], - ); - $p->unbroken_text(1); - $p->parse_file($xmlfile); - $p->eof; -} - -sub process_content { - my ($res,$docroot,$destdir,$settings,$dom,$user) = @_; - my $xmlfile = $docroot."/temp/".$res.".dat"; - my $destresdir = $destdir; - $destresdir =~ s|/home/$user/public_html/|/res/$dom/$user/|; - my $filecount = 0; - my @state; - @{$$settings{files}} = (); - my $p = HTML::Parser->new - ( - xml_mode => 1, - start_h => - [sub { - my ($tagname, $attr) = @_; - push @state, $tagname; - if (@state eq "CONTENT MAINDATA") { - %{$$settings{maindata}} = (); - } elsif (@state eq "CONTENT MAINDATA TEXTCOLOR") { - $$settings{maindata}{color} = $attr->{value}; - } elsif (@state eq "CONTENT MAINDATA FLAGS ISHTML") { - $$settings{maindata}{ishtml} = $attr->{value}; - } elsif (@state eq "CONTENT MAINDATA FLAGS ISNEWLINELITERAL") { - $$settings{maindata}{isnewline} = $attr->{value}; - } elsif ("@state" eq "CONTENT FLAGS ISAVAILABLE" ) { - $$settings{isavailable} = $attr->{value}; - } elsif ("@state" eq "CONTENT FLAGS ISFOLDER" ) { - $$settings{isfolder} = $attr->{value}; - } elsif ("@state" eq "CONTENT FLAGS LAUNCHINNEWWINDOW" ) { - $$settings{newwindow} = $attr->{value}; - } elsif ("@state" eq "CONTENT FILES") { -# @{$$settings{files}} = (); - } elsif ("@state" eq "CONTENT FILES FILEREF") { - %{$$settings{files}[$filecount]} = (); - %{$$settings{files}[$filecount]{registry}} = (); - } elsif ("@state" eq "CONTENT FILES FILEREF RELFILE" ) { - $$settings{files}[$filecount]{'relfile'} = $attr->{value}; - } elsif ("@state" eq "CONTENT FILES FILEREF MIMETYPE") { - $$settings{files}[$filecount]{mimetype} = $attr->{value}; - } elsif ("@state" eq "CONTENT FILES FILEREF CONTENTTYPE") { - $$settings{files}[$filecount]{contenttype} = $attr->{value}; - } elsif ("@state" eq "CONTENT FILES FILEREF FILEACTION") { - $$settings{files}[$filecount]{fileaction} = $attr->{value}; - } elsif ("@state" eq "CONTENT FILES FILEREF PACKAGEPARENT") { - $$settings{files}[$filecount]{packageparent} = $attr->{value}; - } elsif ("@state" eq "CONTENT FILES FILEREF LINKNAME") { - $$settings{files}[$filecount]{linkname} = $attr->{value}; - } elsif ("@state" eq "CONTENT FILES FILEREF REGISTRY REGISTRYENTRY") { - my $key = $attr->{key}; - $$settings{files}[$filecount]{registry}{$key} = $attr->{value}; - } - }, "tagname, attr"], - text_h => - [sub { - my ($text) = @_; - if ("@state" eq "CONTENT TITLE") { - $$settings{title} = $text; - } elsif ("@state" eq "CONTENT MAINDATA TEXT") { - $$settings{maindata}{text} = $text; - } elsif ("@state" eq "CONTENT FILES FILEREF REFTEXT") { - $$settings{files}[$filecount]{reftext} = $text; - } - }, "dtext"], - end_h => - [sub { - my ($tagname) = @_; - if ("@state" eq "CONTENT FILES FILEREF") { - $filecount ++; - } - pop @state; - }, "tagname"], - ); - $p->unbroken_text(1); - $p->parse_file($xmlfile); - $p->eof; - my $linktag = ''; - my $fontcol = ''; - if (@{$$settings{files}} > 0) { - for (my $filecount=0; $filecount<@{$$settings{files}}; $filecount++) { - if ($$settings{files}[$filecount]{'fileaction'} eq 'embed') { - if ( $$settings{files}[$filecount]{reftext} =~ m#<\!\-\-\s_(\d+)\\_\s\-\-\>#) { - my $newtag = qq||; - $$settings{maindata}{text} =~ s#<\!\-\-\s_/($1)\\_\s\-\-\>#$newtag#; - } elsif ( $$settings{files}[$filecount]{reftext} =~m#^_/(\d+)\\_$# ) { - my $reftag = $1; - my $newtag; - if ($$settings{files}[$filecount]{mimetype} =~ m/^image/) { - $newtag = qq|$$settings{files}[$filecount]{registry}{alttext}//; -# $$settings{maindata}{text} =~ s//$newtag/; -# print STDERR $$settings{maindata}{text}; - } - } else { - my $filename=$$settings{files}[$filecount]{'relfile'}; -# print "File is $filename\n"; - my $newfilename="$destresdir/resfiles/$res/$$settings{files}[$filecount]{relfile}"; -# print "New filename is $newfilename\n"; - $$settings{maindata}{text} =~ s#(src|SRC|value)="$filename"#$1="$newfilename"#g; - } - } elsif ($$settings{files}[$filecount]{fileaction} eq 'link') { - $linktag = qq|$$settings{files}[$filecount]{linkname}|; - } elsif ($$settings{files}[$filecount]{fileaction} eq 'package') { -# print "Found a package\n"; - } - } - } - if (defined($$settings{maindata}{textcolor})) { - $fontcol = qq||; - } - if (defined($$settings{maindata}{text})) { - if ($$settings{maindata}{ishtml} eq "false") { - if ($$settings{maindata}{isnewline} eq "true") { - $$settings{maindata}{text} =~ s#\n#
#g; - } - } else { - $$settings{maindata}{text} = &HTML::Entities::decode($$settings{maindata}{text}); - } - } - - open(FILE,">$destdir/resfiles/$res.html"); - print FILE qq| - -$$settings{title} - - -$fontcol - |; - unless ($$settings{title} eq '') { - print FILE qq|$$settings{title}

\n|; - } - print FILE qq| -$$settings{maindata}{text} -$linktag|; - if (defined($$settings{maindata}{textcolor})) { - print FILE qq|
|; - } - print FILE qq| - - |; - close(FILE); -} - - - # ---------------------------------------------------------------- Main Handler sub handler { my $r=shift; @@ -1659,8 +756,13 @@ sub handler { my $current_page = ''; my $loadentries = ''; my $qcount = ''; + +# get personal information for this user + my $user=$ENV{'user.name'}; + my $dom=$ENV{'user.domain'}; + # -# phase two: re-attach user +# re-attach user # if ($ENV{'form.uploaduname'}) { $ENV{'form.filename'}='/priv/'.$ENV{'form.uploaduname'}.'/'. @@ -1689,28 +791,30 @@ sub handler { ' unspecified filename for upload', $r->filename); return HTTP_NOT_FOUND; } + my $zipupload = '/home/'.$uname.'/public_html'.$fn; my $pathname = &File::Basename::dirname($fn); my $fullpath = '/priv/'.$uname.$pathname; unless ($pathname eq '/') { $fullpath .= '/'; } my $loadentries = ''; + + my @areas = (); + my %cmsmap = (); + my %areaname = (); + my $numcrs = 0; + + &Apache::imsprocessor::ims_config(\@areas,\%cmsmap,\%areaname); # ----------------------------------------------------------- Start page output &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; - - if ($ENV{'form.phase'} eq 'three') { - $current_page = &display_control(); - my @PAGES = ('ChooseDir','Blackboard5','ANGEL','WebCT'); - $page_name = $PAGES[$current_page]; - - if ($page_name eq 'ChooseDir') { - &jscript_zero($fullpath,\$javascript); - } elsif ($page_name eq 'Confirmation') { - &jscript_two(\$javascript,$uname); - } - } elsif ($ENV{'form.phase'} eq 'two') { - &jscript_zero($fullpath,\$javascript); + + if ($ENV{'form.phase'} eq 'two') { + &jscript_one($fullpath,\$javascript,$uname,$udom); + } elsif ($ENV{'form.phase'} eq 'three') { + &jscript_two(\$javascript,$user,$dom,\$numcrs); + } elsif ($ENV{'form.phase'} eq 'four') { + &jscript_three(\$javascript); } $r->print("LON-CAPA Construction Space\n"); @@ -1719,19 +823,22 @@ sub handler { if (($uname ne $ENV{'user.name'}) || ($udom ne $ENV{'user.domain'})) { $r->print('

'.&mt('Co-Author').': '.$uname. &mt(' at ').$udom.'

'); - } - - if ($ENV{'form.phase'} eq 'three') { - &display_zero ($r,$uname,$fn,$current_page) if $page_name eq 'ChooseDir'; - &expand_bb5 ($r,$uname,$udom,$fn,$fullpath,$current_page) if $page_name eq 'Blackboard5'; - &expand_angel ($r,$uname,$udom,$fn,$fullpath,$current_page) if $page_name eq 'ANGEL'; - &expand_webct ($r,$uname,$udom,$fn,$fullpath,$current_page) if $page_name eq 'WebCT'; - - } elsif ($ENV{'form.phase'} eq 'two') { + } + if ($ENV{'form.phase'} eq 'two') { my $flag = &Apache::lonupload::phasetwo($r,$fn,$uname,$udom,'imsimport'); if ($flag eq 'ok') { - my $current_page = 0; - &display_zero($r,$uname,$fn,$current_page); + &display_one($r,$uname,$fn,$fullpath); + } + } elsif ( ($ENV{'form.phase'} eq 'three') || ($ENV{'form.phase'} eq 'four') ) { + my $docroot = $ENV{'form.newdir'}; + my $newdir = ''; + if ($docroot =~ m|public_html/(.+)$|) { + $newdir = $1; + } + if ($ENV{'form.phase'} eq 'three') { + &display_two ($r,$zipupload,\@areas,\%areaname,\%cmsmap,$uname,$newdir,\$numcrs,$fullpath); + } elsif ($ENV{'form.phase'} eq 'four') { + &display_three ($r,$uname,$udom,\@areas,\%areaname,\%cmsmap,$docroot,$newdir); } } else { &Apache::lonupload::phaseone($r,$fn,$uname,$udom,'imsimport');