Files
François Voron c4de66b81c Revamp authentication (#831)
* Implement Transport classes

* Implement authentication strategy classes

* Revamp authentication with Transport and Strategy

* Revamp strategy and OAuth so that they can use a callable dependency

* Update docstring

* Make ErrorCode a proper Enum and cleanup unused OpenAPI utils

* Remove useless check

* Tweak typing in authenticator

* Update docs

* Improve logout/destroy token logic

* Update docs

* Update docs

* Update docs and full examples

* Apply formatting to examples

* Update OAuth doc and examples

* Add migration doc

* Implement Redis session token

* Add Redis Session documentation

* RedisSession -> Redis

* Fix links in docs
2021-12-30 15:22:07 +01:00

1.1 KiB

Ormar

FastAPI Users provides the necessary tools to work with ormar.

Installation

Install the database driver that corresponds to your DBMS:

pip install asyncpg psycopg2
pip install aiomysql pymysql
pip install aiosqlite

For the sake of this tutorial from now on, we'll use a simple SQLite database.

Setup User table

Let's declare our User ORM model.

--8<-- "docs/src/db_ormar.py"

As you can see, FastAPI Users provides an abstract model that will include base fields for our User table. You can of course add you own fields there to fit to your needs!

Create the database adapter

The database adapter of FastAPI Users makes the link between your database configuration and the users logic. It should be generated by a FastAPI dependency.

--8<-- "docs/src/db_ormar.py"

Notice that we pass a reference to your UserDB model.

!!! warning In production, it's strongly recommended to setup a migration system to update your SQL schemas. See Alembic.