version 1.152, 2011/08/10 14:54:42
|
version 1.166, 2012/08/25 21:48:12
|
Line 86 $dom,$settings,$rowtotal,$action.
|
Line 86 $dom,$settings,$rowtotal,$action.
|
|
|
$dom is the domain, $settings is a reference to a hash of current settings for |
$dom is the domain, $settings is a reference to a hash of current settings for |
the current context, $rowtotal is a reference to the scalar used to record the |
the current context, $rowtotal is a reference to the scalar used to record the |
number of rows displayed on the page, and $action is the context (either quotas |
number of rows displayed on the page, and $action is the context (quotas, |
or requestcourses). |
requestcourses or requestauthor). |
|
|
The print_quotas routine was orginally created to display/store information |
The print_quotas routine was orginally created to display/store information |
about default quota sizes for portfolio spaces for the different types of |
about default quota sizes for portfolio spaces for the different types of |
Line 171 use Locale::Language;
|
Line 171 use Locale::Language;
|
use DateTime::TimeZone; |
use DateTime::TimeZone; |
use DateTime::Locale; |
use DateTime::Locale; |
|
|
|
my $registered_cleanup; |
|
my $modified_urls; |
|
|
sub handler { |
sub handler { |
my $r=shift; |
my $r=shift; |
if ($r->header_only) { |
if ($r->header_only) { |
Line 190 sub handler {
|
Line 193 sub handler {
|
"/adm/domainprefs:mau:0:0:Cannot modify domain settings"; |
"/adm/domainprefs:mau:0:0:Cannot modify domain settings"; |
return HTTP_NOT_ACCEPTABLE; |
return HTTP_NOT_ACCEPTABLE; |
} |
} |
|
|
|
$registered_cleanup=0; |
|
@{$modified_urls}=(); |
|
|
&Apache::lonhtmlcommon::clear_breadcrumbs(); |
&Apache::lonhtmlcommon::clear_breadcrumbs(); |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
['phase','actions']); |
['phase','actions']); |
Line 204 sub handler {
|
Line 211 sub handler {
|
'directorysrch','usercreation','usermodification', |
'directorysrch','usercreation','usermodification', |
'contacts','defaults','scantron','coursecategories', |
'contacts','defaults','scantron','coursecategories', |
'serverstatuses','requestcourses','helpsettings', |
'serverstatuses','requestcourses','helpsettings', |
'coursedefaults','usersessions','loadbalancing'],$dom); |
'coursedefaults','usersessions','loadbalancing', |
|
'requestauthor'],$dom); |
my @prefs_order = ('rolecolors','login','defaults','quotas','autoenroll', |
my @prefs_order = ('rolecolors','login','defaults','quotas','autoenroll', |
'autoupdate','autocreate','directorysrch','contacts', |
'autoupdate','autocreate','directorysrch','contacts', |
'usercreation','usermodification','scantron', |
'usercreation','usermodification','scantron', |
'requestcourses','coursecategories','serverstatuses','helpsettings', |
'requestcourses','requestauthor','coursecategories', |
|
'serverstatuses','helpsettings', |
'coursedefaults','usersessions'); |
'coursedefaults','usersessions'); |
if (keys(%servers) > 1) { |
if (keys(%servers) > 1) { |
push(@prefs_order,'loadbalancing'); |
push(@prefs_order,'loadbalancing'); |
Line 240 sub handler {
|
Line 249 sub handler {
|
col2 => 'Value'}], |
col2 => 'Value'}], |
}, |
}, |
'quotas' => |
'quotas' => |
{ text => 'User blogs, personal information pages, portfolios', |
{ text => 'Blogs, personal web pages, webDAV, portfolios', |
help => 'Domain_Configuration_Quotas', |
help => 'Domain_Configuration_Quotas', |
header => [{col1 => 'User affiliation', |
header => [{col1 => 'User affiliation', |
col2 => 'Available tools', |
col2 => 'Available tools', |
Line 316 sub handler {
|
Line 325 sub handler {
|
{col1 => 'Setting', |
{col1 => 'Setting', |
col2 => 'Value'}], |
col2 => 'Value'}], |
}, |
}, |
|
'requestauthor' => |
|
{text => 'Request authoring space', |
|
help => 'Domain_Configuration_Request_Author', |
|
header => [{col1 => 'User affiliation', |
|
col2 => 'Availability/Processing of requests',}, |
|
{col1 => 'Setting', |
|
col2 => 'Value'}], |
|
}, |
'coursecategories' => |
'coursecategories' => |
{ text => 'Cataloging of courses/communities', |
{ text => 'Cataloging of courses/communities', |
help => 'Domain_Configuration_Cataloging_Courses', |
help => 'Domain_Configuration_Cataloging_Courses', |
Line 336 sub handler {
|
Line 353 sub handler {
|
'helpsettings' => |
'helpsettings' => |
{text => 'Help page settings', |
{text => 'Help page settings', |
help => 'Domain_Configuration_Help_Settings', |
help => 'Domain_Configuration_Help_Settings', |
header => [{col1 => 'Authenticated Help Settings', |
header => [{col1 => 'Help Settings (logged-in users)', |
col2 => ''}, |
col2 => 'Value'}, |
{col1 => 'Unauthenticated Help Settings', |
{col1 => 'Help Settings (before log-in)', |
col2 => ''}], |
col2 => 'Value'}], |
}, |
}, |
'coursedefaults' => |
'coursedefaults' => |
{text => 'Course/Community defaults', |
{text => 'Course/Community defaults', |
Line 393 sub handler {
|
Line 410 sub handler {
|
if ($phase eq 'process') { |
if ($phase eq 'process') { |
&Apache::lonconfigsettings::make_changes($r,$dom,$phase,$context,\@prefs_order,\%prefs,\%domconfig,$confname,\@roles); |
&Apache::lonconfigsettings::make_changes($r,$dom,$phase,$context,\@prefs_order,\%prefs,\%domconfig,$confname,\@roles); |
} elsif ($phase eq 'display') { |
} elsif ($phase eq 'display') { |
my $js; |
my $js = &recaptcha_js(); |
if (keys(%servers) > 1) { |
if (keys(%servers) > 1) { |
my ($othertitle,$usertypes,$types) = |
my ($othertitle,$usertypes,$types) = |
&Apache::loncommon::sorted_inst_types($dom); |
&Apache::loncommon::sorted_inst_types($dom); |
$js = &lonbalance_targets_js($dom,$types,\%servers). |
$js = &lonbalance_targets_js($dom,$types,\%servers). |
&new_spares_js(). |
&new_spares_js(). |
&common_domprefs_js(); |
&common_domprefs_js(). |
|
&Apache::loncommon::javascript_array_indexof(); |
} |
} |
&Apache::lonconfigsettings::display_settings($r,$dom,$phase,$context,\@prefs_order,\%prefs,\%domconfig,$confname,$js); |
&Apache::lonconfigsettings::display_settings($r,$dom,$phase,$context,\@prefs_order,\%prefs,\%domconfig,$confname,$js); |
} else { |
} else { |
Line 479 sub process_changes {
|
Line 497 sub process_changes {
|
$output = &modify_serverstatuses($dom,%domconfig); |
$output = &modify_serverstatuses($dom,%domconfig); |
} elsif ($action eq 'requestcourses') { |
} elsif ($action eq 'requestcourses') { |
$output = &modify_quotas($dom,$action,%domconfig); |
$output = &modify_quotas($dom,$action,%domconfig); |
|
} elsif ($action eq 'requestauthor') { |
|
$output = &modify_quotas($dom,$action,%domconfig); |
} elsif ($action eq 'helpsettings') { |
} elsif ($action eq 'helpsettings') { |
$output = &modify_helpsettings($r,$dom,$confname,%domconfig); |
$output = &modify_helpsettings($r,$dom,$confname,%domconfig); |
} elsif ($action eq 'coursedefaults') { |
} elsif ($action eq 'coursedefaults') { |
Line 513 sub print_config_box {
|
Line 533 sub print_config_box {
|
if ($numheaders > 1) { |
if ($numheaders > 1) { |
my $colspan = ''; |
my $colspan = ''; |
my $rightcolspan = ''; |
my $rightcolspan = ''; |
if (($action eq 'rolecolors') || ($action eq 'coursecategories') || ($action eq 'helpsettings')) { |
if (($action eq 'rolecolors') || ($action eq 'coursecategories')) { |
$colspan = ' colspan="2"'; |
$colspan = ' colspan="2"'; |
} |
} |
if ($action eq 'usersessions') { |
if ($action eq 'usersessions') { |
Line 541 sub print_config_box {
|
Line 561 sub print_config_box {
|
$colspan = ' colspan="2"'; |
$colspan = ' colspan="2"'; |
} elsif ($action eq 'requestcourses') { |
} elsif ($action eq 'requestcourses') { |
$output .= &print_quotas($dom,$settings,\$rowtotal,$action); |
$output .= &print_quotas($dom,$settings,\$rowtotal,$action); |
|
} elsif ($action eq 'requestauthor') { |
|
$output .= &print_quotas($dom,$settings,\$rowtotal,$action); |
} elsif ($action eq 'helpsettings') { |
} elsif ($action eq 'helpsettings') { |
$output .= &print_helpsettings('top',$dom,$confname,$settings,\$rowtotal); |
$output .= &print_helpsettings('top',$dom,$confname,$settings,\$rowtotal); |
} elsif ($action eq 'usersessions') { |
} elsif ($action eq 'usersessions') { |
Line 607 sub print_config_box {
|
Line 629 sub print_config_box {
|
} elsif ($action eq 'login') { |
} elsif ($action eq 'login') { |
$output .= &print_login('bottom',$dom,$confname,$phase,$settings,\$rowtotal); |
$output .= &print_login('bottom',$dom,$confname,$phase,$settings,\$rowtotal); |
} elsif ($action eq 'requestcourses') { |
} elsif ($action eq 'requestcourses') { |
$output .= &print_courserequestmail($dom,$settings,\$rowtotal); |
$output .= &print_requestmail($dom,$action,$settings,\$rowtotal); |
|
} elsif ($action eq 'requestauthor') { |
|
$output .= &print_requestmail($dom,$action,$settings,\$rowtotal); |
} elsif ($action eq 'helpsettings') { |
} elsif ($action eq 'helpsettings') { |
$output .= &print_helpsettings('bottom',$dom,$confname,$settings,\$rowtotal); |
$output .= &print_helpsettings('bottom',$dom,$confname,$settings,\$rowtotal); |
} elsif ($action eq 'usersessions') { |
} elsif ($action eq 'usersessions') { |
Line 1050 sub print_rolecolors {
|
Line 1074 sub print_rolecolors {
|
sub display_color_options { |
sub display_color_options { |
my ($dom,$confname,$phase,$role,$itemcount,$choices,$is_custom,$defaults,$designs, |
my ($dom,$confname,$phase,$role,$itemcount,$choices,$is_custom,$defaults,$designs, |
$images,$bgs,$links,$alt_text,$rowtotal,$logintext) = @_; |
$images,$bgs,$links,$alt_text,$rowtotal,$logintext) = @_; |
|
my $londocroot = $Apache::lonnet::perlvar{'lonDocRoot'}; |
my $css_class = $itemcount%2?' class="LC_odd_row"':''; |
my $css_class = $itemcount%2?' class="LC_odd_row"':''; |
my $datatable = '<tr'.$css_class.'>'. |
my $datatable = '<tr'.$css_class.'>'. |
'<td>'.$choices->{'font'}.'</td>'; |
'<td>'.$choices->{'font'}.'</td>'; |
Line 1127 sub display_color_options {
|
Line 1152 sub display_color_options {
|
$showfile = $imgfile; |
$showfile = $imgfile; |
my $imgdir = $1; |
my $imgdir = $1; |
my $filename = $2; |
my $filename = $2; |
if (-e "/home/httpd/html/$imgdir/tn-".$filename) { |
if (-e "$londocroot/$imgdir/tn-".$filename) { |
$showfile = "/$imgdir/tn-".$filename; |
$showfile = "/$imgdir/tn-".$filename; |
} else { |
} else { |
my $input = "/home/httpd/html".$imgfile; |
my $input = $londocroot.$imgfile; |
my $output = '/home/httpd/html/'.$imgdir.'/tn-'.$filename; |
my $output = "$londocroot/$imgdir/tn-".$filename; |
if (!-e $output) { |
if (!-e $output) { |
my ($width,$height) = &thumb_dimensions(); |
my ($width,$height) = &thumb_dimensions(); |
my ($fullwidth,$fullheight) = &check_dimensions($input); |
my ($fullwidth,$fullheight) = &check_dimensions($input); |
Line 1139 sub display_color_options {
|
Line 1164 sub display_color_options {
|
if ($fullwidth > $width && $fullheight > $height) { |
if ($fullwidth > $width && $fullheight > $height) { |
my $size = $width.'x'.$height; |
my $size = $width.'x'.$height; |
system("convert -sample $size $input $output"); |
system("convert -sample $size $input $output"); |
$showfile = '/'.$imgdir.'/tn-'.$filename; |
$showfile = "/$imgdir/tn-".$filename; |
} |
} |
} |
} |
} |
} |
Line 1367 sub print_quotas {
|
Line 1392 sub print_quotas {
|
@options =('norequest','approval','validate','autolimit'); |
@options =('norequest','approval','validate','autolimit'); |
%validations = &Apache::lonnet::auto_courserequest_checks($dom); |
%validations = &Apache::lonnet::auto_courserequest_checks($dom); |
%titles = &courserequest_titles(); |
%titles = &courserequest_titles(); |
|
} elsif ($context eq 'requestauthor') { |
|
@usertools = ('author'); |
|
@options = ('norequest','approval','automatic'); |
|
%titles = &authorrequest_titles(); |
} else { |
} else { |
@usertools = ('aboutme','blog','portfolio'); |
@usertools = ('aboutme','blog','webdav','portfolio'); |
%titles = &tool_titles(); |
%titles = &tool_titles(); |
} |
} |
if (ref($types) eq 'ARRAY') { |
if (ref($types) eq 'ARRAY') { |
foreach my $type (@{$types}) { |
foreach my $type (@{$types}) { |
my $currdefquota; |
my $currdefquota; |
unless ($context eq 'requestcourses') { |
unless (($context eq 'requestcourses') || |
|
($context eq 'requestauthor')) { |
if (ref($settings) eq 'HASH') { |
if (ref($settings) eq 'HASH') { |
if (ref($settings->{defaultquota}) eq 'HASH') { |
if (ref($settings->{defaultquota}) eq 'HASH') { |
$currdefquota = $settings->{defaultquota}->{$type}; |
$currdefquota = $settings->{defaultquota}->{$type}; |
Line 1444 sub print_quotas {
|
Line 1474 sub print_quotas {
|
$cell{$item} .= $titles{'unlimited'}; |
$cell{$item} .= $titles{'unlimited'}; |
} |
} |
} |
} |
|
} elsif ($context eq 'requestauthor') { |
|
my $curroption; |
|
if (ref($settings) eq 'HASH') { |
|
$curroption = $settings->{$type}; |
|
} |
|
if (!$curroption) { |
|
$curroption = 'norequest'; |
|
} |
|
foreach my $option (@options) { |
|
my $val = $option; |
|
if ($option eq 'norequest') { |
|
$val = 0; |
|
} |
|
my $checked = ''; |
|
if ($option eq $curroption) { |
|
$checked = ' checked="checked"'; |
|
} |
|
$datatable .= '<span class="LC_nobreak"><label>'. |
|
'<input type="radio" name="authorreq_'.$type. |
|
'" value="'.$val.'"'.$checked.' />'. |
|
$titles{$option}.'</label></span> '; |
|
} |
} else { |
} else { |
my $checked = 'checked="checked" '; |
my $checked = 'checked="checked" '; |
if (ref($settings) eq 'HASH') { |
if (ref($settings) eq 'HASH') { |
Line 1469 sub print_quotas {
|
Line 1521 sub print_quotas {
|
$datatable .= '</tr></table>'; |
$datatable .= '</tr></table>'; |
} |
} |
$datatable .= '</td>'; |
$datatable .= '</td>'; |
unless ($context eq 'requestcourses') { |
unless (($context eq 'requestcourses') || |
|
($context eq 'requestauthor')) { |
$datatable .= |
$datatable .= |
'<td class="LC_right_item"><span class="LC_nobreak">'. |
'<td class="LC_right_item"><span class="LC_nobreak">'. |
'<input type="text" name="quota_'.$type. |
'<input type="text" name="quota_'.$type. |
Line 1480 sub print_quotas {
|
Line 1533 sub print_quotas {
|
} |
} |
} |
} |
} |
} |
unless ($context eq 'requestcourses') { |
unless (($context eq 'requestcourses') || ($context eq 'requestauthor')) { |
$defaultquota = '20'; |
$defaultquota = '20'; |
if (ref($settings) eq 'HASH') { |
if (ref($settings) eq 'HASH') { |
if (ref($settings->{'defaultquota'}) eq 'HASH') { |
if (ref($settings->{'defaultquota'}) eq 'HASH') { |
Line 1550 sub print_quotas {
|
Line 1603 sub print_quotas {
|
$defcell{$item} .= $titles{'unlimited'}; |
$defcell{$item} .= $titles{'unlimited'}; |
} |
} |
} |
} |
|
} elsif ($context eq 'requestauthor') { |
|
my $curroption; |
|
if (ref($settings) eq 'HASH') { |
|
if (ref($settings->{'requestauthor'}) eq 'HASH') { |
|
$curroption = $settings->{'requestauthor'}; |
|
} |
|
} |
|
if (!$curroption) { |
|
$curroption = 'norequest'; |
|
} |
|
foreach my $option (@options) { |
|
my $val = $option; |
|
if ($option eq 'norequest') { |
|
$val = 0; |
|
} |
|
my $checked = ''; |
|
if ($option eq $curroption) { |
|
$checked = ' checked="checked"'; |
|
} |
|
$datatable .= '<span class="LC_nobreak"><label>'. |
|
'<input type="radio" name="authorreq_default"'. |
|
' value="'.$val.'"'.$checked.' />'. |
|
$titles{$option}.'</label></span> '; |
|
} |
} else { |
} else { |
my $checked = 'checked="checked" '; |
my $checked = 'checked="checked" '; |
if (ref($settings) eq 'HASH') { |
if (ref($settings) eq 'HASH') { |
Line 1575 sub print_quotas {
|
Line 1652 sub print_quotas {
|
$datatable .= '</tr></table>'; |
$datatable .= '</tr></table>'; |
} |
} |
$datatable .= '</td>'; |
$datatable .= '</td>'; |
unless ($context eq 'requestcourses') { |
unless (($context eq 'requestcourses') || ($context eq 'requestauthor')) { |
$datatable .= '<td class="LC_right_item"><span class="LC_nobreak">'. |
$datatable .= '<td class="LC_right_item"><span class="LC_nobreak">'. |
'<input type="text" name="defaultquota" value="'. |
'<input type="text" name="defaultquota" value="'. |
$defaultquota.'" size="5" /> Mb</span></td>'; |
$defaultquota.'" size="5" /> Mb</span></td>'; |
Line 1653 sub print_quotas {
|
Line 1730 sub print_quotas {
|
$advcell{$item} .= $titles{'unlimited'}; |
$advcell{$item} .= $titles{'unlimited'}; |
} |
} |
} |
} |
|
} elsif ($context eq 'requestauthor') { |
|
my $curroption; |
|
if (ref($settings) eq 'HASH') { |
|
$curroption = $settings->{'_LC_adv'}; |
|
} |
|
my $checked = ''; |
|
if ($curroption eq '') { |
|
$checked = ' checked="checked"'; |
|
} |
|
$datatable .= '<span class="LC_nobreak"><label>'. |
|
'<input type="radio" name="authorreq__LC_adv"'. |
|
' value=""'.$checked.' />'. |
|
&mt('No override set').'</label></span> '; |
|
foreach my $option (@options) { |
|
my $val = $option; |
|
if ($option eq 'norequest') { |
|
$val = 0; |
|
} |
|
my $checked = ''; |
|
if ($val eq $curroption) { |
|
$checked = ' checked="checked"'; |
|
} |
|
$datatable .= '<span class="LC_nobreak"><label>'. |
|
'<input type="radio" name="crsreq_'.$item. |
|
'__LC_adv" value="'.$val.'"'.$checked.' />'. |
|
$titles{$option}.'</label></span> '; |
|
} |
} else { |
} else { |
my $checked = 'checked="checked" '; |
my $checked = 'checked="checked" '; |
if (ref($settings) eq 'HASH') { |
if (ref($settings) eq 'HASH') { |
Line 1682 sub print_quotas {
|
Line 1786 sub print_quotas {
|
return $datatable; |
return $datatable; |
} |
} |
|
|
sub print_courserequestmail { |
sub print_requestmail { |
my ($dom,$settings,$rowtotal) = @_; |
my ($dom,$action,$settings,$rowtotal) = @_; |
my ($now,$datatable,%dompersonnel,@domcoord,@currapproval,$rows); |
my ($now,$datatable,%dompersonnel,@domcoord,@currapproval,$rows); |
$now = time; |
$now = time; |
$rows = 0; |
$rows = 0; |
Line 1714 sub print_courserequestmail {
|
Line 1818 sub print_courserequestmail {
|
my $numinrow = 4; |
my $numinrow = 4; |
my $numdc = @domcoord; |
my $numdc = @domcoord; |
my $css_class = 'class="LC_odd_row"'; |
my $css_class = 'class="LC_odd_row"'; |
$datatable = '<tr'.$css_class.'>'. |
my $text; |
' <td>'.&mt('Receive notification of course requests requiring approval.'). |
if ($action eq 'requestcourses') { |
' </td>'. |
$text = &mt('Receive notification of course requests requiring approval'); |
|
} else { |
|
$text = &mt('Receive notification of authoring space requests requiring approval') |
|
} |
|
$datatable = '<tr '.$css_class.'>'. |
|
' <td>'.$text.'</td>'. |
' <td class="LC_left_item">'; |
' <td class="LC_left_item">'; |
if (@domcoord > 0) { |
if (@domcoord > 0) { |
$datatable .= '<table>'; |
$datatable .= '<table>'; |
Line 2154 sub print_contacts {
|
Line 2263 sub print_contacts {
|
} |
} |
|
|
sub print_helpsettings { |
sub print_helpsettings { |
|
my ($position,$dom,$confname,$settings,$rowtotal) = @_; |
|
my ($css_class,$datatable,$itemcount); |
|
my $switchserver = &check_switchserver($dom,$confname); |
|
$itemcount = 1; |
|
if ($position eq 'top') { |
|
my (%checkedon,%checkedoff,%choices,%defaultchecked,@toggles,$align); |
|
$choices{'submitbugs'} = &mt('Display link to: [_1]?', |
|
&Apache::loncommon::modal_link('http://bugs.loncapa.org', |
|
&mt('LON-CAPA bug tracker'),600,500)); |
|
%defaultchecked = ('submitbugs' => 'on'); |
|
@toggles = ('submitbugs',); |
|
$align = 'LC_left_item'; |
|
|
my ($position,$dom,$confname,$settings,$rowtotal) = @_; |
($datatable,$itemcount) = &radiobutton_prefs($settings,\@toggles,\%defaultchecked, |
my ($css_class,$datatable); |
\%choices,$itemcount); |
|
} else { |
my $switchserver = &check_switchserver($dom,$confname); |
$css_class = $itemcount%2 ? ' class="LC_odd_row"' : ''; |
|
$datatable .= '<tr'.$css_class.'>'; |
my $itemcount = 1; |
my $url = '/adm/loginproblems.html'; |
|
my $type = 'default'; |
if ($position eq 'top') { |
my %lt = &Apache::lonlocal::texthash ( |
|
del => 'Delete?', |
my (%checkedon,%checkedoff,%choices,%defaultchecked,@toggles); |
rep => 'Replace:', |
|
upl => 'Upload:', |
%choices = |
default => 'Default', |
&Apache::lonlocal::texthash ( |
custom => 'Custom', |
submitbugs => 'Display "Submit a bug" link?', |
); |
); |
if (ref($settings) eq 'HASH') { |
|
if (ref($settings->{'loginhelpurl'}) eq 'HASH') { |
%defaultchecked = ('submitbugs' => 'on'); |
|
|
} elsif ($settings->{'loginhelpurl'} ne '') { |
@toggles = ('submitbugs',); |
$type = 'custom'; |
|
$url = $settings->{'loginhelpurl'}.'?inhibitmenu=yes'; |
foreach my $item (@toggles) { |
} |
if ($defaultchecked{$item} eq 'on') { |
} |
$checkedon{$item} = ' checked="checked" '; |
$datatable .= '<td class="LC_left_item"><span class="LC_nobreak">'. |
$checkedoff{$item} = ' '; |
&mt('Log-in help page currently in use: [_1]', |
} elsif ($defaultchecked{$item} eq 'off') { |
&Apache::loncommon::modal_link($url,$lt{$type},600,500)). |
$checkedoff{$item} = ' checked="checked" '; |
'</span></td>'."\n". |
$checkedon{$item} = ' '; |
'<td class="LC_left_item">'; |
} |
if ($type eq 'custom') { |
} |
$datatable .= '<span class="LC_nobreak"><label>'. |
|
'<input type="checkbox" name="loginhelpurl_del" value="1" />'.$lt{'del'}. |
if (ref($settings) eq 'HASH') { |
'</label> '.$lt{'rep'}.'</span>'; |
foreach my $item (@toggles) { |
|
if ($settings->{$item} eq '1') { |
|
$checkedon{$item} = ' checked="checked" '; |
|
$checkedoff{$item} = ' '; |
|
} elsif ($settings->{$item} eq '0') { |
|
$checkedoff{$item} = ' checked="checked" '; |
|
$checkedon{$item} = ' '; |
|
} |
|
} |
|
} |
|
|
|
foreach my $item (@toggles) { |
|
$css_class = $itemcount%2 ? ' class="LC_odd_row"' : ''; |
|
$datatable .= |
|
'<tr'.$css_class.'> |
|
<td><span class="LC_nobreak">'.$choices{$item}.'</span></td> |
|
<td><span class="LC_nobreak"> </span></td> |
|
<td class="LC_right_item"><span class="LC_nobreak"> |
|
<label><input type="radio" name="'.$item.'" '.$checkedon{$item}.' value="1" />'.&mt('Yes').'</label> |
|
<label><input type="radio" name="'.$item.'" '.$checkedoff{$item}.' value="0" />'.&mt('No').'</label>'. |
|
'</span></td>'. |
|
'</tr>'; |
|
$itemcount ++; |
|
} |
|
|
|
} else { |
|
|
|
$css_class = $itemcount%2 ? ' class="LC_odd_row"' : ''; |
|
|
|
$datatable .= '<tr'.$css_class.'>'; |
|
|
|
if (ref($settings) eq 'HASH') { |
|
if ($settings->{'loginhelpurl'} ne '') { |
|
my($directory, $filename) = $settings->{'loginhelpurl'} =~ m/(.*\/)(.*)$/; |
|
$datatable .= '<td width="33%"><span class="LC_left_item"><label><a href="'.$settings->{'loginhelpurl'}.'" target="_blank">'.&mt('Custom Login Page Help File In Use').'</a></label></span></td>'; |
|
$datatable .= '<td width="33%"><span class="LC_right_item"><label><input type="checkbox" name="loginhelpurl_del" value="1" />'.&mt('Delete?').'</label></span></td>' |
|
} else { |
|
$datatable .= '<td width="33%"><span class="LC_left_item"><label>'.&mt('Default Login Page Help File In Use').'</label></span></td>'; |
|
$datatable .= '<td width="33%"><span class="LC_right_item"> </span></td>'; |
|
} |
|
} else { |
|
$datatable .= '<td><span class="LC_left_item"> </span></td>'; |
|
$datatable .= '<td><span class="LC_right_item"> </span></td>'; |
|
} |
|
|
|
$datatable .= '<td width="33%"><span class="LC_right_item">'; |
|
if ($switchserver) { |
|
$datatable .= &mt('Upload to library server: [_1]',$switchserver); |
|
} else { |
} else { |
$datatable .= &mt('Upload Custom Login Page Help File:'); |
$datatable .= $lt{'upl'}; |
$datatable .='<input type="file" name="loginhelpurl" />'; |
|
} |
} |
$datatable .= '</span></td></tr>'; |
$datatable .='<br />'; |
|
if ($switchserver) { |
} |
$datatable .= &mt('Upload to library server: [_1]',$switchserver); |
|
} else { |
return $datatable; |
$datatable .= '<input type="file" name="loginhelpurl" />'; |
|
} |
|
$datatable .= '</td></tr>'; |
|
} |
|
return $datatable; |
} |
} |
|
|
|
|
sub radiobutton_prefs { |
sub radiobutton_prefs { |
my ($settings,$toggles,$defaultchecked,$choices,$itemcount) = @_; |
my ($settings,$toggles,$defaultchecked,$choices,$itemcount) = @_; |
return unless ((ref($toggles) eq 'ARRAY') && (ref($defaultchecked) eq 'HASH') && |
return unless ((ref($toggles) eq 'ARRAY') && (ref($defaultchecked) eq 'HASH') && |
(ref($choices) eq 'HASH')); |
(ref($choices) eq 'HASH')); |
|
|
my (%checkedon,%checkedoff,$datatable,$css_class); |
my (%checkedon,%checkedoff,$datatable,$css_class,$cell_colspan); |
|
|
foreach my $item (@{$toggles}) { |
foreach my $item (@{$toggles}) { |
if ($defaultchecked->{$item} eq 'on') { |
if ($defaultchecked->{$item} eq 'on') { |
Line 2762 sub print_loadbalancing {
|
Line 2836 sub print_loadbalancing {
|
if (ref($types) eq 'ARRAY') { |
if (ref($types) eq 'ARRAY') { |
$rownum += scalar(@{$types}); |
$rownum += scalar(@{$types}); |
} |
} |
my $css_class = 'class="LC_odd_row"'; |
my $css_class = ' class="LC_odd_row"'; |
my $targets_div_style = 'display: none'; |
my $targets_div_style = 'display: none'; |
my $disabled_div_style = 'display: block'; |
my $disabled_div_style = 'display: block'; |
my $homedom_div_style = 'display: none'; |
my $homedom_div_style = 'display: none'; |
Line 2835 sub print_loadbalancing {
|
Line 2909 sub print_loadbalancing {
|
$datatable .= '</div></td></tr>'. |
$datatable .= '</div></td></tr>'. |
&loadbalancing_rules($dom,$intdom,$currrules,$othertitle, |
&loadbalancing_rules($dom,$intdom,$currrules,$othertitle, |
$usertypes,$types,\%servers,$currbalancer, |
$usertypes,$types,\%servers,$currbalancer, |
$targets_div_style,$homedom_div_style); |
$targets_div_style,$homedom_div_style,$css_class); |
$$rowtotal += $rownum; |
$$rowtotal += $rownum; |
return $datatable; |
return $datatable; |
} |
} |
|
|
sub loadbalancing_rules { |
sub loadbalancing_rules { |
my ($dom,$intdom,$currrules,$othertitle,$usertypes,$types,$servers, |
my ($dom,$intdom,$currrules,$othertitle,$usertypes,$types,$servers, |
$currbalancer,$targets_div_style,$homedom_div_style) = @_; |
$currbalancer,$targets_div_style,$homedom_div_style,$css_class) = @_; |
my $output; |
my $output; |
my ($alltypes,$othertypes,$titles) = |
my ($alltypes,$othertypes,$titles) = |
&loadbalancing_titles($dom,$intdom,$usertypes,$types); |
&loadbalancing_titles($dom,$intdom,$usertypes,$types); |
Line 2859 sub loadbalancing_rules {
|
Line 2933 sub loadbalancing_rules {
|
} |
} |
$output .= &loadbalance_rule_row($type,$titles->{$type},$current, |
$output .= &loadbalance_rule_row($type,$titles->{$type},$current, |
$servers,$currbalancer,$dom, |
$servers,$currbalancer,$dom, |
$targets_div_style,$homedom_div_style); |
$targets_div_style,$homedom_div_style,$css_class); |
} |
} |
} |
} |
return $output; |
return $output; |
Line 2897 sub loadbalancing_titles {
|
Line 2971 sub loadbalancing_titles {
|
|
|
sub loadbalance_rule_row { |
sub loadbalance_rule_row { |
my ($type,$title,$current,$servers,$currbalancer,$dom,$targets_div_style, |
my ($type,$title,$current,$servers,$currbalancer,$dom,$targets_div_style, |
$homedom_div_style) = @_; |
$homedom_div_style,$css_class) = @_; |
my @rulenames = ('default','homeserver'); |
my @rulenames = ('default','homeserver'); |
my %ruletitles = &offloadtype_text(); |
my %ruletitles = &offloadtype_text(); |
if ($type eq '_LC_external') { |
if ($type eq '_LC_external') { |
Line 2905 sub loadbalance_rule_row {
|
Line 2979 sub loadbalance_rule_row {
|
} else { |
} else { |
push(@rulenames,'specific'); |
push(@rulenames,'specific'); |
} |
} |
|
push(@rulenames,'none'); |
my $style = $targets_div_style; |
my $style = $targets_div_style; |
if (($type eq '_LC_external') || ($type eq '_LC_internetdom')) { |
if (($type eq '_LC_external') || ($type eq '_LC_internetdom')) { |
$style = $homedom_div_style; |
$style = $homedom_div_style; |
} |
} |
my $output = |
my $output = |
'<tr><td valign="top"><div id="balanceruletitle_'.$type.'" style="'.$style.'">'.$title.'</div></td>'."\n". |
'<tr'.$css_class.'><td valign="top"><div id="balanceruletitle_'.$type.'" style="'.$style.'">'.$title.'</div></td>'."\n". |
'<td><div id="balancerule_'.$type.'" style="'.$style.'">'."\n"; |
'<td><div id="balancerule_'.$type.'" style="'.$style.'">'."\n"; |
for (my $i=0; $i<@rulenames; $i++) { |
for (my $i=0; $i<@rulenames; $i++) { |
my $rule = $rulenames[$i]; |
my $rule = $rulenames[$i]; |
Line 2961 sub offloadtype_text {
|
Line 3036 sub offloadtype_text {
|
'homeserver' => "Offloads to user's home server", |
'homeserver' => "Offloads to user's home server", |
'externalbalancer' => "Offloads to Load Balancer in user's domain", |
'externalbalancer' => "Offloads to Load Balancer in user's domain", |
'specific' => 'Offloads to specific server', |
'specific' => 'Offloads to specific server', |
|
'none' => 'No offload', |
); |
); |
return %ruletitles; |
return %ruletitles; |
} |
} |
Line 2992 sub contact_titles {
|
Line 3068 sub contact_titles {
|
|
|
sub tool_titles { |
sub tool_titles { |
my %titles = &Apache::lonlocal::texthash ( |
my %titles = &Apache::lonlocal::texthash ( |
aboutme => 'Personal Information Page', |
aboutme => 'Personal web page', |
blog => 'Blog', |
blog => 'Blog', |
|
webdav => 'WebDAV', |
portfolio => 'Portfolio', |
portfolio => 'Portfolio', |
official => 'Official courses (with institutional codes)', |
official => 'Official courses (with institutional codes)', |
unofficial => 'Unofficial courses', |
unofficial => 'Unofficial courses', |
Line 3016 sub courserequest_titles {
|
Line 3093 sub courserequest_titles {
|
return %titles; |
return %titles; |
} |
} |
|
|
|
sub authorrequest_titles { |
|
my %titles = &Apache::lonlocal::texthash ( |
|
norequest => 'Not allowed', |
|
approval => 'Approval by Dom. Coord.', |
|
automatic => 'Automatic approval', |
|
); |
|
return %titles; |
|
} |
|
|
sub courserequest_conditions { |
sub courserequest_conditions { |
my %conditions = &Apache::lonlocal::texthash ( |
my %conditions = &Apache::lonlocal::texthash ( |
approval => '(Processing of request subject to approval by Domain Coordinator).', |
approval => '(Processing of request subject to approval by Domain Coordinator).', |
Line 3145 sub print_usercreation {
|
Line 3231 sub print_usercreation {
|
} |
} |
my ($othertitle,$usertypes,$types) = |
my ($othertitle,$usertypes,$types) = |
&Apache::loncommon::sorted_inst_types($dom); |
&Apache::loncommon::sorted_inst_types($dom); |
|
my $createsettings; |
|
if (ref($settings) eq 'HASH') { |
|
$createsettings = $settings->{cancreate}; |
|
} |
if (ref($usertypes) eq 'HASH') { |
if (ref($usertypes) eq 'HASH') { |
if (keys(%{$usertypes}) > 0) { |
if (keys(%{$usertypes}) > 0) { |
my $createsettings; |
|
if (ref($settings) eq 'HASH') { |
|
$createsettings = $settings->{cancreate}; |
|
} |
|
$datatable .= &insttypes_row($createsettings,$types,$usertypes, |
$datatable .= &insttypes_row($createsettings,$types,$usertypes, |
$dom,$numinrow,$othertitle, |
$dom,$numinrow,$othertitle, |
'statustocreate'); |
'statustocreate'); |
$$rowtotal ++; |
$$rowtotal ++; |
} |
} |
} |
} |
|
$datatable .= &captcha_choice('cancreate',$createsettings); |
} else { |
} else { |
my @contexts = ('author','course','domain'); |
my @contexts = ('author','course','domain'); |
my @authtypes = ('int','krb4','krb5','loc'); |
my @authtypes = ('int','krb4','krb5','loc'); |
Line 3208 sub print_usercreation {
|
Line 3295 sub print_usercreation {
|
return $datatable; |
return $datatable; |
} |
} |
|
|
|
sub captcha_choice { |
|
my ($context,$settings) = @_; |
|
my ($keyentry,$currpub,$currpriv,%checked,$rowname,$pubtext,$privtext); |
|
my %lt = &captcha_phrases(); |
|
$keyentry = 'hidden'; |
|
if ($context eq 'cancreate') { |
|
$rowname = &mt('CAPTCHA validation (e-mail as username)'); |
|
} elsif ($context eq 'help') { |
|
$rowname = &mt('CAPTCHA validation'); |
|
} |
|
if (ref($settings) eq 'HASH') { |
|
if ($settings->{'captcha'}) { |
|
$checked{$settings->{'captcha'}} = ' checked="checked"'; |
|
} else { |
|
$checked{'original'} = ' checked="checked"'; |
|
} |
|
if ($settings->{'captcha'} eq 'recaptcha') { |
|
$pubtext = $lt{'pub'}; |
|
$privtext = $lt{'priv'}; |
|
$keyentry = 'text'; |
|
} |
|
if (ref($settings->{'recaptchakeys'}) eq 'HASH') { |
|
$currpub = $settings->{'recaptchakeys'}{'public'}; |
|
$currpriv = $settings->{'recaptchakeys'}{'private'}; |
|
} |
|
} else { |
|
$checked{'original'} = ' checked="checked"'; |
|
} |
|
my $output = '<tr class="LC_odd_row">'. |
|
'<td class="LC_left_item">'.$rowname.'</td><td class="LC_right_item" colspan="2">'."\n". |
|
'<table><tr><td>'."\n"; |
|
foreach my $option ('original','recaptcha','notused') { |
|
$output .= '<span class="LC_nobreak"><label><input type="radio" name="'.$context.'_captcha" value="'. |
|
$option.'" '.$checked{$option}.' onchange="javascript:updateCaptcha('."this,'$context'".');" />'. |
|
$lt{$option}.'</label></span>'; |
|
unless ($option eq 'notused') { |
|
$output .= (' 'x2)."\n"; |
|
} |
|
} |
|
# |
|
# Note: If reCAPTCHA is to be used for LON-CAPA servers in a domain, a domain coordinator should visit: |
|
# https://www.google.com/recaptcha and generate a Public and Private key. For domains with multiple |
|
# servers a single key pair will be used for all servers, so the internet domain (e.g., yourcollege.edu) |
|
# specified for use with the key should be broad enough to accommodate all servers in the LON-CAPA domain. |
|
# |
|
$output .= '</td></tr>'."\n". |
|
'<tr><td>'."\n". |
|
'<span class="LC_nobreak"><span id="'.$context.'_recaptchapubtxt">'.$pubtext.'</span> '."\n". |
|
'<input type="'.$keyentry.'" id="'.$context.'_recaptchapub" name="'.$context.'_recaptchapub" value="'. |
|
$currpub.'" size="40" /></span><br />'."\n". |
|
'<span class="LC_nobreak"><span id="'.$context.'_recaptchaprivtxt">'.$privtext.'</span> '."\n". |
|
'<input type="'.$keyentry.'" id="'.$context.'_recaptchapriv" name="'.$context.'_recaptchapriv" value="'. |
|
$currpriv.'" size="40" /></span></td></tr></table>'."\n". |
|
'</td></tr>'; |
|
return $output; |
|
} |
|
|
sub user_formats_row { |
sub user_formats_row { |
my ($type,$settings,$rules,$ruleorder,$numinrow,$rowcount) = @_; |
my ($type,$settings,$rules,$ruleorder,$numinrow,$rowcount) = @_; |
my $output; |
my $output; |
Line 3858 sub print_serverstatuses {
|
Line 4002 sub print_serverstatuses {
|
sub serverstatus_pages { |
sub serverstatus_pages { |
return ('userstatus','lonstatus','loncron','server-status','codeversions', |
return ('userstatus','lonstatus','loncron','server-status','codeversions', |
'clusterstatus','metadata_keywords','metadata_harvest', |
'clusterstatus','metadata_keywords','metadata_harvest', |
'takeoffline','takeonline','showenv','toggledebug'); |
'takeoffline','takeonline','showenv','toggledebug','ping','domconf'); |
} |
} |
|
|
sub coursecategories_javascript { |
sub coursecategories_javascript { |
Line 4172 sub insttypes_row {
|
Line 4316 sub insttypes_row {
|
if ($context eq 'cansearch') { |
if ($context eq 'cansearch') { |
$showdom = ' ('.$dom.')'; |
$showdom = ' ('.$dom.')'; |
} |
} |
|
my $class = 'LC_left_item'; |
|
if ($context eq 'statustocreate') { |
|
$class = 'LC_right_item'; |
|
} |
my $output = '<tr class="LC_odd_row">'. |
my $output = '<tr class="LC_odd_row">'. |
'<td>'.$lt{$context}.$showdom. |
'<td>'.$lt{$context}.$showdom. |
'</td><td class="LC_left_item" colspan="2"><table>'; |
'</td><td class="'.$class.'" colspan="2"><table>'; |
my $rem; |
my $rem; |
if (ref($types) eq 'ARRAY') { |
if (ref($types) eq 'ARRAY') { |
for (my $i=0; $i<@{$types}; $i++) { |
for (my $i=0; $i<@{$types}; $i++) { |
Line 4926 sub publishlogo {
|
Line 5074 sub publishlogo {
|
# See if there is anything left |
# See if there is anything left |
unless ($fname) { return ('error: no uploaded file'); } |
unless ($fname) { return ('error: no uploaded file'); } |
$fname="$subdir/$fname"; |
$fname="$subdir/$fname"; |
my $filepath='/home/'.$confname.'/public_html'; |
my $docroot=$r->dir_config('lonDocRoot'); |
|
my $filepath="$docroot/priv"; |
|
my $relpath = "$dom/$confname"; |
my ($fnamepath,$file,$fetchthumb); |
my ($fnamepath,$file,$fetchthumb); |
$file=$fname; |
$file=$fname; |
if ($fname=~m|/|) { |
if ($fname=~m|/|) { |
($fnamepath,$file) = ($fname =~ m|^(.*)/([^/]+)$|); |
($fnamepath,$file) = ($fname =~ m|^(.*)/([^/]+)$|); |
} |
} |
my @parts=split(/\//,$filepath.'/'.$fnamepath); |
my @parts=split(/\//,"$filepath/$relpath/$fnamepath"); |
my $count; |
my $count; |
for ($count=4;$count<=$#parts;$count++) { |
for ($count=5;$count<=$#parts;$count++) { |
$filepath.="/$parts[$count]"; |
$filepath.="/$parts[$count]"; |
if ((-e $filepath)!=1) { |
if ((-e $filepath)!=1) { |
mkdir($filepath,02770); |
mkdir($filepath,02770); |
Line 4981 $env{'user.name'}.':'.$env{'user.domain'
|
Line 5131 $env{'user.name'}.':'.$env{'user.domain'
|
close(FH); |
close(FH); |
chmod(0660, $source); # Permissions to rw-rw---. |
chmod(0660, $source); # Permissions to rw-rw---. |
|
|
my $docroot=$r->dir_config('lonDocRoot'); |
|
my $targetdir=$docroot.'/res/'.$dom.'/'.$confname .'/'.$fnamepath; |
my $targetdir=$docroot.'/res/'.$dom.'/'.$confname .'/'.$fnamepath; |
my $copyfile=$targetdir.'/'.$file; |
my $copyfile=$targetdir.'/'.$file; |
|
|
Line 5004 $env{'user.name'}.':'.$env{'user.domain'
|
Line 5153 $env{'user.name'}.':'.$env{'user.domain'
|
if (copy($source,$copyfile)) { |
if (copy($source,$copyfile)) { |
print $logfile "\nCopied original source to ".$copyfile."\n"; |
print $logfile "\nCopied original source to ".$copyfile."\n"; |
$output = 'ok'; |
$output = 'ok'; |
&write_metadata($dom,$confname,$formname,$targetdir,$file,$logfile); |
|
$logourl = '/res/'.$dom.'/'.$confname.'/'.$fname; |
$logourl = '/res/'.$dom.'/'.$confname.'/'.$fname; |
|
push(@{$modified_urls},[$copyfile,$source]); |
|
my $metaoutput = |
|
&write_metadata($dom,$confname,$formname,$targetdir,$file,$logfile); |
|
unless ($registered_cleanup) { |
|
my $handlers = $r->get_handlers('PerlCleanupHandler'); |
|
$r->set_handlers('PerlCleanupHandler' => [\¬ifysubscribed,@{$handlers}]); |
|
$registered_cleanup=1; |
|
} |
} else { |
} else { |
print $logfile "\nUnable to write ".$copyfile.':'.$!."\n"; |
print $logfile "\nUnable to write ".$copyfile.':'.$!."\n"; |
$output = &mt('Failed to copy file to RES space').", $!"; |
$output = &mt('Failed to copy file to RES space').", $!"; |
Line 5023 $env{'user.name'}.':'.$env{'user.domain'
|
Line 5179 $env{'user.name'}.':'.$env{'user.domain'
|
my $copyfile=$targetdir.'/tn-'.$file; |
my $copyfile=$targetdir.'/tn-'.$file; |
if (copy($outfile,$copyfile)) { |
if (copy($outfile,$copyfile)) { |
print $logfile "\nCopied source to ".$copyfile."\n"; |
print $logfile "\nCopied source to ".$copyfile."\n"; |
&write_metadata($dom,$confname,$formname, |
my $thumb_metaoutput = |
$targetdir,'tn-'.$file,$logfile); |
&write_metadata($dom,$confname,$formname, |
|
$targetdir,'tn-'.$file,$logfile); |
|
push(@{$modified_urls},[$copyfile,$outfile]); |
|
unless ($registered_cleanup) { |
|
my $handlers = $r->get_handlers('PerlCleanupHandler'); |
|
$r->set_handlers('PerlCleanupHandler' => [\¬ifysubscribed,@{$handlers}]); |
|
$registered_cleanup=1; |
|
} |
} else { |
} else { |
print $logfile "\nUnable to write ".$copyfile. |
print $logfile "\nUnable to write ".$copyfile. |
':'.$!."\n"; |
':'.$!."\n"; |
Line 5089 sub write_metadata {
|
Line 5252 sub write_metadata {
|
{ |
{ |
print $logfile "\nWrite metadata file for ".$targetdir.'/'.$file; |
print $logfile "\nWrite metadata file for ".$targetdir.'/'.$file; |
my $mfh; |
my $mfh; |
unless (open($mfh,'>'.$targetdir.'/'.$file.'.meta')) { |
if (open($mfh,'>'.$targetdir.'/'.$file.'.meta')) { |
|
foreach (sort keys %metadatafields) { |
|
unless ($_=~/\./) { |
|
my $unikey=$_; |
|
$unikey=~/^([A-Za-z]+)/; |
|
my $tag=$1; |
|
$tag=~tr/A-Z/a-z/; |
|
print $mfh "\n\<$tag"; |
|
foreach (split(/\,/,$metadatakeys{$unikey})) { |
|
my $value=$metadatafields{$unikey.'.'.$_}; |
|
$value=~s/\"/\'\'/g; |
|
print $mfh ' '.$_.'="'.$value.'"'; |
|
} |
|
print $mfh '>'. |
|
&HTML::Entities::encode($metadatafields{$unikey},'<>&"') |
|
.'</'.$tag.'>'; |
|
} |
|
} |
|
$output = 'ok'; |
|
print $logfile "\nWrote metadata"; |
|
close($mfh); |
|
} else { |
|
print $logfile "\nFailed to open metadata file"; |
$output = &mt('Could not write metadata'); |
$output = &mt('Could not write metadata'); |
} |
} |
foreach (sort keys %metadatafields) { |
|
unless ($_=~/\./) { |
|
my $unikey=$_; |
|
$unikey=~/^([A-Za-z]+)/; |
|
my $tag=$1; |
|
$tag=~tr/A-Z/a-z/; |
|
print $mfh "\n\<$tag"; |
|
foreach (split(/\,/,$metadatakeys{$unikey})) { |
|
my $value=$metadatafields{$unikey.'.'.$_}; |
|
$value=~s/\"/\'\'/g; |
|
print $mfh ' '.$_.'="'.$value.'"'; |
|
} |
|
print $mfh '>'. |
|
&HTML::Entities::encode($metadatafields{$unikey},'<>&"') |
|
.'</'.$tag.'>'; |
|
} |
|
} |
|
$output = 'ok'; |
|
print $logfile "\nWrote metadata"; |
|
close($mfh); |
|
} |
} |
|
return $output; |
|
} |
|
|
|
sub notifysubscribed { |
|
foreach my $targetsource (@{$modified_urls}){ |
|
next unless (ref($targetsource) eq 'ARRAY'); |
|
my ($target,$source)=@{$targetsource}; |
|
if ($source ne '') { |
|
if (open(my $logfh,'>>'.$source.'.log')) { |
|
print $logfh "\nCleanup phase: Notifications\n"; |
|
my @subscribed=&subscribed_hosts($target); |
|
foreach my $subhost (@subscribed) { |
|
print $logfh "\nNotifying host ".$subhost.':'; |
|
my $reply=&Apache::lonnet::critical('update:'.$target,$subhost); |
|
print $logfh $reply; |
|
} |
|
my @subscribedmeta=&subscribed_hosts("$target.meta"); |
|
foreach my $subhost (@subscribedmeta) { |
|
print $logfh "\nNotifying host for metadata only ".$subhost.':'; |
|
my $reply=&Apache::lonnet::critical('update:'.$target.'.meta', |
|
$subhost); |
|
print $logfh $reply; |
|
} |
|
print $logfh "\n============ Done ============\n"; |
|
close($logfh); |
|
} |
|
} |
|
} |
|
return OK; |
|
} |
|
|
|
sub subscribed_hosts { |
|
my ($target) = @_; |
|
my @subscribed; |
|
if (open(my $fh,"<$target.subscription")) { |
|
while (my $subline=<$fh>) { |
|
if ($subline =~ /^($match_lonid):/) { |
|
my $host = $1; |
|
if ($host ne $Apache::lonnet::perlvar{'lonHostID'}) { |
|
unless (grep(/^\Q$host\E$/,@subscribed)) { |
|
push(@subscribed,$host); |
|
} |
|
} |
|
} |
|
} |
|
} |
|
return @subscribed; |
} |
} |
|
|
sub check_switchserver { |
sub check_switchserver { |
Line 5136 sub modify_quotas {
|
Line 5348 sub modify_quotas {
|
%limithash,$toolregexp,%conditions,$resulttext,%changes); |
%limithash,$toolregexp,%conditions,$resulttext,%changes); |
if ($action eq 'quotas') { |
if ($action eq 'quotas') { |
$context = 'tools'; |
$context = 'tools'; |
} else { |
} else { |
$context = $action; |
$context = $action; |
} |
} |
if ($context eq 'requestcourses') { |
if ($context eq 'requestcourses') { |
Line 5146 sub modify_quotas {
|
Line 5358 sub modify_quotas {
|
%titles = &courserequest_titles(); |
%titles = &courserequest_titles(); |
$toolregexp = join('|',@usertools); |
$toolregexp = join('|',@usertools); |
%conditions = &courserequest_conditions(); |
%conditions = &courserequest_conditions(); |
|
} elsif ($context eq 'requestauthor') { |
|
@usertools = ('author'); |
|
%titles = &authorrequest_titles(); |
} else { |
} else { |
@usertools = ('aboutme','blog','portfolio'); |
@usertools = ('aboutme','blog','webdav','portfolio'); |
%titles = &tool_titles(); |
%titles = &tool_titles(); |
} |
} |
my %domdefaults = &Apache::lonnet::get_domain_defaults($dom); |
my %domdefaults = &Apache::lonnet::get_domain_defaults($dom); |
Line 5163 sub modify_quotas {
|
Line 5378 sub modify_quotas {
|
$confhash{$item}{$type} = $env{$key}; |
$confhash{$item}{$type} = $env{$key}; |
} |
} |
} |
} |
|
} elsif ($context eq 'requestauthor') { |
|
if ($key =~ /^\Qform.authorreq_\E(.+)$/) { |
|
$confhash{$1} = $env{$key}; |
|
} |
} else { |
} else { |
if ($key =~ /^form\.quota_(.+)$/) { |
if ($key =~ /^form\.quota_(.+)$/) { |
$confhash{'defaultquota'}{$1} = $env{$key}; |
$confhash{'defaultquota'}{$1} = $env{$key}; |
Line 5172 sub modify_quotas {
|
Line 5391 sub modify_quotas {
|
} |
} |
} |
} |
} |
} |
if ($context eq 'requestcourses') { |
if (($context eq 'requestcourses') || ($context eq 'requestauthor')) { |
my @approvalnotify = &Apache::loncommon::get_env_multiple('form.reqapprovalnotify'); |
my @approvalnotify = &Apache::loncommon::get_env_multiple('form.reqapprovalnotify'); |
@approvalnotify = sort(@approvalnotify); |
@approvalnotify = sort(@approvalnotify); |
$confhash{'notify'}{'approval'} = join(',',@approvalnotify); |
$confhash{'notify'}{'approval'} = join(',',@approvalnotify); |
Line 5208 sub modify_quotas {
|
Line 5427 sub modify_quotas {
|
$confhash{$item}{$type} .= $limithash{$item}{$type}; |
$confhash{$item}{$type} .= $limithash{$item}{$type}; |
} |
} |
} |
} |
|
} elsif ($context eq 'requestauthor') { |
|
$unset = '0'; |
|
if ($type eq '_LC_adv') { |
|
$unset = ''; |
|
} |
} else { |
} else { |
if (grep(/^\Q$type\E$/,@{$toolshash{$item}})) { |
if (grep(/^\Q$type\E$/,@{$toolshash{$item}})) { |
$confhash{$item}{$type} = 1; |
$confhash{$item}{$type} = 1; |
Line 5216 sub modify_quotas {
|
Line 5440 sub modify_quotas {
|
} |
} |
} |
} |
if (ref($domconfig{$action}) eq 'HASH') { |
if (ref($domconfig{$action}) eq 'HASH') { |
if (ref($domconfig{$action}{$item}) eq 'HASH') { |
if ($action eq 'requestauthor') { |
|
if ($domconfig{$action}{$type} ne $confhash{$type}) { |
|
$changes{$type} = 1; |
|
} |
|
} elsif (ref($domconfig{$action}{$item}) eq 'HASH') { |
if ($domconfig{$action}{$item}{$type} ne $confhash{$item}{$type}) { |
if ($domconfig{$action}{$item}{$type} ne $confhash{$item}{$type}) { |
$changes{$item}{$type} = 1; |
$changes{$item}{$type} = 1; |
} |
} |
Line 5236 sub modify_quotas {
|
Line 5464 sub modify_quotas {
|
if ($confhash{$item}{$type} ne $unset) { |
if ($confhash{$item}{$type} ne $unset) { |
$changes{$item}{$type} = 1; |
$changes{$item}{$type} = 1; |
} |
} |
|
} elsif ($context eq 'requestauthor') { |
|
if ($confhash{$type} ne $unset) { |
|
$changes{$type} = 1; |
|
} |
} else { |
} else { |
if (!$confhash{$item}{$type}) { |
if (!$confhash{$item}{$type}) { |
$changes{$item}{$type} = 1; |
$changes{$item}{$type} = 1; |
Line 5244 sub modify_quotas {
|
Line 5476 sub modify_quotas {
|
} |
} |
} |
} |
} |
} |
unless ($context eq 'requestcourses') { |
unless (($context eq 'requestcourses') || ($context eq 'requestauthor')) { |
if (ref($domconfig{'quotas'}) eq 'HASH') { |
if (ref($domconfig{'quotas'}) eq 'HASH') { |
if (ref($domconfig{'quotas'}{'defaultquota'}) eq 'HASH') { |
if (ref($domconfig{'quotas'}{'defaultquota'}) eq 'HASH') { |
foreach my $key (keys(%{$domconfig{'quotas'}{'defaultquota'}})) { |
foreach my $key (keys(%{$domconfig{'quotas'}{'defaultquota'}})) { |
Line 5287 sub modify_quotas {
|
Line 5519 sub modify_quotas {
|
} |
} |
} |
} |
|
|
foreach my $key (keys(%confhash)) { |
if ($context eq 'requestauthor') { |
$domdefaults{$key} = $confhash{$key}; |
$domdefaults{'requestauthor'} = \%confhash; |
|
} else { |
|
foreach my $key (keys(%confhash)) { |
|
$domdefaults{$key} = $confhash{$key}; |
|
} |
} |
} |
|
|
my %quotahash = ( |
my %quotahash = ( |
$action => { %confhash } |
$action => { %confhash } |
); |
); |
Line 5302 sub modify_quotas {
|
Line 5538 sub modify_quotas {
|
&Apache::lonnet::do_cache_new('domdefaults',$dom,\%domdefaults,$cachetime); |
&Apache::lonnet::do_cache_new('domdefaults',$dom,\%domdefaults,$cachetime); |
|
|
$resulttext = &mt('Changes made:').'<ul>'; |
$resulttext = &mt('Changes made:').'<ul>'; |
unless ($context eq 'requestcourses') { |
unless (($context eq 'requestcourses') || |
|
($context eq 'requestauthor')) { |
if (ref($changes{'defaultquota'}) eq 'HASH') { |
if (ref($changes{'defaultquota'}) eq 'HASH') { |
$resulttext .= '<li>'.&mt('Portfolio default quotas').'<ul>'; |
$resulttext .= '<li>'.&mt('Portfolio default quotas').'<ul>'; |
foreach my $type (@{$types},'default') { |
foreach my $type (@{$types},'default') { |
Line 5319 sub modify_quotas {
|
Line 5556 sub modify_quotas {
|
} |
} |
my %newenv; |
my %newenv; |
foreach my $item (@usertools) { |
foreach my $item (@usertools) { |
if (ref($changes{$item}) eq 'HASH') { |
my (%haschgs,%inconf); |
|
if ($context eq 'requestauthor') { |
|
%haschgs = %changes; |
|
%inconf = %confhash; |
|
} else { |
|
if (ref($changes{$item}) eq 'HASH') { |
|
%haschgs = %{$changes{$item}}; |
|
} |
|
if (ref($confhash{$item}) eq 'HASH') { |
|
%inconf = %{$confhash{$item}}; |
|
} |
|
} |
|
if (keys(%haschgs) > 0) { |
my $newacc = |
my $newacc = |
&Apache::lonnet::usertools_access($env{'user.name'}, |
&Apache::lonnet::usertools_access($env{'user.name'}, |
$env{'user.domain'}, |
$env{'user.domain'}, |
$item,'reload',$context); |
$item,'reload',$context); |
if ($context eq 'requestcourses') { |
if (($context eq 'requestcourses') || |
|
($context eq 'requestauthor')) { |
if ($env{'environment.canrequest.'.$item} ne $newacc) { |
if ($env{'environment.canrequest.'.$item} ne $newacc) { |
$newenv{'environment.canrequest.'.$item} = $newacc; |
$newenv{'environment.canrequest.'.$item} = $newacc; |
} |
} |
Line 5333 sub modify_quotas {
|
Line 5583 sub modify_quotas {
|
$newenv{'environment.availabletools.'.$item} = $newacc; |
$newenv{'environment.availabletools.'.$item} = $newacc; |
} |
} |
} |
} |
$resulttext .= '<li>'.$titles{$item}.'<ul>'; |
unless ($context eq 'requestauthor') { |
|
$resulttext .= '<li>'.$titles{$item}.'<ul>'; |
|
} |
foreach my $type (@{$types},'default','_LC_adv') { |
foreach my $type (@{$types},'default','_LC_adv') { |
if ($changes{$item}{$type}) { |
if ($haschgs{$type}) { |
my $typetitle = $usertypes->{$type}; |
my $typetitle = $usertypes->{$type}; |
if ($type eq 'default') { |
if ($type eq 'default') { |
$typetitle = $othertitle; |
$typetitle = $othertitle; |
} elsif ($type eq '_LC_adv') { |
} elsif ($type eq '_LC_adv') { |
$typetitle = 'LON-CAPA Advanced Users'; |
$typetitle = 'LON-CAPA Advanced Users'; |
} |
} |
if ($confhash{$item}{$type}) { |
if ($inconf{$type}) { |
if ($context eq 'requestcourses') { |
if ($context eq 'requestcourses') { |
my $cond; |
my $cond; |
if ($confhash{$item}{$type} =~ /^autolimit=(\d*)$/) { |
if ($inconf{$type} =~ /^autolimit=(\d*)$/) { |
if ($1 eq '') { |
if ($1 eq '') { |
$cond = &mt('(Automatic processing of any request).'); |
$cond = &mt('(Automatic processing of any request).'); |
} else { |
} else { |
$cond = &mt('(Automatic processing of requests up to limit of [quant,_1,request] per user).',$1); |
$cond = &mt('(Automatic processing of requests up to limit of [quant,_1,request] per user).',$1); |
} |
} |
} else { |
} else { |
$cond = $conditions{$confhash{$item}{$type}}; |
$cond = $conditions{$inconf{$type}}; |
} |
} |
$resulttext .= '<li>'.&mt('Set to be available to [_1].',$typetitle).' '.$cond.'</li>'; |
$resulttext .= '<li>'.&mt('Set to be available to [_1].',$typetitle).' '.$cond.'</li>'; |
} else { |
} else { |
Line 5360 sub modify_quotas {
|
Line 5612 sub modify_quotas {
|
} |
} |
} else { |
} else { |
if ($type eq '_LC_adv') { |
if ($type eq '_LC_adv') { |
if ($confhash{$item}{$type} eq '0') { |
if ($inconf{$type} eq '0') { |
$resulttext .= '<li>'.&mt('Set to be unavailable to [_1]',$typetitle).'</li>'; |
$resulttext .= '<li>'.&mt('Set to be unavailable to [_1]',$typetitle).'</li>'; |
} else { |
} else { |
$resulttext .= '<li>'.&mt('No override set for [_1]',$typetitle).'</li>'; |
$resulttext .= '<li>'.&mt('No override set for [_1]',$typetitle).'</li>'; |
Line 5371 sub modify_quotas {
|
Line 5623 sub modify_quotas {
|
} |
} |
} |
} |
} |
} |
$resulttext .= '</ul></li>'; |
unless ($context eq 'requestauthor') { |
|
$resulttext .= '</ul></li>'; |
|
} |
} |
} |
} |
} |
if ($action eq 'requestcourses') { |
if (($action eq 'requestcourses') || ($action eq 'requestauthor')) { |
if (ref($changes{'notify'}) eq 'HASH') { |
if (ref($changes{'notify'}) eq 'HASH') { |
if ($changes{'notify'}{'approval'}) { |
if ($changes{'notify'}{'approval'}) { |
if (ref($confhash{'notify'}) eq 'HASH') { |
if (ref($confhash{'notify'}) eq 'HASH') { |
if ($confhash{'notify'}{'approval'}) { |
if ($confhash{'notify'}{'approval'}) { |
$resulttext .= '<li>'.&mt('Notification of requests requiring approval will be sent to: ').$confhash{'notify'}{'approval'}.'</li>'; |
$resulttext .= '<li>'.&mt('Notification of requests requiring approval will be sent to: ').$confhash{'notify'}{'approval'}.'</li>'; |
} else { |
} else { |
$resulttext .= '<li>'.&mt('No Domain Coordinators will receive notification of course requests requiring approval.').'</li>'; |
$resulttext .= '<li>'.&mt('No Domain Coordinators will receive notification of requests requiring approval.').'</li>'; |
} |
} |
} |
} |
} |
} |
Line 5394 sub modify_quotas {
|
Line 5648 sub modify_quotas {
|
} else { |
} else { |
if ($context eq 'requestcourses') { |
if ($context eq 'requestcourses') { |
$resulttext = &mt('No changes made to rights to request creation of courses.'); |
$resulttext = &mt('No changes made to rights to request creation of courses.'); |
|
} elsif ($context eq 'requestauthor') { |
|
$resulttext = &mt('No changes made to rights to request author space.'); |
} else { |
} else { |
$resulttext = &mt('No changes made to availability of personal information pages, blogs, portfolios or default quotas'); |
$resulttext = &mt('No changes made to availability of personal information pages, blogs, portfolios or default quotas'); |
} |
} |
Line 6088 sub modify_usercreation {
|
Line 6344 sub modify_usercreation {
|
} |
} |
push(@contexts,'statustocreate'); |
push(@contexts,'statustocreate'); |
} |
} |
|
&process_captcha('cancreate',\%changes,\%cancreate,\%curr_usercreation); |
if (ref($curr_usercreation{'cancreate'}) eq 'HASH') { |
if (ref($curr_usercreation{'cancreate'}) eq 'HASH') { |
foreach my $item (@contexts) { |
foreach my $item (@contexts) { |
if (($item eq 'selfcreate') || ($item eq 'statustocreate')) { |
if (($item eq 'selfcreate') || ($item eq 'statustocreate')) { |
Line 6270 sub modify_usercreation {
|
Line 6527 sub modify_usercreation {
|
my %lt = &usercreation_types(); |
my %lt = &usercreation_types(); |
foreach my $type (@{$changes{'cancreate'}}) { |
foreach my $type (@{$changes{'cancreate'}}) { |
my $chgtext; |
my $chgtext; |
unless ($type eq 'statustocreate') { |
unless (($type eq 'statustocreate') || ($type eq 'captcha') || ($type eq 'recaptchakeys')) { |
$chgtext = $lt{$type}.', '; |
$chgtext = $lt{$type}.', '; |
} |
} |
if ($type eq 'selfcreate') { |
if ($type eq 'selfcreate') { |
Line 6329 sub modify_usercreation {
|
Line 6586 sub modify_usercreation {
|
} |
} |
} |
} |
} |
} |
|
} elsif ($type eq 'captcha') { |
|
if ($cancreate{$type} eq 'notused') { |
|
$chgtext .= &mt('No CAPTCHA validation in use for self-creation screen.'); |
|
} else { |
|
my %captchas = &captcha_phrases(); |
|
if ($captchas{$cancreate{$type}}) { |
|
$chgtext .= &mt("Validation for self-creation screen set to $captchas{$cancreate{$type}}."); |
|
} else { |
|
$chgtext .= &mt('Validation for self-creation screen set to unknown type.'); |
|
} |
|
} |
|
} elsif ($type eq 'recaptchakeys') { |
|
my ($privkey,$pubkey); |
|
if (ref($cancreate{$type}) eq 'HASH') { |
|
$pubkey = $cancreate{$type}{'public'}; |
|
$privkey = $cancreate{$type}{'private'}; |
|
} |
|
$chgtext .= &mt('ReCAPTCHA keys changes').'<ul>'; |
|
if (!$pubkey) { |
|
$chgtext .= '<li>'.&mt('Public key deleted').'</li>'; |
|
} else { |
|
$chgtext .= '<li>'.&mt('Public key set to [_1]',$pubkey).'</li>'; |
|
} |
|
if (!$privkey) { |
|
$chgtext .= '<li>'.&mt('Private key deleted').'</li>'; |
|
} else { |
|
$chgtext .= '<li>'.&mt('Private key set to [_1]',$pubkey).'</li>'; |
|
} |
|
$chgtext .= '</ul>'; |
} else { |
} else { |
if ($cancreate{$type} eq 'none') { |
if ($cancreate{$type} eq 'none') { |
$chgtext .= &mt('creation of new users is not permitted, except by a Domain Coordinator.'); |
$chgtext .= &mt('creation of new users is not permitted, except by a Domain Coordinator.'); |
Line 6428 sub modify_usercreation {
|
Line 6714 sub modify_usercreation {
|
return $resulttext; |
return $resulttext; |
} |
} |
|
|
|
sub process_captcha { |
|
my ($container,$changes,$newsettings,$current) = @_; |
|
return unless ((ref($changes) eq 'HASH') && (ref($newsettings) eq 'HASH') || (ref($current) eq 'HASH')); |
|
$newsettings->{'captcha'} = $env{'form.'.$container.'_captcha'}; |
|
unless ($newsettings->{'captcha'} eq 'recaptcha' || $newsettings->{'captcha'} eq 'notused') { |
|
$newsettings->{'captcha'} = 'original'; |
|
} |
|
if ($current->{'captcha'} ne $newsettings->{'captcha'}) { |
|
if (ref($changes->{'cancreate'}) eq 'ARRAY') { |
|
push(@{$changes->{'cancreate'}},'captcha'); |
|
} elsif (!defined($changes->{'cancreate'})) { |
|
$changes->{'cancreate'} = ['captcha']; |
|
} |
|
} |
|
my ($newpub,$newpriv,$currpub,$currpriv); |
|
if ($newsettings->{'captcha'} eq 'recaptcha') { |
|
$newpub = $env{'form.'.$container.'_recaptchapub'}; |
|
$newpriv = $env{'form.'.$container.'_recaptchapriv'}; |
|
} |
|
$newsettings->{'recaptchakeys'} = { |
|
public => $newpub, |
|
private => $newpriv, |
|
}; |
|
if (ref($current->{'recaptchakeys'}) eq 'HASH') { |
|
$currpub = $current->{'recaptchakeys'}{'public'}; |
|
$currpriv = $current->{'recaptchakeys'}{'private'}; |
|
} |
|
if (($newpub ne $currpub) || ($newpriv ne $currpriv)) { |
|
if (ref($changes->{'cancreate'}) eq 'ARRAY') { |
|
push(@{$changes->{'cancreate'}},'recaptchakeys'); |
|
} elsif (!defined($changes->{'cancreate'})) { |
|
$changes->{'cancreate'} = ['recaptchakeys']; |
|
} |
|
} |
|
return; |
|
} |
|
|
sub modify_usermodification { |
sub modify_usermodification { |
my ($dom,%domconfig) = @_; |
my ($dom,%domconfig) = @_; |
my ($resulttext,%curr_usermodification,%changes); |
my ($resulttext,%curr_usermodification,%changes); |
Line 7084 sub modify_serverstatuses {
|
Line 7407 sub modify_serverstatuses {
|
|
|
sub modify_helpsettings { |
sub modify_helpsettings { |
my ($r,$dom,$confname,%domconfig) = @_; |
my ($r,$dom,$confname,%domconfig) = @_; |
my ($resulttext,$errors,%changes,%helphash); |
my ($resulttext,$errors,%changes,%helphash); |
|
my $customhelpfile = $env{'form.loginhelpurl.filename'}; |
my $customhelpfile = $env{'form.loginhelpurl.filename'}; |
my $defaulthelpfile = '/adm/loginproblems.html'; |
my $defaulthelpfile = 'defaulthelp.html'; |
my $defaulttext = &mt('Default in use'); |
my $servadm = $r->dir_config('lonAdmEMail'); |
my $servadm = $r->dir_config('lonAdmEMail'); |
my ($configuserok,$author_ok,$switchserver) = |
my ($configuserok,$author_ok,$switchserver) = &config_check($dom,$confname,$servadm); |
&config_check($dom,$confname,$servadm); |
my %defaultchecked = ('submitbugs' => 'on'); |
|
my @offon = ('off','on'); |
my %defaultchecked = ('submitbugs' => 'on'); |
my %title = ( |
my @offon = ('off','on'); |
submitbugs => 'Display link for users to submit a bug', |
my %title = ( submitbugs => 'Display link for users to submit a bug', |
loginhelpurl => 'Unauthenticated login help page set to custom file' |
loginhelpurl => 'Unauthenticated login help page set to custom file'); |
); |
|
|
my @toggles = ('submitbugs'); |
my @toggles = ('submitbugs'); |
|
|
$helphash{'helpsettings'} = {}; |
$helphash{'helpsettings'} = {}; |
|
|
if (ref($domconfig{'helpsettings'}) ne 'HASH') { |
if (ref($domconfig{'helpsettings'}) ne 'HASH') { |
if ($domconfig{'helpsettings'} eq '') { |
if ($domconfig{'helpsettings'} eq '') { |
$domconfig{'helpsettings'} = {}; |
$domconfig{'helpsettings'} = {}; |
} |
} |
} |
} |
|
|
if (ref($domconfig{'helpsettings'}) eq 'HASH') { |
if (ref($domconfig{'helpsettings'}) eq 'HASH') { |
|
|
foreach my $item (@toggles) { |
foreach my $item (@toggles) { |
|
if ($defaultchecked{$item} eq 'on') { |
if ($defaultchecked{$item} eq 'on') { |
if ($domconfig{'helpsettings'}{$item} eq '') { |
if (($domconfig{'helpsettings'}{$item} eq '') && |
if ($env{'form.'.$item} eq '0') { |
($env{'form.'.$item} eq '0')) { |
$changes{$item} = 1; |
$changes{$item} = 1; |
} |
} elsif ($domconfig{'helpsettings'}{$item} ne $env{'form.'.$item}) { |
} elsif ($domconfig{'helpsettings'}{$item} ne $env{'form.'.$item}) { |
$changes{$item} = 1; |
$changes{$item} = 1; |
} |
} |
} elsif ($defaultchecked{$item} eq 'off') { |
} elsif ($defaultchecked{$item} eq 'off') { |
if (($domconfig{'helpsettings'}{$item} eq '') && |
if ($domconfig{'helpsettings'}{$item} eq '') { |
($env{'form.'.$item} eq '1')) { |
if ($env{'form.'.$item} eq '1') { |
$changes{$item} = 1; |
$changes{$item} = 1; |
} elsif ($domconfig{'helpsettings'}{$item} ne $env{'form.'.$item}) { |
} |
$changes{$item} = 1; |
} elsif ($domconfig{'helpsettings'}{$item} ne $env{'form.'.$item}) { |
} |
$changes{$item} = 1; |
} |
} |
$helphash{'helpsettings'}{$item} = $env{'form.'.$item}; |
} |
} |
if (($env{'form.'.$item} eq '0') || ($env{'form.'.$item} eq '1')) { |
|
$helphash{'helpsettings'}{$item} = $env{'form.'.$item}; |
if ($customhelpfile ne '') { |
} |
my $error; |
} |
if ($configuserok eq 'ok') { |
if ($customhelpfile ne '') { |
if ($switchserver) { |
my $error; |
$error = &mt("Upload of custom help file is not permitted to this server: [_1]",$switchserver); |
if ($configuserok eq 'ok') { |
} else { |
if ($switchserver) { |
if ($author_ok eq 'ok') { |
$error = &mt("Upload of custom help file is not permitted to this server: [_1]",$switchserver); |
my ($result,$loginhelpurl) = |
} else { |
&publishlogo($r,'upload','loginhelpurl',$dom, |
if ($author_ok eq 'ok') { |
$confname,'help','','',$customhelpfile); |
my ($result,$loginhelpurl) = &publishlogo($r,'upload','loginhelpurl',$dom, |
if ($result eq 'ok') { |
$confname,'help','','',$customhelpfile); |
$helphash{'helpsettings'}{'loginhelpurl'} = $loginhelpurl; |
if ($result eq 'ok') { |
$changes{'loginhelpurl'} = 1; |
$helphash{'helpsettings'}{'loginhelpurl'} = $loginhelpurl; |
} else { |
$changes{'loginhelpurl'} = 1; |
$error = &mt("Upload of [_1] failed because an error occurred publishing the file in RES space. Error was: [_2].",$customhelpfile,$result); |
} else { |
} |
$error = &mt("Upload of [_1] failed because an error occurred publishing the file in RES space. Error was: [_2].",$customhelpfile,$result); |
} else { |
} |
$error = &mt("Upload of [_1] failed because an author role could not be assigned to a Domain Configuration user ([_2]) in domain: [_3]. Error was: [_4].",$customhelpfile,$confname,$dom,$author_ok); |
} else { |
} |
$error = &mt("Upload of [_1] failed because an author role could not be assigned to a Domain Configuration user ([_2]) in domain: [_3]. Error was: [_4].",$customhelpfile,$confname,$dom,$author_ok); |
} |
} |
} else { |
} |
$error = &mt("Upload of [_1] failed because a Domain Configuration user ([_2]) could not be created in domain: [_3]. Error was: [_4].",$customhelpfile,$confname,$dom,$configuserok); |
} else { |
} |
$error = &mt("Upload of [_1] failed because a Domain Configuration user ([_2]) could not be created in domain: [_3]. Error was: [_4].",$customhelpfile,$confname,$dom,$configuserok); |
if ($error) { |
} |
&Apache::lonnet::logthis($error); |
if ($error) { |
$errors .= '<li><span class="LC_error">'.$error.'</span></li>'; |
&Apache::lonnet::logthis($error); |
} |
$errors .= '<li><span class="LC_error">'.$error.'</span></li>'; |
} |
} |
|
} |
if ($domconfig{'helpsettings'}{'loginhelpurl'} ne '') { |
if ($domconfig{'helpsettings'}{'loginhelpurl'} ne '') { |
if ($env{'form.loginhelpurl_del'}) { |
if ($env{'form.loginhelpurl_del'}) { |
$helphash{'helpsettings'}{'loginhelpurl'} = ''; |
$helphash{'helpsettings'}{'loginhelpurl'} = ''; |
Line 7165 sub modify_helpsettings {
|
Line 7483 sub modify_helpsettings {
|
} |
} |
} |
} |
} |
} |
|
|
|
|
my $putresult; |
my $putresult; |
|
|
if (keys(%changes) > 0) { |
if (keys(%changes) > 0) { |
$putresult = &Apache::lonnet::put_dom('configuration',\%helphash,$dom); |
$putresult = &Apache::lonnet::put_dom('configuration',\%helphash,$dom); |
} else { |
} else { |
$putresult = 'ok'; |
$putresult = 'ok'; |
} |
} |
|
|
if ($putresult eq 'ok') { |
if ($putresult eq 'ok') { |
if (keys(%changes) > 0) { |
if (keys(%changes) > 0) { |
$resulttext = &mt('Changes made:').'<ul>'; |
$resulttext = &mt('Changes made:').'<ul>'; |
foreach my $item (sort(keys(%changes))) { |
foreach my $item (sort(keys(%changes))) { |
if ($item eq 'submitbugs') { |
if ($item eq 'submitbugs') { |
$resulttext .= '<li>'.&mt("$title{$item} set to $offon[$env{'form.'.$item}]").'</li>'; |
$resulttext .= '<li>'.&mt('Display link to: [_1] set to "'.$offon[$env{'form.'.$item}].'".', |
} |
&Apache::loncommon::modal_link('http://bugs.loncapa.org', |
if ($item eq 'loginhelpurl') { |
&mt('LON-CAPA bug tracker'),600,500)).'</li>'; |
if ($helphash{'helpsettings'}{'loginhelpurl'} eq '') { |
} |
$resulttext .= '<li>'.&mt('[_1] help file removed; [_2] file will be used for the unathorized help page in this domain.',$customhelpfile,$defaulthelpfile).'</li>'; |
if ($item eq 'loginhelpurl') { |
} else { |
if ($helphash{'helpsettings'}{'loginhelpurl'} eq '') { |
$resulttext .= '<li>'.&mt("$title{$item} [_1]",$customhelpfile).'</li>'; |
$resulttext .= '<li>'.&mt('custom log-in help file removed.').' '. |
} |
&Apache::loncommon::modal_link($defaulthelpfile, |
} |
$defaulttext,600,500).'</li>'; |
} |
} else { |
$resulttext .= '</ul>'; |
$resulttext .= '<li>'.&Apache::loncommon::modal_link( |
} else { |
$helphash{'helpsettings'}{'loginhelpurl'}. |
$resulttext = &mt('No changes made to help settings'); |
'?inhibitmenu=yes', |
} |
&mt('custom log-in help file'),600,500). |
|
'</li>'; |
|
} |
|
} |
|
} |
|
$resulttext .= '</ul>'; |
|
} else { |
|
$resulttext = &mt('No changes made to help settings'); |
|
} |
} else { |
} else { |
$resulttext = '<span class="LC_error">'. |
$errors .= '<li><span class="LC_error">'.&mt('An error occurred storing the settings: [_1]', |
&mt('An error occurred: [_1]',$putresult).'</span>'; |
$putresult).'</span></li>'; |
} |
} |
if ($errors) { |
if ($errors) { |
$resulttext .= &mt('The following errors occurred: ').'<ul>'. |
$resulttext .= &mt('The following errors occurred: ').'<ul>'. |
Line 7861 sub active_dc_picker {
|
Line 8183 sub active_dc_picker {
|
sub usersession_titles { |
sub usersession_titles { |
return &Apache::lonlocal::texthash( |
return &Apache::lonlocal::texthash( |
hosted => 'Hosting of sessions for users from other domains on servers in this domain', |
hosted => 'Hosting of sessions for users from other domains on servers in this domain', |
|
|
remote => 'Hosting of sessions for users in this domain on servers in other domains', |
remote => 'Hosting of sessions for users in this domain on servers in other domains', |
spares => 'Servers offloaded to, when busy', |
spares => 'Servers offloaded to, when busy', |
version => 'LON-CAPA version requirement', |
version => 'LON-CAPA version requirement', |
excludedomain => 'Allow all, but exclude specific domains', |
excludedomain => 'Allow all, but exclude specific domains', |
includedomain => 'Deny all, but include specific domains', |
includedomain => 'Deny all, but include specific domains', |
primary => 'Primary (checked first)', |
primary => 'Primary (checked first)', |
default => 'Default', |
default => 'Default', |
); |
); |
} |
} |
|
|
Line 8194 END
|
Line 8515 END
|
|
|
} |
} |
|
|
|
sub recaptcha_js { |
|
my %lt = &captcha_phrases(); |
|
return <<"END"; |
|
|
|
<script type="text/javascript"> |
|
// <![CDATA[ |
|
|
|
function updateCaptcha(caller,context) { |
|
var privitem; |
|
var pubitem; |
|
var privtext; |
|
var pubtext; |
|
if (document.getElementById(context+'_recaptchapub')) { |
|
pubitem = document.getElementById(context+'_recaptchapub'); |
|
} else { |
|
return; |
|
} |
|
if (document.getElementById(context+'_recaptchapriv')) { |
|
privitem = document.getElementById(context+'_recaptchapriv'); |
|
} else { |
|
return; |
|
} |
|
if (document.getElementById(context+'_recaptchapubtxt')) { |
|
pubtext = document.getElementById(context+'_recaptchapubtxt'); |
|
} else { |
|
return; |
|
} |
|
if (document.getElementById(context+'_recaptchaprivtxt')) { |
|
privtext = document.getElementById(context+'_recaptchaprivtxt'); |
|
} else { |
|
return; |
|
} |
|
if (caller.checked) { |
|
if (caller.value == 'recaptcha') { |
|
pubitem.type = 'text'; |
|
privitem.type = 'text'; |
|
pubitem.size = '40'; |
|
privitem.size = '40'; |
|
pubtext.innerHTML = "$lt{'pub'}"; |
|
privtext.innerHTML = "$lt{'priv'}"; |
|
} else { |
|
pubitem.type = 'hidden'; |
|
privitem.type = 'hidden'; |
|
pubtext.innerHTML = ''; |
|
privtext.innerHTML = ''; |
|
} |
|
} |
|
return; |
|
} |
|
|
|
// ]]> |
|
</script> |
|
|
|
END |
|
|
|
} |
|
|
|
sub captcha_phrases { |
|
return &Apache::lonlocal::texthash ( |
|
priv => 'Private key', |
|
pub => 'Public key', |
|
original => 'original (CAPTCHA)', |
|
recaptcha => 'successor (ReCAPTCHA)', |
|
notused => 'unused', |
|
); |
|
} |
|
|
1; |
1; |