2012-04-02 13:41:37 +00:00
|
|
|
package xCAT::SSHInteract;
|
2012-03-29 20:10:50 +00:00
|
|
|
use Exporter;
|
|
|
|
use Net::Telnet;
|
|
|
|
use strict;
|
|
|
|
our @ISA = qw/Exporter Net::Telnet/;
|
|
|
|
our @EXPORT_OK = ();
|
|
|
|
use IO::Pty;
|
|
|
|
use POSIX;
|
|
|
|
|
|
|
|
sub _startssh {
|
2012-04-02 19:27:34 +00:00
|
|
|
my $self = shift;
|
2012-03-29 20:10:50 +00:00
|
|
|
my $pty = shift;
|
|
|
|
my $name = shift;
|
|
|
|
my $dest = shift;
|
2012-04-02 19:27:34 +00:00
|
|
|
my %args=@_;
|
2012-03-29 20:10:50 +00:00
|
|
|
my $tty;
|
|
|
|
my $tty_fd;
|
|
|
|
my $pid = fork();
|
|
|
|
if ($pid) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
#in child
|
|
|
|
$tty = $pty->slave or die "$!";
|
|
|
|
$tty_fd = $tty->fileno or die "$!";
|
|
|
|
close($pty);
|
|
|
|
open STDIN, "<&", $tty_fd;
|
|
|
|
open STDOUT,">&",$tty_fd;
|
|
|
|
$pty->make_slave_controlling_terminal();
|
|
|
|
close($tty);
|
2012-04-02 19:27:34 +00:00
|
|
|
my @cmd = ("ssh","-o","StrictHostKeyChecking=no");
|
|
|
|
if ($args{"-nokeycheck"}) {
|
|
|
|
push @cmd,("-o","UserKnownHostsFile=/dev/null");
|
|
|
|
}
|
|
|
|
push @cmd,("-l",$name,$dest);
|
|
|
|
exec @cmd;
|
2012-03-29 20:10:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
sub new {
|
|
|
|
my $class = shift;
|
|
|
|
my %args = @_;
|
|
|
|
my $pty = IO::Pty->new or die "Unable to perform ssh: $!";
|
|
|
|
$args{"-fhopen"} = $pty;
|
|
|
|
$args{"-telnetmode"} = 0;
|
|
|
|
$args{"-telnetmode"} = 0;
|
|
|
|
$args{"-cmd_remove_mode"} = 1;
|
|
|
|
my $username = $args{"-username"};
|
|
|
|
my $host = $args{"-host"};
|
|
|
|
my $password = $args{"-password"};
|
|
|
|
delete $args{"-host"};
|
|
|
|
delete $args{"-username"};
|
|
|
|
delete $args{"-password"};
|
2012-04-02 19:27:34 +00:00
|
|
|
my $nokeycheck = $args{"-nokeycheck"};
|
|
|
|
if ($nokeycheck) { delete $args{"-nokeycheck"}; }
|
2012-03-29 20:10:50 +00:00
|
|
|
my $self = Net::Telnet->new(%args);
|
2012-04-02 19:27:34 +00:00
|
|
|
_startssh($self,$pty,$username,$host,"-nokeycheck"=>$nokeycheck);
|
2012-03-29 20:10:50 +00:00
|
|
|
$self->waitfor("-match" => '/password:/i', -errmode => "return") or die "Unable to reach host ",$self->lastline;
|
|
|
|
$self->print($password);
|
|
|
|
my $nextline = $self->getline();
|
|
|
|
if ($nextline =~ /^password:/ or $nextline =~ /Permission denieid, please try again/) {
|
|
|
|
die "Incorrect Password";
|
|
|
|
}
|
|
|
|
return bless($self,$class);
|
|
|
|
}
|
|
|
|
1;
|