依存関係 - Depends()
と Security()
¶
Depends()
¶
依存関係は、主に呼び出し可能オブジェクトを取る特殊な関数Depends()
で処理されます。
ここに、その参照とパラメータがあります。
fastapi
から直接インポートできます。
from fastapi import Depends
fastapi.Depends ¶
Depends(dependency=None, *, use_cache=True)
FastAPIの依存関係を宣言します。
単一の「依存可能」な呼び出し可能オブジェクト(関数のようなもの)を取ります。
それを直接呼び出さないでください。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
|
「依存可能」な呼び出し可能オブジェクト(関数のようなもの)。 それを直接呼び出さないでください。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()
を使用できます。
fastapi
からSecurity()
を直接インポートできます。
from fastapi import Security
fastapi.Security ¶
Security(dependency=None, *, scopes=None, use_cache=True)
FastAPIのセキュリティ依存関係を宣言します。
通常の依存関係との唯一の違いは、OpenAPIおよび自動UIドキュメント(デフォルトでは/docs
)と統合されるOAuth2スコープを宣言できることです。
単一の「依存可能」な呼び出し可能オブジェクト(関数のようなもの)を取ります。
それを直接呼び出さないでください。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
|
「依存可能」な呼び出し可能オブジェクト(関数のようなもの)。 それを直接呼び出さないでください。FastAPIがあなたのために呼び出すので、オブジェクトを直接渡してください。
TYPE: |
scopes
|
このセキュリティ依存関係を使用するパスオペレーションに必要な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 |
|