RFID: disable register popup
[koha_ffzg] / ffzg / rfid / register.pl
index d043b5e..aedf4ec 100755 (executable)
@@ -6,16 +6,19 @@ use warnings;
 use CGI;
 use JSON;
 use FindBin;
+use IO::Socket::INET;
 
 my $query = new CGI;
 
 use Data::Dump qw(dump);
-warn "# Vars ", dump( $query->Vars );
+my $v = $query->Vars;
+warn "# v ", dump( $v );
 
 my $hash = {
        remote_host => $query->remote_host,
 };
 
+
 if ( my $c = $query->cookie('rfid_reader') ) {
        warn "## RFID cookie rfid_reader = $c\n";
        $hash->{local_ip} = $c;
@@ -24,11 +27,12 @@ if ( my $c = $query->cookie('rfid_reader') ) {
 
 if ( my $session = $query->cookie("CGISESSID") ) {
        $hash->{session} = $session;
-       warn "## RFID session $session\n";
        my $path = "/dev/shm/rfid.$session";
+       warn "## RFID session $path\n";
        if ( -e $path ) {
                open(my $fh, '<', $path);
                $hash->{local_ip} = <$fh>;
+               $hash->{have_reader} = 1;
        }
 }
 
@@ -50,26 +54,30 @@ if ( my $koha_login = $query->param('koha_login') ) {
 } elsif ( $query->param('_last') ) {
 
        my $v = $query->Vars;
-       my $ip;
-       foreach ( keys %$v ) {
-               if ( $v->{$_} =~ m/^10\.60\./ ) { # FIXME our local network
-                       $ip = $v->{$_};
-                       last;
-               }
-       }
+       my $ip = $v->{HTTP_LISTEN};
 
        if ( ! $ip ) {
-               die "RFID ERROR: can't find local IP in ",dump($v);
+               die "RFID ERROR: no HTTP_LISTEN in ",dump($v);
        }
 
-       $hash->{intranet_ip} = $ip;
-
        my $path = "$dir/ip/$ip"; # FIXME
        open(my $fh, '>', $path);
        print $fh encode_json( $v );
        close($fh);
        warn "RFID $path $ip ", -s $path, "\n";
 
+       # XXX this place is too early to test connection, since our client is not listening yet
+       #my $sock = IO::Socket::INET->new($ip) || die "RFID $ip : $!"; # XXX
+
+       $hash->{local_ip} = $ip;
+
+       $path = "$dir/reader/$ip";
+       mkdir $path unless -e $path;
+       $path .= '/mainpage.pl';
+       symlink "$dir/koha-reader.pl", $path unless -e $path;
+
+       $hash->{have_reader} = -e $path;
+
 } else {
        warn $hash->{_error} = "ERROR: ", $hash->{remote_host}, " don't have RFID reader assigned";
 }
@@ -78,7 +86,7 @@ sub js_console {
        warn "RFID: ",@_;
        return q|
 //$(document).ready( function() {
-       console.log('|, join('', @_), qq|);
+       console.log('|, join('', @_), qq|');
 //}
 |;
 }
@@ -100,9 +108,18 @@ if ( $query->param('intranet-js') ) {
                                close($js);
                } else {
                        warn "## RFID no local_ip for ",dump($hash);
+                       print js_console('no local_ipr');
                }
        } else {
-#              warn "## RFID doesn't have reader ",dump($hash);
+               warn "## RFID doesn't have reader ",dump($hash);
+               print js_console('no have_reader');
+               print q|
+!<--
+$(document).ready( function() {
+               $('#breadcrumbs').append('<div id="rfid_popup" style="position: fixed; bottom: 0; right: 0; background: #fff; border: 0.25em solid #ff0; padding: 0.25em; opacity: 0.9; z-index: 1040; font-size: 200%"><a href="https://ffzg.koha-dev.rot13.org:8443/cgi-bin/koha/ffzg/rfid/koha-reader.pl" target="select_rfid_reader">select RFID reader</a></div>');
+});
+-->
+|;
        }
 
 } elsif ( my $ip = $query->param('register_reader') ) {
@@ -115,5 +132,5 @@ if ( $query->param('intranet-js') ) {
 } else {
        print "Content-type: application/json; charset=utf-8\r\n\r\n";
        print encode_json $hash;
-       warn "## RFID hash = ",dump($hash);
 }
+warn "## RFID hash = ",dump($hash);