/[RFID]/3m-810.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /3m-810.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 44 by dpavlin, Tue Jun 23 13:10:18 2009 UTC revision 61 by dpavlin, Tue Feb 9 13:55:18 2010 UTC
# Line 9  use Carp qw/confess/; Line 9  use Carp qw/confess/;
9  use Getopt::Long;  use Getopt::Long;
10  use File::Slurp;  use File::Slurp;
11  use JSON;  use JSON;
12    use POSIX qw(strftime);
13    
14  use IO::Socket::INET;  use IO::Socket::INET;
15    
16  my $meteor_server = '192.168.1.13:4671';  my $debug = 0;
17    
18    my $tags_data;
19    my $tags_security;
20    my $visible_tags;
21    
22    my $meteor_server; # = '192.168.1.13:4671';
23  my $meteor_fh;  my $meteor_fh;
24    
25  sub meteor {  sub meteor {
# Line 40  sub meteor { Line 47  sub meteor {
47  }  }
48    
49  my $listen_port = 9000;                  # pick something not in use  my $listen_port = 9000;                  # pick something not in use
50    my $server_url  = "http://localhost:$listen_port";
51    
52  sub http_server {  sub http_server {
53    
54          my $server = IO::Socket::INET->new(          my $server = IO::Socket::INET->new(
# Line 51  sub http_server { Line 60  sub http_server {
60                                                                                                                                        
61          die "can't setup server" unless $server;          die "can't setup server" unless $server;
62    
63          print "Server $0 accepting clients at http://localhost:$listen_port/\n";          print "Server $0 ready at $server_url\n";
64    
65          sub static {          sub static {
66                  my ($client,$path) = @_;                  my ($client,$path) = @_;
67    
68                  $path = "www/$path";                  $path = "www/$path";
69                    $path .= 'rfid.html' if $path =~ m{/$};
70    
71                  return unless -e $path;                  return unless -e $path;
72    
# Line 78  sub http_server { Line 88  sub http_server {
88                  $client->autoflush(1);                  $client->autoflush(1);
89                  my $request = <$client>;                  my $request = <$client>;
90    
91                  warn "<< $request\n";                  warn "WEB << $request\n" if $debug;
92    
93                  if ($request =~ m{^GET (/.*) HTTP/1.[01]}) {                  if ($request =~ m{^GET (/.*) HTTP/1.[01]}) {
94                          my $method = $1;                          my $method = $1;
95                            my $param;
96                            if ( $method =~ s{\?(.+)}{} ) {
97                                    foreach my $p ( split(/[&;]/, $1) ) {
98                                            my ($n,$v) = split(/=/, $p, 2);
99                                            $param->{$n} = $v;
100                                    }
101                                    warn "WEB << param: ",dump( $param ) if $debug;
102                            }
103                          if ( my $path = static( $client,$1 ) ) {                          if ( my $path = static( $client,$1 ) ) {
104                                  warn ">> $path";                                  warn "WEB >> $path" if $debug;
105                          } elsif ( $method =~ m{/scan} ) {                          } elsif ( $method =~ m{/scan} ) {
                                 my $callback = $1 if $method =~ m{\?callback=([^&;]+)};  
106                                  my $tags = scan_for_tags();                                  my $tags = scan_for_tags();
107                                  my $json;                                  my $json = { time => time() };
108                                  map {                                  map {
109                                          my $d = decode_tag($_);                                          my $d = decode_tag($_);
110                                          $d->{sid} = $_;                                          $d->{sid} = $_;
111                                            $d->{security} = $tags_security->{$_};
112                                          push @{ $json->{tags} },  $d;                                          push @{ $json->{tags} },  $d;
113                                  } keys %$tags;                                  } keys %$tags;
114                                  print $client "HTTP/1.0 200 OK\r\nContent-Type: application/x-javascript\r\n\r\n$callback(", to_json($json), ")\r\n";                                  print $client "HTTP/1.0 200 OK\r\nContent-Type: application/x-javascript\r\n\r\n",
115                                            $param->{callback}, "(", to_json($json), ")\r\n";
116                            } elsif ( $method =~ m{/program} ) {
117    
118                                    my $status = 501; # Not implementd
119    
120                                    foreach my $p ( keys %$param ) {
121                                            next unless $p =~ m/^tag_(\S+)/;
122                                            my $tag = $1;
123                                            my $content = "\x04\x11\x00\x01" . $param->{$p};
124                                            $status = 302;
125    
126                                            warn "PROGRAM $tag $content\n";
127                                            write_tag( $tag, $content );
128                                    }
129    
130                                    print $client "HTTP/1.0 $status $method\r\nLocation: $server_url\r\n\r\n";
131    
132                          } else {                          } else {
133                                  print $client "HTTP/1.0 404 Unkown method\r\n";                                  print $client "HTTP/1.0 404 Unkown method\r\n";
134                          }                          }
# Line 106  sub http_server { Line 141  sub http_server {
141          die "server died";          die "server died";
142  }  }
143    
144  my $debug = 0;  
145    my $last_message = {};
146    sub _message {
147            my $type = shift @_;
148            my $text = join(' ',@_);
149            my $last = $last_message->{$type};
150            if ( $text ne $last ) {
151                    warn $type eq 'diag' ? '# ' : '', $text, "\n";
152                    $last_message->{$type} = $text;
153            }
154    }
155    
156    sub _log { _message('log',@_) };
157    sub diag { _message('diag',@_) };
158    
159  my $device    = "/dev/ttyUSB0";  my $device    = "/dev/ttyUSB0";
160  my $baudrate  = "19200";  my $baudrate  = "19200";
# Line 146  GetOptions( Line 194  GetOptions(
194          'stopbits=i'  => \$stopbits,          'stopbits=i'  => \$stopbits,
195          'handshake=s' => \$handshake,          'handshake=s' => \$handshake,
196          'meteor=s'    => \$meteor_server,          'meteor=s'    => \$meteor_server,
197            'http-server!' => \$http_server,
198  ) or die $!;  ) or die $!;
199    
200  my $verbose = $debug > 0 ? $debug-- : 0;  my $verbose = $debug > 0 ? $debug-- : 0;
# Line 181  it under the same terms ans Perl itself. Line 230  it under the same terms ans Perl itself.
230    
231  =cut  =cut
232    
 my $tags_data;  
 my $visible_tags;  
   
233  my $item_type = {  my $item_type = {
234          1 => 'Book',          1 => 'Book',
235          6 => 'CD/CD ROM',          6 => 'CD/CD ROM',
# Line 209  $databits=$port->databits($databits); Line 255  $databits=$port->databits($databits);
255  $parity=$port->parity($parity);  $parity=$port->parity($parity);
256  $stopbits=$port->stopbits($stopbits);  $stopbits=$port->stopbits($stopbits);
257    
258  print "## using $device $baudrate $databits $parity $stopbits debug: $debug verbose: $verbose\n";  warn "## using $device $baudrate $databits $parity $stopbits debug: $debug verbose: $verbose\n";
259    
260  # Just in case: reset our timing and buffers  # Just in case: reset our timing and buffers
261  $port->lookclear();  $port->lookclear();
# Line 236  sub scan_for_tags { Line 282  sub scan_for_tags {
282    
283          my @tags;          my @tags;
284    
285          cmd( 'D6 00  05   FE     00  05         FA40', "scan for tags, retry $_",          cmd( 'D6 00  05   FE     00  05         FA40', "scan for tags",
286                   'D6 00  0F   FE  00 00  05 ', sub { # 01 E00401003123AA26  941A         # seen, serial length: 8                   'D6 00  0F   FE  00 00  05 ', sub { # 01 E00401003123AA26  941A         # seen, serial length: 8
287                          my $rest = shift || die "no rest?";                          my $rest = shift || die "no rest?";
288                          my $nr = ord( substr( $rest, 0, 1 ) );                          my $nr = ord( substr( $rest, 0, 1 ) );
289    
290                          if ( ! $nr ) {                          if ( ! $nr ) {
291                                  print "no tags in range\n";                                  _log "no tags in range\n";
292                                  update_visible_tags();                                  update_visible_tags();
293                                  meteor( 'info-none-in-range' );                                  meteor( 'info-none-in-range' );
294                                  $tags_data = {};                                  $tags_data = {};
295                          } else {                          } else {
296    
297                                  my $tags = substr( $rest, 1 );                                  my $tags = substr( $rest, 1 );
   
298                                  my $tl = length( $tags );                                  my $tl = length( $tags );
299                                  die "wrong length $tl for $nr tags: ",dump( $tags ) if $tl =! $nr * 8;                                  die "wrong length $tl for $nr tags: ",dump( $tags ) if $tl =! $nr * 8;
300    
301                                  push @tags, uc(unpack('H16', substr($tags, $_ * 8, 8))) foreach ( 0 .. $nr - 1 );                                  push @tags, uc(unpack('H16', substr($tags, $_ * 8, 8))) foreach ( 0 .. $nr - 1 );
302                                  warn "## tags ",as_hex($tags), " [$tl] = ",dump( $tags ) if $debug;                                  warn "## tags ",as_hex($tags), " [$tl] = ",dump( $tags ) if $debug;
303                                  print "$nr tags in range: ", join(',', @tags ) , "\n";                                  _log "$nr tags in range: ", join(',', @tags ) , "\n";
304    
305                                  meteor( 'info-in-range', join(' ',@tags));                                  meteor( 'info-in-range', join(' ',@tags));
306    
# Line 264  sub scan_for_tags { Line 309  sub scan_for_tags {
309                  }                  }
310          );          );
311    
312          warn "## tags: ",dump( @tags );          diag "tags: ",dump( @tags );
313          return $tags_data;          return $tags_data;
314    
315  }  }
# Line 274  sub scan_for_tags { Line 319  sub scan_for_tags {
319  if ( $http_server ) {  if ( $http_server ) {
320          http_server;          http_server;
321  } else {  } else {
322          scan_for_tags while 1;          while (1) {
323                    scan_for_tags;
324                    sleep 1;
325            }
326  }  }
327    
328  die "over and out";  die "over and out";
# Line 286  sub update_visible_tags { Line 334  sub update_visible_tags {
334          $visible_tags = {};          $visible_tags = {};
335    
336          foreach my $tag ( @tags ) {          foreach my $tag ( @tags ) {
337                    $visible_tags->{$tag}++;
338                  if ( ! defined $last_visible_tags->{$tag} ) {                  if ( ! defined $last_visible_tags->{$tag} ) {
339                          if ( defined $tags_data->{$tag} ) {                          if ( defined $tags_data->{$tag} ) {
340  #                               meteor( 'in-range', $tag );  #                               meteor( 'in-range', $tag );
# Line 293  sub update_visible_tags { Line 342  sub update_visible_tags {
342                                  meteor( 'read', $tag );                                  meteor( 'read', $tag );
343                                  read_tag( $tag );                                  read_tag( $tag );
344                          }                          }
                         $visible_tags->{$tag}++;  
345                  } else {                  } else {
346                          warn "## using cached data for $tag" if $debug;                          warn "## using cached data for $tag" if $debug;
347                  }                  }
# Line 350  sub read_tag_data { Line 398  sub read_tag_data {
398          return $last_block + 1;          return $last_block + 1;
399  }  }
400    
401    my $saved_in_log;
402    
403  sub decode_tag {  sub decode_tag {
404          my $tag = shift;          my $tag = shift;
405    
# Line 371  sub decode_tag { Line 421  sub decode_tag {
421                  custom => $custom,                  custom => $custom,
422          };          };
423    
424            if ( ! $saved_in_log->{$tag}++ ) {
425                    open(my $log, '>>', 'rfid-log.txt');
426                    print $log strftime( "%Y-%m-%d %H:%M:%S", localtime ), ",$tag,$content\n";
427                    close($log);
428            }
429    
430          return $hash;          return $hash;
431  }  }
432    
# Line 409  sub read_tag { Line 465  sub read_tag {
465                          ( $from_tag, $security ) = ( substr($rest,0,8), substr($rest,8,1) );                          ( $from_tag, $security ) = ( substr($rest,0,8), substr($rest,8,1) );
466                          die "security from other tag: ",as_hex( $from_tag ) if $from_tag ne str2bytes( $tag );                          die "security from other tag: ",as_hex( $from_tag ) if $from_tag ne str2bytes( $tag );
467                          $security = as_hex( $security );                          $security = as_hex( $security );
468                            $tags_security->{$tag} = $security;
469                          warn "# SECURITY $tag = $security\n";                          warn "# SECURITY $tag = $security\n";
470                  }                  }
471          );          );
# Line 417  sub read_tag { Line 474  sub read_tag {
474  }  }
475    
476  sub write_tag {  sub write_tag {
477          my ($tag) = @_;          my ($tag,$data) = @_;
478    
479          my $path = "$program_path/$tag";          my $path = "$program_path/$tag";
480            $data = read_file( $path ) if -e $path;
481    
482            die "no data" unless $data;
483    
         my $data = read_file( $path );  
484          my $hex_data;          my $hex_data;
485    
486          if ( $data =~ s{^hex\s+}{} ) {          if ( $data =~ s{^hex\s+}{} ) {
# Line 634  sub readchunk { Line 693  sub readchunk {
693                  warn "## DISPATCH payload to with rest", dump( $payload, $to, $rest ) if $debug;                  warn "## DISPATCH payload to with rest", dump( $payload, $to, $rest ) if $debug;
694                  $dispatch->{ $to }->( $rest );                  $dispatch->{ $to }->( $rest );
695          } else {          } else {
696                  print "NO DISPATCH for ",dump( $full ),"\n";                  print "NO DISPATCH for ",as_hex( $full ),"\n";
697          }          }
698    
699          return $data;          return $data;

Legend:
Removed from v.44  
changed lines
  Added in v.61

  ViewVC Help
Powered by ViewVC 1.1.26