]>
cvs.zerfleddert.de Git - rsbs2/blob - rsbs2.pl
0d2a682940d6373a9649d431dc49653d7aafc928
   7 use Digest
::MD5 
qw(md5); 
   9 my $ua = LWP
::UserAgent-
>new; 
  16 my @fw_vars = qw(ENABLE_LAN_AUTONEG ENABLE_LAN_100 ENABLE_LAN_FDUPLEX GATEWAY 
  17         IP_ADDRESS NETMASK TFTP_FIRMWARE_FILE TFTP_ADDR_FIRMWARE ENABLE_DHCP 
  18         ENABLE_DNS DNS_SERVER DNS_DOMAIN_NAME 
  19         ACCESS_CONTROL_SERVER_1 ACCESS_CONTROL_SERVER_2 ACCESS_CONTROL_SERVERS 
  20         ACPI_DISABLE_BIOS_SCAN ACPI_FORCE_RSDP_ADDRESS ACPI_FORCE_RSDT_ADDRESS 
  21         ACPI_RSDP_BIOS_ROM_ADDRESS ACPI_SCAN_DELAY_SECONDS AMR_AUTH_METHOD 
  22         AMR_DISABLE_PCI AMR_ENABLE_ISCSI_TIMEOUT AMR_ENABLED AMR_HOST_INTERFACE 
  23         AMR_SERVER_LIST AMR_USB_FDD_CBI_UFI_TRANSPORT AMR_USB_R2T_TIMEOUT_MSEC 
  24         AVR_4BIT_ACTION AVR_4BIT_SAMPLE_TIME AVR_ARCHITECTURE AVR_CHIP_TYPE 
  25         AVR_CLIENT_LANGUAGE AVR_DISABLE_SVR_MOUSE_ON_SESSION_START 
  26         AVR_KB_VERSION AVR_MAX_SESSION_COUNT AVR_MOUSE_ACCELERATION 
  27         AVR_MOUSE_MAX_STEP_SIZE AVR_NUMB_MOUSE_PACKETS 
  28         AVR_PCI_PATTERN_HANDS_OFF_ENABLED AVR_PREF_KB_STICKY_KEY_MODE_ON 
  29         AVR_PREF_KB_TYPING_MODE_ON AVR_PREF_KB_WARN_UNID_EV 
  30         AVR_REGISTERS_BASE_ADDR AVR_RESET_PAUSE AVR_SCREEN_REFRESH 
  31         AVR_SUPPORTED_CHIP AVR_TILE_TIMEOUT AVR_VIDEO_MEM_BASE_ADDR BAUDRATE 
  32         BAUDRATE_MODEM BAUDRATE_PPP BMC_SUPPORTS_GRACEFULL 
  33         BMC_TIMESYNC_INTERVAL CARD_NAME CONSOLE_IPMI_MOUSE_BYTE_TIME 
  34         CONSOLE_KEYBOARD_ACCESS_MODE CONSOLE_MOUSE_ACCESS_MODE 
  35         CONSOLE_VIDEO_PARAM_MODE CONTACT CONTACT_PHONE CRIT_TEMP_SHUTDOWN 
  36         CRIT_VOLT_SHUTDOWN DHCP_ADD_EXTENSION DHCP_ADD_SERIAL 
  37         DHCP_CONFIGURE_DNS DHCP_HOSTNAME_EXT DHCP_SERVER DHCP_USE_CARDNAME 
  38         DIAG_URL ENABLE_ANON_IPMI ENABLE_ANON_PCI 
  39         ENABLE_ANON_WEB ENABLE_AVR_CHIP_DETECT ENABLE_BMC_AUTODETECT 
  40         ENABLE_BMC_TIMESYNC ENABLE_CRTC_FETCH ENABLE_DHCP ENABLE_DHCP_HOSTNAME 
  41         ENABLE_DS_CONNECTIVITY ENABLE_IO_UART_DECODER ENABLE_LAN_100 
  42         ENABLE_LAN_AUTONEG ENABLE_LAN_FDUPLEX ENABLE_MEM_UART_DECODER 
  43         ENABLE_PPP ENABLE_REMOTE_FLOPPY_BOOT ENABLE_SELF_DELETE 
  44         ENABLE_SERIAL_DBG ETHDRIVER_SID EXPROM_BANNER EXPROM_EBDA_COMPATIBILITY 
  45         EXPROM_ENTRY EXPROM_EXIT_DELAY_SEC EXPROM_F3_DELAY_SEC 
  46         EXPROM_INT13_COMPATIBILITY EXPROM_SETUP_BANNER FIRMWARE_REVISION 
  47         FP_ACDC FP_AMR FP_AVR_ASR FP_AVR_GRAPHIC_CONSOLE FP_AVR_TEXT_CONSOLE 
  48         FP_AVRMANCONF_4BIT_SAMPLE FP_AVRMANCONF_ACCESS_MODES FP_AVRMANCONF_CHIP 
  49         FP_AVRMANCONF_MOUSE_ACCELERATION FP_AVRMANCONF_MOUSE_TYPE 
  50         FP_AVRMANCONF_RESET_PAUSE FP_AVRMANCONF_SCREEN_REFRESH FP_BATTERY 
  51         FP_BOARDRESET_BUTTON FP_COMREDIRECT FP_F3_PPP FP_I2C FP_ICMB FP_INSTR 
  52         FP_INTERNAL_LAN FP_KEY_CONSOLE FP_LAN_SPEED 
  53         FP_LAST_BOARD_POWER_WARNING_ENABLED FP_NO_BLADE_PANEL 
  54         FP_NO_CARDCONF_PANEL FP_NO_DIAG_PANEL FP_NO_DSAUTHCONF_PANEL 
  55         FP_NO_MANAGE_PANEL FP_NO_MEMORY_PANEL FP_NO_SENSOR_PANEL 
  56         FP_NO_SERVERCONF_PANEL FP_NO_SSL_PANEL FP_NO_SYSLOG_PANEL 
  57         FP_NO_USERCONF_PANEL FP_PAGING_EMAIL FP_PAGING_SERIAL FP_PAGING_SNMP 
  58         FP_PCI_CONFIG FP_PPP FP_PROP_BAUDRATE_REQBOOT FP_PROP_PPP_INIT_REQBOOT 
  59         FP_PROP_PS_REQBOOT FP_PROP_TERM_DIRECT_CONNECT_REQBOOT FP_REMOTE_BOOT 
  60         FP_REMOTE_DISK FP_REMOTE_POWER FP_SAC_CONSOLE FP_SEL FP_SENSOR_HISTORY 
  61         FP_SEQ_SEL FP_SERVER_POWER FP_SERVER_REBOOT FP_SERVER_RESET 
  62         FP_SERVER_SHUTDOWN FP_SMM FP_SSL FP_STATUS_DIAG_PANEL 
  63         FP_STATUS_MEMORY_PANEL FP_STATUS_PCI_CONFIG FP_STATUS_SAC_CONSOLE 
  64         FP_SYSTEM_LAN FP_TEXT_ASR FP_TEXT_CONSOLE FP_TUI FP_VERSION FP_VGA_ASR 
  65         FP_VGA_CONSOLE FP_VT100_CONSOLE GATEWAY GATEWAY_MAC 
  66         GRATUITOUS_ARP_INTERVAL HELP_LOCATION HIST0_SAMPLE_TIME HIST0_SENSOR_ID 
  67         HIST1_SAMPLE_TIME HIST1_SENSOR_ID HIST2_SAMPLE_TIME HIST2_SENSOR_ID 
  68         HIST3_SAMPLE_TIME HIST3_SENSOR_ID HTTP_PORT_NUM HTTP_SSL_PORT_NUM 
  69         I2C_ADDR_8BIT_CHASSIS_BMC I2C_ADDR_8BIT_MY_BMC I2C_ADDR_8BIT_THIS_CARD 
  70         INFOTXT_BPROP_ACCESS INFOTXT_DB_ACCESS IP_ADDRESS IP_ADDRESS_SOURCE 
  71         IPMB_RETRY_TIMEOUT IPMB_SEQ_NUM_TIMEOUT IPMB_TX_RETRIES 
  72         IPMI_COUNTRY_SELECT IPV4_HEADER_PARAMETERS ISCSI_DEVICE_VENDOR 
  73         ISCSI_PRODUCT_EMUL_BD ISCSI_PRODUCT_EMUL_CD ISCSI_PRODUCT_EMUL_FD 
  74         LAST_CARD_NAME LAST_ENABLE_DHCP LAST_GATEWAY LAST_IP_ADDRESS 
  75         LAST_NETMASK LOCATION MAC_ADDRESS MODEM_CONNECT MODEM_CONNECT2 
  76         MODEM_SEPARATOR NETMASK PAGE_RETRIES PAGE_RETRY_DELAY_SEC POST_ERRCODE 
  77         POST_PROP PPP_AVAILABLE PPP_INIT PPP_IP_ADDR PPP_NETMASK PPP_PORT 
  78         PPP_STATUS PPP_STAY_ALIVE_SECS PPP_WELCOME PPP2_BAUDRATE PPP2_INIT 
  79         PPP2_IP_ADDR PPP2_NETMASK PPP2_PORT PPP2_STAY_ALIVE_SECS PRODUCT 
  80         PRODUCT_ABBR PS_ASR PS_DISK PS_FAN PS_HARDWARE PS_MEMORY PS_NETWORK 
  81         PS_OTHER PS_POST PS_RMC PS_SECURITY PS_SYS_POWER PS_SYS_STATUS 
  82         PS_TEMPERATURE PS2_ADAPTER_POWER_UP_MODE PS2_FW_UPDATE_CMD 
  83         PS2_FW_UPDATE_IMG_NAME PS2_FW_UPDATE_STATUS RMC_DS_GROUP SAC_PORT 
  84         SERVER_CODEPAGE SERVER_HARD_RESET_PULSE_MS SERVER_HARD_RESET_VIA_IPMI 
  85         SERVER_ID SERVER_IP SERVER_KEYBOARD SERVER_KEYBOARD_LANGUAGES_LIST 
  86         SERVER_MEMORY SERVER_NAME SERVER_POWER_CHANGE_VIA_IPMI 
  87         SERVER_POWER_OFF_MODE SERVER_POWER_OFF_PULSE_MS SERVER_POWER_ON_MODE 
  88         SERVER_POWER_ON_PULSE_MS SERVER_TIMEZONE SERVER_URL 
  89         SESSION_MANAGER_SESSION_TIMEOUT SI_DEF_POLL_INTERVAL_MS 
  90         SI_DEF_POLL_OFFSET_MS SMTP_RESP_TIME_SEC SMTP_RETRIES 
  91         SMTP_RETRY_DELAY_SEC SMTP_REVERSE_PATH SMTP_SERVER SNMP_AGENT_ENABLED 
  92         SNMP_COMMUNITY SNMP_ENTERPRISE_ID SNMP_SERVER SNMP_SERVER_1 
  93         SNMP_SERVER_2 SNMP_SERVER_3 SNMP_SERVER_4 SNMP_SERVER_5 SNMP_SERVER_6 
  94         SNMP_SERVER_7 SNMP_SERVER_MAC SNMP_SYSOID SNMP_TRAP_MASK 
  95         SNMP_TRAP_VERSION SSL_40_OR_128_ENCRYPTION SSL_CAPABLE_FIRMWARE 
  96         SSL_ENABLE_ALOG SSL_ENABLE_ALOG_FALLBACK SSL_ENABLE_CLIENT_CERT 
  97         SSL_ENABLE_HTTP SSL_ENABLE_HTTPS SSL_ENABLE_NOTIFY 
  98         SSL_NOTIFICATION_TIME TELNET_ENABLE TELNET_PORT_NUM 
  99         TERMINAL_DIRECT_CONNECT TERMINAL_ENCODING TEXT_CONSOLE_TIMEOUT 
 100         TFTP_ADDR_FIRMWARE TFTP_ADDR_REBOOT TFTP_FIRMWARE_FILE TFTP_REBOOT_FILE 
 101         TXT_REMOTE_CONSOLE_COLOR_MAP TXT_REMOTE_CONSOLE_FREQ 
 102         USB_DEVICE_SETTINGS USE_SERVER_IP_ADDRESS USER_TIMEOUT VENDOR 
 103         RMC_AUTODETECT RMC_FUNCTIONS RMC_MODULES AGENT_VERSION BIOS_VER 
 104         BOARD_MFT BOARD_MODEL BOARD_PART_NUM BOARD_SERIAL BOARD_VER CAB_MFT 
 105         CAB_MODEL CAB_PROD_NUM CAB_PROD_VER CAB_SERIAL CHA_MODEL 
 106         CSV_ConfAlarmMailFrom CSV_ConfAlarmMailMessage CSV_ConfAlarmMailSubject 
 107         CSV_ConfAlarmMailType CSV_ConfAlarmMailUserInfo0 
 108         CSV_ConfAlarmMailUserInfo1 PER_USER_PAGING RMC_SEL_FILTER 
 109         SERVER_AD_NAME SERVER_AD_NAME2 SERVER_AD_NAME3 SERVER_AD_NAME4 
 110         SERVER_CONTACT SERVER_DESCRIPTION SERVER_IP_ADDRESS SERVER_IP_ADDRESS2 
 111         SERVER_IP_ADDRESS3 SERVER_IP_ADDRESS4 SERVER_IP_DHCP SERVER_IP_DHCP2 
 112         SERVER_IP_DHCP3 SERVER_IP_DHCP4 SERVER_IP_GATEWAY SERVER_IP_GATEWAY2 
 113         SERVER_IP_GATEWAY3 SERVER_IP_GATEWAY4 SERVER_IP_NETMASK 
 114         SERVER_IP_NETMASK2 SERVER_IP_NETMASK3 SERVER_IP_NETMASK4 
 115         SERVER_LOCATION SERVER_MAC_ADDRESS SERVER_MAC_ADDRESS2 
 116         SERVER_MAC_ADDRESS3 SERVER_MAC_ADDRESS4 SERVER_MAX_LAN_ADAPTER 
 117         SERVER_OS SERVER_OS_VENDOR); 
 122         for my $k (0..length($str)-1) { 
 123                 $crc ^= ord(substr($str, $k, 1)) << 8; 
 125                         $crc = (($crc & 0x8000) == 32768 ? ($crc<<1) ^ 0x1021 : $crc<<1); 
 128         $crc = $crc & 0xFFFF; 
 133         my ($password, $challenge) = @_; 
 134         my @challenge_bytes = unpack 'c16', decode_base64
($challenge); 
 135         my @pwd_hash            = unpack 'c16', md5
($password); 
 138                 $xor_bytes[$i] = $challenge_bytes[$i] ^ $pwd_hash[$i]; 
 140         my $hash = md5
(pack 'c16', @xor_bytes); 
 141         my $crc = _crc16
($hash); 
 142         $hash .= chr($crc & 0xff) . chr($crc >> 8 & 0xff); 
 143         return encode_base64
($hash, ""); 
 148         $request = HTTP
::Request-
>new(POST 
=> "http://${host}/cgi/bin"); 
 149         $request->header(Cookie 
=> "sid=$sid"); 
 150         $request->content_type('application/x-www-form-urlencoded'); 
 151         $request->content($xml); 
 152         $response = $ua->request($request); 
 153         die("Error in request: " . $response->status_line . "\n") unless ($response->is_success); 
 154         XMLin
($response->content, SuppressEmpty 
=> ''); 
 160         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="'.$cmd.'"></REQ></RMCSEQ>'; 
 161         my $res = _req
($reqstr); 
 162         if ($res->{RESP
}->{RC
} ne '0x0') { 
 163                 print "${cmd} failed: ".$res->{RESP
}->{RC
}."\n"; 
 171         my $property = shift; 
 173         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="propget"><PROPLIST><PROP NAME="'.$property.'"/></PROPLIST></REQ></RMCSEQ>'; 
 174         my $resp = _req
($reqstr); 
 176         print "get: ${property}\n" if ($verbose); 
 178         if ($resp->{RESP
}->{RC
} ne '0x0') { 
 186         print "Logout\n" if ($verbose); 
 187         my $request = HTTP
::Request-
>new(GET 
=> "http://${host}/cgi/logout"); 
 188         $request->header(Cookie 
=> "sid=$sid"); 
 189         my $response = $ua->request($request); 
 190         die("While trying to logout: " . $response->status_line . "\n") unless ($response->is_success); 
 192         my $xmlin = XMLin
($response->decoded_content); 
 193         die "Error logging out: ".$xmlin->{RC
} if ($xmlin->{RC
} ne '0x0'); 
 197         my $property = shift; 
 200         my $oldval = _getprop
($property)->{RESP
}->{PROPLIST
}->{PROP
}->{VAL
}; 
 202         if ($value eq $oldval) { 
 203                 print "${property} is already ${value}\n" if ($verbose); 
 207         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="propset"><PROP NAME="'.$property.'"><VAL>'.$value.'</VAL></PROP></REQ></RMCSEQ>'; 
 208         my $res = _req
($reqstr); 
 210         if ($res->{RESP
}->{RC
} ne '0x0') { 
 211                 print "Error setting ${property} to ${value}: ".$res->{RESP
}->{RC
}."\n"; 
 214                 print "${property}: ${oldval} -> ${value}\n" if ($verbose); 
 224         setprop
("SERVER_HARD_RESET_VIA_IPMI", "FALSE"); 
 225         setprop
("SERVER_POWER_CHANGE_VIA_IPMI", "FALSE"); 
 227         setprop
("SERVER_POWER_ON_MODE", sprintf("0x%x", $pmode)); 
 228         setprop
("SERVER_POWER_OFF_MODE", sprintf("0x%x", $pmode)); 
 230         print "${action}...\n" if ($verbose); 
 231         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="serveraction"><ACT>'.$action.'</ACT></REQ></RMCSEQ>'; 
 232         my $res = _req
($reqstr); 
 234         if ($res->{RESP
}->{RC
} ne '0x0') { 
 235                 print "FAILED:".$res->{RESP
}->{RC
}."\n"; 
 240         print "powerup\n" if ($verbose); 
 241         setprop
("SERVER_POWER_ON_PULSE_MS", sprintf("0x%x", $poweronms)); 
 242         setprop
("SERVER_POWER_OFF_PULSE_MS", "0x0"); 
 243         serveraction
("powercycle"); 
 247         print "powerdown\n" if ($verbose); 
 248         setprop
("SERVER_POWER_ON_PULSE_MS", "0x0"); 
 249         setprop
("SERVER_POWER_OFF_PULSE_MS", sprintf("0x%x", $poweroffms)); 
 250         serveraction
("powercycle"); 
 254         print "powercycle\n" if ($verbose); 
 255         setprop
("SERVER_POWER_ON_PULSE_MS", sprintf("0x%x", $poweronms)); 
 256         setprop
("SERVER_POWER_OFF_PULSE_MS", sprintf("0x%x", $poweroffms)); 
 257         serveraction
("powercycle"); 
 261         my $property = shift; 
 263         my $phash = _getprop
($property)->{RESP
}->{PROPLIST
}->{PROP
}; 
 265         print "${property}: " . ${phash
}->{VAL
} . " (" . ${phash
}->{PERMS
} . ")\n"; 
 268 sub board_properties 
{ 
 269         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="boardpropget"><PROPLIST><PROP NAME=""/></PROPLIST></REQ></RMCSEQ>'; 
 270         my $resp = _req
($reqstr); 
 272         print " * Board Properties:\n"; 
 273         foreach my $bprop (@{$resp->{RESP
}->{BPROPLIST
}->{BPROP
}}) { 
 274                 print " * " . ${bprop
}->{NAME
} . ": " . ${bprop
}->{VAL
} . "\n"; 
 279         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="boardpropget"><BPROPLIST><BPROP NAME="BOARD_DESCRIPTION"/></BPROPLIST></REQ></RMCSEQ>'; 
 280         my $boarddesc64 = _req
($reqstr)->{RESP
}->{BPROPLIST
}->{BPROP
}->{VAL
}; 
 281         my $boarddesc = decode_base64
($boarddesc64); 
 282         my @board = split(//, $boarddesc); 
 283         foreach my $byte (@board) { 
 284                 printf ("0x%02x ", ord($byte)); 
 290         foreach my $fwvar (@fw_vars) { 
 296         my $reqstr = '<?XML version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="usrlist"></REQ></RMCSEQ>'; 
 297         my $res = _req
($reqstr); 
 300         if ($res->{RESP
}->{RC
} ne '0x0') { 
 301                 print "FAILED:".$res->{RESP
}->{RC
}."\n"; 
 304                 if (ref($res->{RESP
}->{USRLIST
}->{USER
}) eq 'ARRAY') { 
 305                         foreach my $usr (@{$res->{RESP
}->{USRLIST
}->{USER
}}) { 
 306                                 push @users, $usr->{NAME
}; 
 309                         push @users, $res->{RESP
}->{USRLIST
}->{USER
}->{NAME
}; 
 318         my $reqstr = '<?XML version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="usrpropget"><USER NAME="'.$usr.'"></USER></REQ></RMCSEQ>'; 
 319         my $res = _req
($reqstr)->{RESP
}->{USER
}->{PROP
}; 
 327         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="usradd"><USER NAME="'.$usr.'"/></REQ></RMCSEQ>'; 
 328         my $res = _req
($reqstr); 
 329         if ($res->{RESP
}->{RC
} ne '0x0') { 
 330                 print "FAILED:".$res->{RESP
}->{RC
}."\n"; 
 336         my $property = shift; 
 339         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="usrpropget"><USER NAME="'.$usr.'"><PROP NAME="'.$property.'"></PROP></USER></REQ></RMCSEQ>'; 
 340         my $res = _req
($reqstr); 
 342         my $oldval = ${res
}->{RESP
}->{USER
}->{PROP
}->{VAL
}; 
 344         if ($value eq $oldval) { 
 345                 print "${property} is already ${value}\n" if ($verbose); 
 349         $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="usrpropset"><USER NAME="'.$usr.'"><PROP NAME="'.$property.'"><VAL>'.$value.'</VAL></PROP></USER></REQ></RMCSEQ>'; 
 350         $res = _req
($reqstr); 
 352         if ($res->{RESP
}->{RC
} ne '0x0') { 
 353                 print "Error setting ${property} to ${value}: ".$res->{RESP
}->{RC
}."\n"; 
 356                 print "${property}: ${oldval} -> ${value}\n" if ($verbose); 
 362         my $destination_ip = shift; 
 365         my $reqstr='<?xml version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="dbgmsglancfg"><IP>'.${destination_ip
}.'</IP><BCAST>'.${bcast
}.'</BCAST><STORE>FALSE</STORE></REQ></RMCSEQ>'; 
 366         my $res = _req
($reqstr); 
 367         if ($res->{RESP
}->{RC
} ne '0x0') { 
 368                 print "FAILED:".$res->{RESP
}->{RC
}."\n"; 
 372         $reqstr='<?XML version="1.0"?><?RMCXML version="1.0"?><RMCSEQ><REQ CMD="dbgmsgcfg"><ON>TRUE</ON><CHANNELMASK>0x1</CHANNELMASK><MMASK>0x1</MMASK><STORE>FALSE</STORE></REQ></RMCSEQ>'; 
 373         $res = _req
($reqstr); 
 374         if ($res->{RESP
}->{RC
} ne '0x0') { 
 375                 print "FAILED:".$res->{RESP
}->{RC
}."\n"; 
 379         print "Debug messages will be sent to ${destination_ip} (broadcast: ${bcast})\n"; 
 383         my $boardstatus = _cmd
("boardstatus")->{STATUS
}; 
 384         my $fw = _cmd
("boardfwstatus"); 
 385         my $boardfwstatus = $fw->{STATUS
}; 
 386         my $boardfwprogress = $fw->{PROGRESS
}; 
 387         $bs = hex($boardstatus); 
 389         print "Server Power:\t\t" . (($bs & 0x01) ? "ON" : "OFF") . "\n"; 
 390         print "External PSU:\t\t" . (($bs & 0x02) ? "ON" : "OFF") . "\n"; 
 391         print "Battery:\t\t"; 
 395                 } elsif ($bs & 0x800) { 
 403         print "Standby Power:\t\t" . (($bs & 0x08) ? "ON" : "OFF") . "\n"; 
 404         print "LAN:\t\t\t" . (($bs & 0x10) ? "CONNECTED" : "NC") . "\n"; 
 405         print "I2C:\t\t\t" . (($bs & 0x20) ? "CONNECTED" : "NC") . "\n"; 
 406         print "SMM:\t\t\t" . (($bs & 0x40) ? "CONNECTED" : "NC") . "\n"; 
 407         print "Instrumentation:\t" . (($bs & 0x200) ? "CONNECTED" : "NC") . "\n"; 
 408         print "ICMB:\t\t\t" . (($bs & 0x400) ? "CONNECTED" : "NC") . "\n"; 
 409         print "PPP:\t\t\t" . (($bs & 0x10000) ? "ON" : "OFF") . "\n"; 
 410         print "Paging:\t\t\t" . (($bs & 0x20000) ? "ON" : "OFF") . "\n"; 
 411         print "COM redirection:\t" . (($bs & 0x100000) ? "ON" : "OFF") . "\n"; 
 412         print "UART redirect:\t\t" . (($bs & 0x200000) ? "ON" : "OFF") . "\n"; 
 413         print "UART redirect pending:\t" . (($bs & 0x400000) ? "TRUE" : "FALSE") . "\n"; 
 414         my $fws = hex ($boardfwstatus); 
 415         print "FW status:\t\t"; 
 416         if ($fws == 3 || $fws == 32771) { 
 421         if (($fws & 0x8080) || ($fws & 0x80)) { 
 422                 printf("FW error:\t\t0x%02x\n", ($fws & 0xff)); 
 424         print "boardstatus:\t\t${boardstatus}\n"; 
 425         print "boardfwstatus:\t\t${boardfwstatus}\n"; 
 426         print "fw upgrade progress:\t${boardfwprogress}\n"; 
 433         my $response = $ua->get("http://${host}/cgi/challenge"); 
 434         die $response->status_line if (!($response->is_success)); 
 436         my $xmlin = XMLin
($response->decoded_content); 
 437         die "Error getting Challenge: ".$xmlin->{RC
} if ($xmlin->{RC
} ne '0x0'); 
 438         my $challenge = $xmlin->{CHALLENGE
}; 
 439         print "Challenge: ${challenge}\n" if ($verbose); 
 441         $sid = $response->headers->header('Set-Cookie'); 
 442         die "No SessionID!" if (!defined($sid)); 
 444         $sid =~ s/.*sid=(.*);.*/$1/; 
 445         print "SID: ${sid}\n" if ($verbose); 
 447         my $login_hash = _hash
($pass, $challenge); 
 448         print "Hash: ${login_hash}\n" if ($verbose); 
 450         my $request = HTTP
::Request-
>new(GET 
=> "http://${host}/cgi/login?user=${user}&hash=${login_hash}"); 
 451         $request->header(Cookie 
=> "sid=$sid"); 
 452         $response = $ua->request($request); 
 453         die("While trying to login: " . $response->status_line . "\n") unless ($response->is_success); 
 455         $xmlin = XMLin
($response->decoded_content); 
 456         die "Error logging in: ".$xmlin->{RC
} if ($xmlin->{RC
} ne '0x0'); 
 462         my $filename = shift; 
 464         open(INIFILE
,"<${filename}") || die("can't open config: ${filename}: $!"); 
 472                 if (m/^\s*\[(.*)\]\s*$/) { 
 478                         if (m/^\s*([^=]+)\s*=\s*(.*)\s*$/) { 
 479                                 ${$Ini{$sections[$#sections]}}{$1} = $2; 
 488 my %Config = read_inifile
("$ENV{HOME}/.rsbs2rc"); 
 498 my $enable_debug = ""; 
 504 while (defined($ARGV[0])) { 
 505         SWITCH
: for ($ARGV[0]) { 
 513                                 push @gprop, shift @ARGV; 
 518                                 push @sprop, shift @ARGV; 
 543                                 $enable_debug = shift @ARGV; 
 567                 if (defined($ARGV[0])) { 
 568                         $hostalias = $ARGV[0]; 
 573                 while ( defined($ARGV[0]) ) { $valid_arg = 0; shift(@ARGV); } 
 577 if ($valid_arg && (!defined($Config{$hostalias}))) { 
 582         print STDERR 
"Usage: $0 options card-alias\n"; 
 583         print STDERR 
"Options:\n"; 
 584         print STDERR 
"\t-g property\tget property value\n"; 
 585         print STDERR 
"\t-s property=val\tset property value\n"; 
 586         print STDERR 
"\t-u\t\tpowerup\n"; 
 587         print STDERR 
"\t-d\t\tpowerdown\n"; 
 588         print STDERR 
"\t-c\t\tpowercycle\n"; 
 589         print STDERR 
"\t-r\t\treset\n"; 
 590         print STDERR 
"\t-x\t\tshow all properties, variables and settings\n"; 
 591         print STDERR 
"\t-l IP\t\tsend SYSLOG debug messages to IP\n"; 
 592         print STDERR 
"\t-b\t\tshow board/server status\n"; 
 593         print STDERR 
"\t-v\t\tverbose\n"; 
 594         print STDERR 
"\t-save file\tsave configuration to 'file'\n"; 
 595         print STDERR 
"\t-load file\tload configuration from 'file'\n"; 
 597         print STDERR 
"card-alias\tone of: "; 
 598         foreach my $alias (keys(%Config)) { 
 599                 print STDERR 
"\"${alias}\" "; 
 601         print STDERR 
"(see ~/.rsbs2rc)\n"; 
 605 $host = ${$Config{$hostalias}}{"host"}; 
 606 $poweronms = ${$Config{$hostalias}}{"poweronms"} if (defined(${$Config{$hostalias}}{"poweronms"})); 
 607 $poweroffms = ${$Config{$hostalias}}{"poweroffms"} if (defined(${$Config{$hostalias}}{"poweroffms"})); 
 609 $sid = login
(${$Config{$hostalias}}{"user"}, ${$Config{$hostalias}}{"pass"}); 
 618         foreach my $p (@gprop) { 
 624         foreach my $p (@sprop) { 
 625                 (my $pr, $v) = split(/=/,$p,2); 
 626                 my $oldval = setprop
($pr, $v); 
 627                 if (defined($oldval)) { 
 628                         print "${pr}: ${oldval} -> ${v}\n" if (!$verbose); 
 634         my @dontsave = qw(ENABLE_LAN_AUTONEG ENABLE_LAN_100 ENABLE_LAN_FDUPLEX 
 635         GATEWAY IP_ADDRESS NETMASK TFTP_FIRMWARE_FILE TFTP_ADDR_FIRMWARE 
 636         ENABLE_DHCP MAC_ADDRESS LAST_CARD_NAME LAST_ENABLE_DHCP LAST_GATEWAY 
 637         LAST_IP_ADDRESS LAST_NETMASK); 
 639         open (SAVEFILE
, ">${save}") || die "Error opening save-file: $!\n"; 
 640         print SAVEFILE 
"[global]\n"; 
 641         print STDERR 
"saving" if (!$verbose); 
 642         foreach my $ts (@fw_vars) { 
 643                 next if (grep(/^${ts}$/, @dontsave)); 
 645                 my $phash = _getprop
($ts)->{RESP
}->{PROPLIST
}->{PROP
}; 
 646                 next if ($phash->{PERMS
} ne 'RW'); 
 648                 print SAVEFILE 
"${ts}=".$phash->{VAL
}."\n"; 
 649                 print STDERR 
"." if (!$verbose); 
 651         foreach my $usr (usrlist
()) { 
 652                 print SAVEFILE 
"\n[${usr}]\n"; 
 653                 foreach my $up (@{getusrprops
($usr)}) { 
 654                         next if ($up->{PERMS
} ne 'RW'); 
 656                         print SAVEFILE 
$up->{NAME
}."=".$up->{VAL
}."\n"; 
 658                 print STDERR 
"." if (!$verbose); 
 661         print STDERR 
"done\n" if (!$verbose); 
 665         my %loadfile = read_inifile
("${load}"); 
 666         print STDERR 
"loading" if (!$verbose); 
 668         foreach my $p (keys(%{$loadfile{'global'}})) { 
 669                 setprop
($p, $loadfile{'global'}->{$p}); 
 670                 print STDERR 
"." if (!$verbose); 
 673         my @users = usrlist
(); 
 674         foreach my $usr (keys(%loadfile)) { 
 675                 next if ($usr eq 'global'); 
 676                 if (!grep(/^${usr}$/, @users)) { 
 677                         print STDERR 
"\nAdding user \"${usr}\".\n" if ($verbose); 
 680                 foreach my $p (keys(%{$loadfile{$usr}})) { 
 681                         setusrprop
($usr, $p, $loadfile{$usr}->{$p}); 
 682                         print STDERR 
"." if (!$verbose); 
 685         print STDERR 
"done\n" if (!$verbose); 
 686         print "Settings loaded, resetting board...\n"; 
 691 if ($enable_debug ne '') { 
 692         syslog_debug
($enable_debug, "TRUE"); 
 696         print "hardreset\n" if ($verbose); 
 697         serveraction
("hardreset");