CVE-2026-40304 PUBLISHED

zrok's broken ownership check in DELETE /api/v2/unaccess allows non-admin to delete global frontend records

Assigner: GitHub_M
Reserved: 10.04.2026 Published: 17.04.2026 Updated: 17.04.2026

zrok is software for sharing web services, files, and network resources. Prior to version 2.0.1, the unaccess handler (controller/unaccess.go) contains a logical error in its ownership guard: when a frontend record has environment_id = NULL (the marker for admin-created global frontends), the condition short-circuits to false and allows the deletion to proceed without any ownership verification. A non-admin user who knows a global frontend token can call DELETE /api/v2/unaccess with any of their own environment IDs and permanently delete the global frontend, taking down all public shares routed through it. Version 2.0.1 patches the issue.

Metrics

CVSS Vector: CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:H
CVSS Score: 5.3

Product Status

Vendor openziti
Product zrok
Versions
  • Version < 2.0.1 is affected

References

Problem Types

  • CWE-284: Improper Access Control CWE
  • CWE-863: Incorrect Authorization CWE