Security
Headlines
HeadlinesLatestCVEs

Headline

GHSA-8vch-m3f4-q8jf: 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:

  • https://github.com/elysiajs/elysia/pull/1564/commits/26935bf76ebc43b4a43d48b173fc853de43bb51e
  • https://github.com/elysiajs/elysia/pull/1564/commits/3af978663e437dccc6c1a2a3aff4b74e1574849e

Workarounds

Sanitize cookie-related env input

const overrideUnsafeQuote = (value: string) =>
    // '`' + value + '`'
    '`' + value.replace(/'/g, '\\`').replace(/\${/g, '$\\{') + '`'
ghsa
#vulnerability#js#git#rce

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 (elysiajs/elysia#1564)

Reference commit:

  • elysiajs/elysia@26935bf
  • elysiajs/elysia@3af9786

Workarounds

Sanitize cookie-related env input

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

References

  • GHSA-8vch-m3f4-q8jf
  • GHSA-hxj9-33pp-j2cc
  • elysiajs/elysia#1564
  • elysiajs/elysia@26935bf
  • elysiajs/elysia@3af9786
  • https://github.com/sportshead/elysia-poc

ghsa: Latest News

GHSA-9rwj-6rc7-p77c: LangGraph's SQLite is vulnerable to SQL injection via metadata filter key in SQLite checkpointer list method