CVE-2021-41174

Grafana is an open-source platform for monitoring and observability. In affected versions if an attacker is able to convince a victim to visit a URL referencing a vulnerable page, arbitrary JavaScript content may be executed within the context of the victim's browser. The user visiting the malicious link must be unauthenticated and the link must be for a page that contains the login button in the menu bar. The url has to be crafted to exploit AngularJS rendering and contain the interpolation binding for AngularJS expressions. AngularJS uses double curly braces for interpolation binding: {{ }} ex: {{constructor.constructor(‘alert(1)’)()}}. When the user follows the link and the page renders, the login button will contain the original link with a query parameter to force a redirect to the login page. The URL is not validated and the AngularJS rendering engine will execute the JavaScript expression contained in the URL. Users are advised to upgrade as soon as possible. If for some reason you cannot upgrade, you can use a reverse proxy or similar to block access to block the literal string {{ in the path.
Configurations

Configuration 1 (hide)

cpe:2.3:a:grafana:grafana:*:*:*:*:*:*:*:*

History

29 Nov 2021, 17:13

Type Values Removed Values Added
References (CONFIRM) https://security.netapp.com/advisory/ntap-20211125-0003/ - (CONFIRM) https://security.netapp.com/advisory/ntap-20211125-0003/ - Third Party Advisory

25 Nov 2021, 07:15

Type Values Removed Values Added
Summary Grafana is an open-source platform for monitoring and observability. In affected versions if an attacker is able to convince a victim to visit a URL referencing a vulnerable page, arbitrary JavaScript content may be executed within the context of the victim's browser. The user visiting the malicious link must be unauthenticated and the link must be for a page that contains the login button in the menu bar. The url has to be crafted to exploit AngularJS rendering and contain the interpolation binding for AngularJS expressions. AngularJS uses double curly braces for interpolation binding: {{ }} ex: {{constructor.constructor(‘alert(1)’)()}}. When the user follows the link and the page renders, the login button will contain the original link with a query parameter to force a redirect to the login page. The URL is not validated and the AngularJS rendering engine will execute the JavaScript expression contained in the URL. Users are advised to upgrade as soon as possible. If for some reason you cannot upgrade, you can use a reverse proxy or similar to block access to block the literal string {{ in the path. Grafana is an open-source platform for monitoring and observability. In affected versions if an attacker is able to convince a victim to visit a URL referencing a vulnerable page, arbitrary JavaScript content may be executed within the context of the victim's browser. The user visiting the malicious link must be unauthenticated and the link must be for a page that contains the login button in the menu bar. The url has to be crafted to exploit AngularJS rendering and contain the interpolation binding for AngularJS expressions. AngularJS uses double curly braces for interpolation binding: {{ }} ex: {{constructor.constructor(‘alert(1)’)()}}. When the user follows the link and the page renders, the login button will contain the original link with a query parameter to force a redirect to the login page. The URL is not validated and the AngularJS rendering engine will execute the JavaScript expression contained in the URL. Users are advised to upgrade as soon as possible. If for some reason you cannot upgrade, you can use a reverse proxy or similar to block access to block the literal string {{ in the path.
References
  • (CONFIRM) https://security.netapp.com/advisory/ntap-20211125-0003/ -

05 Nov 2021, 16:11

Type Values Removed Values Added
References (CONFIRM) https://github.com/grafana/grafana/security/advisories/GHSA-3j9m-hcv9-rpj8 - (CONFIRM) https://github.com/grafana/grafana/security/advisories/GHSA-3j9m-hcv9-rpj8 - Third Party Advisory
References (MISC) https://github.com/grafana/grafana/commit/3cb5214fa45eb5a571fd70d6c6edf0d729983f82 - (MISC) https://github.com/grafana/grafana/commit/3cb5214fa45eb5a571fd70d6c6edf0d729983f82 - Patch, Third Party Advisory
References (MISC) https://github.com/grafana/grafana/commit/31b78d51c693d828720a5b285107a50e6024c912 - (MISC) https://github.com/grafana/grafana/commit/31b78d51c693d828720a5b285107a50e6024c912 - Patch, Third Party Advisory
References (MISC) https://github.com/grafana/grafana/commit/fb85ed691290d211a5baa44d9a641ab137f0de88 - (MISC) https://github.com/grafana/grafana/commit/fb85ed691290d211a5baa44d9a641ab137f0de88 - Patch, Third Party Advisory
CVSS v2 : unknown
v3 : 6.9
v2 : 4.3
v3 : 6.1
CPE cpe:2.3:a:grafana:grafana:*:*:*:*:*:*:*:*

03 Nov 2021, 18:22

Type Values Removed Values Added
New CVE

Information

Published : 2021-11-03 18:15

Updated : 2023-12-10 14:09


NVD link : CVE-2021-41174

Mitre link : CVE-2021-41174

CVE.ORG link : CVE-2021-41174


JSON object : View

Products Affected

grafana

  • grafana
CWE
CWE-79

Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')