3.0 KiB
Dependency callables
FastAPI Users provides dependency callables to easily inject users in your routes. They are available from your FastAPIUsers
instance.
!!! tip For more information about how to make an authenticated request to your API, check the documentation of your Authentication method.
get_current_user
Get the current user (active or not). Will throw a 401 Unauthorized
if missing or wrong credentials.
@app.get("/protected-route")
def protected_route(user: User = Depends(fastapi_users.get_current_user)):
return f"Hello, {user.email}"
get_current_active_user
Get the current active user. Will throw a 401 Unauthorized
if missing or wrong credentials or if the user is not active.
@app.get("/protected-route")
def protected_route(user: User = Depends(fastapi_users.get_current_active_user)):
return f"Hello, {user.email}"
get_current_superuser
Get the current superuser. Will throw a 401 Unauthorized
if missing or wrong credentials or if the user is not active. Will throw a 403 Forbidden
if the user is not a superuser.
@app.get("/protected-route")
def protected_route(user: User = Depends(fastapi_users.get_current_superuser)):
return f"Hello, {user.email}"
get_optional_current_user
Get the current user (active or not). Will return None
if missing or wrong credentials. It can be useful if you wish to change the behaviour of your endpoint if a user is logged in or not.
@app.get("/optional-user-route")
def optional_user_route(user: Optional[User] = Depends(fastapi_users.get_optional_current_user)):
if user:
return f"Hello, {user.email}"
else:
return "Hello, anonymous"
get_optional_current_active_user
Get the current active user. Will return None
if missing or wrong credentials. It can be useful if you wish to change the behaviour of your endpoint if a user is logged in or not.
@app.get("/optional-user-route")
def optional_user_route(user: User = Depends(fastapi_users.get_optional_current_active_user)):
if user:
return f"Hello, {user.email}"
else:
return "Hello, anonymous"
get_optional_current_superuser
Get the current superuser. Will return None
if missing or wrong credentials. It can be useful if you wish to change the behaviour of your endpoint if a user is logged in or not.
@app.get("/optional-user-route")
def optional_user_route(user: User = Depends(fastapi_users.get_optional_current_superuser)):
if user:
return f"Hello, {user.email}"
else:
return "Hello, anonymous"
In path operation
If you don't need a user, you can use more clear way:
@app.get("/protected-route", dependencies=[Depends(fastapi_users.get_current_superuser)])
def protected_route():
return "Hello, some user."
You can read more about this in FastAPI docs.