projects
/
Biblio-RFID.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
ec011db
)
on short read from SIP2 server reopen connection
author
Dobrica Pavlinusic
<dpavlin@rot13.org>
Fri, 20 Mar 2015 14:31:08 +0000
(15:31 +0100)
committer
Dobrica Pavlinusic
<dpavlin@rot13.org>
Fri, 20 Mar 2015 14:31:08 +0000
(15:31 +0100)
scripts/RFID-JSONP-server.pl
patch
|
blob
|
history
diff --git
a/scripts/RFID-JSONP-server.pl
b/scripts/RFID-JSONP-server.pl
index
f5fc8bf
..
46abca9
100755
(executable)
--- a/
scripts/RFID-JSONP-server.pl
+++ b/
scripts/RFID-JSONP-server.pl
@@
-78,16
+78,36
@@
sub rfid_borrower {
}
}
+sub sip2_socket {
+
+ return $sip2->{sock} if exists $sip2->{sock} && $sip2->{sock}->connected;
+
+ if ( my $server = $sip2->{server} ) {
+ my $sock = $sip2->{sock} = IO::Socket::INET->new( $server ) || die "can't connect to $server: $!";
+ warn "SIP2 server ", $sock->peerhost, ":", $sock->peerport, "\n";
+
+ # login
+ if ( sip2_message("9300CN$sip2->{user}|CO$sip2->{password}|")->{fixed} !~ m/^941/ ) {
+ die "SIP2 login failed";
+ }
+
+ }
+ return $sip2->{sock};
+}
+
sub sip2_message {
my $send = shift;
sub sip2_message {
my $send = shift;
- my $sock = $sip2->{sock} || die "no sip2 socket";
+send_again:
+ my $sock = sip2_socket || die "no sip2 socket";
local $/ = "\r";
$send .= "\r" unless $send =~ m/\r$/;
$send .= "\n" unless $send =~ m/\n$/;
local $/ = "\r";
$send .= "\r" unless $send =~ m/\r$/;
$send .= "\n" unless $send =~ m/\n$/;
+
+ my $retry = 0;
warn "SIP2 >>>> ",dump($send), "\n";
print $sock $send;
$sock->flush;
warn "SIP2 >>>> ",dump($send), "\n";
print $sock $send;
$sock->flush;
@@
-100,7
+120,16
@@
sub sip2_message {
$in =~ s/^\n//;
$in =~ s/\r$//;
$in =~ s/^\n//;
$in =~ s/\r$//;
- die "empty read from SIP server" unless length $in > 1;
+ if ( ! $in ) {
+ $retry++;
+ warn "empty read from SIP server, retry: $retry\n";
+ if ( $retry < 10 ) {
+ close( $sip2->{sock} );
+ goto send_again;
+ }
+ die "aborted";
+ }
+
die "expected $expect" unless substr($in,0,2) != $expect;
die "expected $expect" unless substr($in,0,2) != $expect;
@@
-118,16
+147,6
@@
sub sip2_message {
return $hash;
}
return $hash;
}
-if ( my $server = $sip2->{server} ) {
- my $sock = $sip2->{sock} = IO::Socket::INET->new( $server ) || die "can't connect to $server: $!";
- warn "SIP2 server ", $sock->peerhost, ":", $sock->peerport, "\n";
-
- # login
- if ( sip2_message("9300CN$sip2->{user}|CO$sip2->{password}|")->{fixed} !~ m/^941/ ) {
- die "SIP2 login failed";
- }
-
-}
use lib 'lib';
use Biblio::RFID::RFID501;
use lib 'lib';
use Biblio::RFID::RFID501;