A Python package that exposes the Django model queryset aggregate functions to the DRF API.
Project description
# django-rest-framework-aggregates
[![PyPI version](https://badge.fury.io/py/drf-aggregates.svg)](https://badge.fury.io/py/drf-aggregates) [![Build Status](https://travis-ci.org/uptick/django-rest-framework-aggregates.svg?branch=master)](https://travis-ci.org/uptick/django-rest-framework-aggregates)
Exposes aggregation features of the Django model queryset to the DRF API.
## Requirements
- Python 3.6+
- Django 1.11+
- Django Rest Framework 3.5.3+
## Overview
This renderer overwrites default behaviour for calls made to api v2 .agg endpoints.
Supports `GET` calls to list endpoints in the format:
endpoint.agg/?aggregate[Count]=(field to count)
endpoint.agg/?aggregate[Sum]=(field to sum)
endpoint.agg/?aggregate[custom_function]=arguments
endpoint.agg/?group_by[field to group by]&aggregate[Count]=id
endpoint.agg/?group_by[field to group by]&aggregate[Count]=id&aggregate[Sum]=(field to sum)
Supports date part extraction for aggregation:
endpoint.agg/?group_by[created__year]&aggregate[Count]=id
Supports choices to representation extract:
endpoint.agg/?group_by[choiceField]&aggregate[Count]=id
## Custom Aggregations
The default aggregate functions supported are defined in `django.db.models.aggregates`.
Custom aggregate functions have been defined in `drf_aggregates.aggregates`
User defined aggregation are passed to a custom queryset manager `calculate_aggregates` as kwargs if defined.
Custom aggregate functions set on the queryset should return a dictionary of field names to aggregate functions, which will then be processed with the other aggregates.
## Examples
Example setup can be found in the [example/](/example/) folder.
To enable the renderer, update your Django settings file:
```python
REST_FRAMEWORK = {
'DEFAULT_RENDERER_CLASSES': (
'drf_aggregates.renderers.AggregateRenderer',
...
),
...
}
```
In the [Cars ViewSet](/example/api/views.py) we are outputting the result to json:
```python
def list(self, request, *args, **kwargs):
queryset = self.filter_queryset(self.get_queryset())
data = request.accepted_renderer.render({'queryset': queryset, 'request': request})
return Response(data, content_type=f'application/json')
```
## Tests
In order to run tests locally:
1. Install development requirements:
`pip3 install -r requirements-dev.txt`
2. Update your environment to point to test Django settings file:
`export DJANGO_SETTINGS_MODULE=example.settings.test`
3. Run tests:
`py.test`
[![PyPI version](https://badge.fury.io/py/drf-aggregates.svg)](https://badge.fury.io/py/drf-aggregates) [![Build Status](https://travis-ci.org/uptick/django-rest-framework-aggregates.svg?branch=master)](https://travis-ci.org/uptick/django-rest-framework-aggregates)
Exposes aggregation features of the Django model queryset to the DRF API.
## Requirements
- Python 3.6+
- Django 1.11+
- Django Rest Framework 3.5.3+
## Overview
This renderer overwrites default behaviour for calls made to api v2 .agg endpoints.
Supports `GET` calls to list endpoints in the format:
endpoint.agg/?aggregate[Count]=(field to count)
endpoint.agg/?aggregate[Sum]=(field to sum)
endpoint.agg/?aggregate[custom_function]=arguments
endpoint.agg/?group_by[field to group by]&aggregate[Count]=id
endpoint.agg/?group_by[field to group by]&aggregate[Count]=id&aggregate[Sum]=(field to sum)
Supports date part extraction for aggregation:
endpoint.agg/?group_by[created__year]&aggregate[Count]=id
Supports choices to representation extract:
endpoint.agg/?group_by[choiceField]&aggregate[Count]=id
## Custom Aggregations
The default aggregate functions supported are defined in `django.db.models.aggregates`.
Custom aggregate functions have been defined in `drf_aggregates.aggregates`
User defined aggregation are passed to a custom queryset manager `calculate_aggregates` as kwargs if defined.
Custom aggregate functions set on the queryset should return a dictionary of field names to aggregate functions, which will then be processed with the other aggregates.
## Examples
Example setup can be found in the [example/](/example/) folder.
To enable the renderer, update your Django settings file:
```python
REST_FRAMEWORK = {
'DEFAULT_RENDERER_CLASSES': (
'drf_aggregates.renderers.AggregateRenderer',
...
),
...
}
```
In the [Cars ViewSet](/example/api/views.py) we are outputting the result to json:
```python
def list(self, request, *args, **kwargs):
queryset = self.filter_queryset(self.get_queryset())
data = request.accepted_renderer.render({'queryset': queryset, 'request': request})
return Response(data, content_type=f'application/json')
```
## Tests
In order to run tests locally:
1. Install development requirements:
`pip3 install -r requirements-dev.txt`
2. Update your environment to point to test Django settings file:
`export DJANGO_SETTINGS_MODULE=example.settings.test`
3. Run tests:
`py.test`
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
drf-aggregates-0.0.10.tar.gz
(5.4 kB
view details)
File details
Details for the file drf-aggregates-0.0.10.tar.gz
.
File metadata
- Download URL: drf-aggregates-0.0.10.tar.gz
- Upload date:
- Size: 5.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b3cd3773f2c67deb2e5dfab4a34b81231964fbfaf5e9dd3e251e3ff54903f520 |
|
MD5 | 3c8fbf62a21979133dc51676422362cb |
|
BLAKE2b-256 | 44dc67da2098003c6a5f8a2ce5c8df5d4b2ed9c5e533a0161641aa955351249a |