← Back
CVE-2026-42882 critical CVSS 9.4

Path Traversal in github.com/oxyno-zeta/s3-proxy (CVE-2026-42882)

Summary

path traversal in github.com/oxyno-zeta/s3-proxy (CVE-2026-42882). Confidential information can be exposed externally. Exploitable via `PUT /upload/foo/drafts/../restricted/`. Mitigation: upgrade to `0.0.0-20260424211602-1320e4abd46a` or later.

AI summary snake-internal / snake-material-v2

A vulnerability tracked as **CVE-2026-42882** has been found in github.com/oxyno-zeta/s3-proxy. Attackers can target a specific entry point like `PUT /upload/foo/drafts/../restricted/` over the network to misuse the product. Confidential information can be exposed externally. CVSS score: 9.4/10. What to do: upgrade github.com/oxyno-zeta/s3-proxy to **0.0.0-20260424211602-1320e4abd46a** or later. If unsure, ask your IT team or search "github.com/oxyno-zeta/s3-proxy CVE-2026-42882" on the vendor's site.
CVE-2026-42882 (github.com/oxyno-zeta/s3-proxy) — CWE-22 / CVSS v3 9.4 Attack vector: remote (network-reachable) / unauthenticated / no user interaction Attack surface: PUT /upload/foo/drafts/../restricted/ / PUT /upload/foo / PUT /upload/foo/drafts/ / PUT /open/../restricted/secret.json Patched: `0.0.0-20260424211602-1320e4abd46a` — apply immediately Plan: 1) Audit SBOM/dependencies, 2) Stage→prod upgrade, 3) Add WAF/proxy monitoring on affected endpoints, 4) Hunt IOCs in logs. Refs: see the GHSA / vendor advisory / patched release linked on this page.
❓ What is the problem
**Path traversal** (CWE-22) exists in github.com/oxyno-zeta/s3-proxy. Attackers reach the vulnerable code path via `PUT /upload/foo/drafts/../restricted/` without authentication.
📍 Affected scope
github.com/oxyno-zeta/s3-proxy — . Attack surface: PUT /upload/foo/drafts/../restricted/ / PUT /upload/foo / PUT /upload/foo/drafts/ / PUT /open/../restricted/secret.json.
🔥 Severity
Severity: Critical (CVSS 9.4/10). Confidential information can be exposed externally
🔧 How to fix
Update to **0.0.0-20260424211602-1320e4abd46a**.
🛡️ Workaround
Until the patch is applied: disable the affected feature, apply WAF rules, or restrict access via network ACLs.
🔍 Detection
Search webserver/proxy logs for unusual `PUT /upload/foo/drafts/../restricted/` requests with malformed payloads or SQL meta-characters. Run `grep -r 'github.com/oxyno-zeta/s3-proxy' .` against your dependency files (package-lock.json, requirements.txt, go.sum) to find affected services.

Response Actions (7 steps)

Concrete steps and command examples for SOC/SRE teams to execute in order

  1. 1
    Identify exposure identify
    grep -r 'github.com/oxyno-zeta/s3-proxy' . | grep -v node_modules

    リポジトリと本番環境の依存ファイル (package-lock.json / requirements.txt / go.sum / Gemfile.lock 等) で `github.com/oxyno-zeta/s3-proxy` を grep し、稼働しているサービス・バージョンを把握する。

  2. 3
    Hunt for indicators of compromise detect
    grep 'PUT /upload/foo/drafts/../restricted/' /var/log/nginx/access.log | grep -E '(unusual_payload|sqli_pattern)'

    アクセスログで `PUT /upload/foo/drafts/../restricted/` への異常なリクエスト (不正な認証ヘッダ・SQLメタ文字)を過去 30〜90日分捜索。WAF/SIEM があれば該当パスのアラート発火履歴を確認。

  3. 6
    Apply patch patch
    Upgrade github.com/oxyno-zeta/s3-proxy to 0.0.0-20260424211602-1320e4abd46a

    ステージング環境で 0.0.0-20260424211602-1320e4abd46a に上げて回帰テスト → 本番反映。回帰テストはアプリの主要ハッピーパスと、Step 3 で見つけた異常検知の続報チェックを含めること。

  4. 7
    Post-deployment verification verify
    Replay attack against PUT /upload/foo/drafts/../restricted/ on staging to confirm patch closes the vector

    パッチ適用後、ステージングで PoC または同等の悪用パターンを再現して脆弱性が閉じたことを確認。本番では Step 3 と同じログクエリでアラート再発が無いか継続監視。

Affected packages

go github.com/oxyno-zeta/s3-proxy
[{"type":"SEMVER","events":[{"introduced":"0"},{"fixed":"0.0.0-20260424211602-1320e4abd46a"}]}]

References

🍪 About cookies

We use cookies to keep you logged in, remember your language, and improve the service.

Details →