GHSA-vfgq-g5x8-g595

Suggest an improvement
Source
https://github.com/advisories/GHSA-vfgq-g5x8-g595
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2023/03/GHSA-vfgq-g5x8-g595/GHSA-vfgq-g5x8-g595.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-vfgq-g5x8-g595
Aliases
Related
Published
2023-03-23T19:58:23Z
Modified
2024-08-20T20:58:57.822395Z
Severity
  • 5.7 (Medium) CVSS_V3 - CVSS:3.0/AV:A/AC:L/PR:H/UI:R/S:C/C:H/I:N/A:N CVSS Calculator
Summary
Non-interactive Tailscale SSH sessions on FreeBSD may use the effective group ID of the tailscaled process
Details

A vulnerability identified in the implementation of Tailscale SSH in FreeBSD allowed commands to be run with a higher privilege group ID than that specified by Tailscale SSH access rules.

Affected platforms: FreeBSD

Patched Tailscale client versions: v1.38.2 or later

What happened?

A difference in the behavior of the FreeBSD setgroups system call from POSIX meant that the Tailscale client running on a FreeBSD-based operating system did not appropriately restrict groups on the host when using Tailscale SSH. When accessing a FreeBSD host over Tailscale SSH, the egid of the tailscaled process was used instead of that of the user specified in Tailscale SSH access rules.

Who is affected?

9 tailnets with 22 FreeBSD nodes running Tailscale SSH since Tailscale v1.34 (released on 2022-12-04) may have had Tailscale SSH sessions with a higher privilege group ID than that specified in Tailscale SSH access rules.

We have notified the affected organizations where we have security contacts.

What is the impact?

Tailscale SSH commands may have been run with a higher privilege group ID than that specified in Tailscale SSH access rules if they met all of the following criteria: * The destination node was a FreeBSD device with Tailscale SSH enabled; * Tailscale SSH access rules permitted access for non-root users; and * A non-interactive SSH session was used.

What do I need to do?

If you are running Tailscale on FreeBSD, upgrade to v1.38.2 or later to remediate the issue. Admins of a tailnet can view FreeBSD nodes with unpatched versions in the admin console.

To update the local ports tree in advance of what's available upstream, you can:

  1. cd /usr/ports/security/tailscale
  2. edit the Makefile to set PORTVERSION to 1.38.2
  3. make makesum
  4. make install

Tailscale SSH on other platforms is not affected.

Credits

We would like to thank Ryan Belgrave for reporting this issue.

References

Database specific
{
    "nvd_published_at": "2023-03-23T20:15:00Z",
    "github_reviewed_at": "2023-03-23T19:58:23Z",
    "severity": "MODERATE",
    "github_reviewed": true,
    "cwe_ids": [
        "CWE-269"
    ]
}
References

Affected packages

Go / tailscale.com

Package

Name
tailscale.com
View open source insights on deps.dev
Purl
pkg:golang/tailscale.com

Affected ranges

Type
SEMVER
Events
Introduced
1.34.0
Fixed
1.38.2