version 1.52.2.6, 2024/07/02 13:55:53
|
version 1.63, 2022/11/23 02:55:37
|
Line 144 sub send_selfserve_notification {
|
Line 144 sub send_selfserve_notification {
|
push(@rawmsg,{ |
push(@rawmsg,{ |
mt => $msgtxt, |
mt => $msgtxt, |
args => ["\n ".$contextdesc.",\n",$timestamp.",\n"], |
args => ["\n ".$contextdesc.",\n",$timestamp.",\n"], |
|
|
}); |
}); |
if (ref($textstr) eq 'ARRAY') { |
if (ref($textstr) eq 'ARRAY') { |
push(@rawmsg,@{$textstr}); |
push(@rawmsg,@{$textstr}); |
Line 270 sub send_selfserve_notification {
|
Line 269 sub send_selfserve_notification {
|
if (ref($textstr) eq 'ARRAY') { |
if (ref($textstr) eq 'ARRAY') { |
push(@rawmsg,@{$textstr}); |
push(@rawmsg,@{$textstr}); |
} |
} |
|
} elsif ($context eq 'othdomroleuser') { |
|
my $linktext = 'Roles'; |
|
if (&Apache::loncommon::show_course()) { |
|
$linktext = 'Courses'; |
|
} |
|
$rawsubj = 'Role Assignment Approval'; |
|
push(@rawmsg,{ |
|
mt => 'A domain different to your own LON-CAPA domain ([_1]) wants to assign you a role in their domain.', |
|
args => ["\n$contextdesc\n"], |
|
}, |
|
{ |
|
mt =>"[_1]Click $linktext at top right, then click 'Manage Role Requests' in the gray Functions bar ". |
|
"to display a list of pending role assignments in other domain(s), which you can either accept or reject.", |
|
args => ["\n\n"], |
|
}); |
|
} elsif ($context eq 'othdomroledc') { |
|
$rawsubj = 'Role Assignment Authorization'; |
|
push(@rawmsg,{ |
|
mt => 'Another LON-CAPA domain wants to assign a role in their domain to a user from your domain.', |
|
args => [], |
|
}, |
|
{ |
|
mt =>'[_1]As Domain Coordinator, use: [_2]Main Menu -> Create users or modify the roles and privileges of users |
|
-> Queued Role Assignments (this domain) [_3]to display a list of pending requests, which you can either approve or reject.', |
|
args => ["\n","\n\n ","\n\n"], |
|
}); |
} |
} |
my @to_notify = split(/,/,$notifylist); |
my @to_notify = split(/,/,$notifylist); |
my $numsent = 0; |
my $numsent = 0; |
Line 304 sub send_selfserve_notification {
|
Line 329 sub send_selfserve_notification {
|
my $stamp = time; |
my $stamp = time; |
my $msgcount = &Apache::lonmsg::get_uniq(); |
my $msgcount = &Apache::lonmsg::get_uniq(); |
my $sender_lh = &Apache::loncommon::user_lang($uname,$udom,$cid); |
my $sender_lh = &Apache::loncommon::user_lang($uname,$udom,$cid); |
$subject = &Apache::lonlocal::mt_user($sender_lh,$rawsubj); |
$subject = &mt_user($sender_lh,$rawsubj); |
$message = ''; |
$message = ''; |
foreach my $item (@rawmsg) { |
foreach my $item (@rawmsg) { |
if (ref($item) eq 'HASH') { |
if (ref($item) eq 'HASH') { |
$message .= &Apache::lonlocal::mt_user($sender_lh,$item->{mt},@{$item->{args}})."\n"; |
$message .= &mt_user($sender_lh,$item->{mt},@{$item->{args}})."\n"; |
} |
} |
} |
} |
&Apache::lonmsg::process_sent_mail($subject,'',$numsent,$stamp,$uname,$udom,$msgcount,$cid,$$,$message, |
&Apache::lonmsg::process_sent_mail($subject,'',$numsent,$stamp,$uname,$udom,$msgcount,$cid,$$,$message, |
Line 322 sub send_selfserve_notification {
|
Line 347 sub send_selfserve_notification {
|
foreach my $recip (sort(keys(%{$msgcc}))) { |
foreach my $recip (sort(keys(%{$msgcc}))) { |
my ($ccname,$ccdom) = split(/:/,$recip); |
my ($ccname,$ccdom) = split(/:/,$recip); |
my $recip_lh = &Apache::loncommon::user_lang($ccname,$ccdom,$cid); |
my $recip_lh = &Apache::loncommon::user_lang($ccname,$ccdom,$cid); |
my $subject = &Apache::lonlocal::mt_user($sender_lh,$rawsubj); |
my $subject = &mt_user($sender_lh,$rawsubj); |
my $message = ''; |
my $message = ''; |
foreach my $item (@rawmsg) { |
foreach my $item (@rawmsg) { |
if (ref($item) eq 'HASH') { |
if (ref($item) eq 'HASH') { |
$message .= &Apache::lonlocal::mt_user($sender_lh,$item->{mt}, |
$message .= &mt_user($sender_lh,$item->{mt}, |
@{$item->{args}})."\n"; |
@{$item->{args}})."\n"; |
} |
} |
} |
} |
if ($context eq 'coursemanagers') { |
if ($context eq 'coursemanagers') { |
if ($approvedlist) { |
if ($approvedlist) { |
$message .= "\n\n".&Apache::lonlocal::mt_user($sender_lh,'Approved enrollments:')."\n".$approvedlist; |
$message .= "\n\n".&mt_user($sender_lh,'Approved enrollments:')."\n".$approvedlist; |
} |
} |
if ($rejectedlist) { |
if ($rejectedlist) { |
$message .= "\n\n".&Apache::lonlocal::mt_user($sender_lh,'Rejected enrollments:')."\n".$rejectedlist; |
$message .= "\n\n".&mt_user($sender_lh,'Rejected enrollments:')."\n".$rejectedlist; |
} |
} |
} elsif ($context eq 'domainmanagers') { |
} elsif ($context eq 'domainmanagers') { |
if ($approvedlist) { |
if ($approvedlist) { |
$message .= "\n\n".&Apache::lonlocal::mt_user($sender_lh,'Approved course requests:')."\n".$approvedlist; |
$message .= "\n\n".&mt_user($sender_lh,'Approved course requests:')."\n".$approvedlist; |
} |
} |
if ($rejectedlist) { |
if ($rejectedlist) { |
$message .= "\n\n".&Apache::lonlocal::mt_user($sender_lh,'Rejected course requests:')."\n".$rejectedlist; |
$message .= "\n\n".&mt_user($sender_lh,'Rejected course requests:')."\n".$rejectedlist; |
} |
} |
} elsif ($context eq 'authormanagers') { |
} elsif ($context eq 'authormanagers') { |
if ($approvedlist) { |
if ($approvedlist) { |
$message .= "\n\n".&Apache::lonlocal::mt_user($sender_lh,'Approved author role requests:')."\n".$approvedlist; |
$message .= "\n\n".&mt_user($sender_lh,'Approved author role requests:')."\n".$approvedlist; |
} |
} |
if ($rejectedlist) { |
if ($rejectedlist) { |
$message .= "\n\n".&Apache::lonlocal::mt_user($sender_lh,'Rejected author role requests:')."\n".$rejectedlist; |
$message .= "\n\n".&mt_user($sender_lh,'Rejected author role requests:')."\n".$rejectedlist; |
} |
} |
} elsif ($context eq 'usernamemanagers') { |
} elsif ($context eq 'usernamemanagers') { |
if ($approvedlist) { |
if ($approvedlist) { |
$message .= "\n\n".&Apache::lonlocal::mt_user($sender_lh,'Approved LON-CAPA account requests:')."\n".$approvedlist; |
$message .= "\n\n".&mt_user($sender_lh,'Approved LON-CAPA account requests:')."\n".$approvedlist; |
} |
} |
if ($rejectedlist) { |
if ($rejectedlist) { |
$message .= "\n\n".&Apache::lonlocal::mt_user($sender_lh,'Rejected LON-CAPA account requests:')."\n".$rejectedlist; |
$message .= "\n\n".&mt_user($sender_lh,'Rejected LON-CAPA account requests:')."\n".$rejectedlist; |
} |
} |
} |
} |
$status .= &Apache::lonmsg::user_normal_msg($ccname,$ccdom,$subject,$message,undef,undef,undef,1, |
$status .= &Apache::lonmsg::user_normal_msg($ccname,$ccdom,$subject,$message,undef,undef,undef,1, |
Line 371 sub send_selfserve_notification {
|
Line 396 sub send_selfserve_notification {
|
} |
} |
|
|
sub display_queued_requests { |
sub display_queued_requests { |
my ($context,$dom,$cnum) = @_; |
my ($context,$dom,$cnum,$secondary) = @_; |
my ($namespace,$formaction,$nextelement,%requesthash); |
my ($namespace,$formaction,$nextelement,%requesthash); |
if ($context eq 'course') { |
if ($context eq 'course') { |
$formaction = '/adm/createuser'; |
$formaction = '/adm/createuser'; |
Line 388 sub display_queued_requests {
|
Line 413 sub display_queued_requests {
|
$namespace = 'usernamequeue'; |
$namespace = 'usernamequeue'; |
%requesthash = &Apache::lonnet::dump_dom($namespace,$dom); |
%requesthash = &Apache::lonnet::dump_dom($namespace,$dom); |
$nextelement = '<input type="hidden" name="state" value="done" />'; |
$nextelement = '<input type="hidden" name="state" value="done" />'; |
|
} elsif ($context eq 'othdomqueue') { |
|
$formaction = '/adm/createuser'; |
|
$namespace = 'othdomqueued'; |
|
if ($secondary eq 'domain') { |
|
%requesthash = &Apache::lonnet::dump_dom($namespace,$dom); |
|
foreach my $key (keys(%requesthash)) { |
|
delete($requesthash{$key}) if ($key =~ /:(ca|aa)$/); |
|
} |
|
} elsif ($secondary eq 'author') { |
|
%requesthash = &Apache::lonnet::dump($namespace,$dom,$cnum); |
|
if ($cnum eq &Apache::lonnet::get_domainconfiguser($dom)) { |
|
foreach my $key (keys(%requesthash)) { |
|
delete($requesthash{$key}) if ($key !~ /:(ca|aa)$/); |
|
} |
|
} |
|
} else { |
|
%requesthash = &Apache::lonnet::dump($namespace,$dom,$cnum); |
|
} |
|
} elsif ($context eq 'othdomaction') { |
|
$formaction = '/adm/createuser'; |
|
$namespace = 'queuedrolereqs'; |
|
if ($secondary eq 'domain') { |
|
my $confname = &Apache::lonnet::get_domainconfiguser($dom); |
|
%requesthash = &Apache::lonnet::dump($namespace,$dom,$confname); |
|
} else { |
|
%requesthash = &Apache::lonnet::dump($namespace,$dom,$cnum); |
|
} |
|
$nextelement = '<input type="hidden" name="state" value="done" />'; |
} else { |
} else { |
$formaction = '/adm/createcourse'; |
$formaction = '/adm/createcourse'; |
$namespace = 'courserequestqueue'; |
$namespace = 'courserequestqueue'; |
Line 418 sub display_queued_requests {
|
Line 471 sub display_queued_requests {
|
} elsif ($context eq 'requestusername') { |
} elsif ($context eq 'requestusername') { |
$timestamp = $requesthash{$item}; |
$timestamp = $requesthash{$item}; |
($entry) = (&unescape($item) =~ /^($match_username)_approval$/); |
($entry) = (&unescape($item) =~ /^($match_username)_approval$/); |
|
} elsif ($context eq 'othdomqueue') { |
|
if (ref($requesthash{$item}) eq 'HASH') { |
|
my ($puname,$pudom,$prole,$psec) = split(/:/,$item); |
|
$timestamp = $requesthash{$item}{'timestamp'}; |
|
my $adj = $requesthash{$item}{'adj'}; |
|
$entry = join(':',$puname,$pudom,$prole,$adj, |
|
&escape($requesthash{$item}{'requester'}), |
|
$psec); |
|
} |
|
} elsif ($context eq 'othdomaction') { |
|
if (ref($requesthash{$item}) eq 'HASH') { |
|
$timestamp = $requesthash{$item}{'timestamp'}; |
|
$entry = &escape($item).':'.&escape($requesthash{$item}{'requester'}); |
|
} |
} else { |
} else { |
$timestamp = $requesthash{$item}{'timestamp'}; |
|
if (ref($requesthash{$item}) eq 'HASH') { |
if (ref($requesthash{$item}) eq 'HASH') { |
|
$timestamp = $requesthash{$item}{'timestamp'}; |
my ($cnum,$disposition) = split('_',$item); |
my ($cnum,$disposition) = split('_',$item); |
$entry = $cnum.':'.$requesthash{$item}{'ownername'}.':'. |
$entry = $cnum.':'.$requesthash{$item}{'ownername'}.':'. |
$requesthash{$item}{'ownerdom'}.':'; |
$requesthash{$item}{'ownerdom'}.':'; |
Line 453 sub display_queued_requests {
|
Line 520 sub display_queued_requests {
|
$output .= '<h3>'.&mt('Requests for Authoring Space queued pending approval by a Domain Coordinator').'</h3>'; |
$output .= '<h3>'.&mt('Requests for Authoring Space queued pending approval by a Domain Coordinator').'</h3>'; |
} elsif ($context eq 'requestusername') { |
} elsif ($context eq 'requestusername') { |
$output .= '<h3>'.&mt('Requests for LON-CAPA accounts queued pending approval by a Domain Coordinator').'</h3>'; |
$output .= '<h3>'.&mt('Requests for LON-CAPA accounts queued pending approval by a Domain Coordinator').'</h3>'; |
|
} elsif ($context eq 'othdomqueue') { |
|
if ($secondary eq 'domain') { |
|
$output .= '<h3>'.&mt('Domain role assignments for users from another domain, queued pending approval').'</h3>'; |
|
} elsif ($secondary eq 'author') { |
|
$output .= '<h3>'.&mt('Co-author role assignments for users from another domain, queued pending approval').'</h3>'; |
|
} elsif ($secondary eq 'course') { |
|
$output .= '<h3>'.&mt('Course role assignments for users from another domain, queued pending approval').'</h3>'; |
|
} elsif ($secondary eq 'community') { |
|
$output .= '<h3>'.&mt('Community role assignments for users from another domain, queued pending approval').'</h3>'; |
|
} |
|
} elsif ($context eq 'othdomaction') { |
|
if ($secondary eq 'user') { |
|
$output .= '<h3>'.&mt('Role assignments for you in other domains, queued pending your acceptance of the role.').'</h3>'; |
|
} elsif ($secondary eq 'domain') { |
|
$output .= '<h3>'.&mt('Role assignments in other domains, queued pending domain coordinator approval in this domain.').'</h3>'; |
|
} |
} else { |
} else { |
$output .= '<h3>'.&mt('Course/Community requests queued pending approval by a Domain Coordinator').'</h3>'; |
$output .= '<h3>'.&mt('Course/Community requests queued pending approval by a Domain Coordinator').'</h3>'; |
} |
} |
$output .= &build_queue_display($dom,$context,\%queue_by_date). |
$output .= &build_queue_display($dom,$context,\%queue_by_date,$secondary). |
'<input type="hidden" name="queue" value="approval" />'; |
'<input type="hidden" name="queue" value="approval" />'; |
} else { |
} else { |
$output .= '<div class="LC_info">'; |
$output .= '<div class="LC_info">'; |
Line 470 sub display_queued_requests {
|
Line 553 sub display_queued_requests {
|
$output .= &mt('There are currently no requests for LON-CAPA accounts awaiting approval.'); |
$output .= &mt('There are currently no requests for LON-CAPA accounts awaiting approval.'); |
} elsif ($context eq 'domain') { |
} elsif ($context eq 'domain') { |
$output .= &mt('There are currently no course or community requests awaiting approval.'); |
$output .= &mt('There are currently no course or community requests awaiting approval.'); |
|
} elsif ($context eq 'othdomqueue') { |
|
if ($secondary eq 'domain') { |
|
$output .= &mt('There are currently no domain role assignment(s) for user(s) from another domain queued pending approval'); |
|
} elsif ($secondary eq 'author') { |
|
$output .= &mt('There are currently no co-author role assignment(s) for user(s) from another domain queued pending approval'); |
|
} elsif ($secondary eq 'course') { |
|
$output .= &mt('There are currently no course role assignment(s) for user(s) from another domain queued pending approval'); |
|
} elsif ($secondary eq 'community') { |
|
$output .= &mt('There are currently no community role assignment(s) for user(s) from another domain queued pending approval'); |
|
} |
|
} elsif ($context eq 'othdomaction') { |
|
if ($secondary eq 'user') { |
|
$output .= &mt('There are currently no pending role assignments for you in other domains, queued pending your acceptance of the role.'); |
|
} elsif ($secondary eq 'domain') { |
|
$output .= &mt('There are currently no pending role assignments in other domains, queued pending domain coordinator approval in this domain.'); |
|
} |
} |
} |
$output .= '</div>'; |
$output .= '</div>'; |
} |
} |
if ($context eq 'pending') { |
if ($context eq 'pending') { |
$output .= '<br /><input type="submit" name="validationcheck" value="'. |
$output .= '<br /><input type="submit" name="validationcheck" value="'. |
&mt('Validate').'" /><br />'."\n". |
&mt('Validate').'" /><br />'."\n". |
'<p>'.&mt('Any course/community requests which are successfully validated will be created immediately.').' '. |
'<p>'.&mt('Any course/community requests which are successfully validated will be created immediately.').' '. |
&mt('Unvalidated requests will be listed for manual approval/rejection.').'</p>'; |
&mt('Unvalidated requests will be listed for manual approval/rejection.').'</p>'; |
} elsif (($context ne 'helpdesk') && ($context ne 'displaypending')) { |
} elsif (($context ne 'helpdesk') && ($context ne 'displaypending') && ($context ne 'othdomqueue')) { |
$output .= '<br /><input type="submit" name="processqueue" value="'.&mt('Save').'" />'; |
$output .= '<br /><input type="submit" name="processqueue" value="'.&mt('Save').'" />'; |
} |
} |
$output .= '</form>'; |
$output .= '</form>'; |
Line 492 sub display_queued_requests {
|
Line 591 sub display_queued_requests {
|
$output .= &mt('There are currently no requests for Authoring Space awaiting approval.'); |
$output .= &mt('There are currently no requests for Authoring Space awaiting approval.'); |
} elsif ($context eq 'requestusername') { |
} elsif ($context eq 'requestusername') { |
$output .= &mt('There are currently no requests for LON-CAPA accounts awaiting approval.'); |
$output .= &mt('There are currently no requests for LON-CAPA accounts awaiting approval.'); |
|
} elsif ($context eq 'othdomqueue') { |
|
if ($secondary eq 'domain') { |
|
$output .= &mt('There are currently no domain role assignment(s) for user(s) from another domain queued pending approval'); |
|
} elsif ($secondary eq 'author') { |
|
$output .= &mt('There are currently no co-author role assignment(s) for user(s) from another domain queued pending approval'); |
|
} elsif ($secondary eq 'course') { |
|
$output .= &mt('There are currently no course role assignment(s) for user(s) from another domain queued pending approval'); |
|
} elsif ($secondary eq 'community') { |
|
$output .= &mt('There are currently no community role assignment(s) for user(s) from another domain queued pending approval'); |
|
} |
|
} elsif ($context eq 'othdomaction') { |
|
if ($secondary eq 'user') { |
|
$output .= &mt('There are currently no pending role assignments for you in other domains, queued pending your acceptance of the role.'); |
|
} elsif ($secondary eq 'domain') { |
|
$output .= &mt('There are currently no pending role assignments in other domains, queued pending domain coordinator approval in this domain.'); |
|
} |
} else { |
} else { |
$output .= &mt('There are currently no course or community requests awaiting approval.'); |
$output .= &mt('There are currently no course or community requests awaiting approval.'); |
} |
} |
Line 501 sub display_queued_requests {
|
Line 616 sub display_queued_requests {
|
} |
} |
|
|
sub build_queue_display { |
sub build_queue_display { |
my ($dom,$context,$queue) = @_; |
my ($dom,$context,$queue,$secondary) = @_; |
return unless (ref($queue) eq 'HASH'); |
return unless (ref($queue) eq 'HASH'); |
my %crstypes; |
my (%crstypes,%roles_by_context); |
my $output = &Apache::loncommon::start_data_table(). |
my $output = &Apache::loncommon::start_data_table(). |
&Apache::loncommon::start_data_table_header_row(); |
&Apache::loncommon::start_data_table_header_row(); |
unless (($context eq 'pending') || ($context eq 'displaypending') || ($context eq 'helpdesk')) { |
unless (($context eq 'pending') || ($context eq 'displaypending') || |
|
($context eq 'helpdesk') || ($context eq 'othdomqueue')) { |
$output .= '<th>'.&mt('Action').'</th>'; |
$output .= '<th>'.&mt('Action').'</th>'; |
} |
} |
$output .= '<th>'.&mt('Requestor').'</th>'; |
unless (($context eq 'othdomqueue') || (($context eq 'othdomaction') && ($secondary eq 'user'))) { |
|
$output .= '<th>'.&mt('Requestor').'</th>'; |
|
} |
if ($context eq 'course') { |
if ($context eq 'course') { |
$output .= '<th>'.&mt('Section').'</th>'. |
$output .= '<th>'.&mt('Section').'</th>'. |
'<th>'.&mt('Date requested').'</th>'; |
'<th>'.&mt('Date requested').'</th>'; |
Line 518 sub build_queue_display {
|
Line 636 sub build_queue_display {
|
} elsif ($context eq 'requestusername') { |
} elsif ($context eq 'requestusername') { |
$output .= '<th>'.&mt('Date requested').'</th>'. |
$output .= '<th>'.&mt('Date requested').'</th>'. |
'<th>'.&mt('Details').'</th>'; |
'<th>'.&mt('Details').'</th>'; |
|
} elsif ($context eq 'othdomqueue') { |
|
$output .= '<th>'.&mt('Date requested').'</th>'. |
|
'<th>'.&mt('Role').'</th>'; |
|
if ($secondary eq 'course') { |
|
$output .= '<th>'.&mt('Section').'</th>'; |
|
} |
|
$output .= '<th>'.&mt('Requested for').'</th>'. |
|
'<th>'.&mt('Approval needed from').'</th>'; |
|
} elsif ($context eq 'othdomaction') { |
|
$output .= '<th>'.&mt('Date requested').'</th>'. |
|
'<th>'.&mt('Role type').'</th>'. |
|
'<th>'.&mt('Location').'</th>'; |
|
if ($secondary eq 'domain') { |
|
$output .= '<th>'.&mt('Affected User').'</th>'; |
|
} |
|
foreach my $type ('domain','course') { |
|
my @possroles = &Apache::lonuserutils::roles_by_context($type); |
|
$roles_by_context{$type} = \@possroles; |
|
} |
} elsif ($context eq 'pending' || $context eq 'displaypending' || $context eq 'stillpending') { |
} elsif ($context eq 'pending' || $context eq 'displaypending' || $context eq 'stillpending') { |
$output .= '<th>'.&mt('Institutional code').'</th>'. |
$output .= '<th>'.&mt('Institutional code').'</th>'. |
'<th>'.&mt('Date requested').'</th>'. |
'<th>'.&mt('Date requested').'</th>'. |
Line 528 sub build_queue_display {
|
Line 665 sub build_queue_display {
|
unofficial => 'Unofficial course', |
unofficial => 'Unofficial course', |
community => 'Community', |
community => 'Community', |
textbook => 'Textbook course', |
textbook => 'Textbook course', |
|
placement => 'Placement test', |
); |
); |
$output .= '<th>'.&mt('Type').'</th>'. |
$output .= '<th>'.&mt('Type').'</th>'. |
'<th>'.&mt('Date requested').'</th>'. |
'<th>'.&mt('Date requested').'</th>'. |
Line 540 sub build_queue_display {
|
Line 678 sub build_queue_display {
|
if (ref($queue->{$item}) eq 'ARRAY') { |
if (ref($queue->{$item}) eq 'ARRAY') { |
foreach my $request (sort(@{$queue->{$item}})) { |
foreach my $request (sort(@{$queue->{$item}})) { |
my ($row,$approve,$reject,$showtime,$showsec,$namelink, |
my ($row,$approve,$reject,$showtime,$showsec,$namelink, |
$detailslink,$crstype,$instcode); |
$detailslink,$crstype,$instcode,$showrole,$adjudicator, |
|
$location,$showrequester); |
$showtime = &Apache::lonlocal::locallocaltime($item); |
$showtime = &Apache::lonlocal::locallocaltime($item); |
if ($context eq 'course') { |
if ($context eq 'course') { |
my ($puname,$pudom,$pusec) = split(/:/,$request); |
my ($puname,$pudom,$pusec) = split(/:/,$request); |
Line 556 sub build_queue_display {
|
Line 695 sub build_queue_display {
|
} elsif ($context eq 'requestauthor') { |
} elsif ($context eq 'requestauthor') { |
if (&Apache::lonnet::homeserver($request,$dom) ne 'no_host') { |
if (&Apache::lonnet::homeserver($request,$dom) ne 'no_host') { |
$approve = $count.':'.$request; |
$approve = $count.':'.$request; |
$reject = $request; |
$reject = $request; |
$namelink = &Apache::loncommon::aboutmewrapper( |
$namelink = &Apache::loncommon::aboutmewrapper( |
&Apache::loncommon::plainname($request,$dom), |
&Apache::loncommon::plainname($request,$dom), |
$request,$dom); |
$request,$dom); |
Line 570 sub build_queue_display {
|
Line 709 sub build_queue_display {
|
"'$dom','$request','$queued'".');">'.$request.'</a>'; |
"'$dom','$request','$queued'".');">'.$request.'</a>'; |
$namelink = $request; |
$namelink = $request; |
} |
} |
|
} elsif ($context eq 'othdomqueue') { |
|
my ($uname,$udom,$role,$adj,$requester,$sec) = split(/:/,$request); |
|
if ($adj eq 'user') { |
|
$adjudicator = &mt('Role Assignee'); |
|
} elsif ($adj eq 'domain') { |
|
$adjudicator = &mt("[_1] in user's domain", |
|
&Apache::lonnet::plaintext('dc')); |
|
} |
|
my $crstype; |
|
$showrole = &Apache::lonnet::plaintext($role,$crstype); |
|
unless (&Apache::lonnet::homeserver($uname,$udom) eq 'no_host') { |
|
$namelink = &Apache::loncommon::plainname($uname,$udom)." ($uname:$udom)"; |
|
} |
|
if ($secondary eq 'course') { |
|
$showsec = $sec; |
|
if ($showsec eq '') { |
|
$showsec = &mt('none'); |
|
} |
|
} |
|
} elsif ($context eq 'othdomaction') { |
|
my ($extent,$role,$crstype); |
|
my ($info,$requester) = map { &unescape($_); } split(/:/,$request); |
|
if ($secondary eq 'user') { |
|
($extent,$role) = split(/:/,$info); |
|
$approve = $count.':'.$extent.':'.$role; |
|
$reject = $extent.':'.$role; |
|
} elsif ($secondary eq 'domain') { |
|
(my $uname,$extent,$role) = split(/:/,$info); |
|
$approve = $count.':'.$extent.':'.$role.':'.$uname.':'.$dom; |
|
$reject = $extent.':'.$role.':'.$uname.':'.$dom; |
|
unless (&Apache::lonnet::homeserver($uname,$dom) eq 'no_host') { |
|
$namelink = &Apache::loncommon::plainname($uname,$dom); |
|
unless ($namelink eq $uname.':'.$dom) { |
|
$namelink .= ' ('.$uname.':'.$dom.')'; |
|
} |
|
} |
|
} |
|
if (($role eq 'ca') || ($role eq 'aa')) { |
|
my ($audom,$auname) = ($extent =~ m{^/($match_domain)/($match_username)$}); |
|
$location = &mt('Author').': '.&Apache::loncommon::plainname($auname,$audom); |
|
} elsif ($role eq 'co') { |
|
my ($cdom,$cnum) = ($extent =~ m{^/($match_domain)/($match_courseid)}); |
|
if (&Apache::lonnet::is_course($cdom,$cnum)) { |
|
my %info = &Apache::lonnet::coursedescription("$cdom/$cnum",{'one_time' => 1}); |
|
$crstype = $info{'type'}; |
|
$location = &mt('Community').': '.$info{'description'}; |
|
$showrole = &Apache::lonnet::plaintext($role,'Community'); |
|
} |
|
} elsif ($role =~ m{^cr/}) { |
|
$showrole = &Apache::lonnet::plaintext($role,$crstype); |
|
my ($cdom,$cnum,$csec) = ($extent =~ m{^/($match_domain)/($match_courseid)(?:|/(\w+))$}); |
|
if (&Apache::lonnet::is_course($cdom,$cnum)) { |
|
my %info = &Apache::lonnet::coursedescription("$cdom/$cnum",{'one_time' => 1}); |
|
$crstype = $info{'type'}; |
|
$location = &mt($crstype).': '.$info{'description'}; |
|
if ($csec ne '') { |
|
$location .= ' '.&mt('Section').': '.$csec; |
|
} |
|
} |
|
} else { |
|
foreach my $type ('course','domain') { |
|
if (grep(/^\Q$role\E$/,@{$roles_by_context{$type}})) { |
|
if ($type eq 'course') { |
|
my ($cdom,$cnum,$csec) = ($extent =~ m{^/($match_domain)/($match_courseid)(?:|/(\w+))$}); |
|
if (&Apache::lonnet::is_course($cdom,$cnum)) { |
|
my %info = &Apache::lonnet::coursedescription("$cdom/$cnum",{'one_time' => 1}); |
|
$crstype = $info{'type'}; |
|
$location = &mt($crstype).': '.$info{'description'}; |
|
if ($csec ne '') { |
|
$location .= ' '.&mt('Section').': '.$csec; |
|
} |
|
} |
|
} else { |
|
my ($domain) = ($extent =~ m{^/($match_domain)/}); |
|
$location = &mt('Domain').': '.&Apache::lonnet::domain($domain,'description'); |
|
} |
|
last; |
|
} |
|
} |
|
} |
|
if ($role =~ m{^cr/($match_domain)/($match_username)/(\w+)$}) { |
|
my ($crudom,$cruname,$rolename) = ($1,$2,$3); |
|
my $creator = &Apache::loncommon::plainname($cruname,$crudom); |
|
unless ($creator eq $cruname.':'.$crudom) { |
|
$creator .= ' ('.$cruname.':'.$crudom.')'; |
|
} |
|
$showrole = &mt('Custom role').': '.$rolename.'<br />'. |
|
&mt('Created by').' '.$creator; |
|
} else { |
|
$showrole = &Apache::lonnet::plaintext($role,$crstype); |
|
} |
|
my ($requname,$requdom) = split(/:/,$requester); |
|
$showrequester = &Apache::loncommon::plainname($requname,$requdom); |
|
unless ($showrequester eq $requname.':'.$requdom) { |
|
$showrequester .= ' ('.$requname.':'.$requdom.')'; |
|
} |
} else { |
} else { |
my ($cnum,$ownername,$ownerdom,$type,$cdesc); |
my ($cnum,$ownername,$ownerdom,$type,$cdesc); |
my $queued = 'approval'; |
my $queued = 'approval'; |
Line 591 sub build_queue_display {
|
Line 826 sub build_queue_display {
|
&Apache::loncommon::plainname($ownername,$ownerdom), |
&Apache::loncommon::plainname($ownername,$ownerdom), |
$ownername,$ownerdom); |
$ownername,$ownerdom); |
} |
} |
unless (($context eq 'pending') || ($context eq 'displaypending') || ($context eq 'helpdesk')) { |
unless (($context eq 'pending') || ($context eq 'displaypending') || |
|
($context eq 'helpdesk') || ($context eq 'othdomqueue')) { |
$row = '<td><span class="LC_nobreak"><label>'. |
$row = '<td><span class="LC_nobreak"><label>'. |
'<input type="radio" value="'.$approve.'" name="'.$count.'radioreq" />'.&mt('Approve').'</label>'. |
'<input type="radio" value="'.$approve.'" name="'.$count.'radioreq" />'.&mt('Approve').'</label>'. |
'<label>'.(' 'x2). |
'<label>'.(' 'x2). |
Line 600 sub build_queue_display {
|
Line 836 sub build_queue_display {
|
'<input type="radio" value="'."later:".$reject.'" name="'.$count.'radioreq" checked />'.&mt('Decide Later'). |
'<input type="radio" value="'."later:".$reject.'" name="'.$count.'radioreq" checked />'.&mt('Decide Later'). |
'</label></span><br /></td>'; |
'</label></span><br /></td>'; |
} |
} |
$row .= '<td>'.$namelink.'</td>'."\n"; |
unless (($context eq 'othdomqueue') || ($context eq 'othdomaction')) { |
|
$row .= '<td>'.$namelink.'</td>'."\n"; |
|
} |
if ($context eq 'course') { |
if ($context eq 'course') { |
$row .= '<td>'.$showsec.'</td>'."\n". |
$row .= '<td>'.$showsec.'</td>'."\n". |
'<td>'.$showtime.'</td>'."\n"; |
'<td>'.$showtime.'</td>'."\n"; |
Line 609 sub build_queue_display {
|
Line 847 sub build_queue_display {
|
} elsif ($context eq 'requestusername') { |
} elsif ($context eq 'requestusername') { |
$row .= '<td>'.$showtime.'</td>'."\n". |
$row .= '<td>'.$showtime.'</td>'."\n". |
'<td>'.$detailslink.'</td>'."\n"; |
'<td>'.$detailslink.'</td>'."\n"; |
|
} elsif ($context eq 'othdomqueue') { |
|
$row .= '<td>'.$showtime.'</td>'."\n". |
|
'<td>'.$showrole.'</td>'."\n"; |
|
if ($secondary eq 'course') { |
|
$row .= '<td>'.$showsec.'</td>'."\n"; |
|
} |
|
$row .= '<td>'.$namelink.'</td>'."\n". |
|
'<td>'.$adjudicator.'</td>'."\n"; |
|
} elsif ($context eq 'othdomaction') { |
|
if ($secondary eq 'domain') { |
|
$row .= '<td>'.$showrequester.'</td>'."\n"; |
|
} |
|
$row .= '<td>'.$showtime.'</td>'."\n". |
|
'<td>'.$showrole.'</td>'."\n". |
|
'<td>'.$location.'</td>'."\n"; |
|
if ($secondary eq 'domain') { |
|
$row .= '<td>'.$namelink.'</td>'."\n"; |
|
} |
} else { |
} else { |
if ($context eq 'pending' || $context eq 'displaypending' || $context eq 'stillpending') { |
if ($context eq 'pending' || $context eq 'displaypending' || $context eq 'stillpending') { |
$row .= '<td>'.$instcode.'</td>'."\n"; |
$row .= '<td>'.$instcode.'</td>'."\n"; |
Line 638 sub update_request_queue {
|
Line 894 sub update_request_queue {
|
@processing_errors,@warn_approves,@warn_rejects,@approvals,@warn_dels, |
@processing_errors,@warn_approves,@warn_rejects,@approvals,@warn_dels, |
@rejections,@rejectionerrors,@nopermissions,%courseroles,@toremove, |
@rejections,@rejectionerrors,@nopermissions,%courseroles,@toremove, |
%communityroles,%domdefs,%approvalmsg,%rejectionmsg,$crstype,$queue, |
%communityroles,%domdefs,%approvalmsg,%rejectionmsg,$crstype,$queue, |
$firsturl,$uniquecode,%codes); |
$firsturl,$uniquecode,%codes,%roles_by_context,%requesteractive, |
|
%gotroles); |
my $count=0; |
my $count=0; |
while (my $item = $env{'form.'.$count.'radioreq'}) { |
while (my $item = $env{'form.'.$count.'radioreq'}) { |
if ($item =~ /^\d+:/) { |
if ($item =~ /^\d+:/) { |
Line 648 sub update_request_queue {
|
Line 905 sub update_request_queue {
|
} |
} |
$count ++; |
$count ++; |
} |
} |
|
|
$now = time; |
$now = time; |
$sender = $env{'user.name'}.':'.$env{'user.domain'}; |
$sender = $env{'user.name'}.':'.$env{'user.domain'}; |
if ($context eq 'course') { |
if ($context eq 'course') { |
Line 656 sub update_request_queue {
|
Line 912 sub update_request_queue {
|
$beneficiary = 'enroller'; |
$beneficiary = 'enroller'; |
$cid = $env{'request.course.id'}; |
$cid = $env{'request.course.id'}; |
$crstype = lc(&Apache::loncommon::course_type()); |
$crstype = lc(&Apache::loncommon::course_type()); |
$firsturl = &course_portal_url($cnum,$cdom); |
$firsturl = &Apache::lonnet::course_portal_url($cnum,$cdom); |
%requesthash = &Apache::lonnet::dump($namespace,$cdom,$cnum); |
%requesthash = &Apache::lonnet::dump($namespace,$cdom,$cnum); |
$access_start = $env{'course.'.$cid.'.internal.selfenroll_start_access'}; |
$access_start = $env{'course.'.$cid.'.internal.selfenroll_start_access'}; |
$access_end = $env{'course.'.$cid.'.internal.selfenroll_end_access'}; |
$access_end = $env{'course.'.$cid.'.internal.selfenroll_end_access'}; |
Line 685 sub update_request_queue {
|
Line 941 sub update_request_queue {
|
} |
} |
} |
} |
my $domconfiguser = &Apache::lonnet::get_domainconfiguser($cdom); |
my $domconfiguser = &Apache::lonnet::get_domainconfiguser($cdom); |
$firsturl = &course_portal_url($domconfiguser,$cdom); |
$firsturl = &Apache::lonnet::course_portal_url($domconfiguser,$cdom); |
$approvedmsg = [{ |
$approvedmsg = [{ |
mt => 'Your request for Authoring Space has been approved.', |
mt => 'Your request for Authoring Space has been approved.', |
}, |
}, |
Line 710 sub update_request_queue {
|
Line 966 sub update_request_queue {
|
} |
} |
} |
} |
my $domconfiguser = &Apache::lonnet::get_domainconfiguser($cdom); |
my $domconfiguser = &Apache::lonnet::get_domainconfiguser($cdom); |
$firsturl = &course_portal_url($domconfiguser,$cdom); |
$firsturl = &Apache::lonnet::course_portal_url($domconfiguser,$cdom); |
$approvedmsg = [{ |
$approvedmsg = [{ |
mt => 'Your request for a LON-CAPA account has been approved.', |
mt => 'Your request for a LON-CAPA account has been approved.', |
}, |
}, |
Line 722 sub update_request_queue {
|
Line 978 sub update_request_queue {
|
mt => 'Your request for a LON-CAPA account has not been approved.', |
mt => 'Your request for a LON-CAPA account has not been approved.', |
}]; |
}]; |
$domdesc = &Apache::lonnet::domain($cdom); |
$domdesc = &Apache::lonnet::domain($cdom); |
|
} elsif (($context eq 'othdombydc') || ($context eq 'othdombyuser')) { |
|
$namespace = 'queuedrolereqs'; |
|
$beneficiary = 'requester'; |
|
foreach my $type ('domain','course') { |
|
my @possroles = &Apache::lonuserutils::roles_by_context($type); |
|
$roles_by_context{$type} = \@possroles; |
|
} |
|
if ($context eq 'othdombydc') { |
|
my $confname = &Apache::lonnet::get_domainconfiguser($cdom); |
|
%requesthash = &Apache::lonnet::dump($namespace,$cdom,$confname); |
|
$approvedmsg = [{ |
|
mt => 'The role assignment you requested for a user from another domain has been approved and the role assigned.', |
|
}]; |
|
$rejectedmsg = [{ |
|
mt => 'The role assignment you requested for a user from another domain has not been approved.', |
|
}]; |
|
} else { |
|
%requesthash = &Apache::lonnet::dump($namespace,$cdom,$cnum); |
|
$approvedmsg = [{ |
|
mt => 'The role assignment you requested for a user from another domain has been has been agreed to by the user.', |
|
}]; |
|
$rejectedmsg = [{ |
|
mt => 'The role assignment you requested for a user from another domain has not been agreed to by the user.', |
|
}]; |
|
} |
|
$domdesc = &Apache::lonnet::domain($cdom); |
} else { |
} else { |
$domdesc = &Apache::lonnet::domain($cdom); |
$domdesc = &Apache::lonnet::domain($cdom); |
$namespace = 'courserequestqueue'; |
$namespace = 'courserequestqueue'; |
Line 947 sub update_request_queue {
|
Line 1229 sub update_request_queue {
|
push(@invalidusers,$uname); |
push(@invalidusers,$uname); |
} |
} |
push(@toremove,@invalidusers); |
push(@toremove,@invalidusers); |
|
} elsif (($context eq 'othdombydc') || ($context eq 'othdombyuser')) { |
|
if ($context eq 'othdombydc') { |
|
my ($num,$extent,$role,$uname,$udom) = split(/:/,$item); |
|
my ($logmsg,$result); |
|
if ($udom eq $cdom) { |
|
my $key = $uname.':'.$extent.':'.$role; |
|
if (exists($requesthash{$key})) { |
|
if (ref($requesthash{$key}) eq 'HASH') { |
|
my $requester = $requesthash{$key}->{'requester'}; |
|
my ($requname,$requdom) = split(/:/,$requester); |
|
my $start = $requesthash{$key}->{'start'}; |
|
my $end = $requesthash{$key}->{'end'}; |
|
my $credits = $requesthash{$key}->{'credits'}; |
|
my $reqcontext = $requesthash{$key}->{'context'}; |
|
if ((&Apache::lonnet::homeserver($uname,$udom) ne 'no_host') && |
|
(&Apache::lonnet::homeserver($requname,$requdom) ne 'no_host')) { |
|
if (($role eq 'ca') || ($role eq 'aa')) { |
|
my ($audom,$auname) = ($extent =~ m{^/($match_domain)/($match_username)$}); |
|
if (&Apache::lonnet::homeserver($auname,$audom) ne 'no_host') { |
|
if ($requester eq $auname.':'.$audom) { |
|
unless ($gotroles{$requester}) { |
|
&requester_roles($auname,$audom,\%requesteractive); |
|
$gotroles{$requester} = 1; |
|
} |
|
if (ref($requesteractive{$requester}) eq 'HASH') { |
|
if ($requesteractive{$requester}{':'.$audom.':au'}) { |
|
$result = &Apache::lonnet::assignrole($udom,$uname,$extent,$role, |
|
$end,$start,'','',$reqcontext); |
|
} |
|
} |
|
} |
|
} |
|
} elsif (($role eq 'co') || ($role eq 'cc')) { |
|
my ($crsdom,$crsnum) = ($extent =~ m{^/($match_domain)/($match_courseid)}); |
|
if (&Apache::lonnet::is_course($crsdom,$crsnum)) { |
|
my %info = &Apache::lonnet::coursedescription("$crsdom/$crsnum",{'one_time' => 1}); |
|
if ((($role eq 'co') && ($info{'type'} eq 'Community')) || |
|
(($role eq 'cc') && ($info{'type'} ne 'Community'))) { |
|
if ($info{'internal.courseowner'} eq $requester) { |
|
unless ($gotroles{$requester}) { |
|
&requester_roles($requname,$requdom,\%requesteractive); |
|
$gotroles{$requester} = 1; |
|
} |
|
if (ref($requesteractive{$requester}) eq 'HASH') { |
|
if ($requesteractive{$requester}{"$crsnum:$crsdom:$role"}) { |
|
$result = |
|
&Apache::loncommon::commit_standardrole($udom,$uname,$extent,$role,$start, |
|
$end,$crsdom,$crsnum,'', |
|
$reqcontext); |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} elsif ($role =~ m{^(cr)/($match_domain)/($match_username)/(\w+)$}) { |
|
my ($mrole,$crudom,$cruname,$rolename) = ($1,$2,$3,$4); |
|
my ($crsdom,$crsnum,$csec) = |
|
($extent =~ m{^/($match_domain)/($match_courseid)(?:|/(\w+))$}); |
|
if (&Apache::lonnet::is_course($crsdom,$crsnum)) { |
|
my ($rdummy,$roledef) = |
|
&Apache::lonnet::get('roles',["rolesdef_$rolename"],$crudom,$cruname); |
|
if (($rdummy ne 'con_lost') && ($roledef ne '')) { |
|
unless ($gotroles{$requester}) { |
|
&requester_roles($requname,$requdom,\%requesteractive); |
|
$gotroles{$requester} = 1; |
|
} |
|
if (ref($requesteractive{$requester}) eq 'HASH') { |
|
if (&requester_has_perm($crsdom,$crsnum,$mrole,$requesteractive{$requester})) { |
|
$result = &Apache::loncommon::commit_customrole($udom,$uname,$extent,$crudom,$cruname, |
|
$rolename,$start,$end,$reqcontext); |
|
} |
|
} |
|
} |
|
} |
|
} else { |
|
my $process; |
|
foreach my $type ('course','domain') { |
|
if (grep(/^\Q$role\E$/,@{$roles_by_context{$type}})) { |
|
if ($type eq 'course') { |
|
my ($crsdom,$crsnum,$csec) = ($extent =~ m{^/($match_domain)/($match_courseid)(?:|/(\w+))$}); |
|
if (&Apache::lonnet::is_course($crsdom,$crsnum)) { |
|
my $typeok; |
|
if ($role eq 'cc') { |
|
my %info = &Apache::lonnet::coursedescription("$crsdom/$crsnum",{'one_time' => 1}); |
|
if ($info{'type'} eq 'Course') { |
|
$typeok = 1; |
|
} |
|
} else { |
|
$typeok = 1; |
|
} |
|
if ($typeok) { |
|
unless ($gotroles{$requester}) { |
|
&requester_roles($requname,$requdom,\%requesteractive); |
|
$gotroles{$requester} = 1; |
|
} |
|
if (ref($requesteractive{$requester}) eq 'HASH') { |
|
if (&requester_has_perm($crsdom,$crsnum,$role,$requesteractive{$requester})) { |
|
$result = |
|
&Apache::loncommon::commit_standardrole($udom,$uname,$extent,$role,$start, |
|
$end,$crsdom,$crsnum,$csec, |
|
$reqcontext,$credits); |
|
} |
|
} |
|
} |
|
} |
|
} else { |
|
my ($domain) = ($extent =~ m{^/($match_domain)/}); |
|
if (&Apache::lonnet::domain($domain) ne '') { |
|
unless ($gotroles{$requester}) { |
|
&requester_roles($requname,$requdom,\%requesteractive); |
|
$gotroles{$requester} = 1; |
|
} |
|
if (&requester_has_perm($domain,'',$role,$requesteractive{$requester})) { |
|
$result = &Apache::lonnet::assignrole($udom,$uname,$extent,$role, |
|
$end,$start,'','',$reqcontext); |
|
} |
|
} |
|
} |
|
last; |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} |
|
} |
|
if ($result eq 'ok') { |
|
push(@completed,$item); |
|
} |
|
} else { |
|
my ($num,$extent,$role) = split(/:/,$item); |
|
if (exists($requesthash{$extent.':'.$role})) { |
|
if (ref($requesthash{$extent.':'.$role}) eq 'HASH') { |
|
#FIXME |
|
#check if extent is valid |
|
#check if role is valid |
|
#check requester privs |
|
} |
|
} |
|
} |
} else { |
} else { |
my ($num,$cnum) = split(':',$item); |
my ($num,$cnum) = split(':',$item); |
if (ref($requesthash{$cnum.'_'.$queue}) eq 'HASH') { |
if (ref($requesthash{$cnum.'_'.$queue}) eq 'HASH') { |
Line 981 sub update_request_queue {
|
Line 1403 sub update_request_queue {
|
$ownerdom,$ownername); |
$ownerdom,$ownername); |
if ((ref($history{'details'}) eq 'HASH') && |
if ((ref($history{'details'}) eq 'HASH') && |
($history{'disposition'} eq $queue)) { |
($history{'disposition'} eq $queue)) { |
my ($logmsg,$newusermsg,$addresult,$enrollcount,$response,$keysmsg,$code,%customitems); |
my ($logmsg,$newusermsg,$addresult,$enrollcount,$response, |
|
$keysmsg,$code,%customitems); |
|
my $clonemsg = []; |
my $fullname = ''; |
my $fullname = ''; |
my $inprocess = &Apache::lonnet::auto_crsreq_update($cdom,$cnum,$crstype,'process',$ownername, |
my $inprocess = &Apache::lonnet::auto_crsreq_update($cdom,$cnum,$crstype,'process',$ownername, |
$ownerdom,$fullname,$coursedesc); |
$ownerdom,$fullname,$coursedesc); |
Line 995 sub update_request_queue {
|
Line 1419 sub update_request_queue {
|
if ($history{'details'}{'clonecrs'}) { |
if ($history{'details'}{'clonecrs'}) { |
$customitems{'_LC_clonefrom'} = $history{'details'}{'clonedom'}.'_'.$history{'details'}{'clonecrs'}; |
$customitems{'_LC_clonefrom'} = $history{'details'}{'clonedom'}.'_'.$history{'details'}{'clonecrs'}; |
} |
} |
my ($result,$postprocess) = &course_creation($cdom,$cnum,$context,$history{'details'},\$logmsg, |
my ($result,$postprocess) = &course_creation($cdom,$cnum,$context,$history{'details'}, |
\$newusermsg,\$addresult,\$enrollcount, |
\$logmsg,$clonemsg,\$newusermsg,\$addresult,\$enrollcount, |
\$response,\$keysmsg,\%domdefs,$longroles,\$code,\%customitems); |
\$response,\$keysmsg,\%domdefs,$longroles,\$code,\%customitems); |
if ($result eq 'created') { |
if ($result eq 'created') { |
if ($crstype eq 'community') { |
if ($crstype eq 'community') { |
Line 1004 sub update_request_queue {
|
Line 1428 sub update_request_queue {
|
} else { |
} else { |
$approvedmsg = $approvalmsg{'course'}; |
$approvedmsg = $approvalmsg{'course'}; |
} |
} |
my $firsturl = &course_portal_url($cnum,$cdom); |
my $firsturl = &Apache::lonnet::course_portal_url($cnum,$cdom); |
if (ref($approvedmsg) eq 'ARRAY') { |
if (ref($approvedmsg) eq 'ARRAY') { |
if (ref($approvedmsg->[1]) eq 'HASH') { |
if (ref($approvedmsg->[1]) eq 'HASH') { |
$approvedmsg->[1]->{'args'} = [$firsturl]; |
$approvedmsg->[1]->{'args'} = [$firsturl]; |
} |
} |
|
if ((ref($clonemsg) eq 'ARRAY') && (@{$clonemsg})) { |
|
push(@{$approvedmsg},@{$clonemsg}); |
|
} |
if ($code) { |
if ($code) { |
push(@{$approvedmsg}, |
push(@{$approvedmsg}, |
{ |
{ |
Line 1087 sub update_request_queue {
|
Line 1514 sub update_request_queue {
|
@changes = map {$_.'_approval'} (@changes); |
@changes = map {$_.'_approval'} (@changes); |
} elsif ($context eq 'requestusername') { |
} elsif ($context eq 'requestusername') { |
@changes = map {&escape($_).'_approval'} (@changes); |
@changes = map {&escape($_).'_approval'} (@changes); |
|
} elsif (($context eq 'othdombydc') || ($context eq 'othdombyuser')) { |
|
@changes = (); |
} |
} |
if (@rejections) { |
if (@rejections) { |
foreach my $item (@rejections) { |
foreach my $item (@rejections) { |
Line 1141 sub update_request_queue {
|
Line 1570 sub update_request_queue {
|
if ($userresult ne 'ok') { |
if ($userresult ne 'ok') { |
push(@warn_rejects,$uname); |
push(@warn_rejects,$uname); |
} |
} |
|
} elsif (($context eq 'othdombydc') || ($context eq 'othdombyuser')) { |
|
#FIXME |
} else { |
} else { |
my $cnum = $item; |
my $cnum = $item; |
if (ref($requesthash{$cnum.'_'.$queue}) eq 'HASH') { |
if (ref($requesthash{$cnum.'_'.$queue}) eq 'HASH') { |
Line 1323 sub update_request_queue {
|
Line 1754 sub update_request_queue {
|
$now,'usernamemanagers',$sender, |
$now,'usernamemanagers',$sender, |
$approvedlist,$rejectedlist); |
$approvedlist,$rejectedlist); |
} |
} |
|
} elsif (($context eq 'othdombydc') || ($context eq 'othdombyuser')) { |
|
#FIXME |
} else { |
} else { |
$chgmsg = "'Action was taken on the following course and community requests by [_1].',$namelink"; |
$chgmsg = "'Action was taken on the following course and community requests by [_1].',$namelink"; |
if (@completed) { |
if (@completed) { |
Line 1588 sub update_request_queue {
|
Line 2021 sub update_request_queue {
|
return $output; |
return $output; |
} |
} |
|
|
sub course_portal_url { |
sub requester_roles { |
my ($cnum,$cdom) = @_; |
my ($requname,$requdom,$activeroles) = @_; |
my $chome = &Apache::lonnet::homeserver($cnum,$cdom); |
if (ref($activeroles) eq 'HASH') { |
my $hostname = &Apache::lonnet::hostname($chome); |
my %roleshash = &Apache::lonnet::get_my_roles($requname,$requdom,'userroles'); |
my $protocol = $Apache::lonnet::protocol{$chome}; |
$activeroles->{$requname.':'.$requdom} = \%roleshash; |
$protocol = 'http' if ($protocol ne 'https'); |
} |
my %domdefaults = &Apache::lonnet::get_domain_defaults($cdom); |
return; |
my $firsturl; |
} |
if ($domdefaults{'portal_def'}) { |
|
$firsturl = $domdefaults{'portal_def'}; |
sub requester_has_perm { |
} else { |
my ($crsdom,$crsnum,$mrole,$requesterroles) = @_; |
$firsturl = $protocol.'://'.$hostname; |
return unless (ref($requesterroles) eq 'HASH'); |
|
my $has_perm; |
|
foreach my $key (keys(%{$requesterroles})) { |
|
if ($crsnum eq '') { |
|
next unless ($key =~ /^\Q:$crsdom:\E/); |
|
} else { |
|
next unless (($key =~ /^\Q$crsnum:$crsdom:\E/) || ($key =~ /^\Q:$crsdom:\E/)); |
|
} |
|
my ($keycrs,$keydom,$keyrole) = split(/:/,$key); |
|
if (($keycrs ne '') && ($crsnum ne '')) { |
|
if ($keycrs eq $crsnum) { |
|
if ($Apache::lonnet::pr{$keyrole.':c'} =~ /(^|:)c\Q$mrole\E(&|:)/) { |
|
$has_perm = 1; |
|
last; |
|
} |
|
} |
|
} else { |
|
if ($Apache::lonnet::pr{$keyrole.':d'} =~ /(^|:)c\Q$mrole\E(&|:)/) { |
|
$has_perm = 1; |
|
last; |
|
} |
|
} |
} |
} |
return $firsturl; |
return $has_perm; |
} |
} |
|
|
sub get_student_counts { |
sub get_student_counts { |
Line 1623 sub get_student_counts {
|
Line 2077 sub get_student_counts {
|
} |
} |
|
|
sub course_creation { |
sub course_creation { |
my ($dom,$cnum,$context,$details,$logmsg,$newusermsg,$addresult,$enrollcount,$output, |
my ($dom,$cnum,$context,$details,$logmsg,$clonemsg,$newusermsg,$addresult, |
$keysmsg,$domdefs,$longroles,$coderef,$customhash) = @_; |
$enrollcount,$output,$keysmsg,$domdefs,$longroles,$coderef,$customhash, |
|
$callercontext,$user_lh) = @_; |
unless ((ref($details) eq 'HASH') && (ref($domdefs) eq 'HASH') && |
unless ((ref($details) eq 'HASH') && (ref($domdefs) eq 'HASH') && |
(ref($longroles) eq 'HASH')) { |
(ref($longroles) eq 'HASH')) { |
return ('error: Invalid request'); |
return ('error: Invalid request'); |
} |
} |
my ($result,$ownername,$ownerdom,$autocoowner); |
my ($result,$ownername,$ownerdom); |
my $crstype = $details->{'crstype'}; |
my $crstype = $details->{'crstype'}; |
my $coursedesc = $details->{'cdescr'}; |
my $coursedesc = $details->{'cdescr'}; |
my $accessstart = $details->{'accessstart'}; |
my $accessstart = $details->{'accessstart'}; |
my $accessend = $details->{'accessend'}; |
my $accessend = $details->{'accessend'}; |
my %domconfig = &Apache::lonnet::get_dom('configuration',['requestcourses','autoenroll'],$dom); |
my %domconfig = &Apache::lonnet::get_dom('configuration',['requestcourses'],$dom); |
if (ref($domconfig{'requestcourses'}) eq 'HASH') { |
if (ref($domconfig{'requestcourses'}) eq 'HASH') { |
if (ref($domconfig{'requestcourses'}{'uniquecode'}) eq 'HASH') { |
if (ref($domconfig{'requestcourses'}{'uniquecode'}) eq 'HASH') { |
if ($domconfig{'requestcourses'}{'uniquecode'}{$crstype}) { |
if ($domconfig{'requestcourses'}{'uniquecode'}{$crstype}) { |
Line 1642 sub course_creation {
|
Line 2097 sub course_creation {
|
} |
} |
} |
} |
} |
} |
if (ref($domconfig{'autoenroll'}) eq 'HASH') { |
|
$autocoowner = $domconfig{'autoenroll'}{'co-owners'}; |
|
} |
|
if ($context eq 'domain') { |
if ($context eq 'domain') { |
$ownername = $details->{'owner'}; |
$ownername = $details->{'owner'}; |
$ownerdom = $details->{'domain'}; |
$ownerdom = $details->{'domain'}; |
Line 1661 sub course_creation {
|
Line 2113 sub course_creation {
|
} |
} |
my %reqdetails = &build_batchcreatehash($dom,$cnum,$context,$details,$owneremail,$domdefs); |
my %reqdetails = &build_batchcreatehash($dom,$cnum,$context,$details,$owneremail,$domdefs); |
my $cid = &LONCAPA::batchcreatecourse::build_course($dom,$cnum,'requestcourses', |
my $cid = &LONCAPA::batchcreatecourse::build_course($dom,$cnum,'requestcourses', |
\%reqdetails,$longroles,$logmsg,$newusermsg,$addresult, |
\%reqdetails,$longroles,$logmsg,$clonemsg,$newusermsg,$addresult, |
$enrollcount,$output,$keysmsg,$ownerdom,$ownername,$cnum,$crstype,$coderef); |
$enrollcount,$output,$keysmsg,$ownerdom,$ownername,$cnum,$crstype, |
|
$coderef,$callercontext,$user_lh); |
my $postprocess; |
my $postprocess; |
if ($cid eq "/$dom/$cnum") { |
if ($cid eq "/$dom/$cnum") { |
$result = 'created'; |
$result = 'created'; |
Line 1673 sub course_creation {
|
Line 2126 sub course_creation {
|
$postprocess = &Apache::lonnet::auto_crsreq_update($dom,$cnum,$crstype,$result,$ownername, |
$postprocess = &Apache::lonnet::auto_crsreq_update($dom,$cnum,$crstype,$result,$ownername, |
$ownerdom,$fullname,$coursedesc,$code, |
$ownerdom,$fullname,$coursedesc,$code, |
$accessstart,$accessend,$customhash); |
$accessstart,$accessend,$customhash); |
if ($autocoowner) { |
|
my $instcode = $details->{'instcode'}; |
|
if (($instcode ne '') && (ref($reqdetails{'users'}) eq 'HASH')) { |
|
my @posscoowners; |
|
my $now = time; |
|
foreach my $person (keys(%{$reqdetails{'users'}})) { |
|
my ($uname,$udom) = split(/:/,$person); |
|
next if (($udom ne $dom) || (($uname eq $ownername) && ($udom eq $ownerdom))); |
|
if ((&Apache::lonnet::homeserver($uname,$udom,1) ne 'no_host') && |
|
(ref($reqdetails{'users'}{$person}) eq 'HASH')) { |
|
if ((grep(/^cc$/,keys(%{$reqdetails{'users'}{$person}}))) && |
|
(ref($reqdetails{'users'}{$person}{'cc'}) eq 'HASH')) { |
|
my $start = $reqdetails{'users'}{$person}{'cc'}{'start'}; |
|
my $end = $reqdetails{'users'}{$person}{'cc'}{'end'}; |
|
if ((($start eq '') || ($start <= $now)) && |
|
(($end eq '') || ($end >= $now))) { |
|
push(@posscoowners,$person); |
|
} |
|
} |
|
} |
|
} |
|
my @coowners; |
|
if (@posscoowners) { |
|
foreach my $user (@posscoowners) { |
|
my ($checkcc,$desc) = |
|
&Apache::lonnet::auto_validate_instcode($cnum,$dom,$instcode,$user); |
|
unless ($checkcc eq 'valid') { |
|
if (ref($reqdetails{'crosslists'}) eq 'HASH') { |
|
foreach my $key (keys(%{$reqdetails{'crosslists'}})) { |
|
if (ref($reqdetails{'crosslists'}{$key}) eq 'HASH') { |
|
my $inst_crosslist = $reqdetails{'crosslists'}{$key}{'inst'}; |
|
if ($inst_crosslist ne '') { |
|
$checkcc = |
|
&Apache::lonnet::auto_validate_inst_crosslist($cnum,$dom,$instcode, |
|
$inst_crosslist,$user); |
|
last if ($checkcc eq 'valid'); |
|
} |
|
} |
|
} |
|
} |
|
} |
|
if ($checkcc eq 'valid') { |
|
if (@coowners > 0) { |
|
unless (grep(/^\Q$user\E$/,@coowners)) { |
|
push(@coowners,$user); |
|
} |
|
} else { |
|
push(@coowners,$user); |
|
} |
|
} |
|
} |
|
} |
|
if (@coowners > 0) { |
|
my $chome = &Apache::lonnet::homeserver($cnum,$dom); |
|
unless ($chome eq 'no_host') { |
|
&Apache::lonnet::store_coowners($dom,$cnum,$chome,'',@coowners); |
|
} |
|
} |
|
} |
|
} |
|
} else { |
} else { |
$result = 'error: '.$cid; |
$result = 'error: '.$cid; |
} |
} |
Line 1742 sub course_creation {
|
Line 2135 sub course_creation {
|
sub build_batchcreatehash { |
sub build_batchcreatehash { |
my ($dom,$cnum,$context,$details,$owneremail,$domdefs) = @_; |
my ($dom,$cnum,$context,$details,$owneremail,$domdefs) = @_; |
my %batchhash; |
my %batchhash; |
my @items = qw{owner domain coursehome clonecrs clonedom datemode dateshift enrollstart enrollend accessstart accessend sections users uniquecode}; |
my @items = qw{owner domain coursehome clonecrs clonedom datemode dateshift tinyurls enrollstart enrollend accessstart accessend sections users uniquecode}; |
if ((ref($details) eq 'HASH') && (ref($domdefs) eq 'HASH')) { |
if ((ref($details) eq 'HASH') && (ref($domdefs) eq 'HASH')) { |
my $emailenc = &escape($owneremail); |
my $emailenc = &escape($owneremail); |
my $owner = $details->{'owner'}.':'.$details->{'domain'}; |
my $owner = $details->{'owner'}.':'.$details->{'domain'}; |
Line 1776 sub build_batchcreatehash {
|
Line 2169 sub build_batchcreatehash {
|
$batchhash{'authparam'} = $domdefs->{'auth_arg_def'}; |
$batchhash{'authparam'} = $domdefs->{'auth_arg_def'}; |
if ($details->{'crstype'} eq 'community') { |
if ($details->{'crstype'} eq 'community') { |
$batchhash{'crstype'} = 'Community'; |
$batchhash{'crstype'} = 'Community'; |
|
} elsif ($details->{'crstype'} eq 'placement') { |
|
$batchhash{'crstype'} = 'Placement'; |
} else { |
} else { |
if ($details->{'crstype'} eq 'textbook') { |
if ($details->{'crstype'} eq 'textbook') { |
if ($details->{'clonecrs'} && $details->{'clonedom'}) { |
if ($details->{'clonecrs'} && $details->{'clonedom'}) { |
my %clonedfrom = &Apache::lonnet::coursedescription($details->{'clonedom'}.'_'.$details->{'clonecrs'}); |
my %clonedfrom = &Apache::lonnet::coursedescription($details->{'clonedom'}.'_'.$details->{'clonecrs'}); |
$batchhash{'textbook'} = $clonedfrom{'description'}; |
$batchhash{'textbook'} = $clonedfrom{'description'}; |
} |
} |
|
} elsif ($details->{'crstype'} eq 'lti') { |
|
$batchhash{'lti'} = 1; |
} |
} |
$batchhash{'crstype'} = 'Course'; |
$batchhash{'crstype'} = 'Course'; |
} |
} |
Line 2108 sub process_official_reqs {
|
Line 2505 sub process_official_reqs {
|
$longroles{$role}=&Apache::lonnet::plaintext($role); |
$longroles{$role}=&Apache::lonnet::plaintext($role); |
} |
} |
my %domdefs = &Apache::lonnet::get_domain_defaults($dom); |
my %domdefs = &Apache::lonnet::get_domain_defaults($dom); |
my ($output,$linefeed); |
my ($output,$linefeed,$user_lh); |
if ($context eq 'auto') { |
if ($context eq 'auto') { |
$linefeed = "\n"; |
$linefeed = "\n"; |
|
$user_lh = &Apache::loncommon::user_lang($dcname,$dcdom); |
} else { |
} else { |
$linefeed = '<br />'."\n"; |
$linefeed = '<br />'."\n"; |
} |
} |
Line 2172 sub process_official_reqs {
|
Line 2570 sub process_official_reqs {
|
$reqstatus = $disposition; |
$reqstatus = $disposition; |
if ($disposition eq 'process') { |
if ($disposition eq 'process') { |
my ($logmsg,$newusermsg,$addresult,$enrollcount,$response,$keysmsg,$code); |
my ($logmsg,$newusermsg,$addresult,$enrollcount,$response,$keysmsg,$code); |
|
my $clonemsg = []; |
my %customitems; |
my %customitems; |
my $fullname = &Apache::loncommon::plainname($ownername,$ownerdom); |
my $fullname = &Apache::loncommon::plainname($ownername,$ownerdom); |
my $inprocess = &Apache::lonnet::auto_crsreq_update($dom,$cnum,$crstype,'process',$ownername, |
my $inprocess = &Apache::lonnet::auto_crsreq_update($dom,$cnum,$crstype,'process',$ownername, |
Line 2187 sub process_official_reqs {
|
Line 2586 sub process_official_reqs {
|
$customitems{'_LC_clonefrom'} = $history{'details'}{'clonedom'}.'_'.$history{'details'}{'clonecrs'}; |
$customitems{'_LC_clonefrom'} = $history{'details'}{'clonedom'}.'_'.$history{'details'}{'clonecrs'}; |
} |
} |
my ($result,$postprocess) = |
my ($result,$postprocess) = |
&course_creation($dom,$cnum,'domain',$history{'details'},\$logmsg,\$newusermsg,\$addresult, |
&course_creation($dom,$cnum,'domain',$history{'details'},\$logmsg,$clonemsg,\$newusermsg, |
\$enrollcount,\$response,\$keysmsg,\%domdefs,\%longroles,\$code,\%customitems); |
\$addresult,\$enrollcount,\$response,\$keysmsg,\%domdefs,\%longroles, |
|
\$code,\%customitems,$context,$user_lh); |
if ($result eq 'created') { |
if ($result eq 'created') { |
$disposition = 'created'; |
$disposition = 'created'; |
$reqstatus = 'created'; |
$reqstatus = 'created'; |
my $cid = $dom.'_'.$cnum; |
my $cid = $dom.'_'.$cnum; |
push(@{$newcids{$instcode}},$cid); |
push(@{$newcids{$instcode}},$cid); |
if ($dcname && $dcdom) { |
if ($dcname && $dcdom) { |
my $firsturl = &course_portal_url($cnum,$dom); |
my $firsturl = &Apache::lonnet::course_portal_url($cnum,$dom); |
my $beneficiary = 'pendingrequestor'; |
my $beneficiary = 'pendingrequestor'; |
my $now = time; |
my $now = time; |
my $owner = $ownername.':'.$ownerdom; |
my $owner = $ownername.':'.$ownerdom; |
Line 2203 sub process_official_reqs {
|
Line 2603 sub process_official_reqs {
|
[{ |
[{ |
mt => 'Your requested course: [_1], (queued pending validation) has now been created.', |
mt => 'Your requested course: [_1], (queued pending validation) has now been created.', |
args => [$cdescr], |
args => [$cdescr], |
}, |
}]; |
|
if ((ref($clonemsg) eq 'ARRAY') && (@{$clonemsg})) { |
|
push(@{$approvedmsg},@{$clonemsg}); |
|
} |
|
push(@{$approvedmsg}, |
{ |
{ |
mt => 'Visit [_1] to log-in and access the course.', |
mt => 'Visit [_1] to log-in and access the course.', |
args => [$firsturl], |
args => [$firsturl], |
}, |
}, |
{ |
{ |
mt => 'If currently logged-in to LON-CAPA, log-out and log-in again to select your new course role.' |
mt => 'If currently logged-in to LON-CAPA, log-out and log-in again to select your new course role.', |
}]; |
args => [], |
|
} |
|
); |
my $sender = $dcname.':'.$dcdom; |
my $sender = $dcname.':'.$dcdom; |
if (ref($postprocess) eq 'HASH') { |
if (ref($postprocess) eq 'HASH') { |
if (ref($postprocess->{'createdmsg'}) eq 'ARRAY') { |
if (ref($postprocess->{'createdmsg'}) eq 'ARRAY') { |
Line 2316 sub postprocess_crsenv {
|
Line 2722 sub postprocess_crsenv {
|
my %needcrsidput = ( |
my %needcrsidput = ( |
'internal.selfenroll_types' => 1, |
'internal.selfenroll_types' => 1, |
'internal.selfenroll_start_date' => 1, |
'internal.selfenroll_start_date' => 1, |
'internal.selfenroll_end_date' => 1, |
'internal. selfenroll_end_date' => 1, |
); |
); |
my (@needupdate,%newcrsenv); |
my (@needupdate,%newcrsenv); |
foreach my $key (keys(%{$postprocessenv})) { |
foreach my $key (keys(%{$postprocessenv})) { |