graphene/docs/pages/docs/quickstart-django.md
2015-11-30 22:41:44 -08:00

4.2 KiB
Raw Blame History

title description
Django Tutorial A Quick guide to Graphene in Django

Django Tutorial

In our previous quickstart page we created a very simple schema.

Now we will adapt the schema to automatically map some Django models, and expose this schema in a /graphql API endpoint.

Project setup

# Create the project directory
mkdir tutorial
cd tutorial

# Create a virtualenv to isolate our package dependencies locally
virtualenv env
source env/bin/activate  # On Windows use `env\Scripts\activate`

# Install Django and Graphene with Django support
pip install django
pip install graphene[django]
pip install django-graphiql

# Set up a new project with a single application
django-admin.py startproject tutorial .  # Note the trailing '.' character
django-admin.py startapp quickstart

Now sync your database for the first time:

python manage.py migrate

We'll also create an initial user named admin with a password of password.

python manage.py createsuperuser

Once you've set up a database and initial user created and ready to go, open up the app's directory and we'll get coding...

Schema

GraphQL presents your objects to the world as a graph structure rather than a more heiricarcal structure to which you may be acustomed. In order to create this representation, Graphene needs to know about each type of object which will appear in the graph. Below we define these as the UserType and GroupType classes.

This graph also has a 'root' through which all access begins. This is the Query class below. In this example, we provide the ability to list all users via all_users, and the ability to obtain a single user via get_user.

Open tutorial/quickstart/schema.py and type the following:

import graphene
from graphene.contrib.django import DjangoObjectType

from django.contrib.auth.models import User, Group

# Graphene will automatically map the User model's fields onto the UserType.
# This is configured in the UserType's Meta class
class UserType(DjangoObjectType):
    class Meta:
        model = User
        only_fields = ('username', 'email', 'groups')


class GroupType(DjangoObjectType):
    class Meta:
        model = Group
        only_fields = ('name', )


class Query(graphene.ObjectType):
    all_users = graphene.List(UserType)
    get_user = graphene.Field(UserType,
                              id=graphene.String().NonNull)
    get_group = graphene.Field(GroupType,
                               id=graphene.String().NonNull)

    def resolve_all_users(self, args, info):
        return User.objects.all()

    def resolve_get_user(self, args, info):
        return User.objects.get(id=args.get('id'))

    def resolve_get_group(self, args, info):
        return Group.objects.get(id=args.get('id'))

schema = graphene.Schema(query=Query)

Adding GraphiQL

For having the GraphiQL static assets we need to append django_graphiql in INSTALLED_APPS in tutorial/settings.py:

INSTALLED_APPS = [
    # The other installed apps
    'django_graphiql',
]

Creating GraphQL and GraphiQL views

Unlike a RESTful API, there is only a single URL from which a GraphQL is accessed. Requests to this URL are handled by Graphene's GraphQLView view.

Additionally, an interface for navigating this API will be very useful. Graphene includes the graphiql in-browser IDE which assists in exploring and querying your new API. Well add a URL for this too.

from django.conf.urls import url, include
from django.views.decorators.csrf import csrf_exempt
from graphene.contrib.django.views import GraphQLView
from quickstart.schema import schema


# Wire up our GraphQL schema to /graphql.
# Additionally, we include GraphiQL view for querying easily our schema.
urlpatterns = [
    url(r'^graphql', csrf_exempt(GraphQLView.as_view(schema=schema))),
    url(r'^graphiql', include('django_graphiql.urls')),
]

Testing our GraphQL schema

We're now ready to test the API we've built. Let's fire up the server from the command line.

python ./manage.py runserver

Go to localhost:8080/graphiql and type your first query!

myQuery {
    getUser(id:"1") {
        username
    }
}