mirror of
https://github.com/fastapi-users/fastapi-users.git
synced 2025-11-02 04:05:19 +08:00
Tortoise ORM support (#59)
* add tortoise to dependencies * add tortoise as optional dependency in pyproject.toml * add tortoise support (tests needed) * Add tortoise support (also defined orm_mode in pydantic model * tests for tortoise support * format by black * docs for tortoise * delete type annotations * delete underscore * do it in 1 line * add 1 line before yield * fix in docs * fix bug and add annotation for test * Tweak documentation and fix Tortoise error about id update * Improve Tortoise coverage by using get instead of filter * Fix Pipfile.lock
This commit is contained in:
committed by
François Voron
parent
358150bbff
commit
b5b0bbbb01
58
fastapi_users/db/tortoise.py
Normal file
58
fastapi_users/db/tortoise.py
Normal file
@ -0,0 +1,58 @@
|
||||
from typing import List, Optional, Type
|
||||
|
||||
from tortoise import Model, fields
|
||||
from tortoise.exceptions import DoesNotExist
|
||||
|
||||
from fastapi_users.db import BaseUserDatabase
|
||||
from fastapi_users.models import BaseUserDB
|
||||
|
||||
|
||||
class BaseUserModel:
|
||||
id = fields.TextField(pk=True, generated=False)
|
||||
email = fields.CharField(index=True, unique=True, null=False, max_length=255)
|
||||
hashed_password = fields.CharField(null=False, max_length=255)
|
||||
is_active = fields.BooleanField(default=True, null=False)
|
||||
is_superuser = fields.BooleanField(default=False, null=False)
|
||||
|
||||
class Meta:
|
||||
table = "user"
|
||||
|
||||
|
||||
class TortoiseUserDatabase(BaseUserDatabase):
|
||||
|
||||
model: Type[Model]
|
||||
|
||||
def __init__(self, model: Type[Model]):
|
||||
self.model = model
|
||||
|
||||
async def list(self) -> List[BaseUserDB]:
|
||||
users = await self.model.all()
|
||||
return [BaseUserDB.from_orm(user) for user in users]
|
||||
|
||||
async def get(self, id: str) -> Optional[BaseUserDB]:
|
||||
try:
|
||||
user = await self.model.get(id=id)
|
||||
return BaseUserDB.from_orm(user)
|
||||
except DoesNotExist:
|
||||
return None
|
||||
|
||||
async def get_by_email(self, email: str) -> Optional[BaseUserDB]:
|
||||
try:
|
||||
user = await self.model.get(email=email)
|
||||
return BaseUserDB.from_orm(user)
|
||||
except DoesNotExist:
|
||||
return None
|
||||
|
||||
async def create(self, user: BaseUserDB) -> BaseUserDB:
|
||||
model = self.model(**user.dict())
|
||||
await model.save()
|
||||
return user
|
||||
|
||||
async def update(self, user: BaseUserDB) -> BaseUserDB:
|
||||
user_dict = user.dict()
|
||||
user_dict.pop("id") # Tortoise complains if we pass the PK again
|
||||
await self.model.filter(id=user.id).update(**user_dict)
|
||||
return user
|
||||
|
||||
async def delete(self, user: BaseUserDB) -> None:
|
||||
await self.model.filter(id=user.id).delete()
|
||||
@ -25,6 +25,9 @@ class BaseUser(BaseModel):
|
||||
def create_update_dict_superuser(self):
|
||||
return self.dict(exclude_unset=True, exclude={"id"})
|
||||
|
||||
class Config:
|
||||
orm_mode = True
|
||||
|
||||
|
||||
class BaseUserCreate(BaseUser):
|
||||
email: EmailStr
|
||||
|
||||
Reference in New Issue
Block a user