chore(deps): update dependency pydantic-settings to v2.14.2 [security] #124
No reviewers
Labels
No labels
bug
dependencies
duplicate
enhancement
help wanted
invalid
question
renovate: stop-updating
wontfix
bug
duplicate
enhancement
help wanted
invalid
question
renovate: stop-updating
security
wontfix
No milestone
No project
No assignees
1 participant
Notifications
Due date
No due date set.
Dependencies
No dependencies set.
Reference: nomyo-ai/nomyo-router#124
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "renovate/pypi-pydantic-settings-vulnerability"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
This PR contains the following updates:
==2.14.1→==2.14.2pydantic-settings: NestedSecretsSettingsSource follows symlinks outside secrets_dir, enabling local file read and bypassing secrets_dir_max_size
GHSA-4xgf-cpjx-pc3j
More information
Details
Summary
NestedSecretsSettingsSourcereads secret values from files in a configuredsecrets_dir. Whensecrets_nested_subdir=True, a directory entry insidesecrets_dirthat is a symbolic link pointing outsidesecrets_diris followed, so files outside the configured directory are read into settings values. The same code path bypasses the documentedsecrets_dir_max_sizeprotection. An attacker or lower-privileged component able to influence entries in the configured secrets directory (for example, a writable or shared secrets mount) can turn this into an unintended local file read into settings and can defeat the advertised loading-size cap. This report does not claim network reachability by itself.Details
NestedSecretsSettingsSourceperformed two passes oversecrets_dirusing two different, inconsistent directory-traversal implementations:validate_secrets_path()usedPath.glob('**/*'), which does not descend into a symbolically-linked directory.load_secrets()usedglob.iglob(f'{path}/**/*', recursive=True)followed byread_text(), which does follow symlinked directories and reads through the link target.Because the two passes disagreed on symlinks, a symlinked directory inside
secrets_dirwhose target lives elsewhere was invisible to the size accounting (counted as 0 bytes) while still being fully read by the loader. This produces two distinct problems:secrets_dirthat resolves outside it is followed, and the external file's contents are loaded into the corresponding settings field.secrets_dir_max_sizebypass (CWE-400). The size check never sees the out-of-tree content, so the documented size cap is neither respected nor able to reject the oversized external file. A related amplification exists for cyclic in-tree symlinks, whichglob.iglob(recursive=True)re-traverses, inflating the size accounting and the number of loaded secrets.Reproduction
In a clean Linux container, with a
secrets_dircontaining a symlinksecrets/db -> /path/outsideand anoutside/passwdfile of 512 bytes, whilesecrets_dir_max_size=100:On affected versions,
Settings().db.passwdis populated with the 512-byte out-of-tree file and noSettingsErroris raised, even though the file exceedssecrets_dir_max_size.Impact
Applications that opt into
NestedSecretsSettingsSourcewithsecrets_nested_subdir=Trueand load secrets from a directory whose entries can be influenced by an attacker or a lower-privileged component (for example, a writable or shared secrets mount, or a secrets directory partially populated from untrusted input) are affected. The impact is:secrets_dircan be read into settings values (local file read).secrets_dir_max_sizecap can be bypassed, and cyclic symlinks can inflate resource usage during loading.The vulnerability requires the ability to place a symbolic link inside the configured secrets directory; it is not remotely reachable on its own. Applications that do not use
NestedSecretsSettingsSource, or that pointsecrets_dirat a directory fully under the application's control, are not affected.Mitigation
Upgrade to pydantic-settings 2.14.2, which:
secrets_dir, so symlinked directories pointing outside are never followed;secrets_dir, as defense in depth.If upgrading is not immediately possible, ensure the configured
secrets_diris fully owned and controlled by the application (no writable or attacker-influenced entries), or avoidsecrets_nested_subdir=True.Severity
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:L/I:L/A:LReferences
This data is provided by OSV and the GitHub Advisory Database (CC-BY 4.0).
Release Notes
pydantic/pydantic-settings (pydantic-settings)
v2.14.2Compare Source
What's Changed
This is a security patch release.
NestedSecretsSettingsSourcefrom following symlinks outsidesecrets_dirby @hramezani in #889Security
Fixes GHSA-4xgf-cpjx-pc3j:
NestedSecretsSettingsSourcewithsecrets_nested_subdir=Truecould follow a symbolic link insidesecrets_dirpointing outside it, reading out-of-tree files into settings values and bypassing thesecrets_dir_max_sizecap. Affected versions:>= 2.12.0, < 2.14.2.Full Changelog: https://github.com/pydantic/pydantic-settings/compare/v2.14.1...v2.14.2
Configuration
📅 Schedule: (UTC)
🚦 Automerge: Enabled.
♻ Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR has been generated by Mend Renovate.