62 lines
2.7 KiB
YAML
62 lines
2.7 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.02376
|
|
epss-percentile: 0.89839
|
|
cpe: cpe:2.3:a:hashicorp:consul:*:*:*:*:-:*:*:*
|
|
metadata:
|
|
verified: true
|
|
max-request: 2
|
|
vendor: hashicorp
|
|
product: consul
|
|
shodan-query:
|
|
- title:"Consul by HashiCorp"
|
|
- http.title:"consul by hashicorp"
|
|
- cpe:"cpe:2.3:a:hashicorp:consul"
|
|
fofa-query: title="consul by hashicorp"
|
|
google-query: intitle:"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://oast.me","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: 4a0a00473045022100ea0f8cb9d0d00089e95ed2ee6c9e52a7a0eb41d6bd10a23c290bedbd627f57410220558e5e7400950e3a67cd10a0433ae060ff041a21031995cc4b7aeed642d55c0c:922c64590222798bb761d5b6d8e72950 |