MongoDB¶
FastAPI Users provides the necessary tools to work with MongoDB databases thanks to mongodb/motor package for full async support.
Setup database connection and collection¶
Let's create a MongoDB connection and instantiate a collection.
import motor.motor_asyncio from fastapi import FastAPI from fastapi_users.db import MongoDBUserDatabase DATABASE_URL = "mongodb://localhost:27017" client = motor.motor_asyncio.AsyncIOMotorClient(DATABASE_URL) db = client["database_name"] collection = db["users"] app = FastAPI() user_db = MongoDBUserDatabase(collection)
You can choose any name for the database and the collection.
Create the database adapter¶
The database adapter of FastAPI Users makes the link between your database configuration and the users logic. Create it like this.
import motor.motor_asyncio from fastapi import FastAPI from fastapi_users.db import MongoDBUserDatabase DATABASE_URL = "mongodb://localhost:27017" client = motor.motor_asyncio.AsyncIOMotorClient(DATABASE_URL) db = client["database_name"] collection = db["users"] app = FastAPI() user_db = MongoDBUserDatabase(collection)
Info
The database adapter will automatically create a unique index on id
and email
.
Warning
FastAPI Users will use its defined id
UUID-string as unique identifier for the user, rather than the builtin MongoDB _id
.
Next steps¶
We will now configure an authentication method.