Merge branch 'master' of ssh://git.code.sf.net/p/xcat/xcat-core
This commit is contained in:
		| @@ -327,7 +327,7 @@ sub preprocess_updatenode | ||||
|         return; | ||||
|     }  | ||||
|  | ||||
|     # --security cannot work with -S -P -F | ||||
|     # --security cannot work with -S -P -F -f | ||||
|     if ($::SECURITY | ||||
|         && ($::SWMAINTENANCE || $::RERUNPS || defined($::RERUNPS) || $::FILESYNC || $::SNFILESYNC)) | ||||
|     { | ||||
| @@ -535,10 +535,8 @@ sub preprocess_updatenode | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     # If -F or -f  option specified, sync files to the noderange or their | ||||
|     # If -F or -f  option specified, sync files to the noderange and their | ||||
|     # service nodes. | ||||
|     # Note: This action only happens on MN, since xdcp, xdsh handles the | ||||
|     #	hierarchy | ||||
|     if ($::FILESYNC) | ||||
|     { | ||||
|         $request->{FileSyncing}->[0] = "yes"; | ||||
| @@ -598,7 +596,8 @@ sub preprocess_updatenode | ||||
|     if ($::ERROR_RC) | ||||
|     { | ||||
|         my $rsp; | ||||
|         push @{$rsp->{data}}, "Could not get list of xCAT service nodes."; | ||||
|         $rsp->{data}->[0] = | ||||
|          "Could not get list of xCAT service nodes"; | ||||
|         xCAT::MsgUtils->message("E", $rsp, $callback); | ||||
|         return; | ||||
|  | ||||
| @@ -626,13 +625,21 @@ sub preprocess_updatenode | ||||
|          } | ||||
|        } | ||||
|     } | ||||
|  | ||||
|     #  if -f or -F in the request then just build an updatenode -f/-F request and run it now | ||||
|     # note -f cannot be combined with any other flags | ||||
|     # -F can only be combined with -S and/or -P | ||||
|     # check if no servicenodes for noderange and using the -f flag | ||||
|     if ($::SNFILESYNC) { | ||||
|       if (!(scalar(@sns))) { | ||||
|         my $rsp; | ||||
|         $rsp->{data}->[0] = | ||||
|          "There are no servicenodes to process for the noderange in the updatenode -f command."; | ||||
|         xCAT::MsgUtils->message("E", $rsp, $callback); | ||||
|         return; | ||||
|       } | ||||
|     } | ||||
|     # process the -F or -f flags  | ||||
|     if (($::FILESYNC) || ($::SNFILESYNC)) | ||||
|     { | ||||
|        # If it is only -F or -f  which are always run on the MN, then run it now and you are | ||||
|        # If it is only -F or -f  in the command, which are always run on the MN,  | ||||
|        # then run it now and you are | ||||
|        # finished. | ||||
|        if ((!defined($::SWMAINTENANCE))  && (!defined($::RERUNPS))) { | ||||
|         $request->{_xcatpreprocessed}->[0] = 1; | ||||
| @@ -640,7 +647,7 @@ sub preprocess_updatenode | ||||
|         return; | ||||
|        } else {   | ||||
|          if (@sns)  {  # if servicenodes | ||||
|            # We have a command with -F and -S and/or -P | ||||
|            # We have a command with -F and -S and/or -P  | ||||
|            # if hierarchical we need to run -f now from the managment node  | ||||
|            # to sync the service nodes | ||||
|            my $reqcopy ; | ||||
| @@ -1560,9 +1567,16 @@ sub updatenodesyncfiles | ||||
|            &buildnodestatus(\@$output,$callback); | ||||
| 	     } | ||||
|    	 | ||||
|        my $rsp = {}; | ||||
|        $rsp->{data}->[0] = "File synchronization has completed."; | ||||
|        $callback->($rsp); | ||||
|        if ($request->{SNFileSyncing}->[0] eq "yes") {  | ||||
|           my $rsp = {}; | ||||
|           $rsp->{data}->[0] = "File synchronization has completed for service nodes."; | ||||
|           $callback->($rsp); | ||||
|        } | ||||
|        if ($request->{FileSyncing}->[0] eq "yes") {  | ||||
|           my $rsp = {}; | ||||
|           $rsp->{data}->[0] = "File synchronization has completed for nodes."; | ||||
|           $callback->($rsp); | ||||
|        } | ||||
|     } | ||||
|     else | ||||
|     {    # no syncfiles defined | ||||
|   | ||||
| @@ -525,7 +525,6 @@ sub process_servicenodes_xdcp | ||||
|     my $synfiledir = shift; | ||||
|     my @snodes     = @$sn; | ||||
|     my @snoderange = @$snrange; | ||||
|     my $args; | ||||
|     $::RUNCMD_RC = 0; | ||||
|     my $cmd = $req->{command}->[0]; | ||||
|  | ||||
| @@ -572,10 +571,15 @@ sub process_servicenodes_xdcp | ||||
|         $addreq->{'_xcatdest'}  = $::mnname; | ||||
|         $addreq->{node}         = \@sn; | ||||
|         $addreq->{noderange}    = \@sn; | ||||
|         $addreq->{arg}->[0]     = "-v"; | ||||
|         $addreq->{arg}->[1]     = "-s"; | ||||
|         $addreq->{arg}->[2]     = "-F"; | ||||
|         $addreq->{arg}->[3]     = $::syncsnfile; | ||||
|         # check input request for --nodestatus | ||||
|         my $args=$req->{arg};   # argument | ||||
|         if (grep(/^--nodestatus$/, @$args)) { | ||||
|           push (@{$addreq->{arg}},"--nodestatus"); # return nodestatus | ||||
|         } | ||||
|          push (@{$addreq->{arg}},"-v");  | ||||
|          push (@{$addreq->{arg}},"-s");  | ||||
|          push (@{$addreq->{arg}},"-F");  | ||||
|          push (@{$addreq->{arg}},$::syncsnfile);  | ||||
|         $addreq->{command}->[0] = $cmd; | ||||
|         $addreq->{cwd}->[0]     = $req->{cwd}->[0]; | ||||
|         $addreq->{env}          = $req->{env}; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user