7.5 High
CVSS2
Attack Vector
NETWORK
Attack Complexity
LOW
Authentication
NONE
Confidentiality Impact
PARTIAL
Integrity Impact
PARTIAL
Availability Impact
PARTIAL
AV:N/AC:L/Au:N/C:P/I:P/A:P
0.009 Low
EPSS
Percentile
82.6%
The remote host is running phpCOIN version 1.2.2 or older. These versions suffer from several SQL injection vulnerabilities due to their failure to properly sanitize input to the ‘search’ parameter of the ‘index.php’ script, the ‘phpcoinsessid’ parameter of the ‘login.php’ script and the ‘id’, ‘dtopic_id’, and ‘dcat_id’ parameters of the ‘mod.php’ script before using it in SQL queries. An attacker may be able to exploit these flaws to alter database queries, potentially revealing sensitive information or even modifying data.
#%NASL_MIN_LEVEL 70300
#
# (C) Tenable Network Security, Inc.
#
include('deprecated_nasl_level.inc');
include('compat.inc');
if (description)
{
script_id(18166);
script_version("1.27");
script_set_attribute(attribute:"plugin_modification_date", value:"2021/01/19");
script_cve_id("CVE-2005-1384");
script_bugtraq_id(13433);
script_name(english:"phpCOIN <= 1.2.2 Multiple SQL Injection Vulnerabilities");
script_summary(english:"Checks for multiple SQL injection vulnerabilities in phpCOIN <= 1.2.2");
script_set_attribute(attribute:"synopsis", value:
"The remote web server contains a PHP application that is prone to
several SQL injection attacks.");
script_set_attribute(attribute:"description", value:
"The remote host is running phpCOIN version 1.2.2 or older. These
versions suffer from several SQL injection vulnerabilities due to
their failure to properly sanitize input to the 'search' parameter of
the 'index.php' script, the 'phpcoinsessid' parameter of the
'login.php' script and the 'id', 'dtopic_id', and 'dcat_id' parameters
of the 'mod.php' script before using it in SQL queries. An attacker
may be able to exploit these flaws to alter database queries,
potentially revealing sensitive information or even modifying data.");
script_set_attribute(attribute:"see_also", value:"https://seclists.org/bugtraq/2005/Apr/499");
script_set_attribute(attribute:"see_also", value:"http://forums.phpcoin.com/index.php?showtopic=4607");
script_set_attribute(attribute:"solution", value:"Unknown at this time.");
script_set_cvss_base_vector("CVSS2#AV:N/AC:L/Au:N/C:P/I:P/A:P");
script_set_cvss_temporal_vector("CVSS2#E:H/RL:OF/RC:C");
script_set_attribute(attribute:"exploitability_ease", value:"No exploit is required");
script_set_attribute(attribute:"exploit_available", value:"false");
script_set_attribute(attribute:"vuln_publication_date", value:"2005/04/28");
script_set_attribute(attribute:"plugin_publication_date", value:"2005/04/29");
script_set_attribute(attribute:"potential_vulnerability", value:"true");
script_set_attribute(attribute:"plugin_type", value:"remote");
script_set_attribute(attribute:"cpe", value:"cpe:/a:coinsoft_technologies:phpcoin");
script_end_attributes();
script_category(ACT_ATTACK);
script_family(english:"CGI abuses");
script_copyright(english:"This script is Copyright (C) 2005-2021 Tenable Network Security, Inc.");
script_dependencies("http_version.nasl");
script_exclude_keys("Settings/disable_cgi_scanning");
script_require_keys("Settings/ParanoidReport", "www/PHP");
script_require_ports("Services/www", 80);
exit(0);
}
include("audit.inc");
include("global_settings.inc");
include("misc_func.inc");
include("http.inc");
if (report_paranoia < 2) audit(AUDIT_PARANOID);
port = get_http_port(default:80);
# Loop through each directory with scripts.
foreach dir (cgi_dirs()) {
# Try a couple of different ways to exploit the flaws.
i = 0;
# - POST request with SQL injection via 'id'.
postdata = string(
"mod=siteinfo&",
"id=", SCRIPT_NAME, "'&",
"phpcoinsessid=3ff9120788558adc3b6c8352d808c861"
);
exploits[i++] = http_mk_post_req(item: dir+"/mod.php", port: port, version: 11,
add_headers: make_array("Content-Type", "application/x-www-form-urlencoded"),
data: postdata );
# - same as above but a GET request.
exploits[i++] = http_mk_get_req(item:string(dir, "/mod.php?", postdata), port:port);
# - POST request with SQL injection via session id.
postdata = string(
"w=user&",
"o=login&",
"phpcoinsessid=", SCRIPT_NAME, "'"
);
exploits[i++] = http_mk_post_req(item: dir + "/login.php", version: 11, port: port,
add_headers: make_array("Content-Type", "application/x-www-form-urlencoded"),
data: postdata);
# - same as above but a GET request.
exploits[i++] = http_mk_get_req(item:string(dir, "/login.php?", postdata), port:port);
foreach exploit (exploits) {
r = http_send_recv_req(port:port, req: exploit);
if (isnull(r)) exit(0);
res = strcat(r[0], r[1], '\r\n', r[2]);
# It's a problem if we see an error with our script name followed
# by a single quote. This error message is hard-coded into
# db_query_execute() in coin_database/db_mysql.php.
if (egrep(pattern:string("Unable to execute query: .+='", SCRIPT_NAME, "''"), string:res)) {
security_hole(port);
set_kb_item(name: 'www/'+port+'/SQLInjection', value: TRUE);
exit(0);
}
}
}
Vendor | Product | Version | CPE |
---|---|---|---|
coinsoft_technologies | phpcoin | cpe:/a:coinsoft_technologies:phpcoin |