依存関係 - 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が呼び出します。オブジェクトを直接渡してください。
型: |
use_cache
|
デフォルトでは、依存関係がリクエストで初めて呼び出された後、その依存関係がリクエストの残りの部分で再び宣言された場合(たとえば、依存関係が複数依存関係によって必要とされる場合)、その値はリクエストの残りの部分で再利用されます。 この動作を無効にして、依存関係が同じリクエストで複数回宣言された場合に再び呼び出されるようにするには、
型: |
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が呼び出します。オブジェクトを直接渡してください。
型: |
scopes
|
このSecurity依存関係を使用するパスオペレーションに必要なOAuth2スコープ。 「スコープ」という用語はOAuth2仕様から来ており、意図的に曖昧で解釈可能であるように思われます。通常は権限、場合によってはロールを指します。 これらのスコープはOpenAPI(および
型: |
use_cache
|
デフォルトでは、依存関係がリクエストで初めて呼び出された後、その依存関係がリクエストの残りの部分で再び宣言された場合(たとえば、依存関係が複数依存関係によって必要とされる場合)、その値はリクエストの残りの部分で再利用されます。 この動作を無効にして、依存関係が同じリクエストで複数回宣言された場合に再び呼び出されるようにするには、
型: |
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 |
|