--- loncom/interface/portfolio.pm 2024/09/07 22:00:49 1.254.2.6.2.5
+++ loncom/interface/portfolio.pm 2024/12/29 21:44:16 1.254.2.7
@@ -1,7 +1,7 @@
# The LearningOnline Network
# portfolio browser
#
-# $Id: portfolio.pm,v 1.254.2.6.2.5 2024/09/07 22:00:49 raeburn Exp $
+# $Id: portfolio.pm,v 1.254.2.7 2024/12/29 21:44:16 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -267,16 +267,13 @@ sub display_directory_line {
sub display_directory {
my ($r,$url,$current_path,$is_empty,$dir_list,$group,$can_upload,
- $can_modify,$can_delete,$can_setacl,$can_viewacl,$caller)=@_;
+ $can_modify,$can_delete,$can_setacl,$caller)=@_;
my $iconpath= $r->dir_config('lonIconsURL') . "/";
my $select_mode;
my $checked_files;
my $port_path = &get_port_path();
my ($uname,$udom) = &get_name_dom($group);
- my $access_admin_text;
- if ($can_viewacl) {
- $access_admin_text = &mt('View Status');
- }
+ my $access_admin_text = &mt('View Status');
if ($can_setacl) {
$access_admin_text = &mt('View/Change Status');
}
@@ -320,9 +317,6 @@ sub display_directory {
} elsif ($can_setacl) {
$acl_helpfile = 'Portfolio ShareFile';
}
- unless ($can_setacl || $can_viewacl) {
- $acl_helpfile = 'Portfolio ShareFile Off';
- }
if ($acl_helpfile) {
$acl_helplink = &Apache::loncommon::help_open_topic($acl_helpfile);
}
@@ -502,7 +496,6 @@ sub display_directory {
my $cond_access = 0;
foreach my $key (sort(keys(%{$access_controls{$fullpath}}))) {
my ($num,$scope,$end,$start) = &unpack_acc_key($key);
- next if ($scope eq 'ip');
if (($now > $start) && (!$end || $end > $now)) {
if ($scope eq 'public') {
$pub_access = 1;
@@ -530,7 +523,7 @@ sub display_directory {
}
}
&display_directory_line($r,$select_mode, $filename, $mtime, $size, $css_class, $line,
- \%access_controls, $curr_access, $now, $version_flag, $href_location,
+ \%access_controls, $curr_access,$now, $version_flag, $href_location,
$url, $current_path, $access_admin_text);
if ($show_versions) {
foreach my $dir_line (@{ $versioned{$fullpath} }) {
@@ -903,7 +896,7 @@ sub access_for_renamed {
}
sub display_access {
- my ($r,$url,$group,$can_setacl,$can_viewacl,$port_path,$action) = @_;
+ my ($r,$url,$group,$can_setacl,$port_path,$action) = @_;
my ($uname,$udom) = &get_name_dom($group);
my $file_name = $env{'form.currentpath'}.$env{'form.access'};
$file_name = &prepend_group($file_name);
@@ -913,8 +906,6 @@ sub display_access {
my $aclcount = keys(%access_controls);
my ($header,$info);
if ($action eq 'chgaccess') {
- my $uhome = &Apache::lonnet::homeserver($uname,$udom);
- my $prefix = &Apache::lonnet::url_prefix($r,$udom,$uhome,'web');
$header =
'
'
.&mt('Allowing others to retrieve file: [_1]'
@@ -927,13 +918,13 @@ sub display_access {
$info .= '
'.&mt('Passphrase-protected files do not require log-in, but will require the viewer to enter the passphrase you set.');
$info .= ''.&explain_conditionals();
$info .= ''.
- &mt('A listing of files viewable without log-in is available at: ')."$prefix/adm/$udom/$uname/aboutme/portfolio.
";
+ &mt('A listing of files viewable without log-in is available at: ')."".&Apache::lonnet::absolute_url()."/adm/$udom/$uname/aboutme/portfolio.
";
if ($group eq '') {
$info .= &mt("For logged in users a 'Display file listing' link will also appear (when there are viewable files) on your personal information page:");
} else {
$info .= &mt("For logged in users a 'Display file listing' link will also appear (when there are viewable files) on the course information page:");
}
- $info .= "
$prefix/adm/$udom/$uname/aboutme
";
+ $info .= "
".&Apache::lonnet::absolute_url()."/adm/$udom/$uname/aboutme
";
if ($group ne '') {
$info .= &mt("Users with course editing rights may add a 'Group Portfolio' item using the Course Editor (Collaboration tab), to provide access to viewable group portfolio files.").'
';
}
@@ -954,21 +945,13 @@ sub display_access {
'cancel' => &mt('Return to directory'),
};
&close_form($r,$url,$button_text);
- } elsif ($can_viewacl) {
+ } else {
$r->print($header);
if ($aclcount) {
$r->print($info);
}
&view_access_settings($r,$url,$access_controls{$file_name},$aclcount);
- } else {
- $r->print($header);
- $r->print(&mt('You do not have sufficient privileges to view access controls').'
');
}
- my %anchor_fields = (
- 'currentpath' => $env{'form.currentpath'}
- );
- $r->print('
'.&make_anchor($url, \%anchor_fields, &mt('Return to directory')));
- return;
}
sub explain_conditionals {
@@ -1018,9 +1001,9 @@ sub build_access_summary {
domains => 'Conditional: domain-based',
users => 'Conditional: user-based',
course => 'Conditional: course/community-based',
- userip => 'Conditional: IP-based',
+ ip => 'Conditional: IP-based',
);
- my @allscopes = ('public','guest','domains','users','course','userip');
+ my @allscopes = ('public','guest','domains','users','course','ip');
foreach my $scope (@allscopes) {
if ((!(exists($todisplay{$scope}))) || (ref($todisplay{$scope}) ne 'HASH')) {
next;
@@ -1097,8 +1080,8 @@ sub build_access_summary {
} elsif ($scope eq 'users') {
my $curr_user_list = &sort_users($content->{'users'});
$r->print(&mt('Users: ').$curr_user_list);
- } elsif ($scope eq 'userip') {
- my $curr_ips_list = &sort_ips($content->{'userip'});
+ } elsif ($scope eq 'ip') {
+ my $curr_ips_list = &sort_ips($content->{'ip'});
$r->print(&mt('IP(s):').' '.$curr_ips_list);
} else {
$r->print(' ');
@@ -1208,7 +1191,7 @@ sub update_access {
my $totalnew = 0;
my $status = 'new';
my ($firstitem,$lastitem);
- my @types = ('course','domains','users','userip');
+ my @types = ('course','domains','users','ip');
foreach my $newitem (@types) {
$allnew += $env{'form.new'.$newitem};
}
@@ -1220,7 +1203,7 @@ sub update_access {
course => 'course/community',
domains => 'domain',
users => 'user',
- userip => 'IP',
+ ip => 'IP',
);
foreach my $newitem (@types) {
next if ($env{'form.new'.$newitem} <= 0);
@@ -1324,7 +1307,7 @@ sub build_access_record {
'udom' => $udom
});
}
- } elsif ($scope eq 'userip') {
+ } elsif ($scope eq 'ip') {
my $ipslist = $env{'form.ips_'.$num};
$ipslist =~ s/\s+//sg;
my %ipshash = map { ($_,1) } (split(/,/,$ipslist));
@@ -1395,7 +1378,7 @@ sub access_setting_table {
push(@domains,$key);
} elsif ($scope eq 'users') {
push(@users,$key);
- } elsif ($scope eq 'userip') {
+ } elsif ($scope eq 'ip') {
push(@ips,$key);
}
}
@@ -1457,7 +1440,7 @@ sub standard_settings {
my $numconditionals = 0;
my $conditionstext;
my %cond_status;
- foreach my $scope ('domains','users','course','userip') {
+ foreach my $scope ('domains','users','course','ip') {
$numconditionals += $acl_count->{$scope};
if ($acl_count->{$scope} > 0) {
if ($conditionstext ne 'Active') {
@@ -1504,7 +1487,7 @@ sub condition_setting {
$r->print(' |
');
&access_element($r,'course',$acl_count,$courses,$access_controls,$now,$then);
$r->print(' | | ');
- &access_element($r,'userip',$acl_count,$ips,$access_controls,$now,$then);
+ &access_element($r,'ip',$acl_count,$ips,$access_controls,$now,$then);
$r->print(' |
');
}
@@ -1525,7 +1508,7 @@ sub access_element {
domains => 'Domain',
users => 'User',
course => 'Course/Community',
- userip => 'IP',
+ ip => 'IP',
);
$r->print(''.&mt($typetext{$type}.'-based conditional access:').' ');
if ($$acl_count{$type}) {
@@ -1550,7 +1533,7 @@ sub display_access_row {
} elsif ($type eq 'users') {
$showtype = &mt('Users');
$infotype = 'User';
- } elsif ($type eq 'userip') {
+ } elsif ($type eq 'ip') {
$showtype = &mt('IP-based');
$infotype = 'IP';
}
@@ -1578,7 +1561,7 @@ sub display_access_row {
$then);
} elsif ($type eq 'users') {
&users_row($r,$status,$key,$access_controls,$now,$then);
- } elsif ($type eq 'userip') {
+ } elsif ($type eq 'ip') {
&ips_row($r,$status,$key,$access_controls,$now,$then);
}
$r->print(&Apache::loncommon::end_data_table_row());
@@ -1761,11 +1744,11 @@ sub users_row {
sub ips_row {
my ($r,$status,$item,$access_controls,$now,$then) = @_;
my ($num,$scope,$end,$start) = &set_identifiers($status,$item,$now,$then,
- 'userip');
+ 'ip');
my $curr_ips_list;
if ($status eq 'old') {
my $content = $$access_controls{$item};
- $curr_ips_list = &sort_ips($content->{'userip'});
+ $curr_ips_list = &sort_ips($content->{'ip'});
}
$r->print(''.&actionbox($status,$num,$scope).' | '.&mt('Format for IP controls').' '.
&mt('[_1] or [_2] or [_3] or [_4] or [_5]','35.8.*','35.8.3.[34-56]',
@@ -1784,7 +1767,7 @@ sub additional_item {
$showtype = 'domain';
} elsif ($type eq 'users') {
$showtype = 'user';
- } elsif ($type eq 'userip') {
+ } elsif ($type eq 'ip') {
$showtype = 'IP';
}
return
@@ -1798,7 +1781,7 @@ sub actionbox {
my $output = ' |