Build powerful, efficient, and flexible GraphQL APIs with seamless Django integration.
Go to file
Alexandre Kirszenberg 2417f79693 Introduce refine_queryset and get_connection_parameters
refine_queryset lets DjangoObjectType define exactly how the queryset
should be refined before being returned to the user. For instance, some
objects could be filtered out according to a predicate, or some fields
could be prefetched depending on what the initial query requested.

get_connection_parameters lets DjangoObjectType define the name and
value of parameters that can be passed to any DjangoConnectionField that
uses them.

Both these additions come as building blocks to allow custom refinements
and filters without having to go through django-filter. Moreover, such
filters can also be further optimized than previously allowed, as the
GraphQL info object is available in refine_queryset.
2019-02-05 18:13:21 +01:00
bin Isolated Graphene Django in a new package 2016-09-17 16:31:17 -07:00
docs Merge pull request #506 from ccsv/patch-1 2018-09-05 13:30:40 +02:00
examples Making GrapheneFilterSetMixin compatible with django_filter 2 2018-09-04 13:15:04 -04:00
graphene_django Introduce refine_queryset and get_connection_parameters 2019-02-05 18:13:21 +01:00
.coveragerc Improved python syntax and sorts (pep8). Improved Readme 2016-09-17 17:09:56 -07:00
.gitignore Add Vim.gitignore to .gitignore 2017-02-14 20:22:51 +02:00
.travis.yml Add back support for django-filter < 2 2018-09-04 13:15:04 -04:00
django_test_settings.py added ModelSerializer tests 2017-11-13 20:33:12 +00:00
LICENSE add license to repo 2018-05-25 01:28:51 -04:00
MANIFEST.in add license to repo 2018-05-25 01:28:51 -04:00
pytest.ini create pytest.ini to contain DJANGO_SETTINGS_MODULE 2016-11-16 09:56:55 -08:00
README.md Update README.md 2017-11-28 21:02:53 -05:00
README.rst Update README.rst 2017-11-28 21:04:08 -05:00
setup.cfg Removed duplicate bdist_wheel section 2017-08-31 15:34:22 +02:00
setup.py Remove iso8601 dependency, updated graphql-core 2018-09-05 13:18:09 +02:00

Please read UPGRADE-v2.0.md to learn how to upgrade to Graphene 2.0.


Graphene Logo Graphene-Django Build Status PyPI version Coverage Status

A Django integration for Graphene.

Installation

For installing graphene, just run this command in your shell

pip install "graphene-django>=2.0"

Settings

INSTALLED_APPS = (
    # ...
    'graphene_django',
)

GRAPHENE = {
    'SCHEMA': 'app.schema.schema' # Where your Graphene schema lives
}

Urls

We need to set up a GraphQL endpoint in our Django app, so we can serve the queries.

from django.conf.urls import url
from graphene_django.views import GraphQLView

urlpatterns = [
    # ...
    url(r'^graphql', GraphQLView.as_view(graphiql=True)),
]

Examples

Here is a simple Django model:

from django.db import models

class UserModel(models.Model):
    name = models.CharField(max_length=100)
    last_name = models.CharField(max_length=100)

To create a GraphQL schema for it you simply have to write the following:

from graphene_django import DjangoObjectType
import graphene

class User(DjangoObjectType):
    class Meta:
        model = UserModel

class Query(graphene.ObjectType):
    users = graphene.List(User)

    def resolve_users(self, info):
        return UserModel.objects.all()

schema = graphene.Schema(query=Query)

Then you can simply query the schema:

query = '''
    query {
      users {
        name,
        lastName
      }
    }
'''
result = schema.execute(query)

To learn more check out the following examples:

Contributing

After cloning this repo, ensure dependencies are installed by running:

pip install -e ".[test]"

After developing, the full test suite can be evaluated by running:

py.test graphene_django --cov=graphene_django # Use -v -s for verbose mode

Documentation

The documentation is generated using the excellent Sphinx and a custom theme.

The documentation dependencies are installed by running:

cd docs
pip install -r requirements.txt

Then to produce a HTML version of the documentation:

make html