X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=scripts%2FRFID-JSONP-server.pl;h=974a316911fe33f89002d566d59eabcc3ab35027;hb=521e5cb39c959e5fcedc0879b261accb935d3edd;hp=08258d1a4c0817ceb2942f3b26db89b0456d443d;hpb=b87d39334a83098104ec6be7da9adbefb7b1f998;p=Biblio-RFID.git diff --git a/scripts/RFID-JSONP-server.pl b/scripts/RFID-JSONP-server.pl index 08258d1..974a316 100755 --- a/scripts/RFID-JSONP-server.pl +++ b/scripts/RFID-JSONP-server.pl @@ -24,6 +24,9 @@ my $debug = 1; my $listen = '127.0.0.1:9000'; $listen = ':9000'; my $reader; +my $koha_url = 'http://ffzg.koha-dev.rot13.org:8080'; +# internal URL so we can find local address of machine and vmware NAT +my $rfid_url = 'http://rfid.koha-dev.vbz.ffzg.hr'; use Getopt::Long; @@ -31,6 +34,7 @@ GetOptions( 'debug!' => \$debug, 'listen=s', => \$listen, 'reader=s', => \$reader, + 'koha=s', => \$koha_url, ) || die $!; our $rfid_sid_cache; @@ -41,7 +45,7 @@ sub rfid_borrower { return $json; } my $ua = LWP::UserAgent->new; - my $url = URI->new('http://ffzg.koha-dev.rot13.org:8080/cgi-bin/koha/ffzg/rfid-borrower.pl'); + my $url = URI->new( $koha_url . '/cgi-bin/koha/ffzg/rfid/borrower.pl'); $url->query_form( RFID_SID => $hash->{sid} , OIB => $hash->{OIB} @@ -67,6 +71,7 @@ my $index_html; { local $/ = undef; $index_html = ; + $index_html =~ s{http://koha.example.com:8080}{$koha_url}sg; } my $server_url; @@ -86,6 +91,9 @@ sub http_server { print "Server $0 ready at $server_url\n"; while (my $client = $server->accept()) { + + eval { # don't die inside here! + $client->autoflush(1); my $request = <$client>; @@ -133,6 +141,7 @@ sub http_server { warn "ERROR ", dump($borrower); } else { $hash->{borrower} = $borrower->{borrower}; + $hash->{content} = $borrower->{borrower}->{cardnumber}; # compatibile with 3M tags } } else { $hash->{security} = uc unpack 'H*', $rfid->afi( $tag ); @@ -173,7 +182,7 @@ sub http_server { $status = 302; warn "SECURE $tag $data\n"; - $rfid->write_afi( $tag => hex($data) ); + $rfid->write_afi( $tag => chr(hex($data)) ); } if ( $json ) { @@ -190,11 +199,49 @@ sub http_server { print $client "HTTP/1.0 500 No method\r\n\r\n"; } close $client; + + }; # end of eval + if ( $@ ) { + warn "ERROR: $@"; + } + } die "server died"; } +sub rfid_register { + my $ip; + + foreach ( split(/\n/, `ip addr` ) ) { + if ( /^\d:\s(\w+):\s/ ) { + $ip->{last} = $1; + } elsif ( /^\s+inet\s((\d+)\.(\d+)\.(\d+)\.(\d+))\/(\d+)/ ) { + $ip->{ $ip->{last} } = $1; + } else { + warn "# SKIP [$_]\n"; + } + + } + + my $ua = LWP::UserAgent->new; + my $url = URI->new( $rfid_url . '/register.pl'); + $url->query_form( + local_ip => $ip->{eth0}, + ); + warn "GET ",$url->as_string; + my $response = $ua->get($url); + if ( $response->is_success ) { + warn "# ", $response->decoded_content; + my $json = decode_json $response->decoded_content; + warn "REGISTER: ",dump($json); + return $json; + } else { + warn "ERROR ", $response->status_line; + } +} + +rfid_register; http_server; __DATA__ @@ -241,10 +288,16 @@ function got_visible_tags(data,textStatus) { $.each(data.tags, function(i,tag) { console.debug( i, tag ); html += '
  • ' + tag.sid; - var borrowernumber = tag.content || tag.borrower.cardnumber; + var content = tag.content || tag.borrower.cardnumber; - if ( borrowernumber ) { - html += ' ' + borrowernumber + ''; + if ( content ) { + html += ' ' + content + ''; html += ''; /* html += '
    '