Overview
- Description
- Grails Spring Security Core plugin is vulnerable to privilege escalation. The vulnerability allows an attacker access to one endpoint (i.e. the targeted endpoint) using the authorization requirements of a different endpoint (i.e. the donor endpoint). In some Grails framework applications, access to the targeted endpoint will be granted based on meeting the authorization requirements of the donor endpoint, which can result in a privilege escalation attack. This vulnerability has been patched in grails-spring-security-core versions 3.3.2, 4.0.5 and 5.1.1. Impacted Applications: Grails Spring Security Core plugin versions: 1.x 2.x >=3.0.0 <3.3.2 >=4.0.0 <4.0.5 >=5.0.0 <5.1.1 We strongly suggest that all Grails framework applications using the Grails Spring Security Core plugin be updated to a patched release of the plugin. Workarounds: Users should create a subclass extending one of the following classes from the `grails.plugin.springsecurity.web.access.intercept` package, depending on their security configuration: * `AnnotationFilterInvocationDefinition` * `InterceptUrlMapFilterInvocationDefinition` * `RequestmapFilterInvocationDefinition` In each case, the subclass should override the `calculateUri` method like so: ``` @Override protected String calculateUri(HttpServletRequest request) { UrlPathHelper.defaultInstance.getRequestUri(request) } ``` This should be considered a temporary measure, as the patched versions of grails-spring-security-core deprecates the `calculateUri` method. Once upgraded to a patched version of the plugin, this workaround is no longer needed. The workaround is especially important for version 2.x, as no patch is available version 2.x of the GSSC plugin.
- Source
- security-advisories@github.com
- NVD status
- Analyzed
Risk scores
CVSS 3.1
- Type
- Primary
- Base score
- 9.8
- Impact score
- 5.9
- Exploitability score
- 3.9
- Vector string
- CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
- Severity
- CRITICAL
Social media
- Hype score
- Not currently trending
Configurations
[ { "nodes": [ { "negate": false, "cpeMatch": [ { "criteria": "cpe:2.3:a:grails:spring_security_core:*:*:*:*:*:grails:*:*", "vulnerable": true, "matchCriteriaId": "1F452774-0B25-4FBD-ACC8-ED715A76203F", "versionEndExcluding": "3.3.2", "versionStartIncluding": "1.0" }, { "criteria": "cpe:2.3:a:grails:spring_security_core:*:*:*:*:*:grails:*:*", "vulnerable": true, "matchCriteriaId": "BA02192B-4871-43BA-8CDE-D5EA222244B2", "versionEndExcluding": "4.0.5", "versionStartIncluding": "4.0.0" }, { "criteria": "cpe:2.3:a:grails:spring_security_core:*:*:*:*:*:grails:*:*", "vulnerable": true, "matchCriteriaId": "66C77F51-5602-41E8-B852-FE373AA3CA4C", "versionEndExcluding": "5.1.1", "versionStartIncluding": "5.0.0" } ], "operator": "OR" } ] } ]