mirror of
https://github.com/fastapi-users/fastapi-users.git
synced 2025-08-15 03:04:27 +08:00
Native model and generic ID (#971)
* 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
This commit is contained in:
@ -12,23 +12,23 @@ from fastapi_users.authentication import (
|
||||
from fastapi_users.authentication.strategy import StrategyDestroyNotSupportedError
|
||||
from fastapi_users.authentication.transport.base import Transport
|
||||
from fastapi_users.manager import BaseUserManager
|
||||
from tests.conftest import MockStrategy, MockTransport, UserDB
|
||||
from tests.conftest import MockStrategy, MockTransport, UserModel
|
||||
|
||||
|
||||
class MockTransportLogoutNotSupported(BearerTransport):
|
||||
pass
|
||||
|
||||
|
||||
class MockStrategyDestroyNotSupported(Strategy, Generic[models.UC, models.UD]):
|
||||
class MockStrategyDestroyNotSupported(Strategy, Generic[models.UP]):
|
||||
async def read_token(
|
||||
self, token: Optional[str], user_manager: BaseUserManager[models.UC, models.UD]
|
||||
) -> Optional[models.UD]:
|
||||
self, token: Optional[str], user_manager: BaseUserManager[models.UP, models.ID]
|
||||
) -> Optional[models.UP]:
|
||||
return None
|
||||
|
||||
async def write_token(self, user: models.UD) -> str:
|
||||
async def write_token(self, user: models.UP) -> str:
|
||||
return "TOKEN"
|
||||
|
||||
async def destroy_token(self, token: str, user: models.UD) -> None:
|
||||
async def destroy_token(self, token: str, user: models.UP) -> None:
|
||||
raise StrategyDestroyNotSupportedError
|
||||
|
||||
|
||||
@ -55,7 +55,7 @@ def backend(
|
||||
|
||||
@pytest.mark.asyncio
|
||||
@pytest.mark.authentication
|
||||
async def test_logout(backend: AuthenticationBackend, user: UserDB):
|
||||
async def test_logout(backend: AuthenticationBackend, user: UserModel):
|
||||
strategy = cast(Strategy, backend.get_strategy())
|
||||
result = await backend.logout(strategy, user, "TOKEN", Response())
|
||||
assert result is None
|
||||
|
Reference in New Issue
Block a user