--- loncom/interface/lonsearchcat.pm 2002/07/12 21:02:27 1.142
+++ loncom/interface/lonsearchcat.pm 2002/07/16 15:02:06 1.143
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Search Catalog
#
-# $Id: lonsearchcat.pm,v 1.142 2002/07/12 21:02:27 matthew Exp $
+# $Id: lonsearchcat.pm,v 1.143 2002/07/16 15:02:06 matthew Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -125,6 +125,10 @@ that produces it. Adding a new view typ
adding a line to the definition of this hash and making sure the function
takes the proper parameters.
+=item $results_db
+
+The name of the database results from searches are put in.
+
=back
=cut
@@ -140,6 +144,7 @@ my $importbutton; # button to take the s
my %groupsearch_db; # database hash
my $diropendb = ""; # db file
+my $results_db = "";
# View Description Function Pointer
my %Views = ("Detailed Citation View" => \&detailed_citation_view,
"Summary View" => \&summary_view,
@@ -178,16 +183,19 @@ sub handler {
$r->content_type('text/html');
$r->send_http_header;
return OK if $r->header_only;
-
+ ##
+ ## Initialize global variables
+ ##
my $domain = $r->dir_config('lonDefDomain');
$diropendb= "/home/httpd/perl/tmp/".&Apache::lonnet::escape($domain).
"\_".&Apache::lonnet::escape($ENV{'user.name'})."_searchcat.db";
-
+ $results_db = "/home/httpd/perl/tmp/".&Apache::lonnet::escape($domain).
+ '_'.&Apache::lonnet::escape($ENV{'user.name'})."_searchresults.db";
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
['catalogmode','launch','acts','mode','form','element',
'reqinterface']);
##
- ## Clear out old values from database
+ ## Clear out old values from groupsearch database
##
if ($ENV{'form.launch'} eq '1') {
if (tie(%groupsearch_db,'GDBM_File',$diropendb,&GDBM_WRCREAT,0640)) {
@@ -239,15 +247,16 @@ END
# We are running a search
my ($query,$customquery,$customshow,$libraries) =
(undef,undef,undef,undef);
+ my $pretty_string;
if ($searchtype eq 'Basic') {
- $query = &parse_basic_search($r);
+ ($query,$pretty_string) = &parse_basic_search($r);
} elsif ($ENV{'form.advancedsubmit'} eq 'SEARCH') {
- ($query,$customquery,$customshow,$libraries)
+ ($query,$customquery,$customshow,$libraries,$pretty_string)
= &parse_advanced_search($r);
return OK if (! defined($query));
}
# Output some information to the user.
- $r->print(&search_results_header($searchtype));
+ $r->print(&search_results_header($searchtype,$pretty_string));
$r->print("Sending search request to LON-CAPA servers.
\n");
$r->rflush();
# Send query statements over the network to be processed by
@@ -561,13 +570,13 @@ to be somewhat persistent.
sub make_persistent {
my %save = %{shift()};
my $persistent='';
- foreach (keys %save) {
- if (/^form\./ && !/submit/) {
- my $name=$_;
+ foreach my $name (keys %save) {
+ if ($name =~ /^form\./ && $name !~ /submit/) {
my @values = (ref($save{$name}) ? @{$save{$name}} : ($save{$name}));
$name=~s/^form\.//;
foreach (@values) {
s/\"/\'/g; # do not mess with html field syntax
+ next if (! $_ );
$persistent.=<
\n";
# Clean up fields for safety
for my $field ('title','author','subject','keywords','url','version',
'creationdatestart_month','creationdatestart_day',
@@ -925,16 +935,25 @@ sub parse_advanced_search {
# Turn the form input into a SQL-based query
my $query='';
my @queries;
+ my $font = '';
# Evaluate logical expression AND/OR/NOT phrase fields.
foreach my $field ('title','author','subject','notes','abstract','url',
'keywords','version','owner','mime') {
if ($ENV{'form.'.$field}) {
my $searchphrase = $ENV{'form.'.$field};
+ $pretty_search_string .= $font."$field contains ".
+ $searchphrase."";
if ($ENV{'form.'.$field.'_related'}) {
- $searchphrase = &related_version($searchphrase);
- $ENV{'form.'.$field} = $searchphrase;
- $ENV{'form.'.$field.'_related'} = undef;
+ my @New_Words;
+ ($searchphrase,@New_Words) = &related_version($searchphrase);
+ if (@New_Words) {
+ $pretty_search_string .= " with related words: ".
+ "@New_Words.";
+ } else {
+ $pretty_search_string .= " with no related words.";
+ }
}
+ $pretty_search_string .= "
\n";
push @queries,&build_SQL_query($field,$searchphrase);
}
}
@@ -945,10 +964,17 @@ sub parse_advanced_search {
# Evaluate option lists
if ($ENV{'form.language'} and $ENV{'form.language'} ne 'any') {
push @queries,"(language like \"$ENV{'form.language'}\")";
+ $pretty_search_string.=$font."language= ".
+ &Apache::loncommon::languagedescription($ENV{'form.language'}).
+ "
\n";
}
if ($ENV{'form.copyright'} and $ENV{'form.copyright'} ne 'any') {
push @queries,"(copyright like \"$ENV{'form.copyright'}\")";
+ $pretty_search_string.=$font."copyright = ".
+ &Apache::loncommon::copyrightdescription($ENV{'form.copyright'}).
+ "
\n";
}
+ #
# Evaluate date windows
my $datequery=&build_date_queries(
$ENV{'form.creationdatestart_month'},
@@ -968,18 +994,23 @@ sub parse_advanced_search {
if ($datequery=~/^Incorrect/) {
&output_date_error($r,$datequery);
return ;
- }
- elsif ($datequery) {
+ } elsif ($datequery) {
+ # Here is where you would set up pretty_search_string to output
+ # date query information.
push @queries,$datequery;
}
# Process form information for custom metadata querying
my $customquery=undef;
if ($ENV{'form.custommetadata'}) {
+ $pretty_search_string .=$font."Custom Metadata Search: ".
+ $ENV{'form.custommetadata'}."
\n";
$customquery=&build_custommetadata_query('custommetadata',
$ENV{'form.custommetadata'});
}
my $customshow=undef;
if ($ENV{'form.customshow'}) {
+ $pretty_search_string .=$font."Custom Metadata Display: ".
+ $ENV{'form.customshow'}."
\n";
$customshow=$ENV{'form.customshow'};
$customshow=~s/[^\w\s]//g;
my @fields=split(/\s+/,$customshow);
@@ -994,18 +1025,28 @@ sub parse_advanced_search {
my @allowed_domains = (ref($ENV{'form.domains'}) ? @{$ENV{'form.domains'}}
: ($ENV{'form.domains'}) );
my %domain_hash = ();
+ my $pretty_domains_string;
foreach (@allowed_domains) {
$domain_hash{$_}++;
}
- foreach (keys(%Apache::lonnet::libserv)) {
- if ($_ eq 'any') {
- $libraries_to_query = undef;
- last;
+ if ($domain_hash{'any'}) {
+ $pretty_domains_string = "Searching all domains.";
+ } else {
+ if (@allowed_domains > 1) {
+ $pretty_domains_string = "Searching domains:";
+ } else {
+ $pretty_domains_string = "Searching domain ";
}
- if (exists($domain_hash{$Apache::lonnet::hostdom{$_}})) {
- push @$libraries_to_query,$_;
+ foreach (sort @allowed_domains) {
+ $pretty_domains_string .= "$_ ";
+ }
+ foreach (keys(%Apache::lonnet::libserv)) {
+ if (exists($domain_hash{$Apache::lonnet::hostdom{$_}})) {
+ push @$libraries_to_query,$_;
+ }
}
}
+ $pretty_search_string .= $pretty_domains_string."
\n";
#
if (@queries) {
$query=join(" AND ",@queries);
@@ -1013,7 +1054,8 @@ sub parse_advanced_search {
} elsif ($customquery) {
$query = '';
}
- return ($query,$customquery,$customshow,$libraries_to_query);
+ return ($query,$customquery,$customshow,$libraries_to_query,
+ $pretty_search_string);
}
######################################################################
@@ -1047,10 +1089,18 @@ sub parse_basic_search {
&output_blank_field_error($r);
return OK;
}
+ my $pretty_search_string = ''.$ENV{'form.basicexp'}.'';
my $search_string = $ENV{'form.basicexp'};
if ($ENV{'form.related'}) {
- $search_string = &related_version($ENV{'form.basicexp'});
+ my @New_Words;
+ ($search_string,@New_Words) = &related_version($ENV{'form.basicexp'});
+ if (@New_Words) {
+ $pretty_search_string .= " with related words: @New_Words.";
+ } else {
+ $pretty_search_string .= " with no related words.";
+ }
}
+ &Apache::lonnet::logthis("Search String: $search_string");
# Build SQL query string based on form page
my $query='';
my $concatarg=join('," ",',
@@ -1058,7 +1108,8 @@ sub parse_basic_search {
'keywords'));
$concatarg='title' if $ENV{'form.titleonly'};
$query=&build_SQL_query('concat('.$concatarg.')',$search_string);
- return 'select * from metadata where '.$query;
+ $pretty_search_string .= "
\n";
+ return 'select * from metadata where '.$query,$pretty_search_string;
}
@@ -1082,16 +1133,17 @@ Note: Using this twice on a string is pr
sub related_version {
my $search_string = shift;
my $result = $search_string;
+ my %New_Words = ();
while ($search_string =~ /(\w+)/cg) {
my $word = $1;
next if (lc($word) =~ /\b(or|and|not)\b/);
my @Words = &Apache::loncommon::get_related_words($word);
- my $replacement = join " OR ", ($word,
- ($#Words>4? @Words[0..4] : @Words)
- );
+ @Words = ($#Words>4? @Words[0..4] : @Words);
+ foreach (@Words) { $New_Words{$_}++;}
+ my $replacement = join " OR ", ($word,@Words);
$result =~ s/(\b)$word(\b)/$1($replacement)$2/g;
}
- return $result;
+ return $result,sort(keys(%New_Words));
}
######################################################################
@@ -1657,7 +1709,7 @@ Checked for existance & 'edit' mode.
######################################################################
######################################################################
sub search_results_header {
- my ($mode) = @_;
+ my ($mode,$pretty_query) = @_;
$mode = lc($mode);
my $title;
if ($mode eq 'advanced') {
@@ -1759,6 +1811,9 @@ SCRIPT
Search query: $pretty_query
"; + } return $result; }