X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=scpubgit%2FObject-Remote.git;a=blobdiff_plain;f=lib%2FObject%2FRemote%2FConnector%2FSSH.pm;h=fcfb445905e710bfc2a01e063f7810c9414e6c3d;hp=c9193d0d3512669b35c7b1bc4861b3ba7d28128f;hb=b9baacc29444767f88abdbca93f65c8bd5e5a676;hpb=47c83a1379a33fc8baa4a128edc1d75d780776b0 diff --git a/lib/Object/Remote/Connector/SSH.pm b/lib/Object/Remote/Connector/SSH.pm index c9193d0..fcfb445 100644 --- a/lib/Object/Remote/Connector/SSH.pm +++ b/lib/Object/Remote/Connector/SSH.pm @@ -1,23 +1,56 @@ package Object::Remote::Connector::SSH; -use Object::Remote::FatNode; -use Net::OpenSSH; +use Object::Remote::ModuleSender; +use Object::Remote::Handle; use Moo; -with 'Object::Remote::Role::Connector'; +with 'Object::Remote::Role::Connector::PerlInterpreter'; -has ssh_masters => (is => 'ro', default => sub { {} }); +has ssh_to => (is => 'ro', required => 1); -sub _open2_for { - my $self = shift; - my @res = $self->_ssh_object_for(@_)->open2('perl','-',@_); - print { $res[0] } $Object::Remote::FatNode::DATA, "__END__\n"; - return @res; +has ssh_perl_command => (is => 'lazy'); + +has ssh_options => (is => 'ro', default => sub { [ '-A' ] }); + +has ssh_command => (is => 'ro', default => sub { 'ssh' }); + +#TODO properly integrate if this works +BEGIN { $ENV{TERM} = 'dumb'; } + +sub _escape_shell_arg { + my ($self, $str) = (@_); + $str =~ s/((?:^|[^\\])(?:\\\\)*)'/$1\\'/g; + return "$str"; } -sub _ssh_object_for { - my ($self, $on) = @_; - $self->ssh_masters->{$on} ||= Net::OpenSSH->new($on); + +sub _build_ssh_perl_command { + my ($self) = @_; + my $perl_command = join('', @{$self->perl_command}); + + #TODO non-trivial to escape properly for ssh and shell + #this "works" but is not right, needs to be replaced + #after testing + return [ + do { my $c = $self->ssh_command; ref($c) ? @$c : $c }, + @{$self->ssh_options}, $self->ssh_to, + $self->_escape_shell_arg($perl_command), + ]; } +sub final_perl_command { shift->ssh_perl_command } + +no warnings 'once'; + +push @Object::Remote::Connection::Guess, sub { + for ($_[0]) { + # 0-9 a-z _ - first char, those or . subsequent - hostnamish + if (defined and !ref and /^(?:.*?\@)?[\w\-][\w\-\.]/) { + my $host = shift(@_); + return __PACKAGE__->new(@_, ssh_to => $host); + } + } + return; +}; + 1;