X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=scripts%2Fscan.pl;h=09846c736e69c0f40bdff6d525463f7f9ea60bc5;hb=0f411f79707d6c4c8d1e84ffd922ac3eb3325ca3;hp=d28eb61375a56d95fa567892c271e961f0a83672;hpb=01c36f3b998f1f7cddbef3b88d8a9120836104d2;p=Biblio-RFID.git diff --git a/scripts/scan.pl b/scripts/scan.pl index d28eb61..09846c7 100755 --- a/scripts/scan.pl +++ b/scripts/scan.pl @@ -4,18 +4,67 @@ use warnings; use strict; use Data::Dump qw(dump); - +use Getopt::Long; use lib 'lib'; +use Biblio::RFID::Reader; + +my $loop = 0; +my $reader; +my $debug = 0; +my $log; + +GetOptions( + 'loop!' => \$loop, + 'reader=s', => \$reader, + 'debug+' => \$debug, + 'log=s' => \$log, +) || die $!; + +my $rfid = Biblio::RFID::Reader->new( $reader ); +$Biblio::RFID::debug = $debug; + +sub tag { + my $tag = shift; + return $tag + , " AFI: " + , uc unpack('H2', $rfid->afi($tag)) + , " " + , dump( $rfid->to_hash( $tag ) ) + , $/ + ; +} -foreach my $reader ( '3M810', 'CPRM02' ) { - my $module = "RFID::Serial::$reader"; - eval "use $module"; - die $@ if $@; - my $rfid = $module->new( device => '/dev/ttyUSB0' ); - my $visible = $rfid->scan; - foreach my $tag ( keys %$visible ) { - warn "XXX $tag"; - print "$tag\t", join('', @{ $visible->{$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 iso_date," reader ", $rfid->from_reader($tag), " enter ", tag($tag); + log_tag $tag; + }, + leave => sub { + my $tag = shift; + print iso_date," leave ", tag($tag); + }, + ); + + warn iso_date," visible: ",join(' ',@visible),"\n"; + + sleep 1; + +} while $loop;