19 |
push @a, scalar localtime() if $a[0] =~ m{^info}; |
push @a, scalar localtime() if $a[0] =~ m{^info}; |
20 |
|
|
21 |
if ( ! defined $meteor_fh ) { |
if ( ! defined $meteor_fh ) { |
22 |
warn "# open connection to $meteor_server"; |
if ( $meteor_fh = |
23 |
$meteor_fh = IO::Socket::INET->new( |
IO::Socket::INET->new( |
24 |
PeerAddr => $meteor_server, |
PeerAddr => $meteor_server, |
25 |
Timeout => 1, |
Timeout => 1, |
26 |
) || warn "can't connect to meteor $meteor_server: $!"; # FIXME warn => die for production |
) |
27 |
$meteor_fh = 0; # don't try again |
) { |
28 |
|
warn "# meteor connected to $meteor_server"; |
29 |
|
} else { |
30 |
|
warn "can't connect to meteor $meteor_server: $!"; |
31 |
|
$meteor_fh = 0; |
32 |
|
} |
33 |
} |
} |
34 |
|
|
35 |
warn ">> meteor ",dump( @a ); |
if ( $meteor_fh ) { |
36 |
print $meteor_fh "ADDMESSAGE test ",join('|',@a),"\n" if $meteor_fh; |
warn ">> meteor ",dump( @a ); |
37 |
|
print $meteor_fh "ADDMESSAGE test ",join('|',@a),"\n" |
38 |
|
} |
39 |
} |
} |
40 |
|
|
41 |
my $debug = 0; |
my $debug = 0; |
48 |
my $handshake = "none"; |
my $handshake = "none"; |
49 |
|
|
50 |
my $program_path = './program/'; |
my $program_path = './program/'; |
51 |
|
my $secure_path = './secure/'; |
52 |
|
|
53 |
my $response = { |
my $response = { |
54 |
'd500090400110a0500027250' => 'version?', |
'd500090400110a0500027250' => 'version?', |
215 |
meteor( 'write', $tag ); |
meteor( 'write', $tag ); |
216 |
write_tag( $tag ); |
write_tag( $tag ); |
217 |
} |
} |
218 |
|
if ( -e "$secure_path/$tag" ) { |
219 |
|
meteor( 'secure', $tag ); |
220 |
|
secure_tag( $tag ); |
221 |
|
} |
222 |
} |
} |
223 |
|
|
224 |
foreach my $tag ( keys %$last_visible_tags ) { |
foreach my $tag ( keys %$last_visible_tags ) { |
313 |
|
|
314 |
$data = substr($data,0,16); |
$data = substr($data,0,16); |
315 |
|
|
316 |
my $hex_data = unpack('H*', $data) . ' 00' x ( 16 - length($data) ); |
my $hex_data = unpack('h*', $data) . ' 00' x ( 16 - length($data) ); |
317 |
|
|
318 |
print "write_tag $tag = $data ",dump( $hex_data ); |
print "write_tag $tag = $data ",dump( $hex_data ); |
319 |
|
|
320 |
cmd( |
cmd( |
321 |
"D6 00 26 04 $tag 00 06 00 04 11 00 01 $hex_data 00 00 00 00 FD3B", "write $tag", |
"d6 00 26 04 $tag 00 06 00 04 11 00 01 $hex_data 00 00 00 00 fd3b", "write $tag", |
322 |
"D6 00 0D 04 00 $tag 06 AFB1", sub { assert() }, |
"d6 00 0d 04 00 $tag 06 afb1", sub { assert() }, |
323 |
) foreach ( 1 .. 3 ); # XXX 3M software does this three times! |
) foreach ( 1 .. 3 ); # xxx 3m software does this three times! |
324 |
|
|
325 |
my $to = $path; |
my $to = $path; |
326 |
$to .= '.' . time(); |
$to .= '.' . time(); |
331 |
delete $tags_data->{$tag}; # force re-read of tag |
delete $tags_data->{$tag}; # force re-read of tag |
332 |
} |
} |
333 |
|
|
334 |
|
sub secure_tag { |
335 |
|
my ($tag) = @_; |
336 |
|
|
337 |
|
my $path = "$secure_path/$tag"; |
338 |
|
my $data = substr(read_file( $path ),0,2); |
339 |
|
|
340 |
|
cmd( |
341 |
|
"d6 00 0c 09 $tag $data 1234", "secure $tag -> $data", |
342 |
|
"d6 00 0c 09 00 $tag 1234", sub { assert() }, |
343 |
|
); |
344 |
|
|
345 |
|
my $to = $path; |
346 |
|
$to .= '.' . time(); |
347 |
|
|
348 |
|
rename $path, $to; |
349 |
|
print ">> $to\n"; |
350 |
|
} |
351 |
|
|
352 |
exit; |
exit; |
353 |
|
|
354 |
for ( 1 .. 3 ) { |
for ( 1 .. 3 ) { |