Skip to main content

EZDjangoCommon

Project description

EZDjangoCommon

ez_django_common is a Django package designed to simplify and standardize common tasks in Django projects. It provides a set of utilities, custom responses, admin enhancements, and other reusable components that can be easily integrated into any Django project. This package aims to reduce boilerplate code and improve consistency across your Django applications.

Features

  • Custom Admin Enhancements: Enhanced Django admin interface with custom widgets, inline models, and improved form handling.
  • Custom Responses: Standardized API responses with support for pagination, error handling, and success messages.
  • JWT Utilities: Custom JWT token views for authentication.
  • Model Mixins: Reusable mixins for common CRUD operations in Django viewsets.
  • Permissions: Customizable Django model permissions with support for additional permissions.
  • Utilities: Helper functions for logging, SMS, and file uploads.

Installation

You can install ez_django_common via pip:

pip install ez-django-common

Or if you want to install from source, you can run this command to install the package:

pip install git+https://github.com/ezhoosh/EZDjangoCommon.git

Optional Features

Watchlog (OpenTelemetry Integration)

If you want to use the watchlog feature for distributed tracing with OpenTelemetry, install with the watchlog extra:

pip install ez-django-common[watchlog]

Or from source:

pip install "ez-django-common[watchlog] @ git+https://github.com/ezhoosh/EZDjangoCommon.git"

This will install the required OpenTelemetry packages:

  • opentelemetry-api
  • opentelemetry-sdk
  • opentelemetry-exporter-otlp
  • opentelemetry-instrumentation
  • opentelemetry-instrumentation-django

Then add these packages to INSTALLED_APPS:

INSTALLED_APPS = [
    'ez_django_common',
    'image_uploader_widget',
    'tinymce',
    ...
]

Usage

Custom Admin Enhancements

BaseModelAdmin

The BaseModelAdmin class provides a set of default configurations for Django admin models, including custom widgets for text and file fields.

from ez_django_common.admin import BaseModelAdmin
from django.contrib import admin
from .models import MyModel

@admin.register(MyModel)
class MyModelAdmin(BaseModelAdmin):
    list_display = ('name', 'created_at')

Custom Inlines

The package provides custom inline classes (TabularInline, StackedInline, NonrelatedTabularInline, NonrelatedStackedInline) that can be used to organize inline models in the admin interface.

from ez_django_common.admin import TabularInline
from django.contrib import admin
from .models import MyModel, RelatedModel

class RelatedModelInline(TabularInline):
    model = RelatedModel

@admin.register(MyModel)
class MyModelAdmin(BaseModelAdmin):
    inlines = [RelatedModelInline]

Unfold

To use unfold for panel admin, first add unfold to INSTALLED_APPS:

INSTALLED_APPS = [
    'unfold', # before django.admin.contrib
    ...
]

then use BaseModelAdmin instead of admin.ModelAdmin in admin classes:

from ez_django_common.admin import BaseModelAdmin

@admin.register(ModelName)
class ModelNameAdmin(BaseModelAdmin):
    ...

Custom Responses

The enveloper function wraps your serializers in a standardized response format, including fields for data, error, and message.

from ez_django_common.custom_responses.enveloper import enveloper

@extend_schema(
    responses=enveloper(SampleRetrieveSerializer, many=False),
)
def retrieve(self, request, *args, **kwargs):
    return super().retrieve(request, *args, **kwargs)

Or if your response is a list of objects:

from ez_django_common.custom_responses.enveloper import enveloper_pagination

@extend_schema(
    ...
    responses=enveloper_pagination(SampleRetrieveSerializer, many=True),
)
def list(self, request, *args, **kwargs):
    return super().list(request, *args, **kwargs)

Custom Exception Handler

The custom_exception_handler provides a standardized way to handle exceptions in your Django REST Framework views.

REST_FRAMEWORK = {
    ...
    "EXCEPTION_HANDLER": "ez_django_common.custom_responses.exception.custom_exception_handler",
    ...
}

JWT Utilities

  • CustomTokenViewBase

The CustomTokenViewBase class provides a base for custom JWT token views, including token refresh and verification.

from ez_django_common.custom_responses.jwt import CustomTokenRefreshView, CustomTokenVerifyView
from rest_framework_simplejwt.views import TokenRefreshView, TokenVerifyView

urlpatterns = [
    path('token/refresh/', CustomTokenRefreshView.as_view(), name='token_refresh'),
    path('token/verify/', CustomTokenVerifyView.as_view(), name='token_verify'),
]

Model Mixins

The package includes several mixins for common CRUD operations in Django viewsets.

from ez_django_common.custom_responses.viewsets import CustomModelViewSet
from .models import MyModel
from .serializers import MySerializer

class MyModelViewSet(CustomModelViewSet):
    queryset = MyModel.objects.all()
    serializer_class = MySerializer

Permissions

  • CustomDjangoModelPermissions

The CustomDjangoModelPermissions class extends Django's default model permissions, allowing you to add additional permissions.

from ez_django_common.permissions import get_custom_model_permissions
from rest_framework.permissions import IsAuthenticated

permission_classes = [IsAuthenticated, get_custom_model_permissions(['myapp.view_mymodel'])]

Auto-Translation (Optional)

The BaseModel includes automatic translation functionality for Django models with django-modeltranslation. To enable this feature:

  1. Install the required dependencies:
pip install googletrans==4.0.0rc1 django-modeltranslation
  1. Add to your Django settings:
# Enable auto-translation
AUTO_TRANSLATE_ENABLED = True

# Configure languages (required for translation)
LANGUAGES = [
    ('en', 'English'),
    ('fa', 'Persian'),
    ('ar', 'Arabic'),
]
LANGUAGE_CODE = 'en'  # Default language
  1. Use the BaseModel in your models:
from ez_django_common.models import BaseModel

class MyModel(BaseModel):
    title = models.CharField(max_length=200)
    description = models.TextField()

# When you save an instance, missing translations will be automatically generated

Note: Auto-translation only works if:

  • AUTO_TRANSLATE_ENABLED = True in settings
  • django-modeltranslation is installed and configured
  • googletrans library is available
  • Your model is registered with modeltranslation

Watchlog (OpenTelemetry Integration)

The watchlog feature provides distributed tracing capabilities using OpenTelemetry. To use this feature:

  1. Install with the watchlog extra:
pip install ez-django-common[watchlog]
  1. Add to your Django settings:
# Enable watchlog
USE_WATCHLOG = True

# Configure Watchlog service
WATCHLOG_SERVICE_NAME = 'my-django-service'
WATCHLOG_SERVICE_ENDPOINT = 'http://watchlog-agent:3774/apm/YOUR_APP_NAME/v1/traces'
  1. The package will automatically instrument your Django application with OpenTelemetry when USE_WATCHLOG = True.

  2. (Optional) To add request/response tracing middleware, add it to your Django settings:

MIDDLEWARE = [
    # ... other middleware
    'ez_django_common.middleware.OpenTelemetryMiddleware',  # Only if watchlog extra is installed
    # ... other middleware
]

Important:

  • The OpenTelemetry dependencies are only installed when you use the [watchlog] extra.
  • If you don't need distributed tracing, you can install the base package without these dependencies.
  • If you set USE_WATCHLOG = True or try to use OpenTelemetryMiddleware without installing the watchlog extra, you will get a helpful error message telling you to install it.

Utilities

  • Upload_to

The upload_to function provides a standardized way to handle file uploads in Django models.

from ez_django_common.storages import upload_to
from django.db import models

def upload_to_path(instance, filename):
    return upload_to(instance, filename, folder="path")

class MyModel(models.Model):
    file = models.FileField(upload_to=upload_to_path)

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

ez_django_common-1.6.2.tar.gz (64.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ez_django_common-1.6.2-py3-none-any.whl (66.7 kB view details)

Uploaded Python 3

File details

Details for the file ez_django_common-1.6.2.tar.gz.

File metadata

  • Download URL: ez_django_common-1.6.2.tar.gz
  • Upload date:
  • Size: 64.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for ez_django_common-1.6.2.tar.gz
Algorithm Hash digest
SHA256 47069aec22932085c618f2f6960b98b74c1772a851e1ae307d4b5f204ebcd54c
MD5 76fa62b17da0066c39759a4c0e1b94fd
BLAKE2b-256 22b6092cf305f7d65af1741f2c2ffcc2c95252e80d4e6d5fe9b9bf89c14a659c

See more details on using hashes here.

File details

Details for the file ez_django_common-1.6.2-py3-none-any.whl.

File metadata

File hashes

Hashes for ez_django_common-1.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0263d54dedaa786e4f6df4dbf2888c7cb401ee935bbbb1bf0204aced6b290365
MD5 8b2fe79f0a0b1a7a3e3b8b0d85a24e32
BLAKE2b-256 7ee8db78add9986e39a20b4a25162a9b6f5c5166be3af10c397d64ce02b64dac

See more details on using hashes here.

Supported by

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