VDB
EN
LOW

GHSA-c2p3-7m5p-cv8x

Symfony hardened the parser when handling untrusted input

상세

### Description

`Symfony\Component\Yaml\Parser` is the entry point for parsing YAML strings into PHP values via `Yaml::parse()`. When the parser is exposed to attacker-controlled input, deeply nested mappings or sequences cause both the block-level (`Parser::parseBlock()`) and inline (`Inline::parseSequence()` / `Inline::parseMapping()`) parsers to recurse without a depth limit. A crafted document exhausts the PHP stack and crashes the worker.

### Resolution

The `Parser` now tracks recursion depth in a shared `ParserState` object across both block-level and inline parsing, with a default limit of **128**. The limit is configurable via a new `$maxNestingLevel` argument on `Parser::__construct()`, `Yaml::parse()` and `Yaml::parseFile()`.

The patch for this issue is available [here](https://github.com/symfony/symfony/commit/914f427ed9630ddb3904dafba763e53d9f133fe3) for branch 5.4.

### Credits

Symfony would like to thank Pietro Tirenna (Shielder) for reporting the issue and Nicolas Grekas for fixing it.

이 버전이 영향받나요?

사용 중인 패키지 버전을 입력하면 즉시 평가합니다.

영향 패키지

Packagist / symfony/yaml
최초 영향 버전: 0 수정 버전: 5.4.52
수정 composer require symfony/yaml:^5.4.52
Packagist / symfony/symfony
최초 영향 버전: 0 수정 버전: 5.4.52
수정 composer require symfony/symfony:^5.4.52
Packagist / symfony/symfony
최초 영향 버전: 6.0.0 수정 버전: 6.4.40
수정 composer require symfony/symfony:^6.4.40
Packagist / symfony/symfony
최초 영향 버전: 7.0.0 수정 버전: 7.4.12
수정 composer require symfony/symfony:^7.4.12
Packagist / symfony/symfony
최초 영향 버전: 8.0.0 수정 버전: 8.0.12
수정 composer require symfony/symfony:^8.0.12
Packagist / symfony/yaml
최초 영향 버전: 6.0.0 수정 버전: 6.4.40
수정 composer require symfony/yaml:^6.4.40
Packagist / symfony/yaml
최초 영향 버전: 7.0.0 수정 버전: 7.4.12
수정 composer require symfony/yaml:^7.4.12
Packagist / symfony/yaml
최초 영향 버전: 8.0.0 수정 버전: 8.0.12
수정 composer require symfony/yaml:^8.0.12

참고