automatically build readme for tools
git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/branches/2.8@15491 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
This commit is contained in:
parent
0fa5e225b0
commit
199505c28b
@ -459,5 +459,11 @@ if [ "$OSNAME" != "AIX" -a "$REL" = "devel" -a "$PROMOTE" != 1 -a -z "$EMBED" ];
|
||||
i=0
|
||||
while [ $((i+=1)) -le 5 ] && ! rsync $verboseflag -r opt/xcat/share/doc/man1 opt/xcat/share/doc/man3 opt/xcat/share/doc/man5 opt/xcat/share/doc/man7 opt/xcat/share/doc/man8 $UPLOADUSER,xcat@web.sourceforge.net:htdocs/
|
||||
do : ; done
|
||||
|
||||
# extract and upload the tools readme
|
||||
rpm2cpio ../$XCATCORE/xCAT-server-*.$NOARCH.rpm | cpio -id ./opt/xcat/share/xcat/tools/README.html
|
||||
i=0
|
||||
while [ $((i+=1)) -le 5 ] && ! rsync $verboseflag opt/xcat/share/xcat/tools/README.html $UPLOADUSER,xcat@web.sourceforge.net:htdocs/tools/
|
||||
do : ; done
|
||||
cd ..
|
||||
fi
|
||||
|
@ -153,6 +153,11 @@ OS diskful/diskfree deployment.
|
||||
All of the cluster configuration information is in the xCAT database. See L<xcatdb(5)|xcatdb.5> for
|
||||
descriptions of every table in the database.
|
||||
|
||||
=head1 XCAT ADDITIONAL TOOLS
|
||||
|
||||
Some additional tools have been contributed to xCAT. You can read about them at http://xcat.sourceforge.net/tools/README.html
|
||||
or in /opt/xcat/share/xcat/tools/README.txt on your xCAT management node.
|
||||
|
||||
=head1 XCAT COMMANDS
|
||||
|
||||
What follows is a short description of each xCAT command. To get more information about a particular
|
||||
|
164
xCAT-server/build-readme
Executable file
164
xCAT-server/build-readme
Executable file
@ -0,0 +1,164 @@
|
||||
#!/usr/bin/perl
|
||||
# IBM(c) 2007 EPL license http://www.eclipse.org/legal/epl-v10.html
|
||||
|
||||
# Runs each of the tools in the share/xcat/tools dir with the --help option
|
||||
# and compiles the output into a tools readme file (both text version and
|
||||
# html version).
|
||||
|
||||
use strict;
|
||||
#use lib '.';
|
||||
|
||||
my $toolsdir = 'share/xcat/tools';
|
||||
my $textreadme = "$toolsdir/README.txt";
|
||||
my $htmlreadme = "$toolsdir/README.html";
|
||||
#my $cachedir = '/tmp';
|
||||
|
||||
my @tools = getToolList($toolsdir);
|
||||
#foreach (@tools) { print "$_\n"; }
|
||||
|
||||
# Put the intro text in the readme files
|
||||
print "Building tools README files...\n";
|
||||
open(TXT, ">$textreadme") or die "Error: could not open $textreadme for writing.\n";
|
||||
open(HTML, ">$htmlreadme") or die "Error: could not open $htmlreadme for writing.\n";
|
||||
writeintro(\*TXT, \*HTML, @tools);
|
||||
|
||||
# Run each tool with --help flag
|
||||
foreach my $toolfile (@tools) {
|
||||
my $cmd = "./$toolsdir/$toolfile --help";
|
||||
my $output = `$cmd`;
|
||||
if ($?) {
|
||||
my $err = "Error: execution of '$cmd' failed with rc=" . ($?>>8) . ".\n";
|
||||
print $err;
|
||||
$output .= $err;
|
||||
}
|
||||
writetoolhelp(\*TXT, \*HTML, $toolfile, $output);
|
||||
}
|
||||
|
||||
# close files
|
||||
writeending(\*HTML);
|
||||
close TXT;
|
||||
close HTML;
|
||||
|
||||
exit;
|
||||
|
||||
|
||||
# get the list of tool script files.
|
||||
sub getToolList {
|
||||
my $toolsdir = shift;
|
||||
|
||||
# 1st get toplevel dir listing
|
||||
opendir(DIR, $toolsdir) or die "Error: could not read $toolsdir.\n";
|
||||
my @files = grep !/^\./, readdir(DIR); # /
|
||||
close(DIR);
|
||||
|
||||
# remove files that are not regular files (not dirs) and executable
|
||||
my @newlist;
|
||||
foreach my $f (@files) {
|
||||
my $file = "$toolsdir/$f";
|
||||
if ((-f $file) && (-x $file)) { push @newlist, $f; }
|
||||
}
|
||||
#foreach (@files) { print "$_\n"; }
|
||||
#foreach (@newlist) { print "$_\n"; }
|
||||
|
||||
return sort @newlist;
|
||||
}
|
||||
|
||||
|
||||
# print some text to both readmes
|
||||
sub printtoboth {
|
||||
my $txt = shift;
|
||||
my $html = shift;
|
||||
my $str = shift;
|
||||
print $txt $str;
|
||||
print $html $str;
|
||||
}
|
||||
|
||||
|
||||
# write the up front stuff of the readme
|
||||
sub writeintro {
|
||||
my $txt = shift; # the file handle to the txt readme file
|
||||
my $html = shift; # the file handle to the html readme file
|
||||
# the rest of @_ contains the tool files in the dir
|
||||
|
||||
# write title part of readmes
|
||||
print $txt <<'TXTEOS1';
|
||||
xCAT TOOL DESCRIPTIONS
|
||||
----------------------
|
||||
|
||||
TXTEOS1
|
||||
|
||||
print $html <<'HTMLEOS1';
|
||||
<html>
|
||||
<head>
|
||||
<title>xCAT Tool Descriptions</title>
|
||||
</head>
|
||||
<body>
|
||||
<h1 align="center">xCAT Tool Descriptions</h1>
|
||||
HTMLEOS1
|
||||
|
||||
# write the table of contents for the html readme
|
||||
print $html "<ul><li><a href='#Introduction'>Introduction</a>\n";
|
||||
foreach my $tool (@_) {
|
||||
print $html "<li><a href='#$tool'>$tool</a>\n";
|
||||
}
|
||||
print $html "</ul>\n";
|
||||
|
||||
# write the intro
|
||||
print $html "<a id='Introduction'></a><h2>Introduction</h2><p>\n";
|
||||
|
||||
printtoboth $txt, $html, <<'EOS1';
|
||||
This is a list of additional tools that are provided by xCAT. They are located
|
||||
in /opt/xcat/share/xcat/tools/, but should also be in your path. Many of these
|
||||
tools have been contributed by xCAT users that are not part of the core xCAT
|
||||
development team. That means they might not be supported as well as the main
|
||||
xCAT code. Read the help here, take a look at the code, and use at your own
|
||||
risk. If you have problems with a tool, post to the xCAT mailing list and
|
||||
the author will try to help you.
|
||||
EOS1
|
||||
|
||||
print $html "</p>\n";
|
||||
|
||||
}
|
||||
|
||||
|
||||
# write the help for one tool
|
||||
sub writetoolhelp {
|
||||
my $txt = shift; # the file handle to the txt readme file
|
||||
my $html = shift; # the file handle to the html readme file
|
||||
my $toolname = shift; # the script name of the tool
|
||||
my $toolhelp = shift; # the --help output from the tool
|
||||
|
||||
# write the heading for this tool
|
||||
print $txt <<"TXTEOS2";
|
||||
|
||||
|
||||
$toolname
|
||||
--------------------
|
||||
|
||||
TXTEOS2
|
||||
|
||||
print $html <<"HTMLEOS2";
|
||||
<hr>
|
||||
<a id='$toolname'></a>
|
||||
<h2>$toolname</h2>
|
||||
<pre>
|
||||
HTMLEOS2
|
||||
|
||||
# write the actual contents of the tool help
|
||||
printtoboth $txt, $html, $toolhelp;
|
||||
|
||||
# finish up
|
||||
print $html <<"HTMLEOS3";
|
||||
</pre>
|
||||
HTMLEOS3
|
||||
}
|
||||
|
||||
|
||||
sub writeending {
|
||||
my $html = shift;
|
||||
# finish up the html readme
|
||||
print $html <<'HTMLEOS4';
|
||||
</body>
|
||||
</html>
|
||||
HTMLEOS4
|
||||
}
|
@ -6,7 +6,10 @@ Getopt::Long::Configure("bundling");
|
||||
Getopt::Long::Configure("pass_through");
|
||||
|
||||
$::USAGE = "Usage: detect_dhcpd -i interface [-m macaddress] [-t timeout] [-V]
|
||||
This command can be used to detect the dhcp server in a network for a specific mac address.
|
||||
|
||||
This command can be used to detect the dhcp server in a network for a specific mac address.
|
||||
|
||||
Options:
|
||||
-i interface: The interface which facing the target network.
|
||||
-m macaddress: The mac that will be used to detect dhcp server. Recommend to use the real mac of the node that will be netboot. If no specified, the mac of interface which specified by -i will be used.
|
||||
-t timeout: The time to wait to detect the dhcp messages. The default value is 10s.\n";
|
||||
@ -14,11 +17,14 @@ if (!GetOptions(
|
||||
'i=s' => \$::IF,
|
||||
'm=s' => \$::MACADD,
|
||||
't=s' => \$::TIMEOUT,
|
||||
'V|verbose' => \$::VERBOSE,)) {
|
||||
'V|verbose' => \$::VERBOSE,
|
||||
'h|help' => \$::HELP,)) {
|
||||
print $::USAGE;
|
||||
exit 1;
|
||||
}
|
||||
|
||||
if ($::HELP) { print $::USAGE; exit 0; }
|
||||
|
||||
my $nic;
|
||||
if ($::IF) {
|
||||
$nic = $::IF;
|
||||
|
@ -21,7 +21,6 @@ use lib "$::XCATROOT/lib/perl";
|
||||
use strict;
|
||||
use warnings;
|
||||
use Getopt::Long;
|
||||
use xCAT::NetworkUtils;
|
||||
|
||||
if (
|
||||
!GetOptions("h|help" => \$::HELP,
|
||||
@ -38,6 +37,8 @@ if ($::HELP)
|
||||
exit 0;
|
||||
}
|
||||
|
||||
require xCAT::NetworkUtils;
|
||||
|
||||
if ($::MACADDR)
|
||||
{
|
||||
my $linklocal = xCAT::NetworkUtils->linklocaladdr($::MACADDR);
|
||||
@ -46,8 +47,7 @@ if ($::MACADDR)
|
||||
|
||||
sub usage
|
||||
{
|
||||
print "Mac to IPv6 link local address utility.\n";
|
||||
print "Usage:\n";
|
||||
print "\t mac2linklocal -m <mac_address>\n";
|
||||
print "Usage: mac2linklocal -m <mac_address>\n\n";
|
||||
print "Determines the IPv6 link local address that is appropriate for a NIC, based on its MAC.\n";
|
||||
return;
|
||||
}
|
||||
|
@ -33,6 +33,7 @@ my %Options = ('interactive',"yes",'warnings','','log',"yes",'dump',"yes");
|
||||
my @warnings;
|
||||
my $logfile = DEFAULT_LOG_FILE;
|
||||
my $now = localtime;
|
||||
my $help;
|
||||
|
||||
#
|
||||
# print a warning and wait a bit if warnings are enabled
|
||||
@ -136,6 +137,22 @@ sub question {
|
||||
return $reply;
|
||||
}
|
||||
|
||||
sub usage {
|
||||
print "Usage: mktoolscenter\n";
|
||||
print " --ph <proxyhost>\n";
|
||||
print " --pp <proxyport>\n";
|
||||
print " --puser <proxyuser>\n";
|
||||
print " --ppw <proxypassword>\n";
|
||||
print " -l <logfile>\n";
|
||||
print " -s\n";
|
||||
print " --nfsserver <NFS server address>\n";
|
||||
print " --nfspath <NFS server path>\n";
|
||||
print " --profilename <profile name>\n";
|
||||
print " --help\n\n";
|
||||
print "Updates IBM system x server hardware using IBM Bootable Media Creator.\n";
|
||||
}
|
||||
|
||||
|
||||
#
|
||||
# Begin main
|
||||
#
|
||||
@ -147,21 +164,14 @@ unless (GetOptions("s"=>\$surrogate, "l=s"=>\$logfile,
|
||||
"ph=s"=>\$proxy{host}, "pp=i"=>\$proxy{port},
|
||||
"puser=s"=>\$proxy{user}, "ppw=s"=>\$proxy{pw},
|
||||
"nfsserver=s"=>\$nfsserver,"nfspath=s"=>\$nfspath,
|
||||
"profilename=s"=>\$profilename,
|
||||
"profilename=s"=>\$profilename, "help"=>\$help,
|
||||
)) {
|
||||
printf "Usage:\n";
|
||||
printf "--ph <proxyhost>\n";
|
||||
printf "--pp <proxyport>\n";
|
||||
printf "--puser <proxyuser>\n";
|
||||
printf "--ppw <proxypassword>\n";
|
||||
printf "-l <logfile>\n";
|
||||
printf "-s\n";
|
||||
printf "--nfsserver <NFS server address>\n";
|
||||
printf "--nfspath <NFS server path>\n";
|
||||
printf "--profilename <profile name>\n";
|
||||
usage();
|
||||
exit(1);
|
||||
}
|
||||
|
||||
if ($help) { usage(); exit 0; }
|
||||
|
||||
if (@ARGV > 0) {
|
||||
open(IN,"<",@ARGV[0]) || die "Cannot open input file @ARGV[0]";
|
||||
$Options{interactive} = '';
|
||||
|
@ -1,12 +1,8 @@
|
||||
#!/usr/bin/perl
|
||||
use strict;
|
||||
use SNMP;
|
||||
use Socket;
|
||||
use Data::Dumper;
|
||||
use Getopt::Long;
|
||||
$SNMP::debugging = 1;
|
||||
$SNMP::verbose = 1;
|
||||
$SNMP::best_guess = 1;
|
||||
# each 0 is four bits: 0000 0000
|
||||
# thus its broken down:
|
||||
# - ports 1-8 are in the first hex number
|
||||
@ -427,6 +423,7 @@ sub show{
|
||||
# we want to put this port on this new vlan, here is how we do it:
|
||||
# connect to switch to see:
|
||||
|
||||
|
||||
my $help =0;
|
||||
$::DEBUG = 0;
|
||||
GetOptions(
|
||||
@ -438,6 +435,11 @@ if($help){
|
||||
displayHelp(0);
|
||||
}
|
||||
|
||||
require SNMP;
|
||||
$SNMP::debugging = 1;
|
||||
$SNMP::verbose = 1;
|
||||
$SNMP::best_guess = 1;
|
||||
|
||||
if($::DEBUG){
|
||||
print "verbose is set to on!\n";
|
||||
}
|
||||
|
@ -17,7 +17,6 @@ BEGIN
|
||||
}
|
||||
|
||||
use lib "$::XCATROOT/lib/perl";
|
||||
use xCAT::Utils;
|
||||
use Getopt::Long;
|
||||
|
||||
use strict;
|
||||
@ -48,6 +47,9 @@ if ($help) {
|
||||
print "\n";
|
||||
exit 0;
|
||||
}
|
||||
|
||||
require xCAT::Utils;
|
||||
|
||||
# check to see if running DB2
|
||||
my $DBname = xCAT::Utils->get_DBName;
|
||||
if ($DBname ne "DB2") {
|
||||
|
@ -13,10 +13,31 @@ BEGIN
|
||||
}
|
||||
|
||||
use lib "$::XCATROOT/lib/perl";
|
||||
use xCAT::Utils;
|
||||
use xCAT::TableUtils;
|
||||
use strict;
|
||||
use Socket; # for name resolution
|
||||
use Getopt::Long;
|
||||
|
||||
my $help;
|
||||
GetOptions('h|help' => \$help);
|
||||
if ($help) {
|
||||
print <<'EOS';
|
||||
Usage: rmblade [-h|--help]
|
||||
|
||||
Response to SNMP for monsetting to remove blade from xCAT when trap is recieved.
|
||||
Pipe the MM IP address and blade slot number into this cmd.
|
||||
|
||||
Example:
|
||||
1. user removes a blade from the chassis
|
||||
2. snmp trap setup to point here
|
||||
3. this script removes the blade configuration from xCAT
|
||||
4. so if blade is placed in new slot or back in then xCAT goes
|
||||
through rediscover process again.
|
||||
EOS
|
||||
exit 0;
|
||||
}
|
||||
|
||||
require xCAT::Utils;
|
||||
require xCAT::TableUtils;
|
||||
|
||||
my $ip='';
|
||||
my $mm='';
|
||||
@ -30,6 +51,7 @@ open(FILE,">>$log") or die "Can't open log!!!";
|
||||
my $date = `date`;
|
||||
chomp($date);
|
||||
print FILE "==================== $date ============================\n";
|
||||
|
||||
sub rmblade {
|
||||
my $blade = shift;
|
||||
my $hex = ip2hex($blade);
|
||||
@ -55,12 +77,13 @@ sub ip2hex {
|
||||
my $packed_ip = gethostbyname($node);
|
||||
if(defined $packed_ip){
|
||||
$ip = inet_ntoa($packed_ip);
|
||||
print FILE "IP that was removed is $ip\n";
|
||||
print FILE "IP that was removed is $ip\n";
|
||||
@quad = split('\.', $ip);
|
||||
$hex = sprintf("%02X%02X%02X%02X", @quad);
|
||||
}
|
||||
return $hex;
|
||||
}
|
||||
|
||||
foreach (<>){
|
||||
if(/ip=UDP/){
|
||||
$ip = $_;
|
||||
|
@ -10,11 +10,28 @@ BEGIN
|
||||
}
|
||||
|
||||
use lib "$::XCATROOT/lib/perl";
|
||||
use xCAT::Utils;
|
||||
use xCAT::TableUtils;
|
||||
use strict;
|
||||
use Socket;
|
||||
|
||||
use Getopt::Long;
|
||||
|
||||
my $help;
|
||||
GetOptions('h|help' => \$help);
|
||||
if ($help) {
|
||||
print <<'EOS';
|
||||
Usage: rmnodecfg [-h|--help] <noderange>
|
||||
|
||||
Removes the configuration of a node so that the next time you reboot
|
||||
it, it forces it to go through the discovery process.
|
||||
This does not remove it completely from xCAT. You may want to do this
|
||||
command before running noderm to completely purge the system of the node
|
||||
EOS
|
||||
exit 0;
|
||||
}
|
||||
|
||||
require xCAT::Utils;
|
||||
require xCAT::TableUtils;
|
||||
|
||||
my $blades = shift;
|
||||
if(! $blades) {
|
||||
print "Please specify a noderange of blades to remove\n";
|
||||
|
@ -60,6 +60,9 @@ xCAT-server provides the core server and configuration management components of
|
||||
|
||||
%setup -q -n xCAT-server
|
||||
%build
|
||||
# build the tools readme files from the --help output of all of the tools
|
||||
./build-readme
|
||||
|
||||
%install
|
||||
rm -rf $RPM_BUILD_ROOT
|
||||
#cp foo bar
|
||||
|
Loading…
Reference in New Issue
Block a user