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 ) { |
300 |
my $total = ( $set_item & 0x0f ); |
my $total = ( $set_item & 0x0f ); |
301 |
my $branch = $br_lib >> 20; |
my $branch = $br_lib >> 20; |
302 |
my $library = $br_lib & 0x000fffff; |
my $library = $br_lib & 0x000fffff; |
303 |
print "TAG $tag [$u1] set: $set/$total [$u2] type: $type '$content' branch: $branch library: $library custom: $custom security: $security\n"; |
print "TAG $tag [$u1] set: $set/$total [$u2] type: $type '$content' library: $library branch: $branch custom: $custom security: $security\n"; |
304 |
|
|
305 |
} |
} |
306 |
|
|
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 = ",dump( $data ), " == $hex_data\n"; |
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 ) { |