Home

Description

OliveTin gives access to predefined shell commands from a web interface. In versions 3000.0.0 and prior, the template engine uses a single shared text/template.Template instance (tpl package-level variable in service/internal/tpl/templates.go) across all goroutines. Every action execution calls tpl.Parse(source) followed by t.Execute() on this shared instance with no synchronization. When two or more actions execute concurrently (which is the normal case — each ExecRequest spawns a goroutine), a race condition occurs: one goroutine's Parse overwrites the template tree while another goroutine is calling Execute, causing cross-user command contamination, Go runtime panic, and incorrect command execution. This issue has been resolved in version 3000.13.0.

PUBLISHED Reserved 2026-05-22 | Published 2026-06-15 | Updated 2026-06-16 | Assigner GitHub_M




HIGH: 7.5CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:H/I:H/A:H

Problem types

CWE-362: Concurrent Execution using Shared Resource with Improper Synchronization ('Race Condition')

CWE-567: Unsynchronized Access to Shared Data in a Multithreaded Context

Product status

< 3000.13.0
affected

References

github.com/...iveTin/security/advisories/GHSA-7fq5-7wr8-rjwj exploit

github.com/...iveTin/security/advisories/GHSA-7fq5-7wr8-rjwj

github.com/OliveTin/OliveTin/releases/tag/3000.13.0

cve.org (CVE-2026-48708)

nvd.nist.gov (CVE-2026-48708)

Download JSON