This commit is contained in:
Eli Peter 2026-06-05 10:16:30 -05:00 committed by GitHub
parent 55247b7fcd
commit 991c84a1eb
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
1464 changed files with 225448 additions and 1985 deletions

View file

@ -0,0 +1,23 @@
"""Phase 12 (Track L.10) — Starlette CMDI benign fixture.
`run_cmd(request)` reads the `cmd` query parameter but rejects anything
outside an allowlist before invoking `subprocess.run` with a fixed
argv, so the sink call is unreachable for attacker-controlled values.
"""
import subprocess
from starlette.applications import Starlette
from starlette.responses import PlainTextResponse
from starlette.routing import Route
_ALLOW = {"status", "uptime", "version"}
async def run_cmd(request):
cmd = request.query_params.get("cmd", "")
if cmd not in _ALLOW:
return PlainTextResponse("rejected", status_code=400)
subprocess.run(["/usr/bin/echo", cmd], check=False)
return PlainTextResponse("ok")
app = Starlette(routes=[Route("/run", endpoint=run_cmd)])

View file

@ -0,0 +1,19 @@
"""Phase 12 (Track L.10) — Starlette CMDI vuln fixture.
`run_cmd(request)` reads the `cmd` query parameter and pipes it
straight to `os.system`. Adapter binding: `Route("/run", endpoint=run_cmd)`
registration with `cmd` flowing through `request.query_params`.
"""
import os
from starlette.applications import Starlette
from starlette.responses import PlainTextResponse
from starlette.routing import Route
async def run_cmd(request):
cmd = request.query_params.get("cmd", "")
os.system(cmd)
return PlainTextResponse("ok")
app = Starlette(routes=[Route("/run", endpoint=run_cmd)])