Giter Club home page Giter Club logo

fastapi-users's Introduction

FastAPI Users

FastAPI Users

Ready-to-use and customizable users management for FastAPI

build codecov PyPI version Downloads

All Contributors


Documentation: https://fastapi-users.github.io/fastapi-users/

Source Code: https://github.com/fastapi-users/fastapi-users


Add quickly a registration and authentication system to your FastAPI project. FastAPI Users is designed to be as customizable and adaptable as possible.

Features

  • Extensible base user model

  • Ready-to-use register, login, reset password and verify e-mail routes

  • Ready-to-use social OAuth2 login flow

  • Dependency callables to inject current user in route

  • Pluggable password validation

  • Customizable database backend

  • Multiple customizable authentication backends

    • JWT authentication backend included
    • Cookie authentication backend included
  • Full OpenAPI schema support, even with several authentication backends

πŸ“š Discover my book: Building Data Science Applications with FastAPI

Building Data Science Applications with FastAPI

Develop, manage, and deploy efficient machine learning applications with Python

What is this book about?

This book covers the following exciting features:

  • Explore the basics of modern Python and async I/O programming
  • Get to grips with basic and advanced concepts of the FastAPI framework
  • Implement a FastAPI dependency to efficiently run a machine learning model
  • Integrate a simple face detection algorithm in a FastAPI backend
  • Integrate common Python data science libraries in a web backend
  • Deploy a performant and reliable web backend for a data science application

If you feel this book is for you, get your copy today!

Contributors and sponsors βœ¨β˜•οΈ

Thanks goes to these wonderful people (emoji key):


François Voron

🚧

Paolo Dina

πŸ’΅ πŸ’»

Dmytro Ohorodnik

πŸ›

Matthew D. Scholefield

πŸ›

roywes

πŸ› πŸ’»

Satwik Kansal

πŸ“–

Edd Salkield

πŸ’» πŸ“–

mark-todd

πŸ’» πŸ“–

lill74

πŸ› πŸ’» πŸ“–

SelfhostedPro

πŸ›‘οΈ πŸ’»

Oskar Gmerek

πŸ“–

Martin Collado

πŸ› πŸ’»

Eric Lopes

πŸ“– πŸ›‘οΈ

Beau Breon

πŸ’»

Niyas Mohammed

πŸ“–

prostomarkeloff

πŸ“– πŸ’»

Marius MΓ©zerette

πŸ› πŸ€”

Nickolas Grigoriadis

πŸ›

Open Data Coder

πŸ€”

Mohammed Alshehri

πŸ€”

Tyler Renelle

πŸ€”

collerek

πŸ’»

Robert Bracco

πŸ’΅

Augusto Herrmann

πŸ“–

Smithybrewer

πŸ›

silllli

πŸ“–

alexferrari88

πŸ’΅

sandalwoodbox

πŸ›

Vlad Hoi

πŸ“–

Joe Nudell

πŸ›

Ben

πŸ’»

BoYanZh

πŸ“–

David Brochart

πŸ“–

Daan Beverdam

πŸ’»

StΓ©phane Raimbault

⚠️ πŸ›

Sondre LillebΓΈ Gundersen

πŸ“–

Maxim

πŸ“– πŸ›

scottdavort

πŸ’΅

John Dukewich

πŸ“–

Yasser Tahiri

πŸ’»

Brandon H. Goding

πŸ’»

PovilasK

πŸ’»

Just van den Broecke

πŸ’΅

jakemanger

πŸ› πŸ’»

Ikko Ashimine

πŸ’»

MatyΓ‘Ε‘ Richter

πŸ’»

This project follows the all-contributors specification. Contributions of any kind welcome!

Development

Setup environment

You should create a virtual environment and activate it:

python -m venv venv/
source venv/bin/activate

And then install the development dependencies:

pip install -r requirements.dev.txt

Run unit tests

You can run all the tests with:

make test

The command will start a MongoDB container for the related unit tests. So you should have Docker installed.

Alternatively, you can run pytest yourself. The MongoDB unit tests will be skipped if no server is available on your local machine:

pytest

There are quite a few unit tests, so you might run into ulimit issues where there are too many open file descriptors. You may be able to set a new, higher limit temporarily with:

ulimit -n 2048

Format the code

Execute the following command to apply isort and black formatting:

make format

License

This project is licensed under the terms of the MIT license.

fastapi-users's People

Contributors

allcontributors[bot] avatar boyanzh avatar brandongoding avatar daanbeverdam avatar davidbrochart avatar dependabot-preview[bot] avatar eddsalkield avatar eltociear avatar frankie567 avatar jakemanger avatar jdukewich avatar jnu avatar mark-todd avatar martincolladodev avatar matyasrichter avatar maxim-le avatar niazangels avatar nullhack avatar oskar-gmerek avatar paolodina avatar povilaskud avatar prostomarkeloff avatar rnd42 avatar roywes avatar satwikkansal avatar selfhostedpro avatar silllli avatar sondrelg avatar vladhoi avatar yezz123 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.