mirror of
				https://github.com/fastapi-users/fastapi-users.git
				synced 2025-10-31 17:38:30 +08:00 
			
		
		
		
	 72aa68c462
			
		
	
	72aa68c462
	
	
	
		
			
			* Use a generic Protocol model for User instead of Pydantic
* Remove UserDB Pydantic schema
* Harmonize schema variable naming to avoid confusions
* Revamp OAuth account model management
* Revamp AccessToken DB strategy to adopt generic model approach
* Make ID a generic instead of forcing UUIDs
* Improve generic typing
* Improve Strategy typing
* Tweak base DB typing
* Don't set Pydantic schemas on FastAPIUsers class: pass it directly on router creation
* Add IntegerIdMixin and export related classes
* Start to revamp doc for V10
* Revamp OAuth documentation
* Fix code highlights
* Write the 9.x.x ➡️ 10.x.x migration doc
* Fix pyproject.toml
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from typing import Optional
 | |
| 
 | |
| from beanie import PydanticObjectId
 | |
| from fastapi import Depends, Request
 | |
| from fastapi_users import BaseUserManager, FastAPIUsers
 | |
| from fastapi_users.authentication import (
 | |
|     AuthenticationBackend,
 | |
|     BearerTransport,
 | |
|     JWTStrategy,
 | |
| )
 | |
| from fastapi_users.db import BeanieUserDatabase, ObjectIDIDMixin
 | |
| 
 | |
| from app.db import User, get_user_db
 | |
| 
 | |
| SECRET = "SECRET"
 | |
| 
 | |
| 
 | |
| class UserManager(ObjectIDIDMixin, BaseUserManager[User, PydanticObjectId]):
 | |
|     reset_password_token_secret = SECRET
 | |
|     verification_token_secret = SECRET
 | |
| 
 | |
|     async def on_after_register(self, user: User, request: Optional[Request] = None):
 | |
|         print(f"User {user.id} has registered.")
 | |
| 
 | |
|     async def on_after_forgot_password(
 | |
|         self, user: User, token: str, request: Optional[Request] = None
 | |
|     ):
 | |
|         print(f"User {user.id} has forgot their password. Reset token: {token}")
 | |
| 
 | |
|     async def on_after_request_verify(
 | |
|         self, user: User, token: str, request: Optional[Request] = None
 | |
|     ):
 | |
|         print(f"Verification requested for user {user.id}. Verification token: {token}")
 | |
| 
 | |
| 
 | |
| async def get_user_manager(user_db: BeanieUserDatabase = Depends(get_user_db)):
 | |
|     yield UserManager(user_db)
 | |
| 
 | |
| 
 | |
| bearer_transport = BearerTransport(tokenUrl="auth/jwt/login")
 | |
| 
 | |
| 
 | |
| def get_jwt_strategy() -> JWTStrategy:
 | |
|     return JWTStrategy(secret=SECRET, lifetime_seconds=3600)
 | |
| 
 | |
| 
 | |
| auth_backend = AuthenticationBackend(
 | |
|     name="jwt",
 | |
|     transport=bearer_transport,
 | |
|     get_strategy=get_jwt_strategy,
 | |
| )
 | |
| 
 | |
| fastapi_users = FastAPIUsers[User, PydanticObjectId](get_user_manager, [auth_backend])
 | |
| 
 | |
| current_active_user = fastapi_users.current_user(active=True)
 |