/[mdap]/mdap-server.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /mdap-server.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2 by dpavlin, Sun Apr 22 12:52:15 2007 UTC revision 9 by dpavlin, Sun Apr 22 16:40:49 2007 UTC
# Line 7  use Data::Dump qw/dump/; Line 7  use Data::Dump qw/dump/;
7  use constant GROUP => '224.0.0.103';  use constant GROUP => '224.0.0.103';
8  use constant PORT  => '3235';  use constant PORT  => '3235';
9    
10  my $local_port = 1000;  my $debug = shift @ARGV;
11    
12  my $resend_search_delay = 3;  my $resend_search_delay = 3;
13    my $tftp_path = '/srv/tftp/';
14    
15    warn "search for ants every ${resend_search_delay}s\ntftp server path: $tftp_path\n";
16    
17    sub fw {
18            my ($board, $offset,$len) = @_;
19            open(my $fh, "$tftp_path/$board") || die "Can't open image $tftp_path/$board: $!";
20            my $b;
21            seek($fh, $offset, 0) || die "can't seek to $offset: $!";
22            read($fh, $b, $len) || die "can't read $len bytes from $offset: $!";
23            close($fh);
24            return $b;
25    }
26    
27    sub fw_build {
28            my $board_name = shift || return 0;
29            my $v = join('.', unpack('CCCC',fw($board_name,0x20,4)) );
30            print "# fw_build $board_name $v\n";
31            return $v;
32    }
33    
34    sub fw_exists {
35            my $board = shift;
36            return -e "$tftp_path/$board";
37    }
38    
39  my $sock = IO::Socket::Multicast->new(LocalPort=>PORT,ReuseAddr=>1);  my $sock = IO::Socket::Multicast->new(LocalPort=>PORT,ReuseAddr=>1);
40  $sock->mcast_add(GROUP) || die "Couldn't set group: $!\n";  $sock->mcast_add(GROUP) || die "Couldn't set group: $!\n";
# Line 29  sub ant2hash { Line 54  sub ant2hash {
54    
55  sub mdap_send {  sub mdap_send {
56          my $data = shift;          my $data = shift;
         warn ">> $data\n>>----------\n";  
         my $null = chr(0);  
57          $sock->mcast_send( "${data}", GROUP . ':' . PORT );          $sock->mcast_send( "${data}", GROUP . ':' . PORT );
58            if ($debug) {
59                    warn ">> ", dump( $data ), $/;
60            } else {
61                    $data =~ s/\s+/ /gi;
62                    warn ">> ", substr($data,0,70), $/;
63            }
64  }  }
65    
66  local $SIG{ALRM} = sub {  local $SIG{ALRM} = sub {
# Line 41  local $SIG{ALRM} = sub { Line 70  local $SIG{ALRM} = sub {
70    
71  alarm( $resend_search_delay );  alarm( $resend_search_delay );
72    
73    mdap_send("ANT-SEARCH MDAP/1.1\r\n46");
74    
75  while (1) {  while (1) {
76          my $data;          my $data;
77          next unless $sock->recv($data,1024);          next unless $sock->recv($data,1024);
78    
79          if ( $data =~ m#^(REPLY-\S+)\s(MDAP/\d+\.\d+)# ) {          if ( $data =~ m#^(INFO|ANT-SEARCH|EXEC-CLI|REPLY-\S+)\s(MDAP)/(\d+\.\d+)# ) {
80    
81                  my ($type,$proto) = ($1,$2);                  my ($type,$proto,$mdap_ver) = ($1,$2,$3);
82    
83                  my $h = ant2hash($data);                  my $h = ant2hash($data);
84    
85                  print "# $type $proto ", dump( $h ), $/;                  my $client_version = $h->{'MDAP-VERSION'};
86                    $mdap_ver = $client_version if ($client_version);
87    
88                    print "<< $type $proto/$mdap_ver << ", length($data), " bytes\n";
89    
90                    warn dump($h),$/ if ($debug);
91    
92                    # we are getting our own INFO messages
93                    next if ( $type =~ m#^(INFO|ANT-SEARCH|EXEC-CLI)# );
94    
95                    my $ant = $h->{'ANT-ID'} || die "no ANT-ID in ", dump( $h );
96    
97                  if ($type eq 'REPLY-ANT-SEARCH') {                  if ($type eq 'REPLY-ANT-SEARCH') {
98                          mdap_send("INFO MDAP/1.2                          mdap_send("INFO MDAP/$mdap_ver\r\nSEQ-NR:1\r\nTO-ANT:$ant\r\nUSER-ID:Administrator\r\nUSER-PWD:\r\n22");
 SEQ-NR:1  
 TO-ANT:0644JTHJ4  
 USER-ID:Administrator  
 USER-PWD:\r\n22");  
99                  } elsif ($type eq 'REPLY-INFO') {                  } elsif ($type eq 'REPLY-INFO') {
100                          if (                          my $board = $h->{'_BOARD_NAME'} || die "no _BOARD_NAME?";
101                                  $h->{'_BUILD'} eq '6.1.7.2' &&                          if ( fw_exists( $board ) ) {
102                                  $h->{'_BUILDNAME'} eq 'ZZO9AA6.172' &&                                  if ( $h->{'_BUILD'} ne fw_build( $board ) ) {
103                                  $h->{'_BUILDVARIANT'} eq 'AA' &&                                          print "UPDATE STEP 1 on ant $ant\n";
104                                  1                                          mdap_send("EXEC-CLI MDAP/$mdap_ver\r\nCLI-CMD:software upgrade\r\nSEQ-NR:1\r\nTO-ANT:$ant\r\nUSER-ID:Administrator\r\nUSER-PWD:\r\n1F");
105                          ) {                                  } else {
106                                  mdap_send("EXEC-CLI MDAP/1.2                                          print "OK ant $ant allready updated...\n";
107  CLI-CMD:software upgrade                                  }
 SEQ-NR:1  
 TO-ANT:0644JTHJ4  
 USER-ID:Administrator  
 USER-PWD:\r\n1F");  
108                          } else {                          } else {
109                                    print "!! NO FIRMWARE for $board in $tftp_path for ant $ant, skipping update\n";
110                          }                          }
111                    } elsif ( $type eq 'REPLY-EXEC-CLI' && $h->{'SEQ-NR'} == 1 ) {
112                                                            print "UPDATE STEP 2 on ant $ant\n";
113                                    mdap_send("EXEC-CLI MDAP/$mdap_ver\r\nSEQ-NR:2\r\nTO-ANT:$ant\r\nUSER-ID:Administrator\r\nUSER-PWD:\r\n5F");
114                  } else {                  } else {
115                          print "!! reply ignored\n";                          print "!! reply ignored ", dump( $h ), $/;
116                  }                  }
117    
118          } else {          } else {
119                  print $data, "\n", "-" x 30, "\n";                  warn "<=" x 15, "\n", $data, "\n", "<=" x 15, "\n";
120          }          }
121  }  }

Legend:
Removed from v.2  
changed lines
  Added in v.9

  ViewVC Help
Powered by ViewVC 1.1.26