Bug 822638 (CVE-2013-2115) - VUL-0: struts: CVE-2013-2115: CVE-2013-1966: Remote code execution
Summary: VUL-0: struts: CVE-2013-2115: CVE-2013-1966: Remote code execution
Status: RESOLVED INVALID
Alias: CVE-2013-2115
Product: SUSE Security Incidents
Classification: Novell Products
Component: Incidents (show other bugs)
Version: unspecified
Hardware: Other Other
: P5 - None : Major
Target Milestone: ---
Assignee: E-mail List
QA Contact: Security Team bot
URL:
Whiteboard:
Keywords:
Depends on:
Blocks:
 
Reported: 2013-05-31 12:14 UTC by Alexander Bergmann
Modified: 2015-06-30 07:30 UTC (History)
1 user (show)

See Also:
Found By: ---
Services Priority:
Business Priority:
Blocker: ---
Marketing QA Status: ---
IT Deployment: ---


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Alexander Bergmann 2013-05-31 12:14:21 UTC
Public via:

http://struts.apache.org/release/2.3.x/docs/s2-014.html

Affected Software: Struts 2.0.0 - Struts 2.3.14.1
CVE Identifier: CVE-2013-2115, CVE-2013-1966

Both the s:url and s:a tag provide an includeParams attribute.

The main scope of that attribute is to understand whether includes http request parameter or not.

The allowed values of includeParams are:

    none - include no parameters in the URL (default)
    get - include only GET parameters in the URL
    all - include both GET and POST parameters in the URL

A request that included a specially crafted request parameter could be used to inject arbitrary OGNL code into the stack, afterward used as request parameter of an URL or A tag , which will cause a further evaluation.

The second evaluation happens when the URL/A tag tries to resolve every parameters present in the original request.
This lets malicious users put arbitrary OGNL statements into any request parameter (not necessarily managed by the code) and have it evaluated as an OGNL expression to enable method execution and execute arbitrary methods, bypassing Struts and OGNL library protections.

The issue was originally addressed by Struts 2.3.14.1 and Security Announcement S2-013. However, the solution introduced with 2.3.14.1 did not address all possible attack vectors, such that every version of Struts 2 before 2.3.14.2 is still vulnerable to such attacks.
Comment 1 Alexander Bergmann 2013-05-31 12:17:58 UTC
We do not have any struts 2 version in our distributions.