• Stars
    star
    665
  • Rank 67,810 (Top 2 %)
  • Language
    Python
  • License
    Apache License 2.0
  • Created over 10 years ago
  • Updated about 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Extra Fields for Django Rest Framework

DRF-EXTRA-FIELDS

Extra Fields for Django Rest Framework

Build Status codecov PyPI Version Python Versions

Latest Changes

  • v3.5.0
    • Development environment fixes & improvements.
    • Since Python 3.6 support is ended, the codebase is refactored/modernized for Python 3.7.
    • WebP is added to default ALLOWED_TYPES of the Base64ImageField.
    • Deprecated imghdr library is replaced with filetype.
    • Unintended Pillow dependency is removed.
  • v3.4.0
    • ⚠️ BACKWARD INCOMPATIBLE ⚠️
      • Support for Django 3.0 and Django 3.1 is ended.
    • Django 4.0 is now supported.
  • v3.3.0
    • ⚠️ BACKWARD INCOMPATIBLE ⚠️
      • Support for Python 3.6 is ended.
  • v3.2.1
    • A typo in the python_requires argument of setup.py that prevents installation for Python 3.6 is fixed.
  • v3.2.0
    • ⚠️ BACKWARD INCOMPATIBLE ⚠️
      • Support for Python 3.5 is ended.
    • Python 3.9 and Python 3.10 are now supported.
    • Django 3.2 is now supported.
  • v3.1.1
    • psycopg2 dependency is made optional.
  • v3.1.0
    • Possible Breaking Change:
      • In this version we have changed file class used in Base64FileField from ContentFile to SimpleUploadedFile (you may see the change here).
    • child_attrs property is added to RangeFields.

Usage

Install the package

pip install drf-extra-fields

Note:

  • This package renamed as "drf-extra-fields", earlier it was named as django-extra-fields.
  • Install version 0.1 for Django Rest Framework 2.*
  • Install version 0.3 or greater for Django Rest Framework 3.*

Fields:

Base64ImageField

An image representation for Base64ImageField

Inherited from ImageField

Signature: Base64ImageField()

  • It takes a base64 image as a string.
  • A base64 image: 
  • Base64ImageField accepts the entire string or just the part after base64, R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7
  • It takes the optional parameter represent_in_base64 (False by default), if set to True it will allow for base64-encoded downloads of an ImageField.
  • You can inherit the Base64ImageField class and set allowed extensions (ALLOWED_TYPES list), or customize the validation messages (INVALID_FILE_MESSAGE, INVALID_TYPE_MESSAGE)

Example:

# serializer

from drf_extra_fields.fields import Base64ImageField

class UploadedBase64ImageSerializer(serializers.Serializer):
    file = Base64ImageField(required=False)
    created = serializers.DateTimeField()

# use the serializer
file = 'R0lGODlhAQABAIAAAP///////yH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=='
serializer = UploadedBase64ImageSerializer(data={'created': now, 'file': file})

Base64FileField

A file representation for Base64FileField

Inherited from FileField

Signature: Base64FileField()

  • It takes a base64 file as a string.
  • Other options like for Base64ImageField
  • You have to provide your own full implementation of this class. You have to implement file validation in get_file_extension method and set ALLOWED_TYPES list.

Example:

class PDFBase64File(Base64FileField):
    ALLOWED_TYPES = ['pdf']

    def get_file_extension(self, filename, decoded_file):
        try:
            PyPDF2.PdfFileReader(io.BytesIO(decoded_file))
        except PyPDF2.utils.PdfReadError as e:
            logger.warning(e)
        else:
            return 'pdf'

PointField

Point field for GeoDjango

Signature: PointField()

  • It takes a dictionary contains latitude and longitude keys like below

    { "latitude": 49.8782482189424, "longitude": 24.452545489 }

  • It takes the optional parameter str_points (False by default), if set to True it serializes the longitude/latitude values as strings

  • It takes the optional parameter srid (None by default), if set the Point created object will have its srid attribute set to the same value.

Example:

# serializer

from drf_extra_fields.geo_fields import PointField

class PointFieldSerializer(serializers.Serializer):
    point = PointField(required=False)
    created = serializers.DateTimeField()

# use the serializer
point = {
    "latitude": 49.8782482189424,
    "longitude": 24.452545489
    }
serializer = PointFieldSerializer(data={'created': now, 'point': point})

RangeField

The Range Fields map to Django's PostgreSQL specific Range Fields.

