依存関係 - Depends() と Security()¶
Depends()¶
依存関係は、主にcallableを受け取る特別な関数Depends()で処理されます。
参照とパラメータはこちらです。
fastapiから直接インポートできます。
from fastapi import Depends
fastapi.Depends ¶
Depends(dependency=None, *, use_cache=True)
FastAPIの依存関係を宣言します。
単一の「依存可能な」callable(関数など)を受け取ります。
直接呼び出さないでください。FastAPIがあなたのために呼び出します。
FastAPIの依存関係に関するドキュメントで詳細をお読みください。
例
from typing import Annotated
from fastapi import Depends, FastAPI
app = FastAPI()
async def common_parameters(q: str | None = None, skip: int = 0, limit: int = 100):
return {"q": q, "skip": skip, "limit": limit}
@app.get("/items/")
async def read_items(commons: Annotated[dict, Depends(common_parameters)]):
return commons
| パラメータ | 説明 |
|---|---|
dependency
|
「依存可能な」callable(関数など)。 直接呼び出さないでください。FastAPIがあなたのために呼び出します。オブジェクトを直接渡すだけです。
TYPE: |
use_cache
|
デフォルトでは、リクエストで依存関係が初めて呼び出された後、リクエストの残りの部分で依存関係が再度宣言された場合(たとえば、依存関係が複数の依存関係によって必要とされる場合)、その値はリクエストの残りの部分で再利用されます。 この動作を無効にし、同じリクエストで依存関係が複数回宣言された場合に再度呼び出されることを保証するには、
TYPE: |
fastapi/param_functions.pyにあるソースコード
2220 2221 2222 2223 2224 2225 2226 2227 2228 2229 2230 2231 2232 2233 2234 2235 2236 2237 2238 2239 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275 2276 2277 | |
Security()¶
多くのシナリオでは、Depends()を使用して依存関係でセキュリティ(認可、認証など)を処理できます。
ただし、OAuth2スコープも宣言したい場合は、Depends()の代わりにSecurity()を使用できます。
Security()はfastapiから直接インポートできます。
from fastapi import Security
fastapi.Security ¶
Security(dependency=None, *, scopes=None, use_cache=True)
FastAPIのセキュリティ依存関係を宣言します。
通常の依存関係との唯一の違いは、OpenAPIおよび自動UIドキュメント(デフォルトでは/docs)と統合されるOAuth2スコープを宣言できることです。
単一の「依存可能な」callable(関数など)を受け取ります。
直接呼び出さないでください。FastAPIがあなたのために呼び出します。
FastAPIのセキュリティに関するドキュメントおよびFastAPIのOAuth2スコープに関するドキュメントで詳細をお読みください。
例
from typing import Annotated
from fastapi import Security, FastAPI
from .db import User
from .security import get_current_active_user
app = FastAPI()
@app.get("/users/me/items/")
async def read_own_items(
current_user: Annotated[User, Security(get_current_active_user, scopes=["items"])]
):
return [{"item_id": "Foo", "owner": current_user.username}]
| パラメータ | 説明 |
|---|---|
dependency
|
「依存可能な」callable(関数など)。 直接呼び出さないでください。FastAPIがあなたのために呼び出します。オブジェクトを直接渡すだけです。
TYPE: |
scopes
|
このSecurity依存関係を使用する*パス操作*に必要なOAuth2スコープ。 「スコープ」という用語はOAuth2仕様に由来しており、意図的に曖昧で解釈可能であるようです。通常は権限、場合によってはロールを指します。 これらのスコープはOpenAPI(および
TYPE: |
use_cache
|
デフォルトでは、リクエストで依存関係が初めて呼び出された後、リクエストの残りの部分で依存関係が再度宣言された場合(たとえば、依存関係が複数の依存関係によって必要とされる場合)、その値はリクエストの残りの部分で再利用されます。 この動作を無効にし、同じリクエストで依存関係が複数回宣言された場合に再度呼び出されることを保証するには、
TYPE: |
fastapi/param_functions.pyにあるソースコード
2280 2281 2282 2283 2284 2285 2286 2287 2288 2289 2290 2291 2292 2293 2294 2295 2296 2297 2298 2299 2300 2301 2302 2303 2304 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317 2318 2319 2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 2336 2337 2338 2339 2340 2341 2342 2343 2344 2345 2346 2347 2348 2349 2350 2351 2352 2353 2354 2355 2356 2357 2358 2359 2360 | |