--- loncom/interface/lonindexer.pm 2001/08/08 03:00:11 1.16
+++ loncom/interface/lonindexer.pm 2001/08/14 14:13:03 1.18
@@ -1,22 +1,20 @@
# The LearningOnline Network with CAPA
#
# Directory Indexer
-# (Login Screen
#
-# 5/21/99,5/22,5/25,5/26,5/31,6/2,6/10,7/12,7/14 Gerd Kortemeyer)
+# YEAR=1999
+# 5/21/99, 5/22,5/25,5/26,5/31,6/2,6/10,7/12,7/14 Gerd Kortemeyer)
# 11/23 Gerd Kortemeyer
+# YEAR=2000
# 07/20-08/04 H.K. Ng
-#
+# YEAR=2001
# 05/9-05/19/2001 H. K. Ng
# 05/21/2001 H. K. Ng
# 05/23/2001 H. K. Ng
-# 05/31/2001 Scott Harrison
-# 06/01/2001 Scott Harrison
-# 06/02/2001 Scott Harrison
-# 06/15/2001 Scott Harrison
-# 06/26/2001 H. K. Ng
-# 07/08/2001 H. K. Ng
-# 8/6,8/7 Scott Harrison
+# 5/31,6/1,6/2,6/15 Scott Harrison
+# 6/26,7/8 H. K. Ng
+# 8/6,8/7,8/10 Scott Harrison
+# 8/14 H. K. Ng
package Apache::lonindexer;
@@ -26,13 +24,17 @@ use Apache::Constants qw(:common);
use Apache::File;
use GDBM_File;
-my %hash;
-my %dirs;
-my %language;
-my $hidden;
-my $extrafield;
-my $fnum;
-my $dnum;
+my %hash; # tied to a user-specific gdbm file
+my %dirs; # keys are directories, values are the open/close status
+my %language; # has the reference information present in language.tab
+
+# ----- Values which are set by the handler subroutine and are accessible to
+# ----- other methods.
+my $extrafield; # default extra table cell
+my $fnum; # file counter
+my $dnum; # directory counter
+
+# ---------------------------------------------------------------------- BEGIN
sub BEGIN {
my $fh=Apache::File->new($Apache::lonnet::perlvar{'lonTabDir'}.
'/language.tab');
@@ -42,6 +44,7 @@ sub BEGIN {
} <$fh>;
}
+# ---------------------------------------------------------------- Main Handler
sub handler {
my $r = shift;
$r->content_type('text/html');
@@ -49,6 +52,8 @@ sub handler {
return OK if $r->header_only;
$fnum=0;
$dnum=0;
+
+# --------------------------------------------- machine configuration variables
my $iconpath= $r->dir_config('lonIconsURL') . "/";
my $domain = $r->dir_config('lonDefDomain');
my $role = $r->dir_config('lonRole');
@@ -64,44 +69,22 @@ sub handler {
my $uri=$r->uri;
# -------------------------------------- see if called from an interactive mode
-# foreach my $key (sort(keys(%ENV))) {
-# $r->print("$key is $ENV{$key} ");
-# }
-# $r->print("END ENV");
- map {
- my ($name, $value) = split(/=/,$_);
- $value =~ tr/+/ /;
- $value =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;
- if ($name eq 'catalogmode') {
- $ENV{'form.'.$name}=$value;
- }
- if ($name eq 'launch') {
- $ENV{'form.'.$name}=$value;
- }
- if ($name eq 'acts') {
- $ENV{'form.'.$name}=$value;
- }
- } (split(/&/,$ENV{'QUERY_STRING'}));
+ &get_unprocessed_cgi();
- $hidden=''; my $closebutton='';
+ my $closebutton='';
my $groupimportbutton='';
my $colspan='';
$extrafield='';
- my $diropendb = "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_indexer.db";
+ my $diropendb =
+ "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_indexer.db";
if (tie(%hash,'GDBM_File',$diropendb,&GDBM_WRCREAT,0640)) {
if ($ENV{'form.launch'} eq '1') {
- delete $hash{'mode_catalog'};
- map {
- if ($_ =~ /^pre_/) {
- delete $hash{$_};
- }
- if ($_ =~ /^store/) {
- delete $hash{$_};
- }
- } keys %hash;
+ &start_fresh_session();
}
+
+# -------------------- refresh environment with user database values (in %hash)
if ($hash{'mode_catalog'} eq 'interactive') {
$ENV{'form.catalogmode'}='interactive';
}
@@ -109,15 +92,13 @@ sub handler {
$ENV{'form.catalogmode'}='groupimport';
}
+# --------------------- define extra fields and buttons in case of special mode
if ($ENV{'form.catalogmode'} eq 'interactive') {
$hash{'mode_catalog'}='interactive';
$extrafield='
'.
'
';
+ ' border="0" />';
$colspan=" colspan='2' ";
- $hidden=<
-END
$closebutton=<
END
@@ -126,19 +107,18 @@ END
$hash{'mode_catalog'}='groupimport';
$extrafield='
'.
'
';
+ ' border="0" />';
$colspan=" colspan='2' ";
- $hidden=<
-END
$closebutton=<
END
$groupimportbutton=<
+
END
}
+# ------ set catalogmodefunctions to have extra needed javascript functionality
my $catalogmodefunctions='';
if ($ENV{'form.catalogmode'} eq 'interactive' or
$ENV{'form.catalogmode'} eq 'groupimport') {
@@ -148,53 +128,9 @@ function select_data(title,url) {
changeURL(url);
self.close();
}
-function save_group() {
- for (var num=0; numprint(<
@@ -258,27 +187,25 @@ function gothere(val) {
ENDHEADER
+
+# - Evaluate actions from previous page (both cumulatively and chronologically)
if ($ENV{'form.catalogmode'} eq 'groupimport') {
-# $r->print($ENV{'form.acts'}." ");
my $acts=$ENV{'form.acts'};
my @Acts=split(/b/,$acts);
my %ahash;
my %achash;
my $ac=0;
+ # some initial hashes for working with data
map {
my ($state,$ref)=split(/a/);
$ahash{$ref}=$state;
$achash{$ref}=$ac;
$ac++;
} (@Acts);
+ # sorting through the actions and changing the tied database hash
map {
my $key=$_;
if ($ahash{$key} eq '1') {
-# $r->print("NEW: ");
-# $r->print($hash{'pre_'.$key.'_title'});
-# $r->print(" : ");
-# $r->print($hash{'pre_'.$key.'_link'});
-# $r->print(" ");
$hash{'store_'.$hash{'pre_'.$key.'_link'}}=
$hash{'pre_'.$key.'_title'};
$hash{'storectr_'.$hash{'pre_'.$key.'_link'}}=
@@ -291,46 +218,24 @@ ENDHEADER
}
}
} sort {$achash{$a}<=>$achash{$b}} (keys %ahash);
- map {
- if ($_ =~ /^store_/) {
- my $key=$_;
- $key=~s/^store_//;
-# $r->print("STORE: ");
-# $r->print($hash{'storectr_'.$key});
-# $r->print(':');
-# $r->print($hash{'store_'.$key});
-# $r->print(':');
-# $r->print($key);
-# $r->print(" ");
- }
- } keys %hash;
+ # deleting the previously cached listing
map {
if ($_ =~ /^pre_/ && $_ =~/link$/) {
my $key = $_;
$key =~ s/^pre_//;
$key =~ s/_[^_]*$//;
-# $r->print($key);
-# $r->print(':');
-# $r->print($hash{'pre_'.$key.'_title'});
-# $r->print(':');
-# $r->print($hash{'pre_'.$key.'_link'});
-# $r->print(' ');
delete $hash{'pre_'.$key.'_title'};
delete $hash{'pre_'.$key.'_link'};
}
} keys %hash;
}
- $r->print('
The LearningOnline With CAPA Network Directory Browser
'."\n");
- } else {
- $r->print('Unable to tie hash to db file');
- return OK;
- }
- untie %hash;
- if (tie(%hash,'GDBM_File',$diropendb,&GDBM_WRCREAT,0640)) {
-
+# output title
+ $r->print('
The LearningOnline With CAPA '.
+ 'Network Directory Browser
'."\n");
+# get state of file attributes to be showing
if ($ENV{'form.attrs'} ne "") {
- for (my $i=0; $i<=5; $i++) {
+ for (my $i=0; $i<=6; $i++) {
delete $hash{'display_attrs_'.$i};
if ($ENV{'form.attr'.$i} == 1) {
$attrchk[$i] = "checked";
@@ -338,44 +243,55 @@ ENDHEADER
}
}
} else {
- for (my $i=0; $i<=5; $i++) {
+ for (my $i=0; $i<=6; $i++) {
$attrchk[$i] = "checked" if $hash{'display_attrs_'.$i} == 1;
}
}
+# output state of file attributes to be showing
$r->print(<Display file attributes
-
END
+ # output starting row to the indexed file/directory hierarchy
my $titleclr="#ddffff";
$r->print("
\n");
$r->print("
\n");
$r->print("
Name
\n");
- $r->print("
Size (bytes)
\n") if ($hash{'display_attrs_0'} == 1);
- $r->print("
Last accessed
\n") if ($hash{'display_attrs_1'} == 1);
- $r->print("
Last modified
\n") if ($hash{'display_attrs_2'} == 1);
- $r->print("
Author(s)
\n") if ($hash{'display_attrs_3'} == 1);
- $r->print("
Keywords
\n") if ($hash{'display_attrs_4'} == 1);
- $r->print("
Language
\n") if ($hash{'display_attrs_5'} == 1);
+ $r->print("
Size (bytes) ".
+ "
\n") if ($hash{'display_attrs_0'} == 1);
+ $r->print("
Last accessed
\n")
+ if ($hash{'display_attrs_1'} == 1);
+ $r->print("
Last modified
\n")
+ if ($hash{'display_attrs_2'} == 1);
+ $r->print("
Author(s)
\n")
+ if ($hash{'display_attrs_3'} == 1);
+ $r->print("
Keywords
\n")
+ if ($hash{'display_attrs_4'} == 1);
+ $r->print("
Language
\n")
+ if ($hash{'display_attrs_5'} == 1);
$r->print("
");
+ # read in what directories have previously been set to "open"
map {
if ($_ =~ /^diropen_status_/) {
my $key = $_;
@@ -404,6 +320,7 @@ END
my $toplevel;
my $indent = 0;
$uri = $uri.'/' if $uri !~ /.*\/$/;
+
if ($bredir ne "on") {
$hash{'top.level'} = $uri;
$toplevel = $uri;
@@ -411,6 +328,8 @@ END
} else {
$toplevel = $hash{'top.level'};
}
+
+ # if not at top level, provide an uplink arrow
if ($toplevel ne "/res/"){
my (@uri_com) = split(/\//,$uri);
pop @uri_com;
@@ -419,22 +338,31 @@ END
&display_line ($r,'opened',$upone.'&viewOneUp',0,$upone,@list);
$indent = 1;
}
+
+ # recursively go through all the directories and output as appropriate
&scanDir ($r,$toplevel,$indent,\%hash);
+ # information useful for group import
$r->print("");
+
+ # end the tables
$r->print("