Skip to main content

A filtering system for Opensearch documents similar to django-filter

Project description

Django Opensearch DSL Filtering

A filtering system for Opensearch documents similar to django-filter, but designed to work with Opensearch queries instead of Django ORM.

Installation

pip install django-opensearch-dsl-filtering

Features

  • Filter Opensearch documents using a familiar Django-like API
  • Generate Django forms for your filters automatically
  • Support for pagination and sorting
  • Various filter types: CharFilter, NumericFilter, RangeFilter, DateFilter, BooleanFilter

Quick Start

Define a Document FilterSet

from django_opensearch_dsl import Document
from django_opensearch_dsl_filtering import CharFilter, DateFilter, DocumentFilterSet, NumericFilter

# Assuming you have a Document class defined
class BookDocument(Document):
    # Your document definition here
    class Index:
        name = "books"

    class Django:
        model = Book
        fields = ["id"]

# Create a FilterSet for your document
class BookDocumentFilterSet(DocumentFilterSet):
    document = BookDocument

    # Define filters
    title = CharFilter(field_name="title", lookup_expr="match", label="Title")
    author = CharFilter(field_name="author", lookup_expr="match", label="Author")
    publication_date = DateFilter(field_name="publication_date", label="Publication Date")
    price = NumericFilter(field_name="price", label="Price")
    price_min = NumericFilter(field_name="price", lookup_expr="gte", label="Min Price")
    price_max = NumericFilter(field_name="price", lookup_expr="lte", label="Max Price")

    # Define sorting options
    SORT_CHOICES = [
        ("", "Default"),
        ("title", "Title (A-Z)"),
        ("-title", "Title (Z-A)"),
        ("price", "Price (Low to High)"),
        ("-price", "Price (High to Low)"),
    ]

Use the FilterSet in a View

from django.shortcuts import render

def book_search(request):
    # Create a filter set with the request data
    filter_set = BookDocumentFilterSet(data=request.GET)

    # Get the search results
    search = filter_set.search()
    results = search.execute()

    # Get the form for rendering in the template
    form = filter_set.get_form()

    return render(
        request,
        "books/search.html",
        {
            "form": form,
            "results": results,
        },
    )

Use the Form in a Template

<form method="get">
    {{ form.as_p }}
    <button type="submit">Search</button>
</form>

<div class="results">
    {% for result in results %}
        <div class="result">
            <h2>{{ result.title }}</h2>
            <p>Author: {{ result.author }}</p>
            <p>Price: ${{ result.price }}</p>
        </div>
    {% endfor %}
</div>

Available Filters

  • CharFilter: For text fields
  • NumericFilter: For numeric fields
  • RangeFilter: For numeric fields with a range
  • DateFilter: For date fields
  • BooleanFilter: For boolean fields

Customizing Filters

Each filter can be customized with the following parameters:

  • field_name: The name of the field to filter on
  • lookup_expr: The lookup expression to use (e.g., "match", "term", "wildcard", "gt", "lt", etc.)
  • label: The label to use for the form field

License

MIT

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_opensearch_dsl_filtering-0.1.6.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file django_opensearch_dsl_filtering-0.1.6.tar.gz.

File metadata

File hashes

Hashes for django_opensearch_dsl_filtering-0.1.6.tar.gz
Algorithm Hash digest
SHA256 1c909c055c07040048e09ac2f545fd1f845068f4fe2898183a114309cc216cea
MD5 005e5cc2a11e0dd4e3a74d69d183f9c1
BLAKE2b-256 b7ad5bb3076de15a284cf2ba72285ce49a7a82f8b5985f5ea190773d28b751e8

See more details on using hashes here.

File details

Details for the file django_opensearch_dsl_filtering-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for django_opensearch_dsl_filtering-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 20a293a2da5a16c70cdd36f23b58107fec3e55699855b2470e3bac44c0741a33
MD5 52d54b26f07338a4c98d627674a8bb9e
BLAKE2b-256 c3537814b70571b515de5e14566b22dfd30178387934d9b2b40887a6d8206641

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