version 1.11, 2001/04/16 13:45:20
|
version 1.18, 2002/05/17 14:03:04
|
Line 1
|
Line 1
|
#!/usr/bin/perl |
#!/usr/bin/perl |
# The LearningOnline Network |
# The LearningOnline Network |
# searchcat.pl "Search Catalog" batch script |
# searchcat.pl "Search Catalog" batch script |
|
# |
# 04/14/2001 Scott Harrison |
# $Id$ |
|
# |
|
# Copyright Michigan State University Board of Trustees |
|
# |
|
# This file is part of the LearningOnline Network with CAPA (LON-CAPA). |
|
# |
|
# LON-CAPA is free software; you can redistribute it and/or modify |
|
# it under the terms of the GNU General Public License as published by |
|
# the Free Software Foundation; either version 2 of the License, or |
|
# (at your option) any later version. |
|
# |
|
# LON-CAPA is distributed in the hope that it will be useful, |
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
# GNU General Public License for more details. |
|
# |
|
# You should have received a copy of the GNU General Public License |
|
# along with LON-CAPA; if not, write to the Free Software |
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
# |
|
# /home/httpd/html/adm/gpl.txt |
|
# |
|
# http://www.lon-capa.org/ |
|
# |
|
# YEAR=2001 |
|
# 04/14/2001, 04/16/2001 Scott Harrison |
|
# |
|
# YEAR=2002 |
|
# 05/11/2002 Scott Harrison |
|
# |
|
### |
|
|
# This script goes through a LON-CAPA resource |
# This script goes through a LON-CAPA resource |
# directory and gathers metadata. |
# directory and gathers metadata. |
# The metadata is entered into a SQL database. |
# The metadata is entered into a SQL database. |
|
|
|
use lib '/home/httpd/lib/perl/'; |
|
use LONCAPA::Configuration; |
|
|
use IO::File; |
use IO::File; |
use HTML::TokeParser; |
use HTML::TokeParser; |
use DBI; |
use DBI; |
Line 22 sub wanted {
|
Line 55 sub wanted {
|
push(@metalist,"$dir/$_"); |
push(@metalist,"$dir/$_"); |
} |
} |
|
|
# ------------------------------------ Read httpd access.conf and get variables |
# --------------- Read loncapa_apache.conf and loncapa.conf and get variables |
open (CONFIG,"/etc/httpd/conf/access.conf") || die "Can't read access.conf"; |
my $perlvarref=LONCAPA::Configuration::read_conf('loncapa_apache.conf', |
|
'loncapa.conf'); |
|
my %perlvar=%{$perlvarref}; |
|
undef $perlvarref; # remove since sensitive and not needed |
|
delete $perlvar{'lonReceipt'}; # remove since sensitive and not needed |
|
|
while ($configline=<CONFIG>) { |
# ------------------------------------- Only run if machine is a library server |
if ($configline =~ /PerlSetVar/) { |
exit unless $perlvar{'lonRole'} eq 'library'; |
my ($dummy,$varname,$varvalue)=split(/\s+/,$configline); |
|
chomp($varvalue); |
|
$perlvar{$varname}=$varvalue; |
|
} |
|
} |
|
close(CONFIG); |
|
|
|
my $dbh; |
my $dbh; |
# ------------------------------------- Make sure that database can be accessed |
# ------------------------------------- Make sure that database can be accessed |
Line 61 foreach my $user (@homeusers) {
|
Line 92 foreach my $user (@homeusers) {
|
foreach my $m (@metalist) { |
foreach my $m (@metalist) { |
my $ref=&metadata($m); |
my $ref=&metadata($m); |
my $m2='/res/'.&declutter($m); |
my $m2='/res/'.&declutter($m); |
my $q2="select * from metadata where url like binary '/res/$m2'"; |
$m2=~s/\.meta$//; |
|
my $q2="select * from metadata where url like binary '$m2'"; |
my $sth = $dbh->prepare($q2); |
my $sth = $dbh->prepare($q2); |
$sth->execute(); |
$sth->execute(); |
my $r1=$sth->fetchall_arrayref; |
my $r1=$sth->fetchall_arrayref; |
if (@$r1) { |
if (@$r1) { |
$sth=$dbh->prepare("delete from metadata where url like binary '/res/$m2'"); |
$sth=$dbh->prepare("delete from metadata where url like binary '$m2'"); |
$sth->execute(); |
$sth->execute(); |
} |
} |
$sth=$dbh->prepare('insert into metadata values ('. |
$sth=$dbh->prepare('insert into metadata values ('. |
'"'.delete($ref->{'title'}).'"'.','. |
'"'.delete($ref->{'title'}).'"'.','. |
'"'.delete($ref->{'author'}).'"'.','. |
'"'.delete($ref->{'author'}).'"'.','. |
'"'.delete($ref->{'subject'}).'"'.','. |
'"'.delete($ref->{'subject'}).'"'.','. |
'"/res/'.$m2.'"'.','. |
'"'.$m2.'"'.','. |
'"'.delete($ref->{'keywords'}).'"'.','. |
'"'.delete($ref->{'keywords'}).'"'.','. |
'"'.'current'.'"'.','. |
'"'.'current'.'"'.','. |
'"'.delete($ref->{'notes'}).'"'.','. |
'"'.delete($ref->{'notes'}).'"'.','. |
'"'.delete($ref->{'abstract'}).'"'.','. |
'"'.delete($ref->{'abstract'}).'"'.','. |
'"'.delete($ref->{'mime'}).'"'.','. |
'"'.delete($ref->{'mime'}).'"'.','. |
'"'.delete($ref->{'language'}).'"'.','. |
'"'.delete($ref->{'language'}).'"'.','. |
'"'.delete($ref->{'creationdate'}).'"'.','. |
'"'.sqltime(delete($ref->{'creationdate'})).'"'.','. |
'"'.delete($ref->{'lastrevisiondate'}).'"'.','. |
'"'.sqltime(delete($ref->{'lastrevisiondate'})).'"'.','. |
'"'.delete($ref->{'owner'}).'"'.','. |
'"'.delete($ref->{'owner'}).'"'.','. |
'"'.delete($ref->{'copyright'}).'"'.')'); |
'"'.delete($ref->{'copyright'}).'"'.')'); |
$sth->execute(); |
$sth->execute(); |
Line 182 sub propath {
|
Line 214 sub propath {
|
my $proname="$perlvar{'lonUsersDir'}/$udom/$subdir/$uname"; |
my $proname="$perlvar{'lonUsersDir'}/$udom/$subdir/$uname"; |
return $proname; |
return $proname; |
} |
} |
|
|
|
# ---------------------------- convert 'time' format into a datetime sql format |
|
sub sqltime { |
|
my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = |
|
localtime(@_[0]); |
|
$mon++; $year+=1900; |
|
return "$year-$mon-$mday $hour:$min:$sec"; |
|
} |