1
0
Fork 0
mirror of https://github.com/perlbot/perlbuut synced 2025-06-07 17:25:41 -04:00

Add basic evallall

This commit is contained in:
Ryan Voots 2017-04-04 17:01:49 -04:00
parent 5f7d37b8f0
commit f3c423afea

View file

@ -11,7 +11,7 @@ use strict;
no warnings 'void'; no warnings 'void';
my @versions = ('', qw(4 5.5 5.6 5.8 5.10 5.12 5.14 5.16 5.18 5.20 5.22 5.24)); my @versions = ('', qw(4 5.5 5.6 5.8 5.10 5.12 5.14 5.16 5.18 5.20 5.22 5.24 all));
sub new { sub new {
my( $class ) = @_; my( $class ) = @_;
@ -34,9 +34,8 @@ sub command {
my( $self, $said, $pm ) = @_; my( $self, $said, $pm ) = @_;
my $code = $said->{"body"}; my $code = $said->{"body"};
my $dbh = $self->{dbh};
my $command = $said->{command_match}; my $command = $said->{command_match};
my $type = $said->{command_match}; my $type = $said->{command_match};
$type =~ s/^\s*(\w+?)?eval(.*)?/$1$2/; $type =~ s/^\s*(\w+?)?eval(.*)?/$1$2/;
warn "Initial type: $type\n"; warn "Initial type: $type\n";
@ -55,11 +54,11 @@ sub command {
'python' => 'python', 'python' => 'python',
'lua' => 'lua', 'lua' => 'lua',
'j' => 'j', 'j' => 'j',
'w' => 'perl', 'w' => 'perl',
's' => 'perl', 's' => 'perl',
'ws' => 'perl', 'ws' => 'perl',
'sw' => 'perl', 'sw' => 'perl',
map {($_=>"perl$_", "w$_"=>"perl$_", "s$_" => "perl$_", "ws$_"=>"perl$_", "sw$_"=>"perl$_")} @versions map {($_=>"perl$_", "w$_"=>"perl$_", "s$_" => "perl$_", "ws$_"=>"perl$_", "sw$_"=>"perl$_")} @versions
); );
my $orig_type = $type; my $orig_type = $type;
@ -67,15 +66,53 @@ sub command {
if( not $type ) { $type = 'perl'; } if( not $type ) { $type = 'perl'; }
warn "Found $type: $code"; warn "Found $type: $code";
if ($command =~ /([ws]+)?eval/i) { if ($command =~ /([ws]+)?eval/i) {
my $c=$1; my $c=$1;
$code = "use warnings; ".$code if ($c =~ /w/); $code = "use warnings; ".$code if ($c =~ /w/);
$code = "use strict; ".$code if ($c =~ /s/); $code = "use strict; ".$code if ($c =~ /s/);
}
$code =~ s/␤/\n/g;
my $resultstr='';
unless ($type =~ /perlall/) {
$resultstr = $self->do_eval($type, $code);
} else {
my @outs;
# TODO use channel config for this
if ($said->{channel} eq '#perlbot' || $said->{channel} eq '*irc_msg') {
for my $version (@versions) {
my $torun = $version eq '' ? 'blead' : $version;
next if $version eq 'all';
next if $version eq '4';
push @outs, "[[$torun]]", $self->do_eval('perl'.$version, $code);
}
$resultstr = join " ", @outs;
} else {
$resultstr = "evalall only works in /msg or in #perlbot";
} }
}
$code =~ s/␤/\n/g; if (!$said->{captured} && $resultstr !~ /\S/) {
$resultstr = "No output.";
}
if ($type eq 'perl') {
$self->{dbh}->do("INSERT INTO evals (input, output) VALUES (?, ?)", {}, $code, $resultstr);
}
my $filter = POE::Filter::Reference->new();
return( 'handled', $resultstr);
}
sub do_eval {
my ($self, $type, $code) = @_;
my $filter = POE::Filter::Reference->new();
my $socket = IO::Socket::INET->new( PeerAddr => 'localhost', PeerPort => '14400' ) my $socket = IO::Socket::INET->new( PeerAddr => 'localhost', PeerPort => '14400' )
or die "error: cannot connect to eval server"; or die "error: cannot connect to eval server";
my $refs = $filter->put( [ { code => "$type $code" } ] ); my $refs = $filter->put( [ { code => "$type $code" } ] );
@ -89,25 +126,17 @@ sub command {
my $result = $filter->get( [ $output ] ); my $result = $filter->get( [ $output ] );
my $resultstr = $result->[0]->[0]; my $resultstr = $result->[0]->[0];
if ($type eq 'perl') {
$dbh->do("INSERT INTO evals (input, output) VALUES (?, ?)", {}, $code, $resultstr);
}
if (!$said->{captured} && $resultstr !~ /\S/) {
$resultstr = "No output.";
}
$resultstr =~ s/\x0a?\x0d//g; # Prevent sending messages to the IRC server.. $resultstr =~ s/\x0a?\x0d//g; # Prevent sending messages to the IRC server..
$resultstr = decode("utf8", $resultstr); $resultstr = decode("utf8", $resultstr);
$resultstr =~ s/\0//g; $resultstr =~ s/\0//g;
chomp $resultstr; chomp $resultstr;
if (lc $resultstr eq "hello world" || lc $resultstr eq "hello, world!" ) { if (lc $resultstr eq "hello world" || lc $resultstr eq "hello, world!" ) {
$resultstr .= " I'm back!" $resultstr .= " I'm back!"
} }
return( 'handled', $resultstr); return $resultstr;
} }
"Bot::BB3::Plugin::Eval"; "Bot::BB3::Plugin::Eval";