mirror of
				https://github.com/xcat2/xcat-core.git
				synced 2025-11-04 13:22:36 +00:00 
			
		
		
		
	- clear logs in the key components during provisioning (not only debug mode, but debug mode will have more logs) - now only cover rhel7 stateful and stateless - make more syslogs into cluster.log (tag = xcat or xcat.*) - the changes will not impact other distro
		
			
				
	
	
		
			111 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
			
		
		
	
	
			111 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Perl
		
	
	
	
	
	
# IBM(c) 2007 EPL license http://www.eclipse.org/legal/epl-v10.html
 | 
						|
#-------------------------------------------------------
 | 
						|
 | 
						|
=head1
 | 
						|
  xCAT plugin package to handle getpostscript command
 | 
						|
 | 
						|
=cut
 | 
						|
 | 
						|
#-------------------------------------------------------
 | 
						|
package xCAT_plugin::getpostscript;
 | 
						|
use xCAT::Utils;
 | 
						|
use xCAT::MsgUtils;
 | 
						|
use xCAT::NodeRange;
 | 
						|
1;
 | 
						|
 | 
						|
#-------------------------------------------------------
 | 
						|
 | 
						|
=head3  handled_commands
 | 
						|
 | 
						|
Return list of commands handled by this plugin
 | 
						|
 | 
						|
=cut
 | 
						|
 | 
						|
#-------------------------------------------------------
 | 
						|
 | 
						|
sub handled_commands
 | 
						|
{
 | 
						|
    return {
 | 
						|
        'getpostscript' => "getpostscript",
 | 
						|
    };
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
#-------------------------------------------------------
 | 
						|
 | 
						|
=head3  process_request
 | 
						|
 | 
						|
  Process the command
 | 
						|
 | 
						|
=cut
 | 
						|
 | 
						|
#-------------------------------------------------------
 | 
						|
sub process_request
 | 
						|
{
 | 
						|
    my $request  = shift;
 | 
						|
    my $callback = shift;
 | 
						|
    my $nodes    = $request->{node};
 | 
						|
    my $command  = $request->{command}->[0];
 | 
						|
    my $args     = $request->{arg};
 | 
						|
    my $envs     = $request->{env};
 | 
						|
    my $rsp;
 | 
						|
    my $i     = 1;
 | 
						|
    my @nodes = @$nodes;
 | 
						|
 | 
						|
    # do your processing here
 | 
						|
    # return info
 | 
						|
 | 
						|
 | 
						|
    my $client;
 | 
						|
    if ($::XCATSITEVALS{nodeauthentication}) { #if requiring node authentication, this request will have a certificate associated with it, use it instead of name resolution
 | 
						|
        unless (ref $request->{username}) { return; } #TODO: log an attempt without credentials?
 | 
						|
        $client = $request->{username}->[0];
 | 
						|
    } else {
 | 
						|
        unless ($request->{'_xcat_clienthost'}->[0]) {
 | 
						|
 | 
						|
            #ERROR? malformed request
 | 
						|
            xCAT::MsgUtils->trace(0, 'E', "Received malformed getpostscript requesting, ignore it.");
 | 
						|
            return;
 | 
						|
        }
 | 
						|
        $client = $request->{'_xcat_clienthost'}->[0];
 | 
						|
    }
 | 
						|
 | 
						|
    my $origclient = $client;
 | 
						|
    if ($client) { ($client) = noderange($client) }
 | 
						|
    unless ($client) {    #Not able to do identify the host in question
 | 
						|
        xCAT::MsgUtils->trace(0, "E", "Received getpostscript from $origclient, which couldn't be correlated to a node (domain mismatch?)");
 | 
						|
        return;
 | 
						|
    }
 | 
						|
    my $state;
 | 
						|
    if ($request->{scripttype}) { $state = $request->{scripttype}->[0]; }
 | 
						|
 | 
						|
    require xCAT::Postage;
 | 
						|
    my $args = $request->{arg};
 | 
						|
    my @scriptcontents;
 | 
						|
    my $version = 0;
 | 
						|
    if (defined($args) && grep(/version2/, @$args)) {
 | 
						|
        $version = 2
 | 
						|
    }
 | 
						|
    my $notmpfiles;
 | 
						|
    my $nofiles;
 | 
						|
 | 
						|
    # If not version=2, then we return the mypostscript file in an array.
 | 
						|
    if ($version != 2) {
 | 
						|
        $notmpfiles = 1;    # no tmp files and no files
 | 
						|
        $nofiles = 1; # do not create /tftpboot/mypostscript/mypostscript.<nodename>
 | 
						|
        @scriptcontents = xCAT::Postage::makescript([$client], $state, $callback, $notmpfiles, $nofiles);
 | 
						|
        xCAT::MsgUtils->trace(0, "I", "getpostscript: Sending scripts data to $client...");
 | 
						|
        $rsp->{data} = \@scriptcontents;
 | 
						|
        $callback->($rsp);
 | 
						|
    } else {          # version 2, make files, do not return array
 | 
						|
        #  make the mypostscript.<nodename> file
 | 
						|
        # or the mypostscript.<nodename>.tmp file if precreatemypostscripts=0
 | 
						|
        # xcatdsklspost will wget the file
 | 
						|
        $notmpfiles = 0;
 | 
						|
        $nofiles    = 0;
 | 
						|
        xCAT::Postage::makescript([$client], $state, $callback, $notmpfiles, $nofiles);
 | 
						|
    }
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 |