mirror of
				https://github.com/fastapi-users/fastapi-users.git
				synced 2025-11-04 14:45:50 +08:00 
			
		
		
		
	* added samesite option for cookie authentication * formatted with black and added documentation (grabbed from starlette.io documentation)
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
import databases
 | 
						|
import sqlalchemy
 | 
						|
from fastapi import FastAPI, Request
 | 
						|
from fastapi_users import FastAPIUsers, models
 | 
						|
from fastapi_users.authentication import JWTAuthentication
 | 
						|
from fastapi_users.db import SQLAlchemyBaseUserTable, SQLAlchemyUserDatabase
 | 
						|
from sqlalchemy.ext.declarative import DeclarativeMeta, declarative_base
 | 
						|
 | 
						|
DATABASE_URL = "sqlite:///./test.db"
 | 
						|
SECRET = "SECRET"
 | 
						|
 | 
						|
 | 
						|
class User(models.BaseUser):
 | 
						|
    pass
 | 
						|
 | 
						|
 | 
						|
class UserCreate(models.BaseUserCreate):
 | 
						|
    pass
 | 
						|
 | 
						|
 | 
						|
class UserUpdate(User, models.BaseUserUpdate):
 | 
						|
    pass
 | 
						|
 | 
						|
 | 
						|
class UserDB(User, models.BaseUserDB):
 | 
						|
    pass
 | 
						|
 | 
						|
 | 
						|
database = databases.Database(DATABASE_URL)
 | 
						|
Base: DeclarativeMeta = declarative_base()
 | 
						|
 | 
						|
 | 
						|
class UserTable(Base, SQLAlchemyBaseUserTable):
 | 
						|
    pass
 | 
						|
 | 
						|
 | 
						|
engine = sqlalchemy.create_engine(
 | 
						|
    DATABASE_URL, connect_args={"check_same_thread": False}
 | 
						|
)
 | 
						|
Base.metadata.create_all(engine)
 | 
						|
 | 
						|
users = UserTable.__table__
 | 
						|
user_db = SQLAlchemyUserDatabase(UserDB, database, users)
 | 
						|
 | 
						|
 | 
						|
def on_after_register(user: UserDB, request: Request):
 | 
						|
    print(f"User {user.id} has registered.")
 | 
						|
 | 
						|
 | 
						|
def on_after_forgot_password(user: UserDB, token: str, request: Request):
 | 
						|
    print(f"User {user.id} has forgot their password. Reset token: {token}")
 | 
						|
 | 
						|
 | 
						|
jwt_authentication = JWTAuthentication(
 | 
						|
    secret=SECRET, lifetime_seconds=3600, tokenUrl="/auth/jwt/login"
 | 
						|
)
 | 
						|
 | 
						|
app = FastAPI()
 | 
						|
fastapi_users = FastAPIUsers(
 | 
						|
    user_db,
 | 
						|
    [jwt_authentication],
 | 
						|
    User,
 | 
						|
    UserCreate,
 | 
						|
    UserUpdate,
 | 
						|
    UserDB,
 | 
						|
)
 | 
						|
app.include_router(
 | 
						|
    fastapi_users.get_auth_router(jwt_authentication), prefix="/auth/jwt", tags=["auth"]
 | 
						|
)
 | 
						|
app.include_router(
 | 
						|
    fastapi_users.get_register_router(on_after_register), prefix="/auth", tags=["auth"]
 | 
						|
)
 | 
						|
app.include_router(
 | 
						|
    fastapi_users.get_reset_password_router(
 | 
						|
        SECRET, after_forgot_password=on_after_forgot_password
 | 
						|
    ),
 | 
						|
    prefix="/auth",
 | 
						|
    tags=["auth"],
 | 
						|
)
 | 
						|
app.include_router(fastapi_users.get_users_router(), prefix="/users", tags=["users"])
 | 
						|
 | 
						|
 | 
						|
@app.on_event("startup")
 | 
						|
async def startup():
 | 
						|
    await database.connect()
 | 
						|
 | 
						|
 | 
						|
@app.on_event("shutdown")
 | 
						|
async def shutdown():
 | 
						|
    await database.disconnect()
 |