drf-crud-proxy


Namedrf-crud-proxy JSON
Version 0.5.0 PyPI version JSON
download
home_pagehttps://github.com/attevaltojarvi/drf-crud-proxy
SummarySeparate serializers for parsing requests and returning responses in DRF
upload_time2024-10-02 21:26:54
maintainerNone
docs_urlNone
authorattevaltojarvi
requires_pythonNone
licenseMIT
keywords django rest framework serializers rest api django
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            DRF CRUD Proxy
==============

This package provides extended Django REST Framework generic views and viewsets that provide the possibility to specify
different serializers for reading the incoming request and presenting the response.

This is super handy in situations where you want to, for example, let the user send a ForeignKey attribute,
but present the related object alongside the response instead of only the database ID.

Requirements
------------

- Python 3.6, 3.7, 3.8, 3.9, 3.10 and 3.11
- Django 3.2, 4.0, 4.1 and 4.2 (basically works with older versions as well, but they're EOL)
- Django REST Framework 3.8 or newer (probably works on any 3.x version)

Installation
------------

.. code::

  pip install drf-crud-proxy

Usage
-----

Import the generic views and subclass your own views from them. Specify ``request_serializer_class`` and/or
``response_serializer_class`` to the view (both default to DRF's own ``serializer_class`` attribute).

.. code:: python

  # api/views.py

  from drf_crud_proxy import generics
  from app.models import MyModel
  from api.serializers import MyModelCreateSerializer, MyModelSerializer


  class MyModelListCreateView(generics.ProxiedListCreateAPIView):
      queryset = MyModel.objects.all()
      request_serializer_class = MyModelCreateSerializer
      response_serializer_class = MyModelSerializer

The incoming request is handled with ``MyModelCreateSerializer`` and the response with ``MyModelSerializer``.

If you want to customize the data on either situation, override ``get_request_data`` and/or ``get_response_data``
methods in the view.

The package also supports the so-called ``PUT-as-create`` behavior that was removed from DRF in its 3.0 release. Note that
the user has to have model permissions for the corresponding create behavior (``POST`` request).

**NOTE**: The ``PUT-as-create`` functionality doesn't have tests (yet).

License
-------

MIT

Inspiration
-----------

This functionality in DRF is something I've needed in numerous Django projects, so hopefully this will help someone else
too :)

This package has been built on top of the ideas presented by the great vintasoftware's ``drf-rw-serializers`` (https://github.com/vintasoftware/drf-rw-serializers) package. Thanks!

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/attevaltojarvi/drf-crud-proxy",
    "name": "drf-crud-proxy",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "Django REST Framework, Serializers, REST, API, Django",
    "author": "attevaltojarvi",
    "author_email": "atte.valtojarvi@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/ed/d2/86b1d881744fa138dd193bfec30df03c8f6ffa85473487573bf2d622f20b/drf_crud_proxy-0.5.0.tar.gz",
    "platform": null,
    "description": "DRF CRUD Proxy\n==============\n\nThis package provides extended Django REST Framework generic views and viewsets that provide the possibility to specify\ndifferent serializers for reading the incoming request and presenting the response.\n\nThis is super handy in situations where you want to, for example, let the user send a ForeignKey attribute,\nbut present the related object alongside the response instead of only the database ID.\n\nRequirements\n------------\n\n- Python 3.6, 3.7, 3.8, 3.9, 3.10 and 3.11\n- Django 3.2, 4.0, 4.1 and 4.2 (basically works with older versions as well, but they're EOL)\n- Django REST Framework 3.8 or newer (probably works on any 3.x version)\n\nInstallation\n------------\n\n.. code::\n\n  pip install drf-crud-proxy\n\nUsage\n-----\n\nImport the generic views and subclass your own views from them. Specify ``request_serializer_class`` and/or\n``response_serializer_class`` to the view (both default to DRF's own ``serializer_class`` attribute).\n\n.. code:: python\n\n  # api/views.py\n\n  from drf_crud_proxy import generics\n  from app.models import MyModel\n  from api.serializers import MyModelCreateSerializer, MyModelSerializer\n\n\n  class MyModelListCreateView(generics.ProxiedListCreateAPIView):\n      queryset = MyModel.objects.all()\n      request_serializer_class = MyModelCreateSerializer\n      response_serializer_class = MyModelSerializer\n\nThe incoming request is handled with ``MyModelCreateSerializer`` and the response with ``MyModelSerializer``.\n\nIf you want to customize the data on either situation, override ``get_request_data`` and/or ``get_response_data``\nmethods in the view.\n\nThe package also supports the so-called ``PUT-as-create`` behavior that was removed from DRF in its 3.0 release. Note that\nthe user has to have model permissions for the corresponding create behavior (``POST`` request).\n\n**NOTE**: The ``PUT-as-create`` functionality doesn't have tests (yet).\n\nLicense\n-------\n\nMIT\n\nInspiration\n-----------\n\nThis functionality in DRF is something I've needed in numerous Django projects, so hopefully this will help someone else\ntoo :)\n\nThis package has been built on top of the ideas presented by the great vintasoftware's ``drf-rw-serializers`` (https://github.com/vintasoftware/drf-rw-serializers) package. Thanks!\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Separate serializers for parsing requests and returning responses in DRF",
    "version": "0.5.0",
    "project_urls": {
        "Homepage": "https://github.com/attevaltojarvi/drf-crud-proxy"
    },
    "split_keywords": [
        "django rest framework",
        " serializers",
        " rest",
        " api",
        " django"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "94b1d619c4fa51949b27d213244d0848b6153b2b37b250acd2c5980810527e31",
                "md5": "0b6c542294f03737f232a532ead2afa3",
                "sha256": "e4e1f64dbeffe05bc9573fc856c561dc03298d2990805073b5a34ce1b28e2eca"
            },
            "downloads": -1,
            "filename": "drf_crud_proxy-0.5.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "0b6c542294f03737f232a532ead2afa3",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 6752,
            "upload_time": "2024-10-02T21:26:51",
            "upload_time_iso_8601": "2024-10-02T21:26:51.865856Z",
            "url": "https://files.pythonhosted.org/packages/94/b1/d619c4fa51949b27d213244d0848b6153b2b37b250acd2c5980810527e31/drf_crud_proxy-0.5.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "edd286b1d881744fa138dd193bfec30df03c8f6ffa85473487573bf2d622f20b",
                "md5": "dc91a50b0ba082402bf55ac003223820",
                "sha256": "7317f62998d423fd6d3db6bcc59ce7a0b37b06c1e62efd4a07fa8d0cfaa38bc7"
            },
            "downloads": -1,
            "filename": "drf_crud_proxy-0.5.0.tar.gz",
            "has_sig": false,
            "md5_digest": "dc91a50b0ba082402bf55ac003223820",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 6218,
            "upload_time": "2024-10-02T21:26:54",
            "upload_time_iso_8601": "2024-10-02T21:26:54.365494Z",
            "url": "https://files.pythonhosted.org/packages/ed/d2/86b1d881744fa138dd193bfec30df03c8f6ffa85473487573bf2d622f20b/drf_crud_proxy-0.5.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-02 21:26:54",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "attevaltojarvi",
    "github_project": "drf-crud-proxy",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "tox": true,
    "lcname": "drf-crud-proxy"
}
        
Elapsed time: 1.38327s