# # This script was written by David Maciejak # # Ref: Oliver Karow # # This script is released under the GNU GPL v2 if(description) { script_id(17972); script_cve_id("CVE-2005-1006"); script_bugtraq_id(12984); script_version("$Revision: 1.5 $"); script_name(english:"SonicWall SOHO Web Interface XSS"); desc["english"] = " The remote host is a SonicWall SOHO appliance. This version is vulnerable to multiple flaws, and in particular to a cross-site scripting due to a lack of sanitization of user-supplied data. Successful exploitation of this issue may allow an attacker to execute malicious script code on a vulnerable appliance. See also : http://www.sonicwall.com/ Solution : Upgrade to the latest version. Risk factor : Medium"; script_description(english:desc["english"]); script_summary(english:"Checks SonicWall SOHO Web Interface XSS"); script_category(ACT_GATHER_INFO); script_copyright(english:"This script is Copyright (C) 2005 David Maciejak"); script_family(english:"CGI abuses"); script_require_ports("Services/www",80); script_dependencie("http_version.nasl", "cross_site_scripting.nasl"); exit(0); } #the code include("http_func.inc"); include("http_keepalive.inc"); port = get_http_port(default:80); if ( ! get_port_state(port))exit(0); if ( get_kb_item("www/" + port + "/generic_xss") ) exit(0); buf = http_get(item:"/", port:port); r = http_keepalive_send_recv(port:port, data:buf, bodyonly:1, embedded:TRUE); if( r == NULL )exit(0); #if(egrep(pattern:"SonicWall.*", string:r)) if(egrep(pattern:"SonicWall", string:r, icase:TRUE) && egrep(pattern:"", string:r)) { security_warning(port); exit(0); }