--- loncom/automation/Autocreate.pl 2011/03/06 21:17:23 1.17 +++ loncom/automation/Autocreate.pl 2016/11/16 18:09:21 1.20 @@ -2,7 +2,7 @@ # # Automated Course Creation script # -# $Id: Autocreate.pl,v 1.17 2011/03/06 21:17:23 raeburn Exp $ +# $Id: Autocreate.pl,v 1.20 2016/11/16 18:09:21 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -110,15 +110,14 @@ close($fh); exit; } - $env{'user.name'} = $dcname; - $env{'user.domain'} = $dcdom; - $env{'request.role.domain'} = $defdom; + &set_dc_env($dcname,$dcdom,$defdom); my @permissions = ('mau','ccc','cin','cta','cep','ccr','cst'); my %permissionflags = (); &set_permissions(\%permissionflags,\@permissions); my $output = &process_xml($fh,$defdom,$dcname,$dcdom); - print $output; &unset_permissions(\%permissionflags); + &unset_dc_env(); + print $output; } } else { my @permissions = ('mau','ccc','cin','cta','cep','ccr','cst'); @@ -132,9 +131,12 @@ my $settings; if (ref($domconfig{'autocreate'}) eq 'HASH') { $settings = $domconfig{'autocreate'}; + my ($dcname,$dcdom); + if ($settings->{'xmldc'}) { + ($dcname,$dcdom) = split(':',$settings->{'xmldc'}); + } if ($settings->{'xml'}) { if ($settings->{'xmldc'}) { - my ($dcname,$dcdom) = split(':',$settings->{'xmldc'}); if (!&check_activedc($dcdom,$dcname,$dom)) { print $fh "Autocreate.pl in domain $dom configured to run under the auspices of a user without an active domain coordinator role in the domain - course creation will be skipped.\n\n"; next; @@ -146,7 +148,9 @@ } } if ($settings->{'req'}) { + &set_dc_env($dcname,$dcdom); my $output = &Apache::loncoursequeueadmin::process_official_reqs('auto',$dom,$dcname,$dcdom); + &unset_dc_env(); if ($output) { print $fh $output; } @@ -161,10 +165,7 @@ sub process_xml { my ($fh,$dom,$dcname,$dcdom) = @_; - $env{'user.name'} = $dcname; - $env{'user.domain'} = $dcdom; - $env{'request.role.domain'} = $dom; - + &set_dc_env($dcname,$dcdom,$dom); # Initialize language handler &Apache::lonlocal::get_language_handle(); @@ -208,9 +209,7 @@ sub process_xml { $output .= $newcourse.':'; } $output =~ s/:$//; - delete($env{'user.name'}); - delete($env{'user.domain'}); - delete($env{'request.role.domain'}); + &unset_dc_env(); return $output; } @@ -240,3 +239,24 @@ sub unset_permissions { delete($env{"allowed.$allowtype"}); } } + +sub set_dc_env { + my ($dcname,$dcdom,$defdom) = @_; + $env{'user.name'} = $dcname; + $env{'user.domain'} = $dcdom; + $env{'user.home'} = &Apache::lonnet::homeserver($dcname,$dcdom); + if ($defdom ne '') { + $env{'request.role.domain'} = $defdom; + } + return; +} + +sub unset_dc_env { + delete($env{'user.name'}); + delete($env{'user.domain'}); + delete($env{'user.home'}); + if ($env{'request.role.domain'}) { + delete($env{'request.role.domain'}); + } + return; +}