Ariadne comes with a few contrib modules to support integration with Django. This module acts as an additional Django contrib module to reduce some of the boilerplate when integrating with Django.
It copies and follows some of the conventions defined in Django Rest Framework, effort will be made to provide API compatibility with certain DRF extension modules that are relevant.
The overall goal is to provide often re-used modules and GrpahQL schema, so one doesn't have to re-create them per project.
- Pagination classes
- Permissions classes
- Serializer classes ( may not removed and made generic )
- Throttling
- django-filters filter backend
2.2.*, 3.0.*
auto schema, resolver and types loader
Searches for types
and resolvers
modules as well as any .graphql
files defined within any installed Django application.
Once found they can be used to build the final schema and resolver solution for your ariadne application.
Schema, types and resolvers for the graphql Payload
interface.
Currently the FieldErrors
are highly coupled to Django rest framework field validation exceptions.
Rename to relay_pagination maybe?
Contains the PageInfo
graphql type and Connection
interface for utilizing cursor based pagination.
TODO: Should we provide a input type for cursor pagination instead of just copying pagination args info paginate-able list fields??
Filter backend interface to pass filter arguments to django-filter.
ABC for Class Based Resolvers and model resolvers that utilize DRF serializers for saving data. This is likely to change in the future.
DRF UUID field scalar for use with models that may use a UUID as their primary key, or other UUID fields.
Adds resolvers, schema and types that can be utilized to query the any waffle flags, samples and switches.
- Get rid of dependency on DRF?
- Investigate the need for a serializer ( nested data reliance? )
- Organize code into multiple Django apps to select desired componentry
- Documentation and examples
- Better support of lists of enums when used with django-filters ( currently expects comma sep list string, not a list of enums from input field resolver )
- License and make public
- Deployment automation
- Mixins are highly coupled to serializers, should they still be?