--- loncom/enrollment/Enrollment.pm 2004/08/23 17:07:27 1.17
+++ loncom/enrollment/Enrollment.pm 2006/01/12 01:30:44 1.27
@@ -1,5 +1,5 @@
# Automated Enrollment manager
-# $Id: Enrollment.pm,v 1.17 2004/08/23 17:07:27 raeburn Exp $
+# $Id: Enrollment.pm,v 1.27 2006/01/12 01:30:44 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -37,10 +37,13 @@ use strict;
sub update_LC {
my ($dom,$crs,$adds,$drops,$startdate,$enddate,$authtype,$autharg,$classesref,$groupref,$logmsg,$newusermsg,$context) = @_;
+# Get institutional code and title of this class
+ my %courseinfo = ();
+ &get_courseinfo($dom,$crs,\%courseinfo);
# Get current LON-CAPA student enrollment for this class
my $configvars = &LONCAPA::Configuration::read_conf('loncapa.conf');
my $cid = $dom."_".$crs;
- my $roster = &Apache::loncoursedata::get_classlist($cid,$dom,$crs);
+ my $roster = &Apache::loncoursedata::get_classlist($dom,$crs);
my $cend = &Apache::loncoursedata::CL_END;
my $cstart = &Apache::loncoursedata::CL_START;
my $stuid=&Apache::loncoursedata::CL_ID;
@@ -51,6 +54,7 @@ sub update_LC {
my @localstudents = ();
my @futurestudents = ();
my @activestudents = ();
+ my @excludedstudents = ();
my $currlist;
foreach my $uname (keys %{$roster} ) {
if ($uname =~ m/^(.+):$dom$/) {
@@ -62,12 +66,15 @@ sub update_LC {
push @futurestudents, $1;
@{$$currlist{$1}} = @{$$roster{$uname}};
push @localstudents, $1;
+ } elsif ($$roster{$uname}[$lockedtype] == 1) {
+ push @excludedstudents, $1;
}
}
}
my $linefeed = '';
my $addresult = '';
my $dropresult = '';
+ my $switchresult = '';
if ($context eq "updatenow") {
$linefeed = "\n
";
} elsif ($context eq "automated") {
@@ -75,6 +82,18 @@ sub update_LC {
}
my $enrollcount = 0;
my $dropcount = 0;
+ my $switchcount = 0;
+
+# Get role names
+ my %longroles = ();
+ open(FILE,"<$$configvars{'lonTabDir'}.'/rolesplain.tab");
+ my @rolesplain = ;
+ close(FILE);
+ foreach (@rolesplain) {
+ if ($_ =~ /^(st|ta|ex|ad|in|cc):([\w\s]+)$/) {
+ $longroles{$1} = $2;
+ }
+ }
srand( time() ^ ($$ + ($$ << 15)) ); # Seed rand in case initial passwords have to be generated for new users.
@@ -124,7 +143,9 @@ sub update_LC {
# Check for multiple sections for a single student
my @okusers = ();
foreach my $uname (@reg_students) {
- if (@{$allenrolled{$uname}} > 1) {
+ if (grep/^$uname$/,@excludedstudents) {
+ $$logmsg .= "No re-enrollment for $uname - user was previously manually unenrolled and locked.".$linefeed;
+ } elsif (@{$allenrolled{$uname}} > 1) {
my @sections = ();
my $saved;
for (my $i=0; $i<@{$allenrolled{$uname}}; $i++) {
@@ -146,7 +167,7 @@ sub update_LC {
push @okusers, $uname;
}
elsif (@sections > 1) {
- $$logmsg = "$uname appears in classlists for the more than one section of this course, i.e. in sections: ";
+ $$logmsg .= "$uname appears in classlists for more than one section of this course, i.e. in sections: ";
foreach (@sections) {
$$logmsg .= " $_,";
}
@@ -173,7 +194,7 @@ sub update_LC {
}
# Explicitly allow access to creation/modification of students if called as an automated process.
if ($context eq 'automated') {
- $ENV{'allowed.cst'}='F';
+ $env{'allowed.cst'}='F';
}
# Compare IDs with existing LON-CAPA enrollment for this class
@@ -201,7 +222,11 @@ sub update_LC {
my ($auth,$authparam,$first,$middle,$last,$gene,$usec,$end,$start,$emailaddr,$pid,$emailenc);
&prepare_add($authtype,$autharg,$enddate,$startdate,\@stuinfo,\%place,\$dom,\$uname,\$auth,\$authparam,\$first,\$middle,\$last,\$gene,\$usec,\$end,\$start,\$emailaddr,\$pid,\$emailenc);
if ($$currlist{$uname}[$sec] ne $usec) {
- $$logmsg .= "Section for $uname switched from $$currlist{$uname}[$sec] to $usec".$linefeed;
+ $switchresult .= "Section for $uname switched from $$currlist{$uname}[$sec] to ".$usec.$linefeed;
+ if ($context eq 'automated') {
+ $$logmsg .= "Section switch for $uname from $$currlist{$uname}[$sec] to ".$usec.$linefeed; ;
+ }
+ $switchcount ++;
}
&execute_add($context,'switchtype',$uname,$dom,$auth,$authparam,$first,$middle,$last,$gene,$pid,$usec,$end,$start,$emailenc,$cid,\$addresult,\$enrollcount,$linefeed,$logmsg);
}
@@ -240,7 +265,11 @@ sub update_LC {
$access = &showaccess($enddate,$startdate);
}
if ($modify_section_result =~ /^ok/) {
- $$logmsg .= "Section for $uname switched from old section: ".$$currlist{$uname}[$sec] ." to new section: ".$stuinfo[ $place{groupID} ].".".$access.$linefeed;
+ $switchresult .= "Section for $uname switched from old section: ".$$currlist{$uname}[$sec] ." to new section: ".$stuinfo[ $place{groupID} ].".".$access.$linefeed;
+ if ($context eq 'automated') {
+ $$logmsg .= "Section switch for $uname from $$currlist{$uname}[$sec] to $stuinfo[ $place{groupID} ]".$linefeed;
+ }
+ $switchcount ++;
} else {
$$logmsg .= "Error when attempting section change for $uname from old section ".$$currlist{$uname}[$sec]." to new section: ".$stuinfo[ $place{groupID} ]." -error: $modify_section_result".$linefeed;
}
@@ -252,12 +281,16 @@ sub update_LC {
} else {
# Check for changed usernames by checking studentIDs
if ( ($stuinfo[ $place{studentID} ] ne '') && (grep/^$stuinfo[ $place{studentID} ]$/,@LCids) ) {
- if (grep/^$$currlist{$uname}[ $place{'studentID'} ]$/,@allINids) {
- foreach my $match ( @{ $unameFromLCid{ $stuinfo[ $place{studentID} ] } } ) {
- if (grep/^$match$/,@okusers) {
- $$logmsg .= "A possible change in username has been detected for a student enrolled in this course. The existing LON-CAPA classlist contains user: $uname and student ID: ".$$currlist{$uname}[ $place{studentID} ].". This username has been dropped from the institutional classlist, but the same student ID is used for user: $match who still appears in the institutional classlist. You may need to contact your Domain Coordinator to request a move of the student data files for user: $uname to $match".$linefeed;
+ foreach my $match ( @{ $unameFromLCid{ $stuinfo[ $place{studentID} ] } } ) {
+ $$logmsg .= "A possible change in username has been detected for a student enrolled in this course. The existing LON-CAPA classlist contains user: $match and student ID: ".$stuinfo[ $place{studentID} ].". ";
+ if (grep/^$match$/,@okusers) {
+ $$logmsg .= "The username $match remains in the institutional classlist, but the same student ID is used for new user: $uname now found in the institutional classlist. You may need to contact your Domain Coordinator to determine how to reolve this issue and whether to move student data files for user: $match to $uname. ";
+ } else {
+ unless ($drops == 1) {
+ $$logmsg .= "This username - $match - has been dropped from the institutional classlist, but the student ID of this user is also used by $uname who now appears in the institutional classlist. You may need to contact your Domain Coordinator to request a move of the student data files for user: $match to $uname. ";
}
}
+ $$logmsg .= "Because of this student ID conflict, the new username - $uname - has not been added to the LON-CAPA classlist.".$linefeed;
}
} elsif ($adds == 1) {
my ($auth,$authparam,$first,$middle,$last,$gene,$usec,$end,$start,$emailaddr,$pid,$emailenc);
@@ -265,70 +298,28 @@ sub update_LC {
# Check for existing account in this LON-CAPA domain for this username
my $uhome=&Apache::lonnet::homeserver($uname,$dom);
if ($uhome eq 'no_host') { # User does not exist
- my $create_passwd = 0;
- my $authchk = '';
- unless ($authparam eq '') { $authchk = 'ok'; };
-# If no account exists and passwords should be generated
- if ($auth eq "internal") {
- if ($authparam eq '') {
- ($authparam) = &create_password();
- if ($authparam eq '') {
- $authchk = '';
- } else {
- $create_passwd = 1;
- $authchk = 'ok';
- }
- }
- } elsif ($auth eq "localauth") {
- ($authparam,$create_passwd,$authchk) = &Apache::lonnet::auto_create_password($crs,$dom,$authparam);
- } elsif ($auth =~ m/^krb/) {
- if ($authparam eq '') {
- $$logmsg .= "No Kerberos domain was provided for the new user - $uname, so the new student was not enrolled in the course.".$linefeed;
- $authchk = 'invalid';
- }
- } else {
- $authchk = 'invalid';
- $$logmsg .= "An invalid authentication type was provided for the new user - $uname, so the student was not enrolled in the course.".$linefeed;
- }
- if ($authchk eq 'ok') {
-# Now create user.
- my $reply=&Apache::lonnet::modifystudent($dom,$uname,$pid,$auth,$authparam,$first,$middle,$last,$gene,$usec,$end,$start,'',undef,$emailaddr,'auto','',$cid);
- if ($reply eq 'ok') {
- $access = &showaccess($end,$start);
- $enrollcount ++;
- $addresult .= "$first $last ($pid) - $uname enrolled in section/group $usec.".$access.$linefeed;
- if ($context eq 'automated') {
- $$logmsg .= "New $dom user $uname added successfully.";
- }
- unless ($emailenc eq '') {
- my %emailHash;
- $emailHash{'critnotification'} = $emailenc;
- $emailHash{'notification'} = $emailenc;
- my $putresult = &Apache::lonnet::put('environment',\%emailHash,$dom,$uname);
- }
- if ($create_passwd) {
-# Send e-mail with initial password to new user at $emailaddr.
-# If e-mail address is invalid, send password via message to courseowner i
-# (if automated call) or to user if roster update.
- if ($emailaddr eq '') {
- $$newusermsg .= " username: $uname, password: ".$authparam.$linefeed."\n";
- } else {
- my $subject = "New LON-CAPA account";
- my $body = "You have been enrolled in the LON-CAPA system at your school, because you are a registered student in a class that is using the LON-CAPA course management and online homework system.\n\nYou should log-in to the system using the following credentials:\nusername: $uname\npassword: $authparam\n\nThe URL you should use to access the LON-CAPA system at your school is: http://".$ENV{'SERVER_NAME'};
- &Apache::lonmsg::sendemail($emailaddr,$subject,$body);
- }
- if ($context eq 'automated') {
- $$logmsg .= " Initial password - - sent to ".$emailaddr.$linefeed;
- }
- } else {
- if ($context eq 'automated') {
- $$logmsg .= $linefeed;
- }
- }
- } else {
- $$logmsg .= "An error occurred adding new user $uname - ".$reply.$linefeed;
- }
- }
+ my $args = {'auth' => $auth,
+ 'authparam' => $authparam,
+ 'emailenc' => $emailenc,
+ 'udom' => $dom,
+ 'uname' => $uname,
+ 'pid' => $pid,
+ 'first' => $first,
+ 'middle' => $middle,
+ 'last' => $last,
+ 'gene' => $gene,
+ 'usec' => $usec,
+ 'end' => $end,
+ 'start' => $start,
+ 'emailaddr' => $emailaddr,
+ 'cid' => $cid,
+ 'crs' => $crs,
+ 'cdom' => $dom,
+ 'context' => $context,
+ 'linefeed' => $linefeed,
+ 'role' => 'st'
+ };
+ my $outcome = &create_newuser($args,$logmsg,$newusermsg,\$enrollcount,\$addresult,\%longroles,\%courseinfo);
} else {
&execute_add($context,'newstudent',$uname,$dom,$auth,$authparam,$first,$middle,$last,$gene,$pid,$usec,$end,$start,$emailenc,$cid,\$addresult,\$enrollcount,$linefeed,$logmsg);
}
@@ -345,7 +336,7 @@ sub update_LC {
# Check for changed usernames by checking studentIDs
if (grep/^$$currlist{$uname}[ $stuid ]$/,@allINids) {
foreach my $match (@{$unameFromINid{$$currlist{$uname}[ $stuid ]}} ) {
- $$logmsg .= "A possible change in username has been detected for a student enrolled in this course. The existing LON-CAPA classlist contains user: $uname and student ID: $$currlist{$uname}[ $place{studentID} ]. This username has been dropped from the institutional classlist, but the same student ID is used for user: $match who still appears in the institutional classlist. You may need to move the student data files for user: $uname to $match.".$linefeed;
+ $$logmsg .= "A possible change in username has been detected for a student enrolled in this course. The existing LON-CAPA classlist contains user: $uname and student ID: $$currlist{$uname}[ $place{studentID} ]. This username has been dropped from the institutional classlist, but the same student ID is used for user: $match who still appears in the institutional classlist. You may need to move the student data files for user: $uname to $match. Because of this, user $uname has not been dropped from the course.".$linefeed;
push @saved,$uname;
}
} elsif (@saved == 0) {
@@ -368,24 +359,32 @@ sub update_LC {
# Terminated explictly allowed access to student creation/modification
if ($context eq 'automated') {
- delete($ENV{'allowed.cst'});
+ delete($env{'allowed.cst'});
}
if ($enrollcount > 0) {
if ($context eq "updatenow") {
$addresult = substr($addresult,0,rindex($addresult,""));
- $addresult = "The following $enrollcount student(s) was/were added to this LON-CAPA course:
";
+ $addresult = "The following $enrollcount student(s) was/were added to this LON-CAPA course:
";
} else {
- $addresult = "The following $enrollcount student(s) was/were added to this LON-CAPA course:\n\n".$addresult."\n\n";
- }
+ $addresult = "The following $enrollcount student(s) was/were added to this LON-CAPA course:\n\n".$addresult."\n\n";
+ }
}
if ($dropcount > 0) {
if ($context eq "updatenow") {
$dropresult = substr($dropresult,0,rindex($dropresult,""));
- $dropresult = "The following $dropcount student(s) was/were expired from this LON-CAPA course:
";
+ $dropresult = "The following $dropcount student(s) was/were expired from this LON-CAPA course:
";
} else {
$dropresult = "The following $dropcount student(s) was/were expired from this LON-CAPA course:\n\n".$dropresult."\n\n";
}
}
+ if ($switchcount > 0) {
+ if ($context eq "updatenow") {
+ $switchresult = substr($switchresult,0,rindex($switchresult,""));
+ $switchresult = "The following $switchcount student(s) switched sections in this LON-CAPA course:
";
+ } else {
+ $switchresult = "The following $switchcount student(s) switched sections in this LON-CAPA course:\n\n".$switchresult."\n\n";
+ }
+ }
if ( ($adds) && ($enrollcount == 0) ) {
$addresult = "There were no new students to add to the course.";
if ($context eq "updatenow") {
@@ -402,8 +401,129 @@ sub update_LC {
$dropresult .="\n";
}
}
- my $changecount = $enrollcount + $dropcount;
- return ($changecount,$addresult.$dropresult);
+ my $changecount = $enrollcount + $dropcount + $switchcount;
+ return ($changecount,$addresult.$dropresult.$switchresult);
+}
+
+sub create_newuser {
+ my ($args,$logmsg,$newusermsg,$enrollcount,$addresult,$longroles,$courseinfo) = @_;
+ my $auth = $args->{'auth'};
+ my $authparam = $args->{'authparam'};
+ my $emailenc = $args->{'emailenc'};
+ my $udom = $args->{'udom'};
+ my $uname = $args->{'uname'};
+ my $pid = $args->{'pid'};
+ my $first = $args->{'first'};
+ my $middle = $args->{'middle'};
+ my $last = $args->{'last'} ;
+ my $gene = $args->{'gene'};
+ my $usec = $args->{'usec'};
+ my $end = $args->{'end'};
+ my $start = $args->{'start'};
+ my $emailaddr = $args->{'emailaddr'};
+ my $cid = $args->{'cid'};
+ my $crs = $args->{'crs'};
+ my $cdom = $args->{'cdom'};
+ my $context = $args->{'context'};
+ my $linefeed = $args->{'linefeed'};
+ my $role = $args->{'role'};
+ my $create_passwd = 0;
+ my $authchk = '';
+ my $outcome;
+ unless ($authparam eq '') { $authchk = 'ok'; };
+# If no account exists and passwords should be generated
+ if ($auth eq "internal") {
+ if ($authparam eq '') {
+ $authparam = &create_password();
+ if ($authparam eq '') {
+ $authchk = '';
+ } else {
+ $create_passwd = 1;
+ $authchk = 'ok';
+ }
+ }
+ } elsif ($auth eq "localauth") {
+ ($authparam,$create_passwd,$authchk) = &Apache::lonnet::auto_create_password($crs,$cdom,$authparam);
+ } elsif ($auth =~ m/^krb/) {
+ if ($authparam eq '') {
+ $$logmsg .= "No Kerberos domain was provided for the new user - $uname, so the new user was not enrolled in the course.".$linefeed;
+ $authchk = 'invalid';
+ }
+ } else {
+ $authchk = 'invalid';
+ $$logmsg .= "An invalid authentication type was provided for the new user - $uname, so the user was not enrolled in the course.".$linefeed;
+ }
+ if ($authchk eq 'ok') {
+# Now create user.
+ my $type = 'auto';
+ my $userurl = '/'.$cdom.'/'.$crs;
+ if ($usec ne '') {
+ $userurl .= '/'.$usec;
+ }
+ if ($context eq 'createowner' || $context eq 'createcourse') {
+ my $result = &Apache::lonnet::modifyuser($udom,$uname,$pid,$auth,$authparam,$first,$middle,$last,$gene,'1',undef,$emailaddr);
+ if ($result eq 'ok' && $context eq 'createcourse') {
+ $outcome = &Apache::loncreateuser::commit_standardrole($udom,$uname,$userurl,$role,$start,$end,$cdom,$crs,$usec);
+ unless ($outcome =~ /^Error:/) {
+ $outcome = 'ok';
+ }
+ } else {
+ $outcome = $result;
+ }
+ } else {
+ $outcome=&Apache::lonnet::modifystudent($udom,$uname,$pid,$auth,$authparam,$first,$middle,$last,$gene,$usec,$end,$start,'',undef,$emailaddr,'auto','',$cid);
+ }
+ if ($outcome eq 'ok') {
+ my $access = &showaccess($end,$start);
+ $$addresult .= "$first $last ($pid) - $uname enrolled in section/group $usec.".$access.$linefeed;
+ unless ($context eq 'createowner' || $context eq 'createcourse') {
+ $$enrollcount ++;
+ }
+ if ($context eq 'automated') {
+ $$logmsg .= "New $udom user $uname added successfully.";
+ }
+ unless ($emailenc eq '' || $context eq 'createowner' || $context eq 'createcourse') {
+ my %emailHash;
+ $emailHash{'critnotification'} = $emailenc;
+ $emailHash{'notification'} = $emailenc;
+ $emailHash{'permanentemail'} = $emailenc;
+ my $putresult = &Apache::lonnet::put('environment',\%emailHash,$udom,$uname);
+ }
+ if ($create_passwd) {
+# Send e-mail with initial password to new user at $emailaddr.
+# If e-mail address is invalid, send password via message to courseowner i
+# (if automated call) or to user if roster update.
+ if ($emailaddr eq '') {
+ $$newusermsg .= " username: $uname, password: ".$authparam.$linefeed."\n";
+ } else {
+ my $subject = "New LON-CAPA account";
+ my $body;
+ if ($context eq 'createowner') {
+ $body = "A user account has been created for you while creating your new course in the LON-CAPA course management and online homework system.\n\nYou should log-in to the system using the following credentials:\nusername: $uname\npassword: $authparam\n\nThe URL you should use to access the LON-CAPA system at your school is: http://".$ENV{'SERVER_NAME'}."\n\n";
+ } elsif ($context eq 'createcourse') {
+ $body = "You have been assigned the role of $$longroles{$role} in a new course: $$courseinfo{'description'} - $$courseinfo{'inst_code'} in the LON-CAPA course management and online homework system. As you did not have an existing user account in the system, one has been created for you.\n\nYou should log-in to the system using the following credentials:\nusername: $uname\npassword: $authparam\n\nThe URL you should use to access the LON-CAPA system at your school is: http://".$ENV{'SERVER_NAME'}."\n\n";
+ } else {
+ my $access_start = 'immediately';
+ if ($start > 0) {
+ $access_start = localtime($start)
+ }
+ $body = "You have been enrolled in the LON-CAPA system at your school, because you are a registered student in a class that is using the LON-CAPA couse management and online homework system.\n\nYou should log-in to the system using the following credentials:\nusername: $uname\npassword: $authparam\n\nThe URL you should use to access the LON-CAPA system at your school is: http://".$ENV{'SERVER_NAME'}."\n\n.When you log-in you will be able to access the LON-CAPA course for $$courseinfo{'description'} - $$courseinfo{'inst_code'} starting $access_start.\n";
+ }
+ &Apache::lonmsg::sendemail($emailaddr,$subject,$body);
+ }
+ if ($context eq 'automated') {
+ $$logmsg .= " Initial password - - sent to ".$emailaddr.$linefeed;
+ }
+ } else {
+ if ($context eq 'automated') {
+ $$logmsg .= $linefeed;
+ }
+ }
+ } else {
+ $$logmsg .= "An error occurred adding new user $uname - ".$outcome.$linefeed;
+ }
+ }
+ return $outcome;
}
sub prepare_add {
@@ -449,7 +569,7 @@ sub prepare_add {
sub execute_add {
my ($context,$caller,$uname,$dom,$auth,$authparam,$first,$middle,$last,$gene,$pid,$usec,$end,$start,$emailenc,$cid,$addresult,$enrollcount,$linefeed,$logmsg) = @_;
# Get the user's information and authentication
- my %userenv = &Apache::lonnet::get('environment',['firstname','middlename','lastname','generation','id','critnotification','notification'],$dom,$uname);
+ my %userenv = &Apache::lonnet::get('environment',['firstname','middlename','lastname','generation','id','critnotification','notification','permanentemail'],$dom,$uname);
my ($tmp) = keys(%userenv);
if ($tmp =~ /^(con_lost|error)/i) {
%userenv = ();
@@ -462,11 +582,17 @@ sub execute_add {
}
}
if ($userenv{notification} =~ m/%40/) {
- unless ($emailenc eq $userenv{critnotification}) {
+ unless ($emailenc eq $userenv{notification}) {
$$logmsg .= "Current standard notification e-mail
- ".$userenv{notification}." for $uname is different to e-mail address in institutional classlist - ".$emailenc.$linefeed;
}
}
+ if ($userenv{permanentemail} =~ m/%40/) {
+ unless ($emailenc eq $userenv{permanentemail}) {
+ $$logmsg .= "Current permanent e-mail
+- ".$userenv{permanentemail}." for $uname is different to e-mail address in institutional classlist - ".$emailenc.$linefeed;
+ }
+ }
my $krbdefdom = '';
my $currentauth=&Apache::lonnet::queryauthenticate($uname,$dom);
if ($currentauth=~/^(krb[45]):(.*)/) {
@@ -491,7 +617,8 @@ sub execute_add {
$middle ne $userenv{'middlename'} ||
$last ne $userenv{'lastname'} ||
$gene ne $userenv{'generation'} ||
- $pid ne $userenv{'id'} ) {
+ $pid ne $userenv{'id'} ||
+ $emailenc ne $userenv{'permanentemail'} ) {
# Make the change(s)
my %changeHash;
$changeHash{'firstname'} = $first;
@@ -499,6 +626,7 @@ sub execute_add {
$changeHash{'lastname'} = $last;
$changeHash{'generation'} = $gene;
$changeHash{'id'} = $pid;
+ $changeHash{'permanentemail'} = $emailenc;
my $putresult = &Apache::lonnet::put('environment',\%changeHash,$dom,$uname);
if ($putresult eq 'ok') {
$$logmsg .= "User information updated for user: $uname prior to enrollment.".$linefeed;
@@ -655,42 +783,20 @@ sub create_password {
return ($passwd);
}
-sub check_user_status {
- my ($udom,$uname,$cdom,$crs,$role,$secgrp) = @_;
- my %userinfo = &Apache::lonnet::dump('roles',$udom,$uname);
- my @uroles = keys %userinfo;
- my $srchstr;
- my $active_chk = 'none';
- if (@uroles > 0) {
- if ( ($role eq 'cc') || ($secgrp eq '') || ( !defined($secgrp) ) ) {
- $srchstr = '/'.$cdom.'/'.$crs.'_'.$role;
- } else {
- $srchstr = '/'.$cdom.'/'.$crs.'/'.$secgrp.'_'.$role;
- }
- if (grep/^$srchstr$/,@uroles) {
- my $role_end = 0;
- my $role_start = 0;
- $active_chk = 'ok';
- if ( $userinfo{$srchstr} =~ m/^($role)_(\d+)/ ) {
- $role_end = $2;
- if ( $userinfo{$srchstr} =~ m/^($role)_($role_end)_(\d+)$/ )
- {
- $role_start = $3;
- }
- }
- if ($role_start > 0) {
- if (time < $role_start) {
- $active_chk = 'expired';
- }
- }
- if ($role_end > 0) {
- if (time > $role_end) {
- $active_chk = 'expired';
- }
- }
+sub get_courseinfo {
+ my ($dom,$crs,$courseinfo) = @_;
+ my $owner;
+ if (defined($dom) && defined($crs)) {
+ my %settings = &Apache::lonnet::get('environment',['internal.coursecode','description'],$dom,$crs);
+ if ( defined($settings{'internal.coursecode'}) ) {
+ $$courseinfo{'inst_code'} = $settings{'internal.coursecode'};
+
+ }
+ if ( defined($settings{'description'}) ) {
+ $$courseinfo{'description'} = $settings{'description'};
}
}
- return $active_chk;
+ return;
}
sub CL_autharg { return 0; }