Metadata-Version: 2.1
Name: django-autorest
Version: 1.0.1
Summary: A re-useable Django app for automatically building a REST API based on models.
Home-page: https://github.com/gregschmit/django-autorest
Author: Gregory N. Schmit
Author-email: gschmi4@uic.edu
License: MIT
Classifier: Environment :: Web Environment
Classifier: Framework :: Django
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
License-File: LICENSE
Requires-Dist: Django>=2
Requires-Dist: djangorestframework>=3
Requires-Dist: drf-action-serializer
Requires-Dist: inflection

AutoREST
========

.. inclusion-marker-do-not-remove

.. image:: https://travis-ci.org/gregschmit/django-autorest.svg?branch=master
    :alt: TravisCI
    :target: https://travis-ci.org/gregschmit/django-autorest

.. image:: https://img.shields.io/pypi/v/django-autorest
    :alt: PyPI
    :target: https://pypi.org/project/django-autorest/

.. image:: https://coveralls.io/repos/github/gregschmit/django-autorest/badge.svg?branch=master
    :alt: Coveralls
    :target: https://coveralls.io/github/gregschmit/django-autorest?branch=master

.. image:: https://readthedocs.org/projects/django-autorest/badge/?version=latest
    :alt: Documentation Status
    :target: https://django-autorest.readthedocs.io/en/latest/?badge=latest

.. image:: https://img.shields.io/badge/code%20style-black-000000.svg
    :alt: Code Style
    :target: https://github.com/ambv/black

Documentation: https://django-autorest.readthedocs.io

Source: https://github.com/gregschmit/django-autorest

PyPI: https://pypi.org/project/django-autorest/

AutoREST is a reusable Django app for building REST APIs from model definitions and
(optionally) ``admin.py`` definitions.

**The Problem**: Building APIs for models is boring.

**The Solution**: This app builds them for you, optionally using your AdminSite as a
guide, and you can just focus on the custom stuff.


How to Use
==========

.. code-block:: shell

    $ pip install django-autorest

Include ``autorest`` in your ``INSTALLED_APPS``.


Settings
--------

- ``AUTOREST_ADMIN_SITE`` (default ``'django.contrib.admin.site'``): This is an import
  string to the admin site where ``autorest`` can get hints on how the API should be
  configured (e.g., list display fields, edit fields, readonly fields, etc). To disable
  this feature entirely, just set this  to ``False``.
- ``AUTOREST_DEFAULT_USE_ADMIN_SITE`` (default ``False``): Whether the default model
  functionality should be to get config hints from ``admin.py``.
- ``AUTOREST_DEFAULT_ENABLE`` (default: ``True``): Whether API ViewSets/URLs should be
  built for models which don't have an explicit entry in the ``AUTOREST_CONFIG``. If
  this option is ``False``, then only models defined in the ``AUTOREST_CONFIG`` will
  have URLs generated for them.
- ``AUTOREST_CONFIG`` default:

.. code-block:: python

    {
        'auth': {
            'User': {
                'viewset': 'autorest.sample_user_viewset.UserViewSet',
            },
        },
    }


``AUTOREST_CONFIG`` Options:
^^^^^^^^^^^^^^^^^^^^^^^^^^^^

- ``use_admin_site``: Whether to use the admin site to build the API.
- ``serializer``: An import string to a serializer instance. (Note: if you would use
  multiple serializers for different actions like list/detail, then you can use
  `drf-action-serializer <https://github.com/gregschmit/drf-action-serializer>`_) to
  configure a single serializer that supports per-action field configuration.)
- ``viewset``: An import string to a full viewset for this model.


Contributing
============

Submit a pull request if you would like to contribute. You must only contribute code
that you have authored or otherwise hold the copyright to, and you must make any
contributions to this project available under the MIT license.

Development
===========

AutoREST comes with a ``settings.py`` file, allowing it to run as a standalone project.

.. code-block:: shell

    $ git clone https://github.com/gregschmit/django-autorest

Then you can go into the ``django-autorest`` directory and do the initial migrations and
run the server (you may need to type ``python3`` rather than ``python``):

.. code-block:: shell

    $ cd django-autorest
    $ python manage.py migrate
    $ python manage.py createsuperuser
    ...
    $ python manage.py runserver

Then you can see the api at http://127.0.0.1:8000/api/.
