--- loncom/interface/lonindexer.pm 2002/05/09 23:01:41 1.41
+++ loncom/interface/lonindexer.pm 2003/08/11 17:27:24 1.73
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Directory Indexer
#
-# $Id: lonindexer.pm,v 1.41 2002/05/09 23:01:41 www Exp $
+# $Id: lonindexer.pm,v 1.73 2003/08/11 17:27:24 albertel Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -34,15 +34,11 @@
# 05/9-05/19/2001 H. K. Ng
# 05/21/2001 H. K. Ng
# 05/23/2001 H. K. Ng
-# 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
-# 8/28,10/15,11/28,11/29 Scott Harrison
# 11/30 Matthew Hall
-# 12/11,12/13 Scott Harrison
# YEAR=2002
-# 1/17 Scott Harrison
+# 6/29/2002 H. K. Ng
#
###
@@ -66,6 +62,7 @@ use strict;
use Apache::lonnet();
use Apache::loncommon();
use Apache::Constants qw(:common);
+use Apache::lonmeta;
use Apache::File;
use GDBM_File;
@@ -81,19 +78,25 @@ my $fnum; # file counter
my $dnum; # directory counter
# ----- Used to include or exclude files with certain extensions.
-my @Only = ();
+my @Only = ();
my @Omit = ();
# ----------------------------- Handling routine called via Apache and mod_perl
sub handler {
my $r = shift;
+ my $c = $r->connection();
$r->content_type('text/html');
+ &Apache::loncommon::no_cache($r);
$r->send_http_header;
return OK if $r->header_only;
$fnum=0;
$dnum=0;
- untie %hash;
+
+ # Deal with stupid global variables (is there a way around making
+ # these global to this package? It is just so wrong....)
+ undef (@Only);
+ undef (@Omit);
# ------------------------------------- read in machine configuration variables
my $iconpath= $r->dir_config('lonIconsURL') . "/";
@@ -122,24 +125,26 @@ sub handler {
$extrafield='';
my $diropendb =
- "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_indexer.db";
-
- if (tie(%hash,'GDBM_File',$diropendb,&GDBM_WRCREAT,0640)) {
+ "/home/httpd/perl/tmp/$ENV{'user.domain'}_$ENV{'user.name'}_indexer.db";
+ %hash = ();
+ {
+ my %dbfile;
+ if (tie(%dbfile,'GDBM_File',$diropendb,&GDBM_WRCREAT(),0640)) {
+ while(my($key,$value)=each(%dbfile)) {
+ $hash{$key}=$value;
+ }
+ untie(%dbfile);
+ }
+ }
+ {
if ($ENV{'form.launch'} eq '1') {
&start_fresh_session();
- }
-
+ }
# -------------------- refresh environment with user database values (in %hash)
- if ($hash{'mode_catalog'} eq 'interactive') {
- $ENV{'form.catalogmode'}='interactive';
- }
- if ($hash{'mode_catalog'} eq 'groupimport') {
- $ENV{'form.catalogmode'}='groupimport';
- }
+ &setvalues(\%hash,'form.catalogmode',\%ENV,'form.catalogmode' );
# --------------------- define extra fields and buttons in case of special mode
if ($ENV{'form.catalogmode'} eq 'interactive') {
- $hash{'mode_catalog'}='interactive';
$extrafield='
'.
'
';
@@ -149,7 +154,6 @@ sub handler {
END
}
elsif ($ENV{'form.catalogmode'} eq 'groupimport') {
- $hash{'mode_catalog'}='groupimport';
$extrafield='
'.
'
';
@@ -171,11 +175,11 @@ END
# $element is the name of the element in $formname which receives
# the URL.
# &Apache::lonxml::debug('Checking mode, form, element');
- &setvalues(\%hash,'form_mode' ,\%ENV,'form.mode' );
- &setvalues(\%hash,'form_form' ,\%ENV,'form.form' );
- &setvalues(\%hash,'form_element',\%ENV,'form.element');
- &setvalues(\%hash,'form_only' ,\%ENV,'form.only' );
- &setvalues(\%hash,'form_omit' ,\%ENV,'form.omit' );
+ &setvalues(\%hash,'form.mode' ,\%ENV,'form.mode' );
+ &setvalues(\%hash,'form.form' ,\%ENV,'form.form' );
+ &setvalues(\%hash,'form.element',\%ENV,'form.element');
+ &setvalues(\%hash,'form.only' ,\%ENV,'form.only' );
+ &setvalues(\%hash,'form.omit' ,\%ENV,'form.omit' );
# Deal with 'omit' and 'only'
if (exists $ENV{'form.omit'}) {
@@ -315,10 +319,14 @@ END
-
ENDHEADER
-
+$r->print(&Apache::loncommon::bodytag('Browse Resources'));
# - Evaluate actions from previous page (both cumulatively and chronologically)
if ($ENV{'form.catalogmode'} eq 'groupimport') {
my $acts=$ENV{'form.acts'};
@@ -373,44 +380,43 @@ ENDHEADER
}
}
-# ---------------------------------------------------------------- output title
- $r->print(
-'
The LearningOnline Network with CAPA '.
- 'Network Directory Browser
'."\n");
# ---------------------------------- get state of file attributes to be showing
- if ($ENV{'form.attrs'} ne "") {
- for (my $i=0; $i<=6; $i++) {
+ if ($ENV{'form.attrs'} ne '') {
+ for (my $i=0; $i<=9; $i++) {
delete $hash{'display_attrs_'.$i};
if ($ENV{'form.attr'.$i} == 1) {
- $attrchk[$i] = "checked";
+ $attrchk[$i] = 'checked';
$hash{'display_attrs_'.$i} = 1;
}
}
} else {
- for (my $i=0; $i<=6; $i++) {
- $attrchk[$i] = "checked" if $hash{'display_attrs_'.$i} == 1;
+ for (my $i=0; $i<=9; $i++) {
+ $attrchk[$i] = 'checked' if $hash{'display_attrs_'.$i} == 1;
}
}
# ------------------------------- output state of file attributes to be showing
+# All versions has to the last item
+# since it does not take an extra col
$r->print(<Display file attributes
@@ -421,22 +427,28 @@ END
# $r->print(&initdebug());
# $r->print(&writedebug("Omit:@Omit")) if (@Omit);
# $r->print(&writedebug("Only:@Only")) if (@Only);
- $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")
+ $r->print("
\n");
+ $r->print("
\n");
+ $r->print("
Name
\n");
+ $r->print("
Title
\n")
+ if ($hash{'display_attrs_0'} == 1);
+ $r->print("
Size (bytes) ".
+ "
\n") if ($hash{'display_attrs_1'} == 1);
+ $r->print("
Last accessed
\n")
if ($hash{'display_attrs_2'} == 1);
- $r->print("
Author(s)
\n")
+ $r->print("
Last modified
\n")
if ($hash{'display_attrs_3'} == 1);
- $r->print("
Keywords
\n")
+ $r->print("
Author(s)
\n")
if ($hash{'display_attrs_4'} == 1);
- $r->print("
Language
\n")
+ $r->print("
Keywords
\n")
if ($hash{'display_attrs_5'} == 1);
- $r->print("
");
+ $r->print("
Language
\n")
+ if ($hash{'display_attrs_6'} == 1);
+ $r->print("
Resource
\n")
+ if ($hash{'display_attrs_7'} == 1);
+ $r->print("
Usage Statistics (Courses/Network Hits)
\n")
+ if ($hash{'display_attrs_8'} == 1);
+ $r->print('');
# ----------------- read in what directories have previously been set to "open"
foreach (keys %hash) {
@@ -468,7 +480,7 @@ END
my $indent = 0;
$uri = $uri.'/' if $uri !~ /.*\/$/;
- if ($bredir ne "on") {
+ if ($bredir ne 'on') {
$hash{'top.level'} = $uri;
$toplevel = $uri;
@@ -477,7 +489,7 @@ END
}
# -------------------------------- if not at top level, provide an uplink arrow
- if ($toplevel ne "/res/"){
+ if ($toplevel ne '/res/'){
my (@uri_com) = split(/\//,$uri);
pop @uri_com;
my $upone = join('/',@uri_com);
@@ -494,23 +506,33 @@ END
$r->print("");
# -------------------------------------------------------------- end the tables
- $r->print("
");
- $r->print("
");
+ $r->print('
');
+ $r->print('
');
# --------------------------------------------------- end the output and return
- $r->print("