GHSA-p9p4-97g9-wcrh

Suggest an improvement
Source
https://github.com/advisories/GHSA-p9p4-97g9-wcrh
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2022/06/GHSA-p9p4-97g9-wcrh/GHSA-p9p4-97g9-wcrh.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-p9p4-97g9-wcrh
Aliases
Published
2022-06-03T22:19:23Z
Modified
2023-11-08T04:09:22.965736Z
Severity
  • 5.9 (Medium) CVSS_V3 - CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:N/A:N CVSS Calculator
Summary
Dev error stack trace leaking into prod in Play Framework
Details

Impact

Play Framework, when run in dev mode, shows verbose errors for easy debugging, including an exception stack trace. Play does this by configuring its DefaultHttpErrorHandler to do so based on the application mode. In its Scala API Play also provides a static object DefaultHttpErrorHandler that is configured to always show verbose errors. This is used as a default value in some Play APIs, so it is possible to inadvertently use this version in production. It is also possible to improperly configure the DefaultHttpErrorHandler object instance as the injected error handler. Both of these situations could result in verbose errors displaying to users in a production application, which could expose sensitive information from the application.

In particular the constructor for CORSFilter and apply method for CORSActionBuilder use the static object DefaultHttpErrorHandler as a default value.

Patches

This is patched in Play Framework 2.8.16. The DefaultHttpErrorHandler object has been changed to use the prod-mode behavior, and DevHttpErrorHandler has been introduced for the dev-mode behavior.

Workarounds

When constructing a CORSFilter or CORSActionBuilder, ensure that a properly-configured error handler is passed. Generally this should be done by using the HttpErrorHandler instance provided through dependency injection or through Play's BuiltInComponents. Ensure that your application is not using the DefaultHttpErrorHandler static object in any code that may be run in production.

References

https://www.playframework.com/documentation/2.8.x/ScalaErrorHandling#Supplying-a-custom-error-handler https://www.playframework.com/documentation/2.8.x/JavaErrorHandling#Supplying-a-custom-error-handler

For more information

If you have any questions or comments about this advisory: * Open an issue in playframework/playframework * Email us at example email address

Database specific
{
    "nvd_published_at": "2022-06-02T18:15:00Z",
    "github_reviewed_at": "2022-06-03T22:19:23Z",
    "severity": "MODERATE",
    "github_reviewed": true,
    "cwe_ids": [
        "CWE-209"
    ]
}
References

Affected packages

Maven / com.typesafe.play:play_2.12

Package

Name
com.typesafe.play:play_2.12
View open source insights on deps.dev
Purl
pkg:maven/com.typesafe.play/play_2.12

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
2.8.16

Affected versions

2.*

2.6.0-M1
2.6.0-M2
2.6.0-M3
2.6.0-M4
2.6.0-M5
2.6.0-RC1
2.6.0-RC2
2.6.0
2.6.1
2.6.2
2.6.3
2.6.5
2.6.6
2.6.7
2.6.9
2.6.10
2.6.11
2.6.12
2.6.13
2.6.14
2.6.15
2.6.16
2.6.17
2.6.18
2.6.19
2.6.20
2.6.21
2.6.22
2.6.23
2.6.24
2.6.25
2.7.0-M1
2.7.0-M2
2.7.0-M3
2.7.0-M4
2.7.0-RC3
2.7.0-RC4
2.7.0-RC5
2.7.0-RC8
2.7.0-RC9
2.7.0
2.7.1
2.7.2
2.7.3
2.7.4
2.7.5
2.7.6
2.7.7
2.7.8
2.7.9
2.8.0-M1
2.8.0-M2
2.8.0-M3
2.8.0-M4
2.8.0-M5
2.8.0-M6
2.8.0-RC1
2.8.0-RC2
2.8.0-RC4
2.8.0-RC5
2.8.0
2.8.1
2.8.2
2.8.3
2.8.4
2.8.5
2.8.6
2.8.7
2.8.8-RC1
2.8.8
2.8.9-RC1
2.8.9
2.8.10
2.8.11
2.8.12
2.8.13
2.8.14
2.8.15

Maven / com.typesafe.play:play_2.13

Package

Name
com.typesafe.play:play_2.13
View open source insights on deps.dev
Purl
pkg:maven/com.typesafe.play/play_2.13

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
2.8.16

Affected versions

2.*

2.7.3
2.7.4
2.7.5
2.7.6
2.7.7
2.7.8
2.7.9
2.8.0-M2
2.8.0-M3
2.8.0-M4
2.8.0-M5
2.8.0-M6
2.8.0-RC1
2.8.0-RC2
2.8.0-RC4
2.8.0-RC5
2.8.0
2.8.1
2.8.2
2.8.3
2.8.4
2.8.5
2.8.6
2.8.7
2.8.8-RC1
2.8.8
2.8.9-RC1
2.8.9
2.8.10
2.8.11
2.8.12
2.8.13
2.8.14
2.8.15