diff --git a/docs/en/docs/release-notes.md b/docs/en/docs/release-notes.md index b837b8afa..3d18e9f66 100644 --- a/docs/en/docs/release-notes.md +++ b/docs/en/docs/release-notes.md @@ -2,7 +2,96 @@ ## Latest Changes +### Features + * ✨ Add support for shared/top-level parameters (dependencies, tags, etc). PR [#2434](https://github.com/tiangolo/fastapi/pull/2434) by [@tiangolo](https://github.com/tiangolo). + +Up to now, for several options, the only way to apply them to a group of *path operations* was in `include_router`. That works well, but the call to `app.include_router()` or `router.include_router()` is normally done in another file. + +That means that, for example, to apply authentication to all the *path operations* in a router it would end up being done in a different file, instead of keeping related logic together. + +Setting options in `include_router` still makes sense in some cases, for example, to override or increase configurations from a third party router included in an app. But in a router that is part of a bigger application, it would probably make more sense to add those settings when creating the `APIRouter`. + +**In `FastAPI`** + +This allows setting the (mostly new) parameters (additionally to the already existing parameters): + +* `default_response_class`: updated to handle defaults in `APIRouter` and `include_router`. +* `dependencies`: to include ✨ top-level dependencies ✨ that apply to the whole application. E.g. to add global authentication. +* `callbacks`: OpenAPI callbacks that apply to all the *path operations*. +* `deprecated`: to mark all the *path operations* as deprecated. 🤷 +* `include_in_schema`: to allow excluding all the *path operations* from the OpenAPI schema. +* `responses`: OpenAPI responses that apply to all the *path operations*. + +For example: + +```Python +from fastapi import FastAPI, Depends + + +async def some_dependency(): + return + + +app = FastAPI(dependencies=[Depends(some_dependency)]) +``` + +**In `APIRouter`** + +This allows setting the (mostly new) parameters (additionally to the already existing parameters): + +* `default_response_class`: updated to handle defaults in `APIRouter` and `include_router`. For example, it's not needed to set it explicitly when [creating callbacks](https://fastapi.tiangolo.com/advanced/openapi-callbacks/). +* `dependencies`: to include ✨ router-level dependencies ✨ that apply to all the *path operations* in a router. Up to now, this was only possible with `include_router`. +* `callbacks`: OpenAPI callbacks that apply to all the *path operations* in this router. +* `deprecated`: to mark all the *path operations* in a router as deprecated. +* `include_in_schema`: to allow excluding all the *path operations* in a router from the OpenAPI schema. +* `responses`: OpenAPI responses that apply to all the *path operations* in a router. +* `prefix`: to set the path prefix for a router. Up to now, this was only possible when calling `include_router`. +* `tags`: OpenAPI tags to apply to all the *path operations* in this router. + +For example: + +```Python +from fastapi import APIRouter, Depends + + +async def some_dependency(): + return + + +router = APIRouter(prefix="/users", dependencies=[Depends(some_dependency)]) +``` + +**In `include_router`** + +Most of these settings are now supported in `APIRouter`, which normally lives closer to the related code, so it is recommended to use `APIRouter` when possible. + +But `include_router` is still useful to, for example, adding options (like `dependencies`, `prefix`, and `tags`) when including a third party router, or a generic router that is shared between several projects. + +This PR allows setting the (mostly new) parameters (additionally to the already existing parameters): + +* `default_response_class`: updated to handle defaults in `APIRouter` and `FastAPI`. +* `deprecated`: to mark all the *path operations* in a router as deprecated in OpenAPI. +* `include_in_schema`: to allow disabling all the *path operations* from showing in the OpenAPI schema. +* `callbacks`: OpenAPI callbacks that apply to all the *path operations* in this router. + +Note: all the previous parameters are still there, so it's still possible to declare `dependencies` in `include_router`. + +### Docs + +* PR [#2434](https://github.com/tiangolo/fastapi/pull/2434) (above) includes new or updated docs: + * Advanced User Guide - OpenAPI Callbacks. + * Tutorial - Bigger Applications. + * Tutorial - Dependencies - Dependencies in path operation decorators. + * Tutorial - Dependencies - Global Dependencies. + +* 📝 Add FastAPI monitoring blog post to External Links. PR [#2324](https://github.com/tiangolo/fastapi/pull/2324) by [@louisguitton](https://github.com/louisguitton). +* ✏️ Fix typo in Deta tutorial. PR [#2320](https://github.com/tiangolo/fastapi/pull/2320) by [@tiangolo](https://github.com/tiangolo). +* ✨ Add Discord chat. PR [#2322](https://github.com/tiangolo/fastapi/pull/2322) by [@tiangolo](https://github.com/tiangolo). +* 📝 Fix image links for sponsors. PR [#2304](https://github.com/tiangolo/fastapi/pull/2304) by [@tiangolo](https://github.com/tiangolo). + +### Translations + * 🌐 Add Japanese translation for Advanced - Custom Response. PR [#2193](https://github.com/tiangolo/fastapi/pull/2193) by [@Attsun1031](https://github.com/Attsun1031). * 🌐 Add Chinese translation for Benchmarks. PR [#2119](https://github.com/tiangolo/fastapi/pull/2119) by [@spaceack](https://github.com/spaceack). * 🌐 Add Chinese translation for Tutorial - Body - Nested Models. PR [#1609](https://github.com/tiangolo/fastapi/pull/1609) by [@waynerv](https://github.com/waynerv). @@ -11,15 +100,14 @@ * 🌐 Add Chinese translation for Advanced - Additional Status Codes. PR [#1451](https://github.com/tiangolo/fastapi/pull/1451) by [@RunningIkkyu](https://github.com/RunningIkkyu). * 🌐 Add Chinese translation for Advanced - Path Operation Advanced Configuration. PR [#1447](https://github.com/tiangolo/fastapi/pull/1447) by [@RunningIkkyu](https://github.com/RunningIkkyu). * 🌐 Add Chinese translation for Advanced User Guide - Intro. PR [#1445](https://github.com/tiangolo/fastapi/pull/1445) by [@RunningIkkyu](https://github.com/RunningIkkyu). + +### Internal + * 🍱 Update sponsor logos. PR [#2418](https://github.com/tiangolo/fastapi/pull/2418) by [@tiangolo](https://github.com/tiangolo). * 💚 Fix disabling install of Material for MkDocs Insiders in forks, strike 1 ⚾. PR [#2340](https://github.com/tiangolo/fastapi/pull/2340) by [@tiangolo](https://github.com/tiangolo). * 🐛 Fix disabling Material for MkDocs Insiders install in forks. PR [#2339](https://github.com/tiangolo/fastapi/pull/2339) by [@tiangolo](https://github.com/tiangolo). * ✨ Add silver sponsor WeTransfer. PR [#2338](https://github.com/tiangolo/fastapi/pull/2338) by [@tiangolo](https://github.com/tiangolo). -* 📝 Add FastAPI monitoring blog post to External Links. PR [#2324](https://github.com/tiangolo/fastapi/pull/2324) by [@louisguitton](https://github.com/louisguitton). * ✨ Set up and enable Material for MkDocs Insiders for the docs. PR [#2325](https://github.com/tiangolo/fastapi/pull/2325) by [@tiangolo](https://github.com/tiangolo). -* ✨ Add Discord chat. PR [#2322](https://github.com/tiangolo/fastapi/pull/2322) by [@tiangolo](https://github.com/tiangolo). -* ✏️ Fix typo in Deta tutorial. PR [#2320](https://github.com/tiangolo/fastapi/pull/2320) by [@tiangolo](https://github.com/tiangolo). -* 📝 Fix image links for sponsors. PR [#2304](https://github.com/tiangolo/fastapi/pull/2304) by [@tiangolo](https://github.com/tiangolo). ## 0.61.2