mirror of
				https://github.com/fastapi-users/fastapi-users.git
				synced 2025-10-31 09:28:45 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import os
 | |
| import uuid
 | |
| from typing import Optional
 | |
| 
 | |
| from fastapi import Depends, Request
 | |
| from fastapi_users import BaseUserManager, FastAPIUsers, UUIDIDMixin, models
 | |
| from fastapi_users.authentication import (
 | |
|     AuthenticationBackend,
 | |
|     BearerTransport,
 | |
|     JWTStrategy,
 | |
| )
 | |
| from fastapi_users.db import SQLAlchemyUserDatabase
 | |
| from httpx_oauth.clients.google import GoogleOAuth2
 | |
| 
 | |
| from app.db import User, get_user_db
 | |
| 
 | |
| SECRET = "SECRET"
 | |
| 
 | |
| google_oauth_client = GoogleOAuth2(
 | |
|     os.getenv("GOOGLE_OAUTH_CLIENT_ID", ""),
 | |
|     os.getenv("GOOGLE_OAUTH_CLIENT_SECRET", ""),
 | |
| )
 | |
| 
 | |
| 
 | |
| class UserManager(UUIDIDMixin, BaseUserManager[User, uuid.UUID]):
 | |
|     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: SQLAlchemyUserDatabase = Depends(get_user_db)):
 | |
|     yield UserManager(user_db)
 | |
| 
 | |
| 
 | |
| bearer_transport = BearerTransport(tokenUrl="auth/jwt/login")
 | |
| 
 | |
| 
 | |
| def get_jwt_strategy() -> JWTStrategy[models.UP, models.ID]:
 | |
|     return JWTStrategy(secret=SECRET, lifetime_seconds=3600)
 | |
| 
 | |
| 
 | |
| auth_backend = AuthenticationBackend(
 | |
|     name="jwt",
 | |
|     transport=bearer_transport,
 | |
|     get_strategy=get_jwt_strategy,
 | |
| )
 | |
| 
 | |
| fastapi_users = FastAPIUsers[User, uuid.UUID](get_user_manager, [auth_backend])
 | |
| 
 | |
| current_active_user = fastapi_users.current_user(active=True)
 | 
