nuclei-templates/http/cves/2022/CVE-2022-29153.yaml

57 lines
2.5 KiB
YAML

id: CVE-2022-29153
info:
name: HashiCorp Consul/Consul Enterprise - Server-Side Request Forgery
author: c-sh0
severity: high
description: |
HashiCorp Consul and Consul Enterprise up to 1.9.16, 1.10.9, and 1.11 are susceptible to server-side request forgery. When redirects are returned by HTTP health check endpoints, Consul follows these HTTP redirects by default. An attacker can possibly obtain sensitive information, modify data, and/or execute unauthorized administrative operations in the context of the affected site.
impact: |
Successful exploitation of this vulnerability could allow an attacker to send crafted requests to internal resources, leading to unauthorized access or information disclosure.
remediation: 1) HTTP + interval health check configuration provides a disable_redirects option to prohibit this behavior. 2) Fixed in 1.9.17, 1.10.10, and 1.11.5.
reference:
- https://discuss.hashicorp.com/t/hcsec-2022-10-consul-s-http-health-check-may-allow-server-side-request-forgery/38393
- https://github.com/hashicorp/consul/pull/12685
- https://developer.hashicorp.com/consul/docs/discovery/checks
- https://nvd.nist.gov/vuln/detail/CVE-2022-29153
- https://discuss.hashicorp.com
classification:
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:N
cvss-score: 7.5
cve-id: CVE-2022-29153
cwe-id: CWE-918
epss-score: 0.01187
epss-percentile: 0.83456
cpe: cpe:2.3:a:hashicorp:consul:*:*:*:*:-:*:*:*
metadata:
verified: true
max-request: 2
vendor: hashicorp
product: consul
shodan-query: title:"Consul by HashiCorp"
tags: cve,cve2022,consul,hashicorp,ssrf,intrusive
http:
- raw:
- | # register safe test node
PUT /v1/agent/check/register HTTP/1.1
Host: {{Hostname}}
Content-Type: application/json
{"id":"{{randstr}}","name":"TEST NODE","method":"GET","http":"http://example.com","interval":"10s","timeout":"1s","disable_redirects":true}
- | # deregister test node
PUT /v1/agent/check/deregister/{{randstr}} HTTP/1.1
Host: {{Hostname}}
Content-Type: application/json
matchers-condition: and
matchers:
- type: word
part: body
words:
- unknown field "disable_redirects"
- type: status
status:
- 400
# digest: 4a0a00473045022100b47012ec9b2acd0e4ee65060206e85dce6144dfcdcf15aa28cf8e3afc3a9398b0220396d7b6861f755d0db929acd66c8bd8e3a1bfab1d9dd4ba4f696bd44f225de5e:922c64590222798bb761d5b6d8e72950