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

exploitDog

github логотип

GHSA-8vch-m3f4-q8jf

Опубликовано: 09 дек. 2025
Источник: github
Github: Прошло ревью
CVSS4: 7.5

Описание

Elysia affected by arbitrary code injection through cookie config

Arbitrary code execution from cookie config. If dynamic cookies are enabled (ie there exists a schema for cookies), the cookie config is injected into the compiled route without first being sanitised.

Availability of this exploit is generally low, as it requires write access to either the Elysia app's source code (in which case the vulnerability is meaningless) or write access to the cookie config (perhaps where it is assumed to be provisioned by the environment).

However when combined with GHSA-hxj9-33pp-j2cc, this vulnerability allows for a full RCE chain.

Impact

  • aot enabled (default)
  • cookie schema passed to route
  • Cookie config controllable eg. via env

Example of vulnerable code

new Elysia({ cookie: { secrets: `' + console.log('pwned from secrets') + '` }, }) .get("/", () => "hello world", { cookie: t.Cookie({ foo: t.Any(), }), })

POC: https://github.com/sportshead/elysia-poc

Patches

Patched by 1.4.17 (https://github.com/elysiajs/elysia/pull/1564)

Reference commit:

Workarounds

Sanitize cookie-related env input

const overrideUnsafeQuote = (value: string) => // '`' + value + '`' '`' + value.replace(/'/g, '\\`').replace(/\${/g, '$\\{') + '`'

Пакеты

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

elysia

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

< 1.4.18

1.4.18

EPSS

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

7.5 High

CVSS4

Дефекты

CWE-94

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

CVSS3: 8.8
nvd
около 2 месяцев назад

Elysia is a Typescript framework for request validation, type inference, OpenAPI documentation and client-server communication. Versions 1.4.17 and below are subject to arbitrary code execution from cookie config. When dynamic cookies are enabled (e.g. there an existing cookie schema), the cookie config is injected into the compiled route without first being sanitised. Availability of this exploit is generally low, but when combined with GHSA-hxj9-33pp-j2cc, it allows for a full RCE chain. An attack requires write access to either the Elysia app's source code (in which case the vulnerability is meaningless) or write access to the cookie config (perhaps where it is assumed to be provisioned by the environment). This issue is fixed in version 1.4.18.

EPSS

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

7.5 High

CVSS4

Дефекты

CWE-94