#!/usr/bin/perl # IBM(c) 2007 EPL license http://www.eclipse.org/legal/epl-v10.html package xCAT::Usage; use Getopt::Long; use xCAT::Utils; #------------------------------------------------------------------------------- =head1 xCAT::Usage =head2 Package Description xCAT usage module. Some commands such as rpower have different implementations for different hardware. This module holds the usage string for these kind of commands so that the usage can be referenced from different modules. =cut #------------------------------------------------------------------------------- my %usage = ( "rnetboot" => "Usage: rnetboot [-s net|hd] [-f] [-V|--verbose] rnetboot [-h|--help|-v|--version]", "rpower" => "Usage: rpower [--nodeps] [on|onstandby|off|reset|stat|state|boot] [-V|--verbose] rpower [-h|--help|-v|--version] KVM Virtualization specific: rpower [boot] [ -c ] PPC (with IVM or HMC) specific: rpower [--nodeps] [of] [-V|--verbose] PPC (HMC) specific: rpower [onstandby] [-V|--verbose] Blade specific: rpower [cycle|softoff] [-V|--verbose] ", "rbeacon" => "Usage: rbeacon [on|off|stat] [-V|--verbose] rbeacon [-h|--help|-v|--version]", "rvitals" => "Usage: rvitals [all|temp|wattage|voltage|fanspeed|power|leds|lcds|state] [-V|--verbose] rvitals [-h|--help|-v|--version]", "reventlog" => "Usage: reventlog [all|clear|] [-V|--verbose] reventlog [-h|--help|-v|--version]", "rinv" => "Usage: Common: rinv [all|model|serial] [-V|--verbose] rinv [-h|--help|-v|--version] BMC specific: rinv [vpd|mprom|deviceid|uuid|guid] MPA specific: rinv [firm|bios|diag|mprom|sprom|mparom|mac|mtm] PPC specific: rinv [bus|config|serial|model|firm|all]", "rsetboot" => "Usage: rsetboot [net|hd|cd|floppy|def|stat] [-V|--verbose] rsetboot [-h|--help|-v|--version]", "rbootseq" => "Usage: rbootseq [hd0|hd1|hd2|hd3|net|iscsi|usbflash|floppy|none],... rbootseq [-h|--help|-v|--version]", "rscan" => "Usage: rscan [-w][-x|-z] [-V|--verbose] rscan [-h|--help|-v|--version]", "rspconfig" => "Usage: Common: rspconfig [-h|--help|-v|--version] BMC/MPA Common: rspconfig [snmpdest|alert|community] [-V|--verbose] rspconfig [snmpdest=|alert=|community=] BMC specific: rspconfig [ip|netmask|gateway|backupgateway|garp] rspconfig [garp=] iDataplex specific: rspconfig [thermprofile] rspconfig [thermprofile=] MPA specific: rspconfig [sshcfg|snmpcfg|pd1|pd2|network|swnet|ntp|textid] rspconfig [textid=name] rspconfig [sshcfg=| snmpcfg=| pd1=| pd2=| network=<*|[ip],[host],[gateway],[netmask]>| swnet=<[ip],[gateway],[netmask]>| textid=<*>| ntp=<[ntp],[ip],[frequency],[v3]> FSP specific: rspconfig [autopower|iocap|decfg|memdecfg|procdecfg|time|date|spdump|sysdump] rspconfig autopower=| iocap=| decfg=:,...| memdecfg=::::id,...| procdecfg=::id,...| date=| time= HMC specific: rspconfig [sshcfg] rspconfig [sshcfg=]", "getmacs" => "Usage: Common: getmacs [-V|--verbose] getmacs [-h|--help|-v|--version] PPC specific: getmacs [-f][-d][-D -S server -G gateway -C client]", "mkvm" => "Usage: Common: mkvm [-h|--help|-v|--version] For PPC: mkvm noderange -i id -l singlenode [-V|--verbose] mkvm noderange -c destcec -p profile [-V|--verbose] For KVM mkvm noderange -m|--master mastername -s|--size disksize -f|--force", "lsvm" => "Usage: Common: lsvm [-V|--verbose] lsvm [-h|--help|-v|--version] PPC specific: lsvm [-a|--all]", "chvm" => "Usage: chvm [-p profile][-V|--verbose] chvm [-h|--help|-v|--version] chvm = [=...]", "rmvm" => "Usage: rmvm [-V|--verbose] rmvm [-h|--help|-v|--version]", "lsslp" => "Usage: lsslp [-h|--help|-v|--version] lsslp [-V|--verbose][-i ip[,ip..]][-w][-u] [-r|-x|-z][-s BPA|MM|IVM|RSA|FSP|HMC] [-t tries][-m][-e cmd][-c [timeout[timeout,..]]]", "rflash" => "Usage: rflash [ -h|--help|-v|--version] rflash -p directory [--activate concurrent | disruptive][-V|--verbose] rflash [--commit | --recover] [-V|--verbose]" ); my $vers = xCAT::Utils->Version(); my %version = ( "rnetboot" => "$vers", "rpower" => "$vers", "rbeacon" => "$vers", "rvitals" => "$vers", "reventlog" => "$vers", "rinv" => "$vers", "rsetboot" => "$vers", "rbootseq" => "$vers", "rscan" => "$vers", "rspconfig" => "$vers", "getmacs" => "$vers", "mkvm" => "$vers", "lsvm" => "$vers", "chvm" => "$vers", "rmvm" => "$vers", "lsslp" => "$vers", "rflash" => "$vers" ); #-------------------------------------------------------------------------------- =head3 getUsage It returns the usage string for the given command. Arguments: command Returns: the usage string for the command. =cut #------------------------------------------------------------------------------- sub getUsage { my ($class, $command)=@_; if (exists($usage{$command})) { return $usage{$command};} else { return "Usage for command $command cannot be found\n"; } } #-------------------------------------------------------------------------------- =head3 getVersion It returns the version string for the given command. Arguments: command Returns: the version string for the command. =cut #------------------------------------------------------------------------------- sub getVersion { my ($class, $command)=@_; if (exists($version{$command})) { return $version{$command};} else { return "Version string for command $command cannot be found\n"; } } #-------------------------------------------------------------------------------- =head3 parseCommand This function parses the given command to see if the usage or version string need to be returned. Arguments: command arguments Returns: the usage or the version string for the command. The caller need to display the string and then exit. none, if no usage or version strings are needed. The caller can keep going. =cut #------------------------------------------------------------------------------- sub parseCommand { my $command=shift; if ($command =~ /xCAT::Usage/) { $command=shift; } my @exargs=@_; @ARGV=@exargs; #print "command=$command, args=@exargs, ARGV=@ARGV\n"; Getopt::Long::Configure('pass_through','no_ignore_case'); # parse the options if(!GetOptions( 'h|help' => \$::HELP, 'v|version' => \$::VERSION)) { return ""; } if ($::HELP) { return xCAT::Usage->getUsage($command); } if ($::VERSION) { return xCAT::Usage->getVersion($command); } return ""; }