version 1.8, 2001/04/16 12:46:37
|
version 1.15, 2001/04/17 13:36:07
|
Line 2
|
Line 2
|
# The LearningOnline Network |
# The LearningOnline Network |
# searchcat.pl "Search Catalog" batch script |
# searchcat.pl "Search Catalog" batch script |
|
|
# 04/14/2001 Scott Harrison |
# 04/14/2001, 04/16/2001 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. |
Line 18 require "find.pl";
|
Line 18 require "find.pl";
|
sub wanted { |
sub wanted { |
(($dev,$ino,$mode,$nlink,$uid,$gid) = lstat($_)) && |
(($dev,$ino,$mode,$nlink,$uid,$gid) = lstat($_)) && |
-f _ && |
-f _ && |
/^.*\.meta$/ && |
/^.*\.meta$/ && !/^.+\.\d+\.[^\.]+\.meta$/ && |
push(@metalist,"$dir/$_"); |
push(@metalist,"$dir/$_"); |
} |
} |
|
|
Line 34 while ($configline=<CONFIG>) {
|
Line 34 while ($configline=<CONFIG>) {
|
} |
} |
close(CONFIG); |
close(CONFIG); |
|
|
|
# ------------------------------------- Only run if machine is a library server |
|
exit unless $perlvar{'lonRole'} eq 'library'; |
|
|
my $dbh; |
my $dbh; |
# ------------------------------------- Make sure that database can be accessed |
# ------------------------------------- Make sure that database can be accessed |
{ |
{ |
Line 56 foreach my $user (@homeusers) {
|
Line 59 foreach my $user (@homeusers) {
|
} |
} |
|
|
# -- process each file to get metadata and put into search catalog SQL database |
# -- process each file to get metadata and put into search catalog SQL database |
|
# Also, check to see if already there. |
|
# I could just delete (without searching first), but this works for now. |
foreach my $m (@metalist) { |
foreach my $m (@metalist) { |
my $ref=&metadata($m); |
my $ref=&metadata($m); |
my $sth=$dbh->prepare('insert into metadata values ('. |
my $m2='/res/'.&declutter($m); |
|
$m2=~s/\.meta$//; |
|
my $q2="select * from metadata where url like binary '$m2'"; |
|
my $sth = $dbh->prepare($q2); |
|
$sth->execute(); |
|
my $r1=$sth->fetchall_arrayref; |
|
if (@$r1) { |
|
$sth=$dbh->prepare("delete from metadata where url like binary '$m2'"); |
|
$sth->execute(); |
|
} |
|
$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'}).'"'.','. |
'"'.delete($ref->{'url'}).'"'.','. |
'"'.$m2.'"'.','. |
'"'.delete($ref->{'keywords'}).'"'.','. |
'"'.delete($ref->{'keywords'}).'"'.','. |
'"'.delete($ref->{'version'}).'"'.','. |
'"'.'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 171 sub propath {
|
Line 186 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"; |
|
} |