Commit graph

1015 commits

Author SHA1 Message Date
dependabot[bot]
af3e085fb4
chore(deps): bump ruamel-yaml from 0.18.16 to 0.18.17 (#1035)
Bumps ruamel-yaml from 0.18.16 to 0.18.17.


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=ruamel-yaml&package-manager=pip&previous-version=0.18.16&new-version=0.18.17)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-18 12:03:25 +00:00
dependabot[bot]
229afd9e26
chore(deps): bump fastapi from 0.124.4 to 0.125.0 (#1034)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.124.4 to
0.125.0.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.125.0</h2>
<h3>Breaking Changes</h3>
<ul>
<li>🔧 Drop support for Python 3.8. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14563">#14563</a>
by <a href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.
<ul>
<li>This would actually not be a <em>breaking</em> change as no code
would really break. Any Python 3.8 installer would just refuse to
install the latest version of FastAPI and would only install 0.124.4.
Only marking it as a &quot;breaking change&quot; to make it
visible.</li>
</ul>
</li>
</ul>
<h3>Refactors</h3>
<ul>
<li>♻️ Upgrade internal syntax to Python 3.9+ 🎉. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14564">#14564</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Docs</h3>
<ul>
<li>⚰️ Remove Python 3.8 from CI and remove Python 3.8 examples from
source docs. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14559">#14559</a>
by <a href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>
and <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Translations</h3>
<ul>
<li>🌐 Update translations for pt (add-missing). PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14539">#14539</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🔧 Add LLM prompt file for French, generated from the existing French
docs. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14544">#14544</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🌐 Sync Portuguese docs (pages found with script). PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14554">#14554</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🌐 Sync Spanish docs (outdated pages found with script). PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14553">#14553</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🌐 Sync German docs. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14519">#14519</a>
by <a
href="https://github.com/nilslindemann"><code>@​nilslindemann</code></a>.</li>
<li>🔥 Remove inactive/scarce translations to Vietnamese. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14543">#14543</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🔥 Remove inactive/scarce translations to Persian. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14542">#14542</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🔥 Remove translation to emoji to simplify the new setup with LLM
autotranslations. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14541">#14541</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🌐 Update translations for pt (update-outdated). PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14537">#14537</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🌐 Update translations for es (update-outdated). PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14532">#14532</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🌐 Update translations for es (add-missing). PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14533">#14533</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🌐 Remove translations for removed docs. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14516">#14516</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Internal</h3>
<ul>
<li>⬆ Bump <code>markdown-include-variants</code> from 0.0.7 to 0.0.8.
PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14556">#14556</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🔧 Temporarily disable translations still in progress, being migrated
to the new LLM setup. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14555">#14555</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🔧 Update test workflow config, remove commented code. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14540">#14540</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👷 Configure coverage, error on main tests, don't wait for Smokeshow.
PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14536">#14536</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👷 Run Smokeshow always, even on test failures. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14538">#14538</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👷 Make Pydantic versions customizable in CI. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14535">#14535</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👷 Fix checkout GitHub Action fetch-depth for LLM translations,
enable cron monthly. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14531">#14531</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👷 Fix Typer command for CI LLM translations. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14530">#14530</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👷 Update LLM translation CI, add language matrix and extra commands,
prepare for scheduled run. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14529">#14529</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👷 Update github-actions user for GitHub Actions workflows. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14528">#14528</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li> Add requirements for translations. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14515">#14515</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="c75f17d483"><code>c75f17d</code></a>
🔖 Release version 0.125.0</li>
<li><a
href="241ca9a533"><code>241ca9a</code></a>
📝 Update release notes</li>
<li><a
href="3f75f51255"><code>3f75f51</code></a>
📝 Update release notes</li>
<li><a
href="1c4fc96c91"><code>1c4fc96</code></a>
♻️ Upgrade internal syntax to Python 3.9+ 🎉 (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14564">#14564</a>)</li>
<li><a
href="7f9709d75e"><code>7f9709d</code></a>
📝 Update release notes</li>
<li><a
href="84668c2acc"><code>84668c2</code></a>
🔧 Drop support for Python 3.8 (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14563">#14563</a>)</li>
<li><a
href="e0fd79139e"><code>e0fd791</code></a>
📝 Update release notes</li>
<li><a
href="ed97d9dc0c"><code>ed97d9d</code></a>
⚰️ Remove Python 3.8 from CI and remove Python 3.8 examples from source
docs ...</li>
<li><a
href="99ef383398"><code>99ef383</code></a>
📝 Update release notes</li>
<li><a
href="56a549b4d5"><code>56a549b</code></a>
🌐 Update translations for pt (add-missing) (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14539">#14539</a>)</li>
<li>Additional commits viewable in <a
href="https://github.com/fastapi/fastapi/compare/0.124.4...0.125.0">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.124.4&new-version=0.125.0)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-18 12:03:13 +00:00
dependabot[bot]
816eb43e23
chore(deps): bump fastapi from 0.124.2 to 0.124.4 (#1033)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.124.2 to
0.124.4.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.124.4</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix parameter aliases. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14371">#14371</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
</ul>
<h2>0.124.3</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix support for tagged union with discriminator inside of
<code>Annotated</code> with <code>Body()</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14512">#14512</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Refactors</h3>
<ul>
<li> Add set of tests for request parameters and alias. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14358">#14358</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
</ul>
<h3>Docs</h3>
<ul>
<li>📝 Tweak links format. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14505">#14505</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>📝 Update docs about re-raising validation errors, do not include
string as is to not leak information. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14487">#14487</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>🔥 Remove external links section. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14486">#14486</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Translations</h3>
<ul>
<li>🌐 Sync Russian docs. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14509">#14509</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🌐 Sync German docs. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14488">#14488</a>
by <a
href="https://github.com/nilslindemann"><code>@​nilslindemann</code></a>.</li>
</ul>
<h3>Internal</h3>
<ul>
<li>👷 Tweak coverage to not pass Smokeshow max file size limit. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14507">#14507</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li> Expand test matrix to include Windows and MacOS. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14171">#14171</a>
by <a
href="https://github.com/svlandeg"><code>@​svlandeg</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="b1d9769f97"><code>b1d9769</code></a>
🔖 Release version 0.124.4</li>
<li><a
href="89157a803c"><code>89157a8</code></a>
📝 Update release notes</li>
<li><a
href="d86c47477e"><code>d86c474</code></a>
🐛 Fix parameter aliases (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14371">#14371</a>)</li>
<li><a
href="3fe6522aae"><code>3fe6522</code></a>
🔖 Release version 0.124.3</li>
<li><a
href="80d1f732e5"><code>80d1f73</code></a>
📝 Update release notes</li>
<li><a
href="c0556ac3a5"><code>c0556ac</code></a>
🐛 Fix support for tagged union with discriminator inside of
<code>Annotated</code> with ...</li>
<li><a
href="1fcec88ad2"><code>1fcec88</code></a>
📝 Update release notes</li>
<li><a
href="f8b216df30"><code>f8b216d</code></a>
🌐 Sync Russian docs (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14509">#14509</a>)</li>
<li><a
href="4b905b614c"><code>4b905b6</code></a>
📝 Update release notes</li>
<li><a
href="6c54bcefd3"><code>6c54bce</code></a>
 Add set of tests for request parameters and alias (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14358">#14358</a>)</li>
<li>Additional commits viewable in <a
href="https://github.com/fastapi/fastapi/compare/0.124.2...0.124.4">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.124.2&new-version=0.124.4)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-15 12:03:53 +00:00
dependabot[bot]
4b05e32151
chore(deps-dev): bump ruff from 0.14.8 to 0.14.9 (#1030)
Bumps [ruff](https://github.com/astral-sh/ruff) from 0.14.8 to 0.14.9.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/astral-sh/ruff/releases">ruff's
releases</a>.</em></p>
<blockquote>
<h2>0.14.9</h2>
<h2>Release Notes</h2>
<p>Released on 2025-12-11.</p>
<h3>Preview features</h3>
<ul>
<li>[<code>ruff</code>] New <code>RUF100</code> diagnostics for unused
range suppressions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21783">#21783</a>)</li>
<li>[<code>pylint</code>] Detect subclasses of builtin exceptions
(<code>PLW0133</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21382">#21382</a>)</li>
</ul>
<h3>Bug fixes</h3>
<ul>
<li>Fix comment placement in lambda parameters (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21868">#21868</a>)</li>
<li>Skip over trivia tokens after re-lexing (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21895">#21895</a>)</li>
<li>[<code>flake8-bandit</code>] Fix false positive when using
non-standard <code>CSafeLoader</code> path (S506). (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21830">#21830</a>)</li>
<li>[<code>flake8-bugbear</code>] Accept immutable slice default
arguments (<code>B008</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21823">#21823</a>)</li>
</ul>
<h3>Rule changes</h3>
<ul>
<li>[<code>pydocstyle</code>] Suppress <code>D417</code> for parameters
with <code>Unpack</code> annotations (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21816">#21816</a>)</li>
</ul>
<h3>Performance</h3>
<ul>
<li>Use <code>memchr</code> for computing line indexes (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21838">#21838</a>)</li>
</ul>
<h3>Documentation</h3>
<ul>
<li>Document <code>*.pyw</code> is included by default in preview (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21885">#21885</a>)</li>
<li>Document range suppressions, reorganize suppression docs (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21884">#21884</a>)</li>
<li>Update mkdocs-material to 9.7.0 (Insiders now free) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21797">#21797</a>)</li>
</ul>
<h3>Contributors</h3>
<ul>
<li><a href="https://github.com/Avasam"><code>@​Avasam</code></a></li>
<li><a
href="https://github.com/MichaReiser"><code>@​MichaReiser</code></a></li>
<li><a
href="https://github.com/charliermarsh"><code>@​charliermarsh</code></a></li>
<li><a
href="https://github.com/amyreese"><code>@​amyreese</code></a></li>
<li><a
href="https://github.com/phongddo"><code>@​phongddo</code></a></li>
<li><a
href="https://github.com/prakhar1144"><code>@​prakhar1144</code></a></li>
<li><a
href="https://github.com/mahiro72"><code>@​mahiro72</code></a></li>
<li><a href="https://github.com/ntBre"><code>@​ntBre</code></a></li>
<li><a
href="https://github.com/LoicRiegel"><code>@​LoicRiegel</code></a></li>
</ul>
<h2>Install ruff 0.14.9</h2>
<h3>Install prebuilt binaries via shell script</h3>
<pre lang="sh"><code>curl --proto '=https' --tlsv1.2 -LsSf
https://github.com/astral-sh/ruff/releases/download/0.14.9/ruff-installer.sh
| sh
</code></pre>
<!-- raw HTML omitted -->
</blockquote>
<p>... (truncated)</p>
</details>
<details>
<summary>Changelog</summary>
<p><em>Sourced from <a
href="https://github.com/astral-sh/ruff/blob/main/CHANGELOG.md">ruff's
changelog</a>.</em></p>
<blockquote>
<h2>0.14.9</h2>
<p>Released on 2025-12-11.</p>
<h3>Preview features</h3>
<ul>
<li>[<code>ruff</code>] New <code>RUF100</code> diagnostics for unused
range suppressions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21783">#21783</a>)</li>
<li>[<code>pylint</code>] Detect subclasses of builtin exceptions
(<code>PLW0133</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21382">#21382</a>)</li>
</ul>
<h3>Bug fixes</h3>
<ul>
<li>Fix comment placement in lambda parameters (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21868">#21868</a>)</li>
<li>Skip over trivia tokens after re-lexing (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21895">#21895</a>)</li>
<li>[<code>flake8-bandit</code>] Fix false positive when using
non-standard <code>CSafeLoader</code> path (S506). (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21830">#21830</a>)</li>
<li>[<code>flake8-bugbear</code>] Accept immutable slice default
arguments (<code>B008</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21823">#21823</a>)</li>
</ul>
<h3>Rule changes</h3>
<ul>
<li>[<code>pydocstyle</code>] Suppress <code>D417</code> for parameters
with <code>Unpack</code> annotations (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21816">#21816</a>)</li>
</ul>
<h3>Performance</h3>
<ul>
<li>Use <code>memchr</code> for computing line indexes (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21838">#21838</a>)</li>
</ul>
<h3>Documentation</h3>
<ul>
<li>Document <code>*.pyw</code> is included by default in preview (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21885">#21885</a>)</li>
<li>Document range suppressions, reorganize suppression docs (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21884">#21884</a>)</li>
<li>Update mkdocs-material to 9.7.0 (Insiders now free) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21797">#21797</a>)</li>
</ul>
<h3>Contributors</h3>
<ul>
<li><a href="https://github.com/Avasam"><code>@​Avasam</code></a></li>
<li><a
href="https://github.com/MichaReiser"><code>@​MichaReiser</code></a></li>
<li><a
href="https://github.com/charliermarsh"><code>@​charliermarsh</code></a></li>
<li><a
href="https://github.com/amyreese"><code>@​amyreese</code></a></li>
<li><a
href="https://github.com/phongddo"><code>@​phongddo</code></a></li>
<li><a
href="https://github.com/prakhar1144"><code>@​prakhar1144</code></a></li>
<li><a
href="https://github.com/mahiro72"><code>@​mahiro72</code></a></li>
<li><a href="https://github.com/ntBre"><code>@​ntBre</code></a></li>
<li><a
href="https://github.com/LoicRiegel"><code>@​LoicRiegel</code></a></li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="3f63ea4b50"><code>3f63ea4</code></a>
Prepare 0.14.9 release (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21927">#21927</a>)</li>
<li><a
href="c8851ecf70"><code>c8851ec</code></a>
[ty] Defer all parameter and return type annotations (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21906">#21906</a>)</li>
<li><a
href="d442433e93"><code>d442433</code></a>
[ty] Fix workspace symbols to return members too (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21926">#21926</a>)</li>
<li><a
href="c055d665ef"><code>c055d66</code></a>
Document range suppressions, reorganize suppression docs (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21884">#21884</a>)</li>
<li><a
href="7a578ce833"><code>7a578ce</code></a>
Ignore ruff:isort like ruff:noqa in new suppressions (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21922">#21922</a>)</li>
<li><a
href="34f7a04ef7"><code>34f7a04</code></a>
[ty] Handle <code>Definition</code>s in
<code>SemanticModel::scope</code> (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21919">#21919</a>)</li>
<li><a
href="c9fe4e2703"><code>c9fe4e2</code></a>
[ty] Attach salsa db when running ide tests for easier debugging (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21917">#21917</a>)</li>
<li><a
href="fbeeb050af"><code>fbeeb05</code></a>
[ty] Don't show hover for expressions with no inferred type (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21924">#21924</a>)</li>
<li><a
href="4fdb4e8219"><code>4fdb4e8</code></a>
[ty] avoid unions of generic aliases of the same class in fixpoint (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21909">#21909</a>)</li>
<li><a
href="c548ef2027"><code>c548ef2</code></a>
[ty] Squash false positive logs for failing to find
<code>builtins</code> as a real module</li>
<li>Additional commits viewable in <a
href="https://github.com/astral-sh/ruff/compare/0.14.8...0.14.9">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=ruff&package-manager=pip&previous-version=0.14.8&new-version=0.14.9)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-12 12:03:32 +00:00
dependabot[bot]
9e940d7afd
chore(deps): bump fastapi from 0.124.1 to 0.124.2 (#1029)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.124.1 to
0.124.2.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.124.2</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix support for <code>if TYPE_CHECKING</code>, non-evaluated
stringified annotations. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14485">#14485</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="7b0b915749"><code>7b0b915</code></a>
🔖 Release version 0.124.2</li>
<li><a
href="96bdde376f"><code>96bdde3</code></a>
📝 Update release notes</li>
<li><a
href="7ba042e069"><code>7ba042e</code></a>
🐛 Fix support for <code>if TYPE_CHECKING</code>, non-evaluated
stringified annotations ...</li>
<li>See full diff in <a
href="https://github.com/fastapi/fastapi/compare/0.124.1...0.124.2">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.124.1&new-version=0.124.2)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-11 12:03:35 +00:00
dependabot[bot]
08d88db094
chore(deps): bump fastapi from 0.124.0 to 0.124.1 (#1028)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.124.0 to
0.124.1.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.124.1</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix handling arbitrary types when using
<code>arbitrary_types_allowed=True</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14482">#14482</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Docs</h3>
<ul>
<li>📝 Add variants for code examples in &quot;Advanced User Guide&quot;.
PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14413">#14413</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>📝 Update tech stack in project generation docs. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14472">#14472</a>
by <a
href="https://github.com/alejsdev"><code>@​alejsdev</code></a>.</li>
</ul>
<h3>Internal</h3>
<ul>
<li> Add test for Pydantic v2, dataclasses, UUID, and
<code>__annotations__</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14477">#14477</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="60699f306b"><code>60699f3</code></a>
🔖 Release version 0.124.1</li>
<li><a
href="ae7af59c6d"><code>ae7af59</code></a>
📝 Update release notes</li>
<li><a
href="42b250d14d"><code>42b250d</code></a>
🐛 Fix handling arbitrary types when using
<code>arbitrary_types_allowed=True</code> (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14">#14</a>...</li>
<li><a
href="71a17b5932"><code>71a17b5</code></a>
📝 Update release notes</li>
<li><a
href="9475024640"><code>9475024</code></a>
📝 Add variants for code examples in &quot;Advanced User Guide&quot; (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14413">#14413</a>)</li>
<li><a
href="5b28a04d55"><code>5b28a04</code></a>
📝 Update release notes</li>
<li><a
href="8cedb742cb"><code>8cedb74</code></a>
 Add test for Pydantic v2, dataclasses, UUID, and
<code>__annotations__</code> (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14477">#14477</a>)</li>
<li><a
href="320e7ce8fd"><code>320e7ce</code></a>
📝 Update release notes</li>
<li><a
href="81517f66cc"><code>81517f6</code></a>
📝 Update tech stack in project generation docs (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14472">#14472</a>)</li>
<li>See full diff in <a
href="https://github.com/fastapi/fastapi/compare/0.124.0...0.124.1">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.124.0&new-version=0.124.1)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-10 12:03:23 +00:00
dependabot[bot]
d2509b7f56
chore(deps): bump fastapi from 0.123.9 to 0.124.0 (#1026)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.123.9 to
0.124.0.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.124.0</h2>
<h3>Features</h3>
<ul>
<li>🚸 Improve tracebacks by adding endpoint metadata. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14306">#14306</a>
by <a
href="https://github.com/savannahostrowski"><code>@​savannahostrowski</code></a>.</li>
</ul>
<h3>Internal</h3>
<ul>
<li>✏️ Fix typo in <code>scripts/mkdocs_hooks.py</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14457">#14457</a>
by <a
href="https://github.com/yujiteshima"><code>@​yujiteshima</code></a>.</li>
</ul>
<h2>0.123.10</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix using class (not instance) dependency that has
<code>__call__</code> method. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14458">#14458</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🐛 Fix <code>separate_input_output_schemas=False</code> with
<code>computed_field</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14453">#14453</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="b5ca13249e"><code>b5ca132</code></a>
🔖 Release version 0.124.0</li>
<li><a
href="a2cef707e3"><code>a2cef70</code></a>
📝 Update release notes</li>
<li><a
href="5b6245666b"><code>5b62456</code></a>
✏️ Fix typo in <code>scripts/mkdocs_hooks.py</code> (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14457">#14457</a>)</li>
<li><a
href="dbd34f1578"><code>dbd34f1</code></a>
📝 Update release notes</li>
<li><a
href="e1117f7550"><code>e1117f7</code></a>
🚸 Improve tracebacks by adding endpoint metadata (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14306">#14306</a>)</li>
<li><a
href="08b09e5236"><code>08b09e5</code></a>
🔖 Release version 0.123.10</li>
<li><a
href="e7d7038dfa"><code>e7d7038</code></a>
📝 Update release notes</li>
<li><a
href="da0ffab0b2"><code>da0ffab</code></a>
🐛 Fix using class (not instance) dependency that has
<code>__call__</code> method (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14458">#14458</a>)</li>
<li><a
href="516169428d"><code>5161694</code></a>
📝 Update release notes</li>
<li><a
href="812a1926f0"><code>812a192</code></a>
🐛 Fix <code>separate_input_output_schemas=False</code> with
<code>computed_field</code> (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14453">#14453</a>)</li>
<li>See full diff in <a
href="https://github.com/fastapi/fastapi/compare/0.123.9...0.124.0">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.123.9&new-version=0.124.0)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-08 12:03:33 +00:00
dependabot[bot]
16a0a00e8f
chore(deps-dev): bump ruff from 0.14.7 to 0.14.8 (#1025)
Bumps [ruff](https://github.com/astral-sh/ruff) from 0.14.7 to 0.14.8.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/astral-sh/ruff/releases">ruff's
releases</a>.</em></p>
<blockquote>
<h2>0.14.8</h2>
<h2>Release Notes</h2>
<p>Released on 2025-12-04.</p>
<h3>Preview features</h3>
<ul>
<li>[<code>flake8-bugbear</code>] Catch <code>yield</code> expressions
within other statements (<code>B901</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21200">#21200</a>)</li>
<li>[<code>flake8-use-pathlib</code>] Mark fixes unsafe for return type
changes (<code>PTH104</code>, <code>PTH105</code>, <code>PTH109</code>,
<code>PTH115</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21440">#21440</a>)</li>
</ul>
<h3>Bug fixes</h3>
<ul>
<li>Fix syntax error false positives for <code>await</code> outside
functions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21763">#21763</a>)</li>
<li>[<code>flake8-simplify</code>] Fix truthiness assumption for
non-iterable arguments in tuple/list/set calls (<code>SIM222</code>,
<code>SIM223</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21479">#21479</a>)</li>
</ul>
<h3>Documentation</h3>
<ul>
<li>Suggest using <code>--output-file</code> option in GitLab
integration (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21706">#21706</a>)</li>
</ul>
<h3>Other changes</h3>
<ul>
<li>[syntax-error] Default type parameter followed by non-default type
parameter (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21657">#21657</a>)</li>
</ul>
<h3>Contributors</h3>
<ul>
<li><a
href="https://github.com/kieran-ryan"><code>@​kieran-ryan</code></a></li>
<li><a href="https://github.com/11happy"><code>@​11happy</code></a></li>
<li><a
href="https://github.com/danparizher"><code>@​danparizher</code></a></li>
<li><a href="https://github.com/ntBre"><code>@​ntBre</code></a></li>
</ul>
<h2>Install ruff 0.14.8</h2>
<h3>Install prebuilt binaries via shell script</h3>
<pre lang="sh"><code>curl --proto '=https' --tlsv1.2 -LsSf
https://github.com/astral-sh/ruff/releases/download/0.14.8/ruff-installer.sh
| sh
</code></pre>
<h3>Install prebuilt binaries via powershell script</h3>
<pre lang="sh"><code>powershell -ExecutionPolicy Bypass -c &quot;irm
https://github.com/astral-sh/ruff/releases/download/0.14.8/ruff-installer.ps1
| iex&quot;
</code></pre>
<h2>Download ruff 0.14.8</h2>
<table>
<thead>
<tr>
<th>File</th>
<th>Platform</th>
<th>Checksum</th>
</tr>
</thead>
<tbody>
<tr>
<td><a
href="https://github.com/astral-sh/ruff/releases/download/0.14.8/ruff-aarch64-apple-darwin.tar.gz">ruff-aarch64-apple-darwin.tar.gz</a></td>
<td>Apple Silicon macOS</td>
<td><a
href="https://github.com/astral-sh/ruff/releases/download/0.14.8/ruff-aarch64-apple-darwin.tar.gz.sha256">checksum</a></td>
</tr>
<tr>
<td><a
href="https://github.com/astral-sh/ruff/releases/download/0.14.8/ruff-x86_64-apple-darwin.tar.gz">ruff-x86_64-apple-darwin.tar.gz</a></td>
<td>Intel macOS</td>
<td><a
href="https://github.com/astral-sh/ruff/releases/download/0.14.8/ruff-x86_64-apple-darwin.tar.gz.sha256">checksum</a></td>
</tr>
</tbody>
</table>
<!-- raw HTML omitted -->
</blockquote>
<p>... (truncated)</p>
</details>
<details>
<summary>Changelog</summary>
<p><em>Sourced from <a
href="https://github.com/astral-sh/ruff/blob/main/CHANGELOG.md">ruff's
changelog</a>.</em></p>
<blockquote>
<h2>0.14.8</h2>
<p>Released on 2025-12-04.</p>
<h3>Preview features</h3>
<ul>
<li>[<code>flake8-bugbear</code>] Catch <code>yield</code> expressions
within other statements (<code>B901</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21200">#21200</a>)</li>
<li>[<code>flake8-use-pathlib</code>] Mark fixes unsafe for return type
changes (<code>PTH104</code>, <code>PTH105</code>, <code>PTH109</code>,
<code>PTH115</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21440">#21440</a>)</li>
</ul>
<h3>Bug fixes</h3>
<ul>
<li>Fix syntax error false positives for <code>await</code> outside
functions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21763">#21763</a>)</li>
<li>[<code>flake8-simplify</code>] Fix truthiness assumption for
non-iterable arguments in tuple/list/set calls (<code>SIM222</code>,
<code>SIM223</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21479">#21479</a>)</li>
</ul>
<h3>Documentation</h3>
<ul>
<li>Suggest using <code>--output-file</code> option in GitLab
integration (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21706">#21706</a>)</li>
</ul>
<h3>Other changes</h3>
<ul>
<li>[syntax-error] Default type parameter followed by non-default type
parameter (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21657">#21657</a>)</li>
</ul>
<h3>Contributors</h3>
<ul>
<li><a
href="https://github.com/kieran-ryan"><code>@​kieran-ryan</code></a></li>
<li><a href="https://github.com/11happy"><code>@​11happy</code></a></li>
<li><a
href="https://github.com/danparizher"><code>@​danparizher</code></a></li>
<li><a href="https://github.com/ntBre"><code>@​ntBre</code></a></li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="9d4f1c6ae2"><code>9d4f1c6</code></a>
Bump 0.14.8 (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21791">#21791</a>)</li>
<li><a
href="326025d45f"><code>326025d</code></a>
[ty] Always register rename provider if client doesn't support dynamic
regist...</li>
<li><a
href="3aefe85b32"><code>3aefe85</code></a>
[ty] Ensure <code>rename</code> <code>CursorTest</code> calls
<code>can_rename</code> before renaming (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21790">#21790</a>)</li>
<li><a
href="b8ecc83a54"><code>b8ecc83</code></a>
Fix clippy errors on <code>main</code> (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21788">#21788</a>)</li>
<li><a
href="6491932757"><code>6491932</code></a>
[ty] Fix crash when hovering an unknown string annotation (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21782">#21782</a>)</li>
<li><a
href="a9f2bb41bd"><code>a9f2bb4</code></a>
[ty] Don't send publish diagnostics for clients supporting pull
diagnostics (...</li>
<li><a
href="e2b72fbf99"><code>e2b72fb</code></a>
[ty] cleanup test path (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21781">#21781</a>)</li>
<li><a
href="14fce0d440"><code>14fce0d</code></a>
[ty] Improve the display of various special-form types (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21775">#21775</a>)</li>
<li><a
href="8ebecb2a88"><code>8ebecb2</code></a>
[ty] Add subdiagnostic hint if the user wrote <code>X = Any</code>
rather than <code>X: Any</code> ...</li>
<li><a
href="45ac30a4d7"><code>45ac30a</code></a>
[ty] Teach <code>ty</code> the meaning of desperation (try ancestor
<code>pyproject.toml</code>s as...</li>
<li>Additional commits viewable in <a
href="https://github.com/astral-sh/ruff/compare/0.14.7...0.14.8">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=ruff&package-manager=pip&previous-version=0.14.7&new-version=0.14.8)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-05 12:03:53 +00:00
dependabot[bot]
c9bbc5877c
chore(deps): bump fastapi from 0.123.7 to 0.123.9 (#1024)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.123.7 to
0.123.9.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.123.9</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix OAuth2 scopes in OpenAPI in extra corner cases, parent
dependency with scopes, sub-dependency security scheme without scopes.
PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14459">#14459</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h2>0.123.8</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix OpenAPI security scheme OAuth2 scopes declaration, deduplicate
security schemes with different scopes. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14455">#14455</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="f0dd1046a6"><code>f0dd104</code></a>
🔖 Release version 0.123.9</li>
<li><a
href="188d631011"><code>188d631</code></a>
📝 Update release notes</li>
<li><a
href="0b5fa563cd"><code>0b5fa56</code></a>
🐛 Fix OAuth2 scopes in OpenAPI in extra corner cases, parent dependency
with ...</li>
<li><a
href="eb1d50479b"><code>eb1d504</code></a>
🔖 Release version 0.123.8</li>
<li><a
href="e248a4d22b"><code>e248a4d</code></a>
📝 Update release notes</li>
<li><a
href="0ec4bafca2"><code>0ec4baf</code></a>
🐛 Fix OpenAPI security scheme OAuth2 scopes declaration, deduplicate
security...</li>
<li>See full diff in <a
href="https://github.com/fastapi/fastapi/compare/0.123.7...0.123.9">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.123.7&new-version=0.123.9)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-05 12:03:37 +00:00
dependabot[bot]
8df36ce076
chore(deps): bump fastapi from 0.123.5 to 0.123.7 (#1022)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.123.5 to
0.123.7.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.123.7</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix evaluating stringified annotations in Python 3.10. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/11355">#11355</a>
by <a href="https://github.com/chaen"><code>@​chaen</code></a>.</li>
</ul>
<h2>0.123.6</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix support for functools wraps and partial combined, for async
and regular functions and classes in path operations and dependencies.
PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14448">#14448</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="603df6e36f"><code>603df6e</code></a>
🔖 Release version 0.123.7</li>
<li><a
href="6c565482cf"><code>6c56548</code></a>
📝 Update release notes</li>
<li><a
href="861598b4e3"><code>861598b</code></a>
🐛 Fix evaluating stringified annotations in Python 3.10 (<a
href="https://redirect.github.com/fastapi/fastapi/issues/11355">#11355</a>)</li>
<li><a
href="811fa89875"><code>811fa89</code></a>
🔖 Release version 0.123.6</li>
<li><a
href="6c6b9d7a2b"><code>6c6b9d7</code></a>
📝 Update release notes</li>
<li><a
href="bba4d4c95e"><code>bba4d4c</code></a>
🐛 Fix support for functools wraps and partial combined, for async and
regular...</li>
<li>See full diff in <a
href="https://github.com/fastapi/fastapi/compare/0.123.5...0.123.7">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.123.5&new-version=0.123.7)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-04 12:03:51 +00:00
dependabot[bot]
c888b8947b
chore(deps): bump fastapi from 0.123.4 to 0.123.5 (#1021)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.123.4 to
0.123.5.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.123.5</h2>
<h3>Features</h3>
<ul>
<li> Allow using dependables with <code>functools.partial()</code>. PR
<a
href="https://redirect.github.com/fastapi/fastapi/pull/9753">#9753</a>
by <a href="https://github.com/lieryan"><code>@​lieryan</code></a>.</li>
<li> Add support for wrapped functions (e.g.
<code>@functools.wraps()</code>) used with forward references. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/5077">#5077</a>
by <a
href="https://github.com/lucaswiman"><code>@​lucaswiman</code></a>.</li>
<li> Handle wrapped dependencies. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/9555">#9555</a>
by <a href="https://github.com/phy1729"><code>@​phy1729</code></a>.</li>
</ul>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix optional sequence handling with new union syntax from Python
3.10. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14430">#14430</a>
by <a href="https://github.com/Viicos"><code>@​Viicos</code></a>.</li>
</ul>
<h3>Refactors</h3>
<ul>
<li>🔥 Remove dangling extra condiitonal no longer needed. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14435">#14435</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>♻️ Refactor internals, update <code>is_coroutine</code> check to
reuse internal supported variants (unwrap, check class). PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14434">#14434</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Translations</h3>
<ul>
<li>🌐 Sync German docs. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14367">#14367</a>
by <a
href="https://github.com/nilslindemann"><code>@​nilslindemann</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="c57ac7bdf3"><code>c57ac7b</code></a>
🔖 Release version 0.123.5</li>
<li><a
href="3c440c762a"><code>3c440c7</code></a>
📝 Update release notes</li>
<li><a
href="9824486616"><code>9824486</code></a>
 Allow using dependables with <code>functools.partial()</code> (<a
href="https://redirect.github.com/fastapi/fastapi/issues/9753">#9753</a>)</li>
<li><a
href="aee8e78078"><code>aee8e78</code></a>
📝 Update release notes</li>
<li><a
href="f4a17b7568"><code>f4a17b7</code></a>
🌐 Sync German docs (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14367">#14367</a>)</li>
<li><a
href="4ade6d62e2"><code>4ade6d6</code></a>
📝 Update release notes</li>
<li><a
href="1c1e584abd"><code>1c1e584</code></a>
 Add support for wrapped functions (e.g.
<code>@functools.wraps()</code>) used with for...</li>
<li><a
href="930b27e5fa"><code>930b27e</code></a>
📝 Update release notes</li>
<li><a
href="80d69ae0bb"><code>80d69ae</code></a>
🐛 Fix optional sequence handling with new union syntax from Python 3.10
(<a
href="https://redirect.github.com/fastapi/fastapi/issues/14430">#14430</a>)</li>
<li><a
href="cff2236dac"><code>cff2236</code></a>
📝 Update release notes</li>
<li>Additional commits viewable in <a
href="https://github.com/fastapi/fastapi/compare/0.123.4...0.123.5">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.123.4&new-version=0.123.5)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-03 12:04:00 +00:00
dependabot[bot]
26b31f3c05
chore(deps): bump fastapi from 0.123.0 to 0.123.4 (#1020)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.123.0 to
0.123.4.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.123.4</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix OpenAPI schema support for computed fields when using
<code>separate_input_output_schemas=False</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/13207">#13207</a>
by <a href="https://github.com/vgrafe"><code>@​vgrafe</code></a>.</li>
</ul>
<h3>Docs</h3>
<ul>
<li>📝 Fix docstring of <code>servers</code> parameter. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14405">#14405</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
</ul>
<h2>0.123.3</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix Query\Header\Cookie parameter model alias. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14360">#14360</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🐛 Fix optional sequence handling in <code>serialize sequence
value</code> with Pydantic V2. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14297">#14297</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
</ul>
<h2>0.123.2</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix unformatted <code>{type_}</code> in FastAPIError. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14416">#14416</a>
by <a
href="https://github.com/Just-Helpful"><code>@​Just-Helpful</code></a>.</li>
<li>🐛 Fix parsing extra non-body parameter list. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14356">#14356</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🐛 Fix parsing extra <code>Form</code> parameter list. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14303">#14303</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🐛 Fix support for form values with empty strings interpreted as
missing (<code>None</code> if that's the default), for compatibility
with HTML forms. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/13537">#13537</a>
by <a
href="https://github.com/MarinPostma"><code>@​MarinPostma</code></a>.</li>
</ul>
<h3>Docs</h3>
<ul>
<li>📝 Add tip on how to install <code>pip</code> in case of <code>No
module named pip</code> error in <code>virtual-environments.md</code>.
PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14211">#14211</a>
by <a
href="https://github.com/zadevhub"><code>@​zadevhub</code></a>.</li>
<li>📝 Update Primary Key notes for the SQL databases tutorial to avoid
confusion. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14120">#14120</a>
by <a
href="https://github.com/FlaviusRaducu"><code>@​FlaviusRaducu</code></a>.</li>
<li>📝 Clarify estimation note in documentation. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14070">#14070</a>
by <a
href="https://github.com/SaisakthiM"><code>@​SaisakthiM</code></a>.</li>
</ul>
<h2>0.123.1</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Avoid accessing non-existing &quot;$ref&quot; key for Pydantic v2
compat remapping. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14361">#14361</a>
by <a
href="https://github.com/svlandeg"><code>@​svlandeg</code></a>.</li>
<li>🐛 Fix <code>TypeError</code> when encoding a decimal with a
<code>NaN</code> or <code>Infinity</code> value. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/12935">#12935</a>
by <a
href="https://github.com/kentwelcome"><code>@​kentwelcome</code></a>.</li>
</ul>
<h3>Internal</h3>
<ul>
<li>🐛 Fix Windows UnicodeEncodeError in CLI test. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14295">#14295</a>
by <a
href="https://github.com/hemanth-thirthahalli"><code>@​hemanth-thirthahalli</code></a>.</li>
<li>🔧 Update sponsors: add Greptile. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14429">#14429</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👥 Update FastAPI GitHub topic repositories. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14426">#14426</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>⬆ Bump markdown-include-variants from 0.0.6 to 0.0.7. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14423">#14423</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>👥 Update FastAPI People - Sponsors. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14422">#14422</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👥 Update FastAPI People - Contributors and Translators. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14420">#14420</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="4976568fc7"><code>4976568</code></a>
🔖 Release version 0.123.4</li>
<li><a
href="fb30cc2f50"><code>fb30cc2</code></a>
📝 Update release notes</li>
<li><a
href="f95a174288"><code>f95a174</code></a>
🐛 Fix OpenAPI schema support for computed fields when using
`separate_input_o...</li>
<li><a
href="5126e099bd"><code>5126e09</code></a>
📝 Update release notes</li>
<li><a
href="dcf0299195"><code>dcf0299</code></a>
📝 Fix docstring of <code>servers</code> parameter (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14405">#14405</a>)</li>
<li><a
href="c516c9904b"><code>c516c99</code></a>
🔖 Release version 0.123.3</li>
<li><a
href="b49c05ec22"><code>b49c05e</code></a>
📝 Update release notes</li>
<li><a
href="015b4fae9c"><code>015b4fa</code></a>
🐛 Fix Query\Header\Cookie parameter model alias (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14360">#14360</a>)</li>
<li><a
href="eead41bf4c"><code>eead41b</code></a>
📝 Update release notes</li>
<li><a
href="0f613d9051"><code>0f613d9</code></a>
🐛 Fix optional sequence handling in <code>serialize sequence
value</code> with Pydantic ...</li>
<li>Additional commits viewable in <a
href="https://github.com/fastapi/fastapi/compare/0.123.0...0.123.4">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.123.0&new-version=0.123.4)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-02 12:03:46 +00:00
dependabot[bot]
ab24064f83
chore(deps-dev): bump ruff from 0.14.6 to 0.14.7 (#1018)
Bumps [ruff](https://github.com/astral-sh/ruff) from 0.14.6 to 0.14.7.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/astral-sh/ruff/releases">ruff's
releases</a>.</em></p>
<blockquote>
<h2>0.14.7</h2>
<h2>Release Notes</h2>
<p>Released on 2025-11-28.</p>
<h3>Preview features</h3>
<ul>
<li>[<code>flake8-bandit</code>] Handle string literal bindings in
suspicious-url-open-usage (<code>S310</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21469">#21469</a>)</li>
<li>[<code>pylint</code>] Fix <code>PLR1708</code> false positives on
nested functions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21177">#21177</a>)</li>
<li>[<code>pylint</code>] Fix suppression for empty dict without tuple
key annotation (<code>PLE1141</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21290">#21290</a>)</li>
<li>[<code>ruff</code>] Add rule <code>RUF066</code> to detect
unnecessary class properties (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21535">#21535</a>)</li>
<li>[<code>ruff</code>] Catch more dummy variable uses
(<code>RUF052</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/19799">#19799</a>)</li>
</ul>
<h3>Bug fixes</h3>
<ul>
<li>[server] Set severity for non-rule diagnostics (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21559">#21559</a>)</li>
<li>[<code>flake8-implicit-str-concat</code>] Avoid invalid fix in
(<code>ISC003</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21517">#21517</a>)</li>
<li>[<code>parser</code>] Fix panic when parsing IPython escape command
expressions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21480">#21480</a>)</li>
</ul>
<h3>CLI</h3>
<ul>
<li>Show partial fixability indicator in statistics output (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21513">#21513</a>)</li>
</ul>
<h3>Contributors</h3>
<ul>
<li><a
href="https://github.com/mikeleppane"><code>@​mikeleppane</code></a></li>
<li><a href="https://github.com/senekor"><code>@​senekor</code></a></li>
<li><a
href="https://github.com/ShaharNaveh"><code>@​ShaharNaveh</code></a></li>
<li><a
href="https://github.com/JumboBear"><code>@​JumboBear</code></a></li>
<li><a
href="https://github.com/prakhar1144"><code>@​prakhar1144</code></a></li>
<li><a href="https://github.com/tsvikas"><code>@​tsvikas</code></a></li>
<li><a
href="https://github.com/danparizher"><code>@​danparizher</code></a></li>
<li><a
href="https://github.com/chirizxc"><code>@​chirizxc</code></a></li>
<li><a
href="https://github.com/AlexWaygood"><code>@​AlexWaygood</code></a></li>
<li><a
href="https://github.com/MichaReiser"><code>@​MichaReiser</code></a></li>
</ul>
<h2>Install ruff 0.14.7</h2>
<h3>Install prebuilt binaries via shell script</h3>
<pre lang="sh"><code>curl --proto '=https' --tlsv1.2 -LsSf
https://github.com/astral-sh/ruff/releases/download/0.14.7/ruff-installer.sh
| sh
</code></pre>
<h3>Install prebuilt binaries via powershell script</h3>
<pre lang="sh"><code>powershell -ExecutionPolicy Bypass -c &quot;irm
https://github.com/astral-sh/ruff/releases/download/0.14.7/ruff-installer.ps1
| iex&quot;
</code></pre>
<!-- raw HTML omitted -->
</blockquote>
<p>... (truncated)</p>
</details>
<details>
<summary>Changelog</summary>
<p><em>Sourced from <a
href="https://github.com/astral-sh/ruff/blob/main/CHANGELOG.md">ruff's
changelog</a>.</em></p>
<blockquote>
<h2>0.14.7</h2>
<p>Released on 2025-11-28.</p>
<h3>Preview features</h3>
<ul>
<li>[<code>flake8-bandit</code>] Handle string literal bindings in
suspicious-url-open-usage (<code>S310</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21469">#21469</a>)</li>
<li>[<code>pylint</code>] Fix <code>PLR1708</code> false positives on
nested functions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21177">#21177</a>)</li>
<li>[<code>pylint</code>] Fix suppression for empty dict without tuple
key annotation (<code>PLE1141</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21290">#21290</a>)</li>
<li>[<code>ruff</code>] Add rule <code>RUF066</code> to detect
unnecessary class properties (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21535">#21535</a>)</li>
<li>[<code>ruff</code>] Catch more dummy variable uses
(<code>RUF052</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/19799">#19799</a>)</li>
</ul>
<h3>Bug fixes</h3>
<ul>
<li>[server] Set severity for non-rule diagnostics (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21559">#21559</a>)</li>
<li>[<code>flake8-implicit-str-concat</code>] Avoid invalid fix in
(<code>ISC003</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21517">#21517</a>)</li>
<li>[<code>parser</code>] Fix panic when parsing IPython escape command
expressions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21480">#21480</a>)</li>
</ul>
<h3>CLI</h3>
<ul>
<li>Show partial fixability indicator in statistics output (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21513">#21513</a>)</li>
</ul>
<h3>Contributors</h3>
<ul>
<li><a
href="https://github.com/mikeleppane"><code>@​mikeleppane</code></a></li>
<li><a href="https://github.com/senekor"><code>@​senekor</code></a></li>
<li><a
href="https://github.com/ShaharNaveh"><code>@​ShaharNaveh</code></a></li>
<li><a
href="https://github.com/JumboBear"><code>@​JumboBear</code></a></li>
<li><a
href="https://github.com/prakhar1144"><code>@​prakhar1144</code></a></li>
<li><a href="https://github.com/tsvikas"><code>@​tsvikas</code></a></li>
<li><a
href="https://github.com/danparizher"><code>@​danparizher</code></a></li>
<li><a
href="https://github.com/chirizxc"><code>@​chirizxc</code></a></li>
<li><a
href="https://github.com/AlexWaygood"><code>@​AlexWaygood</code></a></li>
<li><a
href="https://github.com/MichaReiser"><code>@​MichaReiser</code></a></li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="ecab623fb2"><code>ecab623</code></a>
Bump 0.14.7 (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21684">#21684</a>)</li>
<li><a
href="42f152108a"><code>42f1521</code></a>
[ty] Generic types aliases (implicit and PEP 613) (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21553">#21553</a>)</li>
<li><a
href="594b7b04d3"><code>594b7b0</code></a>
[ty] Preserve quoting style when autofixing <code>TypedDict</code> keys
(<a
href="https://redirect.github.com/astral-sh/ruff/issues/21682">#21682</a>)</li>
<li><a
href="b5b4917d7f"><code>b5b4917</code></a>
[ty] Fix override of final method summary (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21681">#21681</a>)</li>
<li><a
href="0084e94f78"><code>0084e94</code></a>
[ty] Fix subtyping of <code>type[Any]</code> / <code>type[T]</code> and
protocols (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21678">#21678</a>)</li>
<li><a
href="566c959add"><code>566c959</code></a>
[ty] Rename <code>ReferenceRequestHandler</code> file (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21680">#21680</a>)</li>
<li><a
href="8bcfc198b8"><code>8bcfc19</code></a>
[ty] Implement <code>typing.final</code> for methods (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21646">#21646</a>)</li>
<li><a
href="c534bfaf01"><code>c534bfa</code></a>
[ty] Implement patterns and typevars in the LSP (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21671">#21671</a>)</li>
<li><a
href="5e1b2eef57"><code>5e1b2ee</code></a>
[ty] implement rendering of <code>.. code:: lang</code> in docstrings
(<a
href="https://redirect.github.com/astral-sh/ruff/issues/21665">#21665</a>)</li>
<li><a
href="98681b9356"><code>98681b9</code></a>
[ty] Add <code>db</code> parameter to <code>Parameters::new</code>
method (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21674">#21674</a>)</li>
<li>Additional commits viewable in <a
href="https://github.com/astral-sh/ruff/compare/0.14.6...0.14.7">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=ruff&package-manager=pip&previous-version=0.14.6&new-version=0.14.7)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-01 13:01:08 +00:00
dependabot[bot]
05acb51447
chore(deps): bump fastapi from 0.122.0 to 0.123.0 (#1017)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.122.0 to
0.123.0.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.123.0</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Cache dependencies that don't use scopes and don't have
sub-dependencies with scopes. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14419">#14419</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h2>0.122.1</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Fix hierarchical security scope propagation. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/5624">#5624</a>
by <a
href="https://github.com/kristjanvalur"><code>@​kristjanvalur</code></a>.</li>
</ul>
<h3>Docs</h3>
<ul>
<li>💅 Update CSS to explicitly use emoji font. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14415">#14415</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Internal</h3>
<ul>
<li>⬆ Bump markdown-include-variants from 0.0.5 to 0.0.6. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14418">#14418</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="f2bab95267"><code>f2bab95</code></a>
🔖 Release version 0.123.0</li>
<li><a
href="c38e3e0108"><code>c38e3e0</code></a>
📝 Update release notes</li>
<li><a
href="7fbd30460f"><code>7fbd304</code></a>
🐛 Cache dependencies that don't use scopes and don't have
sub-dependencies wi...</li>
<li><a
href="63d7a2b997"><code>63d7a2b</code></a>
🔖 Release version 0.122.1</li>
<li><a
href="7681f2904d"><code>7681f29</code></a>
📝 Update release notes</li>
<li><a
href="378ad688b7"><code>378ad68</code></a>
🐛 Fix hierarchical security scope propagation (<a
href="https://redirect.github.com/fastapi/fastapi/issues/5624">#5624</a>)</li>
<li><a
href="c6487ed632"><code>c6487ed</code></a>
📝 Update release notes</li>
<li><a
href="62a6974004"><code>62a6974</code></a>
⬆ Bump markdown-include-variants from 0.0.5 to 0.0.6 (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14418">#14418</a>)</li>
<li><a
href="998288261a"><code>9982882</code></a>
📝 Update release notes</li>
<li><a
href="8ab7167eaf"><code>8ab7167</code></a>
💅 Update CSS to explicitly use emoji font (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14415">#14415</a>)</li>
<li>See full diff in <a
href="https://github.com/fastapi/fastapi/compare/0.122.0...0.123.0">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.122.0&new-version=0.123.0)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-12-01 13:00:55 +00:00
bobokun
b32a1a3acc Update SUPPORTED_VERSIONS.json 2025-11-29 10:03:01 -05:00
github-actions[bot]
a8e22a51a2 Update VERSION to 4.6.6-develop1 [skip ci] 2025-11-29 14:59:22 +00:00
bobokun
371627bbeb 4.6.5 2025-11-29 09:59:11 -05:00
bobokun
1570c01b4c feat(tags): add support for tagging private torrents
Introduces a new `private_tag` setting to automatically tag torrents
identified as private.

Changes include:
- Added `is_torrent_private` method to check torrent privacy status via
  attributes or tracker messages
- Updated tagging logic to apply the configured private tag
- Added `private_tag` to config, docs, and Web UI schema
- Bumped version to 4.6.5-develop11
- Adds [FR]: Allow tagging by "Private" tracker or otherwise
Fixes #883
2025-11-29 09:59:11 -05:00
bobokun
5b9d4d806e feat(unregistered): add max limit for unregistered torrent removal
Adds `rem_unregistered_max_torrents` setting to limit the number of
torrents removed per tracker in a single run. This acts as a safeguard
against mass deletions if a tracker reports incorrect status.

- Default limit is set to 10
- Set to 0 to disable the limit
- Updates config, docs, and Web UI
Closes [FR]: Add max limit to rem_unregistered per tracker
Fixes #975
2025-11-29 09:59:11 -05:00
bobokun
ad00f81de2 refactor(share_limits): simplify logic and reduce code duplication
Extract logging and update condition logic into helper methods to improve
readability. Consolidate repetitive tag management code in
`process_share_limits_for_torrent` using internal helper functions.
Optimize torrent updates by tracking tag changes.
2025-11-29 09:59:11 -05:00
bobokun
a519a5bd26 fix(share_limits): skip processing if no action configured
Only process torrents that have reached their seed limits if cleanup
is enabled or if an upload speed limit change is configured. This
prevents unnecessary logging and processing when no action is defined.
2025-11-29 09:59:11 -05:00
bobokun
c0a14f4de6 chore(deps): update ruff-pre-commit to v0.14.6 2025-11-29 09:59:11 -05:00
bobokun
ab3aafe393 fix(share_limits): set limits when throttle skipped
When upload_speed_on_limit_reached is 0, the logic returned early
without applying the configured share limits. This ensures limits are
applied even if throttling is not configured.
2025-11-29 09:59:11 -05:00
dependabot[bot]
320a1b0fe3 Bump fastapi from 0.121.3 to 0.122.0 (#1013)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.121.3 to
0.122.0.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.122.0</h2>
<h3>Fixes</h3>
<ul>
<li>🐛 Use <code>401</code> status code in security classes when
credentials are missing. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/13786">#13786</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.
<ul>
<li>If your code depended on these classes raising the old (less
correct) <code>403</code> status code, check the new docs about how to
override the classes, to use the same old behavior: <a
href="https://fastapi.tiangolo.com/how-to/authentication-error-status-code/">Use
Old 403 Authentication Error Status Codes</a>.</li>
</ul>
</li>
</ul>
<h3>Internal</h3>
<ul>
<li>🔧 Configure labeler to exclude files that start from underscore for
<code>lang-all</code> label. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14213">#14213</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>👷 Add pre-commit config with local script for permalinks. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14398">#14398</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>💄 Use font Fira Code to fix display of Rich panels in docs in
Windows. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14387">#14387</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>👷 Add custom pre-commit CI. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14397">#14397</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
<li>⬆ Bump actions/checkout from 5 to 6. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14381">#14381</a>
by <a
href="https://github.com/apps/dependabot"><code>@​dependabot[bot]</code></a>.</li>
<li>👷 Upgrade <code>latest-changes</code> GitHub Action and pin
<code>actions/checkout@v5</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14403">#14403</a>
by <a
href="https://github.com/svlandeg"><code>@​svlandeg</code></a>.</li>
<li>🛠️ Add <code>add-permalinks</code> and
<code>add-permalinks-page</code> to <code>scripts/docs.py</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14033">#14033</a>
by <a
href="https://github.com/YuriiMotov"><code>@​YuriiMotov</code></a>.</li>
<li>🔧 Upgrade Material for MkDocs and remove insiders. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14375">#14375</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="5b0625df96"><code>5b0625d</code></a>
🔖 Release version 0.122.0</li>
<li><a
href="8732c53478"><code>8732c53</code></a>
📝 Updates release notes</li>
<li><a
href="a4ef97afd9"><code>a4ef97a</code></a>
📝 Update release notes</li>
<li><a
href="51ad909ffe"><code>51ad909</code></a>
🐛 Use <code>401</code> status code in security classes when credentials
are missing (<a
href="https://redirect.github.com/fastapi/fastapi/issues/13">#13</a>...</li>
<li><a
href="e2354a0a06"><code>e2354a0</code></a>
📝 Update release notes</li>
<li><a
href="cc66dee55c"><code>cc66dee</code></a>
📝 Update release notes</li>
<li><a
href="ecfb752487"><code>ecfb752</code></a>
📝 Update release notes</li>
<li><a
href="8b18522205"><code>8b18522</code></a>
📝 Update release notes</li>
<li><a
href="a2395e0243"><code>a2395e0</code></a>
📝 Update release notes</li>
<li><a
href="c7d05a903c"><code>c7d05a9</code></a>
📝 Update release notes</li>
<li>Additional commits viewable in <a
href="https://github.com/fastapi/fastapi/compare/0.121.3...0.122.0">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.121.3&new-version=0.122.0)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-11-29 09:59:11 -05:00
bobokun
dfc4bc370f Better error handling for #982 2025-11-29 09:59:11 -05:00
bobokun
85950b9c72 fix(share_limits): add validation and skip logic for upload_speed_on_limit_reached
Add proper validation for upload_speed_on_limit_reached configuration:
- Skip throttle application when value is 0 (not configured)
- Validate that throttle value is >= -1, log warning for invalid values
- Remove unnecessary condition check that prevented unlimited (-1) throttle
- Improve throttle comparison logic to work correctly with KiB/s values

This ensures the upload speed throttling feature works as intended and
handles edge cases gracefully without applying invalid configurations.
2025-11-29 09:59:11 -05:00
pre-commit-ci[bot]
2507e76b36 [pre-commit.ci] pre-commit autoupdate
updates:
- [github.com/astral-sh/ruff-pre-commit: v0.14.4 → v0.14.5](https://github.com/astral-sh/ruff-pre-commit/compare/v0.14.4...v0.14.5)
2025-11-29 09:59:11 -05:00
bobokun
2f0ca4bdd0 bump develop 2025-11-29 09:59:11 -05:00
Erik Müller
2dfe50a304 Pre check if share limits are reached 2025-11-29 09:59:11 -05:00
Erik Müller
47308469ed Ensure share limits are updated when reached 2025-11-29 09:59:11 -05:00
Erik Müller
937fc8bed8 Fix upload_speed_on_limit_reached toggles share limits 2025-11-29 09:59:11 -05:00
dependabot[bot]
564f9f3fc9 Bump actions/checkout from 5 to 6
Bumps [actions/checkout](https://github.com/actions/checkout) from 5 to 6.
- [Release notes](https://github.com/actions/checkout/releases)
- [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md)
- [Commits](https://github.com/actions/checkout/compare/v5...v6)

---
updated-dependencies:
- dependency-name: actions/checkout
  dependency-version: '6'
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
2025-11-29 09:59:11 -05:00
dependabot[bot]
e4ce032797 Bump ruff from 0.14.5 to 0.14.6 (#1011)
Bumps [ruff](https://github.com/astral-sh/ruff) from 0.14.5 to 0.14.6.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/astral-sh/ruff/releases">ruff's
releases</a>.</em></p>
<blockquote>
<h2>0.14.6</h2>
<h2>Release Notes</h2>
<p>Released on 2025-11-21.</p>
<h3>Preview features</h3>
<ul>
<li>[<code>flake8-bandit</code>] Support new PySNMP API paths
(<code>S508</code>, <code>S509</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21374">#21374</a>)</li>
</ul>
<h3>Bug fixes</h3>
<ul>
<li>Adjust own-line comment placement between branches (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21185">#21185</a>)</li>
<li>Avoid syntax error when formatting attribute expressions with outer
parentheses, parenthesized value, and trailing comment on value (<a
href="https://redirect.github.com/astral-sh/ruff/pull/20418">#20418</a>)</li>
<li>Fix panic when formatting comments in unary expressions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21501">#21501</a>)</li>
<li>Respect <code>fmt: skip</code> for compound statements on a single
line (<a
href="https://redirect.github.com/astral-sh/ruff/pull/20633">#20633</a>)</li>
<li>[<code>refurb</code>] Fix <code>FURB103</code> autofix (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21454">#21454</a>)</li>
<li>[<code>ruff</code>] Fix false positive for complex conversion
specifiers in <code>logging-eager-conversion</code>
(<code>RUF065</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21464">#21464</a>)</li>
</ul>
<h3>Rule changes</h3>
<ul>
<li>[<code>ruff</code>] Avoid false positive on <code>ClassVar</code>
reassignment (<code>RUF012</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21478">#21478</a>)</li>
</ul>
<h3>CLI</h3>
<ul>
<li>Render hyperlinks for lint errors (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21514">#21514</a>)</li>
<li>Add a <code>ruff analyze</code> option to skip over imports in
<code>TYPE_CHECKING</code> blocks (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21472">#21472</a>)</li>
</ul>
<h3>Documentation</h3>
<ul>
<li>Limit <code>eglot-format</code> hook to eglot-managed Python buffers
(<a
href="https://redirect.github.com/astral-sh/ruff/pull/21459">#21459</a>)</li>
<li>Mention <code>force-exclude</code> in &quot;Configuration &gt;
Python file discovery&quot; (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21500">#21500</a>)</li>
</ul>
<h3>Contributors</h3>
<ul>
<li><a href="https://github.com/ntBre"><code>@​ntBre</code></a></li>
<li><a href="https://github.com/dylwil3"><code>@​dylwil3</code></a></li>
<li><a
href="https://github.com/gauthsvenkat"><code>@​gauthsvenkat</code></a></li>
<li><a
href="https://github.com/MichaReiser"><code>@​MichaReiser</code></a></li>
<li><a href="https://github.com/thamer"><code>@​thamer</code></a></li>
<li><a
href="https://github.com/Ruchir28"><code>@​Ruchir28</code></a></li>
<li><a
href="https://github.com/thejcannon"><code>@​thejcannon</code></a></li>
<li><a
href="https://github.com/danparizher"><code>@​danparizher</code></a></li>
<li><a
href="https://github.com/chirizxc"><code>@​chirizxc</code></a></li>
</ul>
<h2>Install ruff 0.14.6</h2>
<h3>Install prebuilt binaries via shell script</h3>
<pre lang="sh"><code>curl --proto '=https' --tlsv1.2 -LsSf
https://github.com/astral-sh/ruff/releases/download/0.14.6/ruff-installer.sh
| sh
&lt;/tr&gt;&lt;/table&gt; 
</code></pre>
</blockquote>
<p>... (truncated)</p>
</details>
<details>
<summary>Changelog</summary>
<p><em>Sourced from <a
href="https://github.com/astral-sh/ruff/blob/main/CHANGELOG.md">ruff's
changelog</a>.</em></p>
<blockquote>
<h2>0.14.6</h2>
<p>Released on 2025-11-21.</p>
<h3>Preview features</h3>
<ul>
<li>[<code>flake8-bandit</code>] Support new PySNMP API paths
(<code>S508</code>, <code>S509</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21374">#21374</a>)</li>
</ul>
<h3>Bug fixes</h3>
<ul>
<li>Adjust own-line comment placement between branches (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21185">#21185</a>)</li>
<li>Avoid syntax error when formatting attribute expressions with outer
parentheses, parenthesized value, and trailing comment on value (<a
href="https://redirect.github.com/astral-sh/ruff/pull/20418">#20418</a>)</li>
<li>Fix panic when formatting comments in unary expressions (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21501">#21501</a>)</li>
<li>Respect <code>fmt: skip</code> for compound statements on a single
line (<a
href="https://redirect.github.com/astral-sh/ruff/pull/20633">#20633</a>)</li>
<li>[<code>refurb</code>] Fix <code>FURB103</code> autofix (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21454">#21454</a>)</li>
<li>[<code>ruff</code>] Fix false positive for complex conversion
specifiers in <code>logging-eager-conversion</code>
(<code>RUF065</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21464">#21464</a>)</li>
</ul>
<h3>Rule changes</h3>
<ul>
<li>[<code>ruff</code>] Avoid false positive on <code>ClassVar</code>
reassignment (<code>RUF012</code>) (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21478">#21478</a>)</li>
</ul>
<h3>CLI</h3>
<ul>
<li>Render hyperlinks for lint errors (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21514">#21514</a>)</li>
<li>Add a <code>ruff analyze</code> option to skip over imports in
<code>TYPE_CHECKING</code> blocks (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21472">#21472</a>)</li>
</ul>
<h3>Documentation</h3>
<ul>
<li>Limit <code>eglot-format</code> hook to eglot-managed Python buffers
(<a
href="https://redirect.github.com/astral-sh/ruff/pull/21459">#21459</a>)</li>
<li>Mention <code>force-exclude</code> in &quot;Configuration &gt;
Python file discovery&quot; (<a
href="https://redirect.github.com/astral-sh/ruff/pull/21500">#21500</a>)</li>
</ul>
<h3>Contributors</h3>
<ul>
<li><a href="https://github.com/ntBre"><code>@​ntBre</code></a></li>
<li><a href="https://github.com/dylwil3"><code>@​dylwil3</code></a></li>
<li><a
href="https://github.com/gauthsvenkat"><code>@​gauthsvenkat</code></a></li>
<li><a
href="https://github.com/MichaReiser"><code>@​MichaReiser</code></a></li>
<li><a href="https://github.com/thamer"><code>@​thamer</code></a></li>
<li><a
href="https://github.com/Ruchir28"><code>@​Ruchir28</code></a></li>
<li><a
href="https://github.com/thejcannon"><code>@​thejcannon</code></a></li>
<li><a
href="https://github.com/danparizher"><code>@​danparizher</code></a></li>
<li><a
href="https://github.com/chirizxc"><code>@​chirizxc</code></a></li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="59c6cb521d"><code>59c6cb5</code></a>
Bump 0.14.6 (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21558">#21558</a>)</li>
<li><a
href="54dba15088"><code>54dba15</code></a>
[ty] Improve debug messages when imports fail (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21555">#21555</a>)</li>
<li><a
href="1af318534a"><code>1af3185</code></a>
[ty] Add support for relative import completions</li>
<li><a
href="553e568624"><code>553e568</code></a>
[ty] Refactor detection of import statements for completions</li>
<li><a
href="cdef3f5ab8"><code>cdef3f5</code></a>
[ty] Use dedicated collector for completions</li>
<li><a
href="6178822427"><code>6178822</code></a>
[ty] Attach subdiagnostics to <code>unresolved-import</code> errors for
relative imports...</li>
<li><a
href="6b7adb0537"><code>6b7adb0</code></a>
[ty] support PEP 613 type aliases (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21394">#21394</a>)</li>
<li><a
href="06941c1987"><code>06941c1</code></a>
[ty] More low-hanging fruit for inlay hint goto-definition (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21548">#21548</a>)</li>
<li><a
href="eb7c098d6b"><code>eb7c098</code></a>
[ty] implement <code>TypedDict</code> structural assignment (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21467">#21467</a>)</li>
<li><a
href="1b28fc1f14"><code>1b28fc1</code></a>
[ty] Add more random TypeDetails and tests (<a
href="https://redirect.github.com/astral-sh/ruff/issues/21546">#21546</a>)</li>
<li>Additional commits viewable in <a
href="https://github.com/astral-sh/ruff/compare/0.14.5...0.14.6">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=ruff&package-manager=pip&previous-version=0.14.5&new-version=0.14.6)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-11-29 09:59:11 -05:00
bobokun
e5398169d0 Update SUPPORTED_VERSIONS.json 2025-11-29 09:59:11 -05:00
dependabot[bot]
977eeba8a8 Bump qbittorrent-api from 2025.11.0 to 2025.11.1 (#1007) 2025-11-29 09:59:11 -05:00
dependabot[bot]
3560d2861e Bump fastapi from 0.121.2 to 0.121.3 (#1006)
Bumps [fastapi](https://github.com/fastapi/fastapi) from 0.121.2 to
0.121.3.
<details>
<summary>Release notes</summary>
<p><em>Sourced from <a
href="https://github.com/fastapi/fastapi/releases">fastapi's
releases</a>.</em></p>
<blockquote>
<h2>0.121.3</h2>
<h3>Refactors</h3>
<ul>
<li>♻️ Make the result of <code>Depends()</code> and
<code>Security()</code> hashable, as a workaround for other tools
interacting with these internal parts. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14372">#14372</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
<h3>Upgrades</h3>
<ul>
<li>⬆️ Bump Starlette to &lt;<code>0.51.0</code>. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14282">#14282</a>
by <a
href="https://github.com/musicinmybrain"><code>@​musicinmybrain</code></a>.</li>
</ul>
<h3>Docs</h3>
<ul>
<li>📝 Add missing hash part. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14369">#14369</a>
by <a
href="https://github.com/nilslindemann"><code>@​nilslindemann</code></a>.</li>
<li>📝 Fix typos in code comments. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14364">#14364</a>
by <a
href="https://github.com/Edge-Seven"><code>@​Edge-Seven</code></a>.</li>
<li>📝 Add docs for using FastAPI Cloud. PR <a
href="https://redirect.github.com/fastapi/fastapi/pull/14359">#14359</a>
by <a
href="https://github.com/tiangolo"><code>@​tiangolo</code></a>.</li>
</ul>
</blockquote>
</details>
<details>
<summary>Commits</summary>
<ul>
<li><a
href="325fd16d32"><code>325fd16</code></a>
🔖 Release version 0.121.3</li>
<li><a
href="7659b70da0"><code>7659b70</code></a>
📝 Update release notes</li>
<li><a
href="85701631a0"><code>8570163</code></a>
♻️ Make the result of <code>Depends()</code> and <code>Security()</code>
hashable, as a workaround ...</li>
<li><a
href="566e3157a5"><code>566e315</code></a>
📝 Update release notes</li>
<li><a
href="569226e753"><code>569226e</code></a>
⬆️ Bump Starlette to &lt;<code>0.51.0</code> (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14282">#14282</a>)</li>
<li><a
href="33a75f4817"><code>33a75f4</code></a>
📝 Update release notes</li>
<li><a
href="89baa704a9"><code>89baa70</code></a>
📝 Add missing hash part (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14369">#14369</a>)</li>
<li><a
href="827ed1e6a2"><code>827ed1e</code></a>
📝 Update release notes</li>
<li><a
href="df83eb7278"><code>df83eb7</code></a>
📝 Fix typos in code comments (<a
href="https://redirect.github.com/fastapi/fastapi/issues/14364">#14364</a>)</li>
<li><a
href="4e84f31694"><code>4e84f31</code></a>
📝 Update release notes</li>
<li>Additional commits viewable in <a
href="https://github.com/fastapi/fastapi/compare/0.121.2...0.121.3">compare
view</a></li>
</ul>
</details>
<br />


[![Dependabot compatibility
score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=fastapi&package-manager=pip&previous-version=0.121.2&new-version=0.121.3)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)

Dependabot will resolve any conflicts with this PR as long as you don't
alter it yourself. You can also trigger a rebase manually by commenting
`@dependabot rebase`.

[//]: # (dependabot-automerge-start)
[//]: # (dependabot-automerge-end)

---

<details>
<summary>Dependabot commands and options</summary>
<br />

You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits
that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after
your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge
and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating
it. You can achieve the same result by closing it manually
- `@dependabot show <dependency name> ignore conditions` will show all
of the ignore conditions of the specified dependency
- `@dependabot ignore this major version` will close this PR and stop
Dependabot creating any more for this major version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop
Dependabot creating any more for this minor version (unless you reopen
the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop
Dependabot creating any more for this dependency (unless you reopen the
PR or upgrade to it yourself)


</details>

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-11-29 09:59:11 -05:00
bobokun
b2d10588ef updated supported_versions 2025-11-29 09:59:11 -05:00
github-actions[bot]
952c75efce Update SUPPORTED_VERSIONS.json for master (#1003)
This PR updates the SUPPORTED_VERSIONS.json to reflect new versions.

Co-authored-by: bobokun <12660469+bobokun@users.noreply.github.com>
2025-11-29 09:59:11 -05:00
github-actions[bot]
d7dd16141f Update VERSION to 4.6.5-develop1 [skip ci] 2025-11-29 09:59:11 -05:00
bobokun
b1e91d7259
4.6.4 (#1002)
# Requirements Updated
- "fastapi==0.121.2"
- "qbittorrent-api==2025.11.0"
- "ruamel.yaml==0.18.16"
- "uvicorn==0.38.0"
- "ruff==0.14.5"

**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.6.3...v4.6.4

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
2025-11-15 11:09:17 -05:00
bobokun
21812368bc
v4.6.3 (#956)
# Requirements Updated
- "fastapi==0.116.2"


# Improvements
- **Desktop App**: Adds minimize to tray and automatic startup on boot
- **Desktop App**: Support for CLI args passthrough to desktop app
- **Webhooks**: Adds additional information (commands and
execution_options) to run_start webhook
- **WebUI**: Adds direct link to latest release when updates are
available

# Bug Fixes
- Fix broken pypi builds
- **Web UI**: Fix config validation causing runs to be stuck in progress
- **Web UI**: Fix config validation causing run start webhooks to
trigger

**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.6.2...v4.6.3

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-17 22:01:27 -04:00
bobokun
89d686ec1f
4.6.2 (#950)
# Improvements
- Adds better validation for security passwords

# Bug Fixes
- Conditionally skip permission validation and setting on Windows
systems
- Improve cross-platform compatibility for authentication settings
handling
- Fixes bug where users cannot set up initial security through the webUI

**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.6.1...v4.6.2

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Actionbot <actions@github.com>
2025-09-13 09:54:10 -04:00
bobokun
28f1a3b027
4.6.1 (#943)
# Requirements Updated
- "argon2-cffi==25.1.0"
- "slowapi==0.1.9"
- "ruff==0.12.12"

# New Features
- Adds authentication support for the webUI and webAPI (Fixes #867)

# Improvements
- Enhanced `--web-server` option to support disabling with
`--web-server=False` while maintaining backward compatibility
- The `schedule.yml` is now renamed to `qbm_settings.yml` in order to
support security features (Automatic migration)
- Makes hyperlinks clickable in the webUI (Fixes #938)

# Bug Fixes
- Better support for windows paths when using remote_dir
- Fix `QBT_CONFIG_DIR` not supporting folders with subdirectories (Fixes
#934)
- Fixes webUI not being packaged with PyPi builds
- Fix bug in remove_orphaned where it's not able to start a new thread
in concurrent runs

**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.6.0...v4.6.1

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-10 19:54:51 -04:00
bobokun
5a4ddf0112
4.6.0 (#931)
# Requirements Updated
- "humanize==4.13.0"
- "ruff==0.12.11"

# Breaking Changes
- **DEPRECATE `QBT_CONFIG` / `--config-file` OPTION**
- No longer supporting `QBT_CONFIG` / `--config-file`. Instead please
switch over to **`QBT_CONFIG_DIR` / `--config-dir`**.
- `QBT_CONFIG` / `--config-file` option will still work for now but is
now considered legacy and will be removed in a future release.
- **Note**: All yml/yaml files will be treated as valid configuration
files and loaded in the `QBT_CONFIG_DIR` path. Please ensure you
**remove** any old/unused configurations that you don't want to be
loaded prior to using this path.

# Improvements
- Adds docker support for PUID/PGID environment variables
- Dockerfile copies the latest `config.yml.sample` in the config folder
- Add `QBT_HOST` / `--host` option to specify webUI host address (#929
Thanks to @QuixThe2nd)
- WebUI: Quick action settings persist now

# Bug Fixes
- WebUI: Fix loading spinner to be centered in the webUI

**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.5.5...v4.6.0

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Fabricio Silva <hi@fabricio.dev>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: Parsa Yazdani <parsa@yazdani.au>
Co-authored-by: Actionbot <actions@github.com>
2025-08-30 14:54:13 -04:00
bobokun
156291723f
4.5.5 (#922)
# Improvements
- **ci(docker)**: add OCI labels and build metadata to Docker images
- **Web UI**: Show an "Update available" badge next to the version and a
toast notification when a newer version is detected
- **Web UI**: Add integrated docs with collapsible sections
- **ci(build)**: Publish to PyPI
- **Category**: Allow category changes regardless of the "Category
Update All" status (Fixes #913)

# Bug Fixes
- Fixes container hanging when using run command with QBT_RUN flag
(Fixes #911)
- Fixes bug on interval scheduler not displaying the correct next run
time
- Fix bug on webAPI requests not being queued correctly when called
during a scheduled run

**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.5.4...v4.5.5

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: Actionbot <actions@github.com>
Co-authored-by: bakerboy448 <55419169+bakerboy448@users.noreply.github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: ineednewpajamas <73252768+ineednewpajamas@users.noreply.github.com>
2025-08-24 18:44:54 -04:00
bobokun
1e12a1610f
4.5.4 (#910)
# Improvements
- Support cross-platform binary builds (Linux/Windows/MacOS)
- Adds desktop app installers (Linux/Windows/MacOS)
- Container images for latest now pointed to newest version
automatically (Fixes #897)
- Enable automatic open of webUI in local installs
- Add persistence toggling for webUI scheduler

# Bug Fixes
- Fix schedule.yml not loaded upon restarting Docker container (Fixes
#906)
- Fix bug where torrents were not being paused after share limits
reached (Fixes #901)
- Fix(api): prevent path traversal vulnerability in backup restore
endpoint (Fixes CWE-22 Security Vulnerability)
- Fix scheduler to run interval jobs immediately on startup

**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.5.3...v4.5.4

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>
2025-08-16 22:28:26 -04:00
bobokun
9ee3527853
v4.5.3 (#900)
# Requirements Updated
- "retrying==1.4.2",


# New Features
- **Web UI**: Implement dynamic schedule management via web UI/API
- **Share Limits**: Add limit upload speed when share limits are reached
(New config option: `upload_speed_on_limit_reached`) (Fixes #731, #737,
#703)
- **Share Limits**: Add min/max torrent size filters (New config option:
`min_torrent_size` / `max_torrent_size`) (Fixes #472)
- **Remove Unregistered**: Add grace period for unregistered torrent
removal (New config option: `rem_unregistered_grace_minutes`) (Fixes
#898)
- **Scheduler (Web API)**: Implement dynamic schedule management via web
API

# Improvements
- **Mover Script**: Allow granular control with pause, resume and move
args
- **web UI**: When saving, don’t delete config comments and empty lines
(Fixes #890)

# Bug Fixes
- Fix Error acquiring lock: cannot assign to field '_last_run_start'
(Fixes #895)
- Fix remove_orphaned not working correctly with `remote_dir` and
reporting 0 files removed
- fix(web-ui): prevent XSS vulnerabilities and prototype pollution
- Potential fix for code scanning alert no. 13: Client-side cross-site
scripting (#896)



**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.5.2...v4.5.3

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>
2025-08-08 20:57:06 -04:00
bobokun
13fab64d3c
4.5.2 (#889)
# Requirements Updated
- "GitPython==3.1.45"
- "retrying==1.4.1",


# New Features
- **Remove Orphaned**: Adds new `min_file_age_minutes` flag to prevent
files newer than a certain time from being deleted (Thanks to @H2OKing89
#859)
- Adds new standalone script `ban_peers.py` for banning selected peers
(Thanks to @tboy1337 #888)

# Improvements
- Adds timeout detectiono for stuck runs for web API rqeeusts

# Bug Fixes
- Fix bug in webUI deleting nohardlink section (Fixes #884)


**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.5.1...v4.5.2

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: cat-of-wisdom <217637421+cat-of-wisdom@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Quentin <qking.dev@gmail.com>
Co-authored-by: ineednewpajamas <73252768+ineednewpajamas@users.noreply.github.com>
Co-authored-by: tboy1337 <30571311+tboy1337@users.noreply.github.com>
Co-authored-by: tboy1337 <tboy1337.unchanged733@aleeas.com>
Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>
2025-08-03 15:09:08 -04:00
bobokun
ca4819bc0b
4.5.1 (#874)
# Requirements Updated
- qbittorrent-api==2025.7.0
- fastapi==0.116.1


# New Features
- **Uncategorized Category**: Allow multiple paths for Uncategorized
category and add error handling (Thanks to @cat-of-wisdom #849)
- **Config Auto Backup and Cleanup**: implement automatic backup
rotation (30 most recent backups per config) and cleanup
- **Web UI**: add base URL support for reverse proxy deployments (Fixes
#871)
- **Share Limits**: add option to preserve upload speed limits when
minimums unmet (New config option
`reset_upload_speed_on_unmet_minimums`) (Fixes #835, #791)

# Improvements
- Optimize webUI form rendering
- Better centralized error handling for qbitorrent API operations
- **Web UI**: add editable group names to share limit modal

# Bug Fixes
- Fix bug in remove orphaned to notify when there are 0 orphaned files
- Fixes [Bug]: Cannot run on Python 3.9.18 #864
- fix(qbit): add error handling for qBittorrent API operations

**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.5.0...v4.5.1

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: cat-of-wisdom <217637421+cat-of-wisdom@users.noreply.github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-07-19 08:59:41 -04:00
bobokun
3fa5fcee3b
v4.5.0 (#862)
# Requirements Updated
- fastapi==0.116.0
- retrying==1.4.0
- uvicorn==0.35.0

# New Features
- **Web UI**: Introduced a new Web UI for configuring and managing qBit
Manage.
  - Visual Configuration Editor for YAML files.
  - Command Execution directly from the UI.
  - Undo/Redo History for changes.
  - Theme Support (light/dark mode).
  - Responsive Design for desktop and mobile.
  - Real-time YAML Preview.
- Pass skip qbitorrent check as optional parameter to the API (Adds
#860)\


**Full Changelog**:
https://github.com/StuffAnThings/qbit_manage/compare/v4.4.0...v4.5.0

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: ineednewpajamas <73252768+ineednewpajamas@users.noreply.github.com>
2025-07-11 19:13:41 -04:00