Each accepts an optional parameter child_attrs, which allows passing parameters to the child field.

For example, calling IntegerRangeField(child_attrs={"allow_null": True}) allows deserializing data with a null value for lower and/or upper:

from rest_framework import serializers
from drf_extra_fields.fields import IntegerRangeField


class RangeSerializer(serializers.Serializer):
    ranges = IntegerRangeField(child_attrs={"allow_null": True})


serializer = RangeSerializer(data={'ranges': {'lower': 0, 'upper': None}})

IntegerRangeField

from rest_framework import serializers
from drf_extra_fields.fields import IntegerRangeField


class RangeSerializer(serializers.Serializer):
    ranges = IntegerRangeField()


serializer = RangeSerializer(data={'ranges': {'lower': 0, 'upper': 1}})

FloatRangeField

from rest_framework import serializers
from drf_extra_fields.fields import FloatRangeField


class RangeSerializer(serializers.Serializer):
    ranges = FloatRangeField()


serializer = RangeSerializer(data={'ranges': {'lower': 0., 'upper': 1.}})

DecimalRangeField

from rest_framework import serializers
from drf_extra_fields.fields import DecimalRangeField


class RangeSerializer(serializers.Serializer):
    ranges = DecimalRangeField()


serializer = RangeSerializer(data={'ranges': {'lower': 0., 'upper': 1.}}, )

DateRangeField

import datetime

from rest_framework import serializers
from drf_extra_fields.fields import DateRangeField


class RangeSerializer(serializers.Serializer):
    ranges = DateRangeField()


serializer = RangeSerializer(data={'ranges': {'lower': datetime.date(2015, 1, 1), 'upper': datetime.date(2015, 2, 1)}})

DateTimeRangeField

import datetime

from rest_framework import serializers
from drf_extra_fields.fields import DateTimeRangeField


class RangeSerializer(serializers.Serializer):
    ranges = DateTimeRangeField()


serializer = RangeSerializer(data={'ranges': {'lower': datetime.datetime(2015, 1, 1, 0), 'upper': datetime.datetime(2015, 2, 1, 0)}})

PresentablePrimaryKeyRelatedField

Represents related object with a serializer.

presentation_serializer could also be a string that represents a dotted path of a serializer, this is useful when you want to represent a related field with the same serializer.

from drf_extra_fields.relations import PresentablePrimaryKeyRelatedField

class UserSerializer(serializers.ModelSerializer):
    class Meta:
        model = User
        fields = (
            'id',
            "username",
        )

class PostSerializer(serializers.ModelSerializer):
    user = PresentablePrimaryKeyRelatedField(
        queryset=User.objects.all(),
        presentation_serializer=UserSerializer,
        presentation_serializer_kwargs={
            'example': [
                'of',
                'passing',
                'kwargs',
                'to',
                'serializer',
            ]
        },
        read_source=None
    )
    class Meta:
        model = Post
        fields = (
            "id",
            "title",
            "user",
        )

Serializer data:

{
    "user": 1,
    "title": "test"
}

Serialized data with PrimaryKeyRelatedField:

{
    "id":1,
    "user": 1,
    "title": "test"
}

Serialized data with PresentablePrimaryKeyRelatedField:

{
    "id":1,
    "user": {
        "id": 1,
        "username": "test"
    },
    "title": "test"
}

PresentableSlugRelatedField

Represents related object retrieved using slug with a serializer.

from drf_extra_fields.relations import PresentableSlugRelatedField

class CategorySerializer(serializers.ModelSerializer):
    class Meta:
        model = Category
        fields = (
            "id",
            "slug",
            "name"
        )

class ProductSerializer(serializers.ModelSerializer):
    category = PresentableSlugRelatedField(
        slug_field="slug",
        queryset=Category.objects.all(),
        presentation_serializer=CategorySerializer,
        presentation_serializer_kwargs={
            'example': [
                'of',
                'passing',
                'kwargs',
                'to',
                'serializer',
            ]
        },
        read_source=None
    )
    class Meta:
        model = Product
        fields = (
            "id",
            "name",
            "category",
        )

Serializer data:

{
    "category": "vegetables",
    "name": "Tomato"
}

Serialized data with SlugRelatedField:

{
    "id": 1,
    "name": "Tomato",
    "category": "vegetables"
}

Serialized data with PresentableSlugRelatedField:

