Path: blob/master/DDOS Scripts/AMP YUBINA SCRIPTS/chargen_scanner_source.c
4607 views
/* priv8 chargen scanner. lel */12#include <pthread.h>3#include <unistd.h>4#include <stdio.h>5#include <stdlib.h>6#include <string.h>7#include <sys/socket.h>8#include <netinet/in.h>9#include <signal.h>10#include <sys/time.h>11#include <sys/types.h>12#include <math.h>13#include <ctype.h>14#include <errno.h>15#include <arpa/inet.h>16#include <netinet/ip.h>17#include <netinet/udp.h>1819volatile int running_threads = 0;20volatile int found_srvs = 0;21volatile unsigned long per_thread = 0;22volatile unsigned long start = 0;23volatile unsigned long scanned = 0;24volatile int sleep_between = 0;25volatile int bytes_sent = 0;26volatile unsigned long hosts_done = 0;27FILE *fd;2829void *flood(void *par1)30{31running_threads++;32int thread_id = (int)par1;33unsigned long start_ip = htonl(ntohl(start)+(per_thread*thread_id));34unsigned long end = htonl(ntohl(start)+(per_thread*(thread_id+1)));35unsigned long w;36int y;37unsigned char buf[65536];38memset(buf, 0x01, 1);39int sizeofpayload = 1;40int sock;41if((sock=socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP))<0) {42perror("cant open socket");43exit(-1);44}45for(w=ntohl(start_ip);w<htonl(end);w++)46{47struct sockaddr_in servaddr;48bzero(&servaddr, sizeof(servaddr));49servaddr.sin_family = AF_INET;50servaddr.sin_addr.s_addr=htonl(w);51servaddr.sin_port=htons(19);52sendto(sock,(char *)buf,sizeofpayload,0, (struct sockaddr *)&servaddr,sizeof(servaddr));53bytes_sent+=sizeofpayload;54scanned++;55hosts_done++;56}57close(sock);58running_threads--;59return;60}6162void sighandler(int sig)63{64fclose(fd);65printf("\n");66exit(0);67}6869void *recievethread()70{71printf("Started Listening Thread\n");72int saddr_size, data_size, sock_raw;73struct sockaddr_in saddr;74struct in_addr in;7576unsigned char *buffer = (unsigned char *)malloc(65536);77sock_raw = socket(AF_INET , SOCK_RAW , IPPROTO_UDP);78if(sock_raw < 0)79{80printf("Socket Error\n");81exit(1);82}83while(1)84{85saddr_size = sizeof saddr;86data_size = recvfrom(sock_raw , buffer , 65536 , 0 , (struct sockaddr *)&saddr , &saddr_size);87if(data_size <0 )88{89printf("Recvfrom error , failed to get packets\n");90exit(1);91}92struct iphdr *iph = (struct iphdr*)buffer;93if(iph->protocol == 17)94{95unsigned short iphdrlen = iph->ihl*4;96struct udphdr *udph = (struct udphdr*)(buffer + iphdrlen);97unsigned char* payload = buffer + iphdrlen + 1;98if(ntohs(udph->source) == 19)99{100int body_length = data_size - iphdrlen - 1;101found_srvs++;102fprintf(fd,"%s %d\n",inet_ntoa(saddr.sin_addr),body_length);103fflush(fd);104105}106}107108}109close(sock_raw);110111}112113int main(int argc, char *argv[ ])114{115116if(argc < 6){117fprintf(stderr, "Invalid parameters!\n");118fprintf(stdout, "Usage: %s <ip range start (192.168.0.0)> <ip range end (192.168.255.255)> <outfile> <threads> <scan delay in ms>\n", argv[0]);119exit(-1);120}121fd = fopen(argv[3], "a");122sleep_between = atoi(argv[5]);123124signal(SIGINT, &sighandler);125126int threads = atoi(argv[4]);127pthread_t thread;128129pthread_t listenthread;130pthread_create( &listenthread, NULL, &recievethread, NULL);131132char *str_start = malloc(18);133memset(str_start, 0, 18);134str_start = argv[1];135char *str_end = malloc(18);136memset(str_end, 0, 18);137str_end = argv[2];138start = inet_addr(str_start);139per_thread = (ntohl(inet_addr(str_end)) - ntohl(inet_addr(str_start))) / threads;140unsigned long toscan = (ntohl(inet_addr(str_end)) - ntohl(inet_addr(str_start)));141int i;142for(i = 0;i<threads;i++){143pthread_create( &thread, NULL, &flood, (void *) i);144}145sleep(1);146printf("Starting Scan...\n");147char *temp = (char *)malloc(17);148memset(temp, 0, 17);149sprintf(temp, "Found");150printf("%-16s", temp);151memset(temp, 0, 17);152sprintf(temp, "Host/s");153printf("%-16s", temp);154memset(temp, 0, 17);155sprintf(temp, "B/s");156printf("%-16s", temp);157memset(temp, 0, 17);158sprintf(temp, "Running Thrds");159printf("%-16s", temp);160memset(temp, 0, 17);161sprintf(temp, "Done");162printf("%s", temp);163printf("\n");164165char *new;166new = (char *)malloc(16*6);167while (running_threads > 0)168{169printf("\r");170memset(new, '\0', 16*6);171sprintf(new, "%s|%-15lu", new, found_srvs);172sprintf(new, "%s|%-15d", new, scanned);173sprintf(new, "%s|%-15d", new, bytes_sent);174sprintf(new, "%s|%-15d", new, running_threads);175memset(temp, 0, 17);176int percent_done=((double)(hosts_done)/(double)(toscan))*100;177sprintf(temp, "%d%%", percent_done);178sprintf(new, "%s|%s", new, temp);179printf("%s", new);180fflush(stdout);181bytes_sent=0;182scanned = 0;183sleep(1);184}185printf("\n");186fclose(fd);187return 0;188}189190