Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

github логотип

GHSA-75jv-vfxf-3865

Опубликовано: 25 июл. 2025
Источник: github
Github: Прошло ревью
CVSS3: 4.2

Описание

Assemblyline 4 service client vulnerable to Arbitrary Write through path traversal in Client code

Path-Traversal -> Arbitrary File Write in Assemblyline Service Client

IMPORTANT: This vulnerability is valid if you decide to use the assemblyline-service-client outside of the normal practice to using Assemblyline in a production environment. In practice, this code should always be executed within a containerized environment such as assemblyline-v4-service which ensures filesystem-level permissions of what the running user is allowed to access. Furthermore, there is fewer chances for a MiTM compromise when deployed properly in a Docker or Kubernetes deployment where the platform will assign the correct network policies to secure connections between containers instead of relying on the user to set this up manually.

See https://github.com/CybercentreCanada/assemblyline/issues/382 for further discussion.


1. Summary

The Assemblyline 4 service client (task_handler.py) accepts a SHA-256 value returned by the service server and uses it directly as a local file name.

No validation / sanitisation is performed.

A malicious or compromised server (or any MITM that can speak to client) can return a path-traversal payload such as
../../../etc/cron.d/evil
and force the client to write the downloaded bytes to an arbitrary location on disk.


2. Affected Versions

ItemValue
Componentassemblyline-service-client
RepositoryCybercentreCanada/assemblyline-service-client
AffectedAll releases up to master branch.

3. CVSS 3.1 Vector & Score

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

4. Technical Details

FieldContent
Locationassemblyline_service_client/task_handler.py, inside download_file()
Vulnerable Linefile_path = os.path.join(self.tasking_dir, sha256)
Root CauseThe sha256 string is taken directly from the service-server JSON response and used as a file name without any validation or sanitisation.
Exploit Flow1. Attacker (service server) returns HTTP 200 for GET /api/v1/file/../../../etc/cron.d/evil.
2. Client writes the response body to /etc/cron.d/evil.
3. Achieves arbitrary file write (code execution if file is executable).

5. Impact

  • Integrity – Overwrite any file writable by the service UID (often root).
  • Availability – Corrupt critical files or exhaust disk space.
  • Code Execution – Drop cron jobs, systemd units, or overwrite binaries.

6. Mitigation / Fix

import re _SHA256_RE = re.compile(r'^[0-9a-fA-F]{64}\Z') def download_file(self, sha256: str, sid: str) -> Optional[str]: if not _SHA256_RE.fullmatch(sha256): self.log.error(f"[{sid}] Invalid SHA256: {sha256}") self.status = STATUSES.ERROR_FOUND return None # or your preferred way to check if a string is a shasum.

Пакеты

Наименование

assemblyline-service-client

pip
Затронутые версииВерсия исправления

< 4.6.0.stable11

4.6.0.stable11

Наименование

assemblyline-service-client

pip
Затронутые версииВерсия исправления

>= 4.6.1.dev0, < 4.6.1.dev138

4.6.1.dev138

EPSS

Процентиль: 5%
0.00023
Низкий

4.2 Medium

CVSS3

Дефекты

CWE-23

Связанные уязвимости

CVSS3: 4.2
nvd
6 месяцев назад

The Assemblyline 4 Service Client interfaces with the API to fetch tasks and publish the result for a service in Assemblyline 4. In versions below 4.6.1.dev138, the Assemblyline 4 Service Client (task_handler.py) accepts a SHA-256 value returned by the service server and uses it directly as a local file name.A malicious or compromised server (or any MITM that can speak to client) can return a path-traversal payload such as `../../../etc/cron.d/evil` and force the client to write the downloaded bytes to an arbitrary location on disk. This is fixed in version 4.6.1.dev138.

EPSS

Процентиль: 5%
0.00023
Низкий

4.2 Medium

CVSS3

Дефекты

CWE-23