1 package RFID::Biblio::Reader;
6 use Data::Dump qw(dump);
13 RFID::Biblio::Reader - simple way to write RFID applications in perl
17 This module will probe all available readers and use calls from
18 L<RFID::Biblio::Reader::API> to invoke correct reader.
24 my $rfid = RFID::Biblio::Reader->new( 'optional reader filter' );
29 my ( $class, $filter ) = @_;
32 $self->{_readers} = [ $self->_available( $filter ) ];
38 my @visible = $rfid->tags(
49 $self->{_tags} ||= {};
50 $self->{_tags}->{$_}->{time} = 0 foreach keys %{$self->{_tags}};
53 foreach my $rfid ( @{ $self->{_readers} } ) {
54 warn "# inventory on $rfid";
55 my @tags = $rfid->inventory;
57 foreach my $tag ( @tags ) {
59 if ( ! exists $self->{_tags}->{$tag} ) {
61 my $blocks = $rfid->read_blocks($tag);
62 $self->{_tags}->{$tag}->{blocks} = $blocks->{$tag} || die "no $tag in ",dump($blocks);
63 my $afi = $rfid->read_afi($tag);
64 $self->{_tags}->{$tag}->{afi} = $afi;
68 warn "ERROR reading $tag: $@\n";
69 $self->_invalidate_tag( $tag );
73 $triggers->{enter}->( $self, $tag ) if $triggers->{enter};
76 $self->{_tags}->{$tag}->{time} = $t;
80 warn "XXX ## _tags ",dump( $self->{_tags} );
82 foreach my $tag ( grep { $self->{_tags}->{$_}->{time} == 0 } keys %{ $self->{_tags} } ) {
83 $triggers->{leave}->( $self, $tag ) if $triggers->{leave};
84 $self->_invalidate_tag( $tag );
89 warn "## _tags ",dump( $self->{_tags} );
91 return grep { $self->{_tags}->{$_}->{time} } keys %{ $self->{_tags} };
96 my $blocks_arrayref = $rfid->blocks( $tag );
100 my $afi = $rfid->afi( $tag );
104 sub blocks { $_[0]->{_tags}->{$_[1]}->{ 'blocks' } || die "no blocks for $_[1]"; };
105 sub afi { $_[0]->{_tags}->{$_[1]}->{ 'afi' } || die "no afi for $_[1]"; };
109 =head2 _invalidate_tag
111 $rfid->_invalidate_tag( $tag );
115 sub _invalidate_tag {
116 my ( $self, $tag ) = @_;
117 my @caller = caller(0);
118 warn "## _invalidate_tag caller $caller[0] $caller[1] +$caller[2]\n";
119 my $old = delete $self->{_tags}->{$tag};
120 warn "# _invalidate_tag $tag ", dump($old);
125 Probe each RFID reader supported and returns succefull ones
127 my $rfid_readers = RFID::Biblio::Reader->_available( $regex_filter );
131 my @readers = ( '3M810', 'CPRM02', 'librfid' );
134 my ( $self, $filter ) = @_;
136 $filter = '' unless defined $filter;
138 warn "# filter: $filter";
142 foreach my $reader ( @readers ) {
143 next if $filter && $reader !~ /$filter/i;
144 my $module = "RFID::Biblio::Reader::$reader";
147 if ( my $rfid = $module->new( device => '/dev/ttyUSB0' ) ) {
149 warn "# added $module\n";
151 warn "# ignored $module\n";
155 die "no readers found" unless @rfid;
162 On any other function calls, we just marshall to all readers
166 # we don't want DESTROY to fallback into AUTOLOAD
172 my $command = $AUTOLOAD;
177 foreach my $r ( @{ $self->{_readers} } ) {
178 push @out, $r->$command(@_);
181 $self->_invalidate_tag( $_[0] ) if $command =~ m/write/;
191 =head2 RFID reader implementations
193 L<RFID::Biblio::Reader::3M810>
195 L<RFID::Biblio::Reader::CPRM02>
197 L<RFID::Biblio::Reader::librfid>