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=4a0776289953d3a34f8d7359fe17b04963d004bc;hb=b9baacc29444767f88abdbca93f65c8bd5e5a676;hpb=498c4ad5b1cc2db13c7b581b44ff3f6b9e33eaba diff --git a/lib/Object/Remote/Connector/SSH.pm b/lib/Object/Remote/Connector/SSH.pm index 4a07762..fcfb445 100644 --- a/lib/Object/Remote/Connector/SSH.pm +++ b/lib/Object/Remote/Connector/SSH.pm @@ -10,9 +10,32 @@ has ssh_to => (is => 'ro', required => 1); 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 _build_ssh_perl_command { my ($self) = @_; - return [ 'ssh', '-A', $self->ssh_to, @{$self->perl_command} ]; + 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 } @@ -23,7 +46,8 @@ 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\-\.]/) { - return __PACKAGE__->new(ssh_to => $_[0]); + my $host = shift(@_); + return __PACKAGE__->new(@_, ssh_to => $host); } } return;