{
    "id": 1,
    "name": "Tomato",
    "category": {
        "id": 1,
        "slug": "vegetables",
        "name": "Vegetables"
    }
}

read_source parameter

This parameter allows you to use different source for read operations and doesn't change field name for write operations. This is only used while representing the data.

HybridImageField

A django-rest-framework field for handling image-uploads through raw post data, with a fallback to multipart form data.

It first tries Base64ImageField. if it fails then tries ImageField.

from rest_framework import serializers
from drf_extra_fields.fields import HybridImageField


class HybridImageSerializer(serializers.Serializer):
    image = HybridImageField()

drf-yasg fix for BASE64 Fields:

The drf-yasg project seems to generate wrong documentation on Base64ImageField or Base64FileField. It marks those fields as readonly. Here is the workaround code for correct the generated document. (More detail on issue #66)

class PDFBase64FileField(Base64FileField):
    ALLOWED_TYPES = ['pdf']

    class Meta:
        swagger_schema_fields = {
            'type': 'string',
            'title': 'File Content',
            'description': 'Content of the file base64 encoded',
            'read_only': False  # <-- FIX
        }

    def get_file_extension(self, filename, decoded_file):
        try:
            PyPDF2.PdfFileReader(io.BytesIO(decoded_file))
        except PyPDF2.utils.PdfReadError as e:
            logger.warning(e)
        else:
            return 'pdf'

LowercaseEmailField

An enhancement over django-rest-framework's EmailField to allow case-insensitive serialization and deserialization of e-mail addresses.

from rest_framework import serializers
from drf_extra_fields.fields import LowercaseEmailField


class EmailSerializer(serializers.Serializer):
    email = LowercaseEmailField()

CONTRIBUTION

TESTS

  • Make sure that you add the test for contributed field to test/test_fields.py and run with command before sending a pull request:
$ pip install tox  # if not already installed
$ tox

Or, if you prefer using Docker (recommended):

tools/run_development.sh
tox

README

  • Make sure that you add the documentation for the field added to README.md

LICENSE

Copyright DRF EXTRA FIELDS HIPO

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

More Repositories

1

university-domains-list

University Domains and Names Data List & API
Python
1,314
star
2

Django-API-Playground

Django-API-Playground
Python
179
star
3

university-domains-list-api

The API server for the University Domains
Python
174
star
4

ProvisioningProfileManager

Simple Mac app for managing local Xcode provisioning profiles
Objective-C
66
star
5

HPSocialNetworkManager

iOS framework for authenticating with Facebook and Twitter, with reverse-auth support
Objective-C
50
star
6

hst

history search & picker in ncurses - also can pick other things
Python
47
star
7

hipo-maskededittext-android

Kotlin
40
star
8

backend-challenges

Backend Challenges
Python
35
star
9

hipochat

Websocket Chat Server using Tornado for backend RabbitMQ for message queue
Python
34
star
10

HIPSocialAuth

iOS7 framework for handling Facebook and Twitter authentication
Objective-C
33
star
11

happy-flappy-bird

Flappy Bird Clone in SpriteKit
Objective-C
31
star
12

gotcha

API Benchmark Tool
Go
28
star
13

http-checks

http-checks is a small little application that can test a couple of hundred urls in seconds
Python
27
star
14

HIPLocationManager

Block based iOS framework for handling user location detection. Supports both iOS7 and iOS8 and saves you time by handling the different permission requirements.
Objective-C
27
star
15

tornado_smack

Syntactic sugar for tornado
Python
24
star
16

ChalkBot

ChalkBot's Hangar
Python
21
star
17

drf-timestamp-pagination

DRF Pagination Serializer to work with Timestamp Paginator
Python
21
star
18

django-suit-flame

Flame package for django suit.
HTML
20
star
19

swift-mimic

API mocking framework for iOS projects that allows localized and quick unit and UI tests
Swift
20
star
20

hipo-drf-exceptions

A Django app for returning consistent, verbose and easy to parse error messages on Django Rest Framework backends.
Python
20
star
21

HIPImageCropper

Reusable image crop and scale interface
Objective-C
19
star
22

inclusive-django-range-fields

Inclusive Django Range Fields which uses default bounds as '[]'.
Python
18
star
23

network-analysis-fundamentals

Networkx kütüphanesi hakkında örnekler
Python
17
star
24

django-timestamp-paginator

Django Timestamp Paginator
Python
16
star
25

django-sloop

The django package for sloop implementation
Python
16
star
26

react-ui-toolkit

React-based UI Toolkit. WIP
TypeScript
15
star
27

algojig

A development and testing jig for Algorand
Python
15
star
28

mobile-team-guidelines

iOS & Android team guidelines for how we work and collaborate with each other
15
star
29

tealinspector

The Teal Inspector for lovely Algorand Developers
Python
15
star
30

home-made-homekit

Home Made HomeKit
C
13
star
31

HIPNetworking

NSURLSession based iOS networking library for iOS7 and iOS8
Objective-C
12
star
32

prism

Prism - the image transformation service from Hipo
Python
10
star
33

djangotcha

API Benchmark for Django
HTML
7
star
34

HipoBot

Bluetooth LE controlled robot with a separate iOS app for video transmission
7
star
35

magpie

API client library for iOS, works with AFNetworking
Swift
7
star
36

weatherbot

ESP8266 Mobile Weather Station
Arduino
7
star
37

3d-model-view-demo-android

Kotlin
7
star
38

Heimdal-iOS

iOS App, Today Widget and Apple Watch App for opening the gates of Hipo via Bluetooth LE
Objective-C
6
star
39

macaron

Android base project and lib center.
Kotlin
5
star
40

hipo-exceptions-android

Hipo Exceptions Android
Kotlin
5
star
41

hipo-exceptions-js

JavaScript client for parsing the `hipo-drf-exceptions`
TypeScript
4
star
42

django-admin-favorite-filters

A small Django package that enables users save their favorite filters on Django Admin.
Python
4
star
43

django-sms-toolkit

Django module to send and store SMS with Twilio.
Python
4
star
44

yediemin

A package for bulletproof attachment serving in Django Rest Framework.
Python
4
star
45

InfiniteScroll

Infinite Scroll JavaScript class
JavaScript
3
star
46

jenkins-ios-automation

iOS build automation scripts for Jenkins
Shell
3
star
47

PushTester

A simple iOS8 app for testing push notifications
Objective-C
3
star
48

Heimdal-Arduino

Arduino code for the Bluetooth LE based gate keeper (literally)
Arduino
3
star
49

django-ses-plus

It's an extension for django-ses package
Python
3
star
50

rolld

a simple process supervisor that restarts your processes gracefully
Python
3
star
51

android-movingview

Android library that provides endless scrolling effect for a given background image
Java
3
star
52

hipo-frontend-project-starter

A kick-starter project template for React and TypeScript
TypeScript
2
star
53

wifi-pineapple

Hipocation 2018 Hackday project
JavaScript
2
star
54

cra-template-hipo-typescript

Custom CRA TypeScript template of Hipo web team for creating new web apps
TypeScript
2
star
55

Tryouts-iOS-SDK

Tryouts iOS SDK
Objective-C
2
star
56

zoom-scheduler

Scheduler app for Zoom calls
Swift
2
star
57

irbot

A Telegram bot for Raspberry PI that allows controlling devices with IR remote.
Python
2
star
58

LightController

Python daemon for Raspberry Pi to control lights in the Hipo office
Python
2
star
59

android-drawingview

Android library that provides a customizable canvas view which you can paint on and save
Java
2
star
60

prism-android

Prism image resizer Android library
Java
2
star
61

yesho

A reusable Django app that displays model properties to superusers (or all users) in the Django Admin Panel. Just add YeshoMixin to your ModelAdmins.
Python
2
star
62

selenium-tutorial

selenium-tutorial
Python
1
star
63

android-customtypeface

A library for setting custom typefaces to Android views
Java
1
star
64

hipogram

Hipo Backend Team Interview Exercise
Python
1
star
65

chatterbox-ios

Plug and play chat library for iOS
Swift
1
star
66

android-base-project

Initial steps we follow to setup a new Android project
Shell
1
star
67

macaroon-utils

Swift
1
star
68

macaroon

iOS UIKit extension framework for providing structural interface functionality
Swift
1
star
69

pagination-demo-android

Kotlin
1
star
70

hipolabs.com

hipolabs.com site
JavaScript
1
star
71

hipotalks-app

HipoTalks App
Python
1
star
72

ci-integration-ios

Ruby
1
star
73

calabash

Distance based grouping algorithms
Python
1
star
74

RoboRoach

A self driving Arduino robot
Arduino
1
star
75

django-pg-trunk

A PostgreSQL profiler for Django that uses pg_stat_statements extension
Python
1
star