X-Git-Url: http://git.rot13.org/?p=Biblio-RFID.git;a=blobdiff_plain;f=scripts%2Fscan.pl;h=d2e18b9e5e90a413b945127768876a4918addda6;hp=10df6b4e902c131d31c9e2c06b29c44af23d784f;hb=100cc8f0b604e0f94cb448985f502b68265ede56;hpb=ab98bbd5444545013e16756519ae1267dc3c56db diff --git a/scripts/scan.pl b/scripts/scan.pl index 10df6b4..d2e18b9 100755 --- a/scripts/scan.pl +++ b/scripts/scan.pl @@ -6,21 +6,23 @@ use strict; use Data::Dump qw(dump); use Getopt::Long; use lib 'lib'; -use RFID::Biblio::Reader; -use RFID::Biblio::RFID501; +use Biblio::RFID::Reader; +use Biblio::RFID::RFID501; my $loop = 0; my $reader; my $debug = 0; +my $log; GetOptions( 'loop!' => \$loop, 'reader=s', => \$reader, 'debug+' => \$debug, + 'log=s' => \$log, ) || die $!; -my $rfid = RFID::Biblio::Reader->new( $reader ); -$RFID::Biblio::debug = $debug; +my $rfid = Biblio::RFID::Reader->new( $reader ); +$Biblio::RFID::debug = $debug; sub tag { my $tag = shift; @@ -28,25 +30,41 @@ sub tag { , " AFI: " , uc unpack('H2', $rfid->afi($tag)) , " " - , dump( RFID::Biblio::RFID501->to_hash( $rfid->blocks($tag) ) ) + , dump( $rfid->to_hash( $tag ) ) , $/ ; } +my $saved; + +sub iso_date { + my @t = localtime(time); + return sprintf "%04d-%02d-%02dT%02d:%02d:%02d", $t[5]+1900,$t[4]+1,$t[3],$t[2],$t[1],$t[0]; +} + +sub log_tag { + my $tag = shift; + return if $saved->{tag} or ! $log; + my $hash = $rfid->to_hash( $tag ); + open(my $fh, '>>', $log) || die "$log: $!"; + print $fh iso_date,",$tag,", $hash->{content}, "\n"; + close($fh); +} + do { my @visible = $rfid->tags( enter => sub { my $tag = shift; - print localtime()." enter ", tag($tag); - + print iso_date," reader ", $rfid->from_reader($tag), " enter ", tag($tag); + log_tag $tag; }, leave => sub { my $tag = shift; - print localtime()." leave ", tag($tag); + print iso_date," leave ", tag($tag); }, ); - warn localtime()." visible: ",join(' ',@visible),"\n"; + warn iso_date," visible: ",join(' ',@visible),"\n"; sleep 1;