BEGIN {
unshift our @Guess, sub { blessed($_[0]) ? $_[0] : undef };
eval { require Object::Remote::Connector::Local };
+ eval { require Object::Remote::Connector::LocalSudo };
eval { require Object::Remote::Connector::SSH };
}
package Object::Remote::Connector::Local;
-use IPC::Open2;
use Moo;
-with 'Object::Remote::Role::Connector';
-
-sub _open2_for {
- my $open_this = (
- -d 't' && -e 'bin/object-remote-node'
- ? 'bin/object-remote-node'
- : 'object-remote-node'
- );
- my $pid = open2(my $its_stdout, my $its_stdin, 'bin/object-remote-node')
- or die "Couldn't start local node: $!";
- return ($its_stdin, $its_stdout, $pid);
-}
+with 'Object::Remote::Role::Connector::PerlInterpreter';
push @Object::Remote::Connection::Guess, sub {
if (($_[0]||'') eq '-') { __PACKAGE__->new->connect }
--- /dev/null
+package Object::Remote::Connector::LocalSudo;
+
+use Moo;
+
+extends 'Object::Remote::Connector::Local';
+
+around _perl_command => sub {
+ my ($orig, $self, $target_user) = @_;
+ return 'sudo', '-u', $target_user, $self->$orig($target_user);
+};
+
+push @Object::Remote::Connection::Guess, sub {
+ for ($_[0]) {
+ # username followed by @
+ if (defined and !ref and /^ ([^\@]*?) \@ $/x) {
+ return __PACKAGE__->new->connect($1);
+ }
+ }
+ return;
+};
+
+1;
package Object::Remote::Connector::SSH;
-use Object::Remote::FatNode;
use Object::Remote::ModuleSender;
use Object::Remote::Handle;
-use IPC::Open2;
use Moo;
-with 'Object::Remote::Role::Connector';
+with 'Object::Remote::Role::Connector::PerlInterpreter';
-sub _open2_for {
- my $self = shift;
- my $pid = open2(my $ssh_stdout, my $ssh_stdin, 'ssh', $_[0], 'perl', '-')
- or die "Failed to start ssh connection: $!";;
- print $ssh_stdin $Object::Remote::FatNode::DATA, "__END__\n";
- return ($ssh_stdin, $ssh_stdout, $pid);
-}
-
-around connect => sub {
- my ($orig, $self) = (shift, shift);
- my $conn = $self->$orig(@_);
- Object::Remote::Handle->new(
- connection => $conn,
- class => 'Object::Remote::ModuleLoader',
- args => { module_sender => Object::Remote::ModuleSender->new }
- )->disarm_free;
- return $conn;
+around _perl_command => sub {
+ my ($orig, $self, $target) = @_;
+ return 'ssh', $target, $self->$orig($target);
};
sub _ssh_object_for {
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\-\.]*/) {
+ if (defined and !ref and /^(?:.*?\@)?[\w\-][\w\-\.]/) {
return __PACKAGE__->new->connect($_[0]);
}
}
--- /dev/null
+package Object::Remote::Role::Connector::PerlInterpreter;
+
+use IPC::Open2;
+use Object::Remote::ModuleSender;
+use Object::Remote::Handle;
+use Object::Remote::FatNode;
+use Moo::Role;
+
+with 'Object::Remote::Role::Connector';
+
+around connect => sub {
+ my ($orig, $self) = (shift, shift);
+ my $conn = $self->$orig(@_);
+ Object::Remote::Handle->new(
+ connection => $conn,
+ class => 'Object::Remote::ModuleLoader',
+ args => { module_sender => Object::Remote::ModuleSender->new }
+ )->disarm_free;
+ return $conn;
+};
+
+sub _perl_command { 'perl', '-' }
+
+sub _open2_for {
+ my $self = shift;
+ my $pid = open2(
+ my $foreign_stdout,
+ my $foreign_stdin,
+ $self->_perl_command(@_),
+ ) or die "Failed to run perl at '$_[0]': $!";
+ print $foreign_stdin $Object::Remote::FatNode::DATA, "__END__\n";
+ return ($foreign_stdin, $foreign_stdout, $pid);
+}
+
+1;