Skip to main content

A tiny library to make writing CBV-based APIs easier in Django.

Project description

django-microapi

Documentation Status

A tiny library to make writing CBV-based APIs easier in Django.

Essentially, this just provides some sugar on top of the plain old django.views.generic.base.View class, all with the intent of making handling JSON APIs easier (without the need for a full framework).

Usage

from django.contrib.auth.decorators import login_required

# We pull in two useful classes from `microapi`.
from microapi import ApiView, ModelSerializer

from .models import BlogPost


# Inherit from the `ApiView` class...
class BlogPostView(ApiView):
    # ...then define `get`/`post`/`put`/`delete`/`patch` methods on the
    # subclass.

    # For example, we'll provide a list view on `get`.
    def get(self, request):
        posts = BlogPost.objects.all().order_by("-created")

        # The `render` method automatically creates a JSON response from
        # the provided data.
        return self.render({
            "success": True,
            "posts": self.serialize_many(posts),
        })

    # And handle creating a new blog post on `post`.
    @login_required
    def post(self, request):
        # Read the JSON
        data = self.read_json(request)

        # TODO: Validate the data here.

        # Use the included `ModelSerializer` to load the user-provided data
        # into a new `BlogPost`.
        post = self.serializer.from_dict(BlogPost(), data)
        # Don't forget to save!
        post.save()

        return self.render({
            "success": True,
            "post": self.serialize(post),
        })

Installation

$ pip install django-microapi

Rationale

There are a lot of API frameworks out there (hell, I built two of them). But for many tasks, they're either overkill or just too opinionated.

So django-microapi is kind of the antithesis to those. With the exception of a tiny extension to View for nicer errors, it doesn't call ANYTHING automatically. Other than being JSON-based, it doesn't have opinions on serialization, or validation, or URL structures.

You write the endpoints you want, and microapi brings some conveniences to the table to make writing that endpoint as simple as possible without assumptions.

I've long had a place in my heart for the simplicity of Django's function-based views, as well as the conveniences of django.shortcuts. microapi tries to channel that love/simplicity.

API Docs

https://django-microapi.rtfd.io/

Testing

To run the tests, you'll need both Pipenv, and Just installed.

$ just test

License

New BSD

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-microapi-1.2.1.tar.gz (9.6 kB view details)

Uploaded Source

Built Distribution

django_microapi-1.2.1-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

File details

Details for the file django-microapi-1.2.1.tar.gz.

File metadata

  • Download URL: django-microapi-1.2.1.tar.gz
  • Upload date:
  • Size: 9.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for django-microapi-1.2.1.tar.gz
Algorithm Hash digest
SHA256 5a51cc5ecfc9dd71c88d46635f1fcb8c6454cf06312c01f3807a27b11b826b4f
MD5 a66efebdf25b24224797f396a6df88fc
BLAKE2b-256 06c895be58162f0e0d5af1aaf9abaddf8b3e67bcdf99ba894dad3683e74bd148

See more details on using hashes here.

File details

Details for the file django_microapi-1.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for django_microapi-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2ec0cec3987f62caae8d971c9a849b2d92bb86b178e1653c3b671cab6273b6b1
MD5 fe6984995b93c5a3d6e8d0f754b962aa
BLAKE2b-256 b5eb9cd78b00dd7336e1b5a3040e19c68d110d55b533433be9d6f98c0cdda788

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page