Skip to content
This repository has been archived by the owner on May 1, 2024. It is now read-only.
/ django-openapi Public archive

A minimal FastAPI implementation in python2/3 + Django without pydantic

License

Notifications You must be signed in to change notification settings

tokikanno/django-openapi

Repository files navigation

Try django-mini-fastapi if you're using Python3 !!!

After migrated all my company's legacy django projects into Python3, I've started a new project called Django Mini FastAPI. This new lib works as a FastAPI adapter to django, and it reused about 95% codes from FastAPI, so it just works as same as FastAPI does (except it still not support async endpoints). So if you lik FastAPI, you have legacy django projects using Python3, just give it try!!!

django-openapi

A minimal FastAPI implementation in Python2 + Django without pydantic

Why do you make this? Can't you just use FastAPI directly?

I'm a big fan of FastAPI. It's elegant and saves lots of doc maintaince & API spec communication costs for me.

But FastAPI needs Python3 to run, some legacy projects I maintained are still using Python2 and built by Django framework. It would take 2 migration steps (Python 2 to 3 and Django to FastAPI) for moving them onto FastAPI framework.

So I decided to build a minimal FastAPI implementation in Python2 + Django, that I could instantly get the benefits from FastAPI without too many migrations on my legacy projects.

Who should use this?

People who like the way FastAPI works but

  • Are still on the long migration process from Python2 to Python3
  • Or don't want to do full system rewrite from Django to FastAPI
  • Or don't want to upgrade from Python2 to Python3

Features

  • Auto OpenAPI schema/document generation from Python function parameter
  • Auto HTTP request parameter validation from Python function parameters
  • Python 2/3 compatiable, you could use almost the same code for you Python2/3 projects

Installation

pip install django-openapi

Live demo provided by Gitpod

Click the button below and launch a free live demo server via Gitpod

Gitpod ready-to-code

If the button doesn't show up, you clould also use below link directly

https://gitpod.io/#https://github.com/tokikanno/django-openapi

After Gitpod launched, if you see a dialog like this, just hit the Open Browser button then you will get to the quick intro live demo server.

image

Use ctrl + p (or cmd + p if u're using MacOS X) and search for intro.py to see the source code of intro demo server.

Quick start

In your Django project

  • Import OpenAPI from django_openapi
  • Create an API object instance
  • Add API object into urlpatterns
# import OpenAPI from django_opeanapi
from django_openapi import OpenAPI

# create an API object instance
api = OpenAPI(title='My OpenAPI Test',	prefix_path='/test_api')

urlpatterns = [
    api.as_django_url_pattern()  # Add API object into urlpatterns
]
  • Start you django debug server and open your browser with url like http://localhost:8000/test_api/_docs, this is the auto document page.
  • Now let's try adding some basic routes for you API
from django_openapi import Path, Query, Form

@api.get('/test/hello_via_path/{word}', tags=['test'])
def hello_via_path(word=Path()):
    return {'hello': word}


@api.get('/test/hello_via_query', tags=['test'])
def hello_via_query(word=Query()):
    return {'hello': word}


@api.post('/test/hello_via_form', tags=['test'])
def hello_via_form(word=Form()):
    return {'hello': word}
  • Reload your browser & see if anything changed to the auto document page
  • Advanced routes via JSON body & JSON schema object
from django_openapi import Body
from django_openapi.schema import BaseModel, StringField

class HelloPayload(BaseModel):
    word = StringField(default_value='world', min_length=3)

@api.post('/test/hello_via_json_body', tags=['test'])
def hello_via_json_body(payload=Body(HelloPayload)):
    return {'hello': payload.word}
  • Reload agagin, the auto document page now should have 4 APIs on it.

image

Browse to the demo folder for more advanced samples.

TODO

  • More documents and samples
  • Better schema validation error message handling
  • More advanced field types (e.g.: EmailStringField, CommaSeparatedArrayField ...)

About

A minimal FastAPI implementation in python2/3 + Django without pydantic

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages