From 30ecd6c0dab9b504e0ec27109f963c5959c27f07 Mon Sep 17 00:00:00 2001 From: immarvin Date: Fri, 8 Jun 2012 03:00:27 +0000 Subject: [PATCH] copycds enhancement: add --inspection option and -p option git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@13033 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd --- xCAT-server/lib/xcat/plugins/copycds.pm | 58 +++++++++++++++++++------ 1 file changed, 44 insertions(+), 14 deletions(-) diff --git a/xCAT-server/lib/xcat/plugins/copycds.pm b/xCAT-server/lib/xcat/plugins/copycds.pm index c9ab517b5..5beabb975 100644 --- a/xCAT-server/lib/xcat/plugins/copycds.pm +++ b/xCAT-server/lib/xcat/plugins/copycds.pm @@ -37,6 +37,9 @@ sub process_request { my $distname = undef; my $arch = undef; my $help = undef; + my $inspection=undef; + my $path=undef; + $identified=0; $::CDMOUNTPATH="/mnt/xcat"; my $existdir = getcwd; @@ -47,22 +50,26 @@ sub process_request { GetOptions( 'n|name|osver=s' => \$distname, 'a|arch=s' => \$arch, - 'h|help' => \$help - ); + 'h|help' => \$help, + 'i|inspection' => \$inspection, + 'p|path=s' => \$path + ); if ($help) { - $callback->({info=>"copycds [{-n|--name|--osver}=distroname] [{-a|--arch}=architecture] 1st.iso [2nd.iso ...]."}); - return; + $callback->({info=>"copycds [{-p|--path}=path] [{-n|--name|--osver}=distroname] [{-a|--arch}=architecture] [-i|--inspection] 1st.iso [2nd.iso ...]."}); + return; } if ($arch and $arch =~ /i.86/) { $arch = 'x86'; } my @args = @ARGV; #copy ARGV unless ($#args >= 0) { - $callback->({error=>"copycds needs at least one full path to ISO currently."}); - return; + $callback->({error=>"copycds needs at least one full path to ISO currently.",errorcode=>[1]}); + return; } my $file; foreach (@args) { + $identified=0; + unless (/^\//) { #If not an absolute path, concatenate with client specified cwd s/^/$request->{cwd}->[0]\//; } @@ -86,25 +93,48 @@ sub process_request { elsif (-r $file and -f $file) # Assume ISO file { $mntopts .= " -o ro,loop"; } else { - $callback->({error=>"The management server was unable to find/read $file. Ensure that file exists on the server at the specified location."}); - return; + $callback->({error=>"The management server was unable to find/read $file. Ensure that file exists on the server at the specified location.",errorcode=>[1]}); + return; } mkdir "/mnt/xcat"; if (system("mount $mntopts $file /mnt/xcat")) { - $callback->({error=>"copycds was unable to mount $file to /mnt/xcat."}); - return; + $callback->({error=>"copycds was unable to mount $file to /mnt/xcat.",errorcode=>[1]}); + return; } my $newreq = dclone($request); $newreq->{command}= [ 'copycd' ]; #Note the singular, it's different - $newreq->{arg} = ["-p","/mnt/xcat"]; + $newreq->{arg} = ["-m","/mnt/xcat"]; + + if($path) + { + push @{$newreq->{arg}},("-p",$path); + } + + if($inspection) + { + push @{$newreq->{arg}},("-i"); + $callback->({info=>"OS Image:".$_}); + } + if ($distname) { - push @{$newreq->{arg}},("-n",$distname); - } + if($inspection){ + $callback->({warning=>"copycds: option --inspection specified, argument specified with option --name is ignored"}); + } + else{ + push @{$newreq->{arg}},("-n",$distname); + } + } if ($arch) { + if($inspection){ + $callback->({warning=>"copycds: option --inspection specified, argument specified with option --arch is ignored"}); + } + else{ push @{$newreq->{arg}},("-a",$arch); - } + } + } + $doreq->($newreq,\&take_answer); $::CDMOUNTPATH="";