FastAPI/MSAL - The MSAL (Microsoft Authentication Library) plugin for FastAPI!
Project description
FastAPI/MSAL - MSAL (Microsoft Authentication Library) plugin for FastAPI
FastAPI - https://github.com/tiangolo/fastapi FastAPI is a modern, fast (high-performance), web framework for building APIs based on standard Python type hints.
MSAL for Python - https://github.com/AzureAD/microsoft-authentication-library-for-python The Microsoft Authentication Library for Python enables applications to integrate with the Microsoft identity platform. It allows you to sign in users or apps with Microsoft identities and obtain tokens to call Microsoft APIs such as Microsoft Graph or your own APIs registered with the Microsoft identity platform. It is built using industry standard OAuth2 and OpenID Connect protocols
The fastapi_msal package was built to allow quick "out of the box" integration with MSAL. As a result the pacage was built around simplicity and ease of use on the expense of flexability and versatility.
Features
- Includes Async implementation of MSAL confidential client class utilizaing Starlette threadpool model.
- Use pydantic models to translate the MSAL objects to data objects which are code and easy to work with.
- Have a built-in router which includes the required paths for the authentication flow.
- Include a dependency class to authenticate and secure your application APIs
- Includes a pydantic setting class for easy and secure configuration from your ENV (or .env or secrets directory)
- Full support with FastAPI swagger documentations and authentication simulation
Installation
With pipenv
pipenv install fastapi_msal
Prerequisets
As part of your fastapi application the following packages should be included TL;DR: If you just wish to install it all use
pipenv install "fastapi_msal[full]"
-
python-multipart From FastAPI documentation: This is required since OAuth2 (Which MSAL is based upon) uses "form data" to send the credentials.
-
itsdangerous Used by Starlette session middleware
Usage
-
Follow the application registration process with the microsoft identity platform. Finishing the processes will allow you to retrieve your app_code and app_credentials (app_secret) As well as register your app callback path with the platform.
-
Create a new main.py file and add the following lines. Make sure to update the lines with the information retrieved in the previous step
import uvicorn
from fastapi import FastAPI, Depends
from starlette.middleware.sessions import SessionMiddleware
from fastapi_msal import MSALAuthorization, UserInfo, MSALClientConfig
client_config: MSALClientConfig = MSALClientConfig()
client_config.client_id = "The Client ID rerived at step #1"
client_config.client_credential = "The Client secret retrived at step #1"
client_config.tenant = "Your tenant id"
app = FastAPI()
app.add_middleware(SessionMiddleware, secret_key="SOME_SSH_KEY_ONLY_YOU_KNOW") # replace with your own!!!
msal_auth = MSALAuthorization(client_config=client_config)
app.include_router(msal_auth.router)
@app.get("/users/me", response_model=UserInfo, response_model_exclude_none=True)
async def read_users_me(current_user: UserInfo = Depends(msal_auth.scheme)) -> UserInfo:
return current_user
if __name__ == "__main__":
uvicorn.run("main:app", host="localhost", port=5000, reload=True)
- Run your app
(pipenv shell)$ python main.py
INFO: Uvicorn running on http://localhost:5000 (Press CTRL+C to quit)
INFO: Started reloader process [12785] using statreload
INFO: Started server process [12787]
INFO: Waiting for application startup.
INFO: Application startup complete.
-
Browse to http://localhost:5000/docs - this is the API docs generated by FastAPI (totaly cool!)
-
Using the "built-in" authenticaiton button (the little lock) you will be able to set the full authentication process (Igonre the cline_id and client_secret - they are not relevant for the process as you already set them)
-
After you complete the process you will get a confirmation popup
-
Trying out the ME api endpoint
TODO List
- Add support for local/redis session cache
- Add Tests
- Poper Documentation
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file fastapi_msal-0.1.1.tar.gz
.
File metadata
- Download URL: fastapi_msal-0.1.1.tar.gz
- Upload date:
- Size: 268.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.25.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 62e23586c90280558056f5ab166d7f4b56179dba0185c3e772b3444dac6d9767 |
|
MD5 | b5ffd675013798d9d9458ec18a52d06c |
|
BLAKE2b-256 | c0f127a38e2fd5b7543aa60b89b70ca41ab7e33f40f7e73c0c91f0e989d6c3e5 |
File details
Details for the file fastapi_msal-0.1.1-py3-none-any.whl
.
File metadata
- Download URL: fastapi_msal-0.1.1-py3-none-any.whl
- Upload date:
- Size: 18.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.25.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 69a6996940651e48a908f5e432d6dbfdfd8b3b01b05388999ae71d1a65961656 |
|
MD5 | 8593cb2bab3e9fdf35049e86fcf69644 |
|
BLAKE2b-256 | 46f9bf2c0c4fa0c5d9b042c7c20926f6d628aade3839197b04f77530bd783db8 |