Build powerful, efficient, and flexible GraphQL APIs with seamless Django integration.
Go to file
Eric Abruzzese ab569ea2d6 Update GraphiQL, add GraphiQL subscription support
* Update the GraphiQL template to use the latest versions of react,
  react-dom, graphiql, and (new) subscriptions-transport-ws.
* Add support for websocket connections and subscriptions to the
  GraphiQL template.
* Add a `SUBSCRIPTION_URL` configuration option to allow GraphiQL to
  route subscriptions to a different path (allowing for more advanced
  infrastructure scenarios).
* Update the README to include some starting points for implementing
  subscriptions and configuring `SUBSCRIPTION_URL`.
2020-07-11 19:25:44 -04:00
.github Update bug_report.md 2020-05-09 13:32:20 +01:00
bin Isolated Graphene Django in a new package 2016-09-17 16:31:17 -07:00
docs fixes minor typo in docs index (#969) 2020-05-22 11:12:27 +01:00
examples Bump django from 3.0.3 to 3.0.7 in /examples/cookbook (#979) 2020-06-06 12:48:19 +01:00
graphene_django Update GraphiQL, add GraphiQL subscription support 2020-07-11 19:25:44 -04:00
.coveragerc Improved python syntax and sorts (pep8). Improved Readme 2016-09-17 17:09:56 -07:00
.gitignore Added tox.ini 2019-05-22 01:49:52 +01:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2019-05-06 13:28:02 +01:00
CONTRIBUTING.md Introduce Black formatting, additional tests 2019-05-02 17:46:35 +01: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
Makefile Update flake8 (#688) 2019-06-24 18:55:44 +01:00
MANIFEST.in Add static files to MANIFEST.in 2019-03-25 12:45:43 -04:00
pytest.ini create pytest.ini to contain DJANGO_SETTINGS_MODULE 2016-11-16 09:56:55 -08:00
README.md Update GraphiQL, add GraphiQL subscription support 2020-07-11 19:25:44 -04:00
README.rst Rebuild documentation 2019-05-07 19:23:01 +01:00
setup.cfg Bugfix: Correct filter types for DjangoFilterConnectionFields (#682) 2019-07-07 12:11:27 -07:00
setup.py Move to_const function from Graphene into Graphene-Django (#992) 2020-06-25 15:11:18 +01:00
tox.ini Use psycopg2-binary in tox (#964) 2020-05-21 13:18:43 +01:00

Graphene Logo Graphene-Django

A Django integration for Graphene.

travis pypi Anaconda-Server Badge coveralls

💬 Join the community on Slack

Documentation

Visit the documentation to get started!

Quickstart

For installing graphene, just run this command in your shell

pip install "graphene-django>=2.0"

Settings

INSTALLED_APPS = (
    # ...
    'django.contrib.staticfiles', # Required for GraphiQL
    '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.urls import path
from graphene_django.views import GraphQLView

urlpatterns = [
    # ...
    path('graphql', GraphQLView.as_view(graphiql=True)),
]

Subscription Support

The graphene-django project does not currently support GraphQL subscriptions out of the box. However, there are several community-driven modules for adding subscription support, and the GraphiQL interface provided by graphene-django supports subscriptions over websockets.

To implement websocket-based support for GraphQL subscriptions, you'll need to:

  1. Install and configure django-channels.
  2. Install and configure1, 2 a third-party module for adding subscription support over websockets. A few options include:
  3. Ensure that your application (or at least your GraphQL endpoint) is being served via an ASGI protocol server like daphne (built in to django-channels), uvicorn, or hypercorn.

1 Note: By default, the GraphiQL interface that comes with graphene-django assumes that you are handling subscriptions at the same path as any other operation (i.e., you configured both urls.py and routing.py to handle GraphQL operations at the same path, like /graphql).

If these URLs differ, GraphiQL will try to run your subscription over HTTP, which will produce an error. If you need to use a different URL for handling websocket connections, you can configure SUBSCRIPTION_PATH in your settings.py:

GRAPHENE = {
    # ...
    "SUBSCRIPTION_PATH": "/ws/graphql"  # The path you configured in `routing.py`, including a leading slash.
}

Once your application is properly configured to handle subscriptions, you can use the GraphiQL interface to test subscriptions like any other operation.

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 query the schema:

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

To learn more check out the following examples:

Contributing

See CONTRIBUTING.md

Release Notes