6 use Data::Dump qw(dump);
13 my $socket = IO::Socket::INET->new(
20 print "$0 waiting for client connection on port 4096\n";
25 BW => 0.0, # just paper cost
26 COLOR => 3.99, # FIXME
31 my $next_nop_t = time() + 5;
34 our $client_socket = $socket->accept();
37 my $text = join('', @_);
39 print $client_socket "$text\r\n";
43 #my $line = <$client_socket>;
46 my $timeout = $next_nop_t - time();
49 local $SIG{ALRM} = sub { die "alarm\n" }; # NB: \n required
51 warn "# NOP alarm $timeout";
52 $line = <$client_socket>;
58 $line = <$client_socket>;
61 $line = <$client_socket>;
64 if ( defined $line ) {
65 $line =~ s/[\r\n]+$//;
68 warn "<< NULL ", $client_socket->connected ? '' : 'NOT ', "connected";
74 # get the host and port number of newly connected client.
75 my $peer_address = $client_socket->peerhost();
76 my $peer_port = $client_socket->peerport();
78 print "Connection from: $peer_address:$peer_port\n";
81 my $total_charged = 0.00;
85 $v = $_[0] if defined $_[0];
86 return sprintf "%1.2f kn", $v;
89 while ($client_socket->connected) {
91 my $line = client_line;
92 last if ! defined $line;
94 if ( $line =~ m/^\.SQ ([\d\.]+) (\S+)/ ) {
95 my ($version,$serial) = ($1,$2);
97 #client_send ".SQ FAILED message";
98 } elsif ( $line =~ m/^\.CFG/ ) {
99 client_send ".CFG OK %s";
100 } elsif ( $line =~ m/\.SERVER LIST/ ) {
101 client_send ".ERROR NO-ENTERPRISE";
102 } elsif ( $line =~ m/\.CARD (\S+)/ ) {
104 client_send ".CARD OK Ime Prezime (nobody\@example.com)";
105 } elsif ( $line =~ m/\.PIN (\S+)/ ) {
107 client_send ".PIN OK Ime Pinzime (nobody\@example.com)";
108 } elsif ( $line =~ m/\.ACTION$/ ) {
109 # CMENUS0 - no printer
110 client_send ".ACTION CMENUS68"; # FIXME can be CMENUS2
112 } elsif ( $line =~ m/\.ACTION COPY/ ) {
113 client_send ".ACTION COPY"; # safeq sends this twice
114 client_send ".COPY Mozete kopirati |".credit;
116 client_send ".CREDIT ".credit;
117 } elsif ( $line =~ m/\.COPY (.+)/ ) {
120 foreach ( split(/,/,$1) ) {
121 die "can't find [$_] in prices=",dump($prices) unless exists $prices->{$_};
122 $charge += $prices->{$_};
124 warn "CHARGE: $charge\n";
126 $total_charged += $charge;
128 client_send ".CREDIT ".credit;
129 client_send ".COPY $total_pages"; # page copied
132 } elsif ( $line =~ m/\.ACTION LIST/ ) {
134 client_send "2"; # nr of items in list
135 # status: 0 - pendng/3 - printed
139 client_send "3|1|Koha online catalog|XWC7232";
140 client_send "0|1|Koha online catalog|XWC5225";
143 } elsif ( $line =~ m/\.ACTION PRINT (ALL|\d+)/ ) {
145 my $job = $1 if $1 =~ m/^\d+$/; # 0 means print all?
147 my $charge = $prices->{'A4'} || die "no A4 price";
151 if ( $nr_jobs == 0 ) {
152 client_send ".ACTION NOJOB Nema se šta tiskat";
157 warn "FIXME $line\n";
158 client_send ".ACTION PRINT"; # device locked from terminal screen?
160 # check if printer ready
161 my $printer_ready = 0;
162 if ( ! $printer_ready ) {
163 client_send ".WARN 1/1|The printer is not ready|job has been suspended ... (1x)";
167 my $send = 0; # 0 .. 100
168 my $printed = 0; # 0 .. nr pages
170 # total pages in batch
174 client_send ".PRINT 1|1/1|Microsoft Word - molba_opca";
175 client_send ".NOP S $send C 0";
177 # open 10.60.3.25:9100
180 client_send ".NOP S $send C 0";
181 client_send ".MSG Please check display of device" if $send == 100;
183 # check smtp counters to be sure page is printed
186 $total_charged += $charge;
189 client_send ".DONE $nr_jobs $total_pages ".credit($total_charged);
191 } elsif ( $line =~ m/^\.NOP/ ) {
192 # XXX it's important to sleep, before sending response or
193 # interface on terminal device will be unresponsive
194 $next_nop_t = time() + 5; # NOP every 5s?
195 } elsif ( $line =~ m/^\.END/ ) {
196 client_send ".DONE BLK WAIT";
198 my $nr_jobs = 0; # FIXME
199 client_send ".DONE $total_pages ".credit($total_charged);
200 # $client_socket->close;
201 } elsif (defined $line) {
202 warn "UNKNOWN: ",dump($line);
208 warn "NULL line ", $client_socket->connected ? '' : 'NOT ', "connected";
211 warn "# return to accept";