Please read [UPGRADE-v2.0.md](https://github.com/graphql-python/graphene/blob/master/UPGRADE-v2.0.md) to learn how to upgrade to Graphene `2.0`. --- # ![Graphene Logo](http://graphene-python.org/favicon.png) Graphene-Django [![Build Status](https://travis-ci.org/graphql-python/graphene-django.svg?branch=master)](https://travis-ci.org/graphql-python/graphene-django) [![PyPI version](https://badge.fury.io/py/graphene-django.svg)](https://badge.fury.io/py/graphene-django) [![Coverage Status](https://coveralls.io/repos/graphql-python/graphene-django/badge.svg?branch=master&service=github)](https://coveralls.io/github/graphql-python/graphene-django?branch=master) A [Django](https://www.djangoproject.com/) integration for [Graphene](http://graphene-python.org/). ## Installation For instaling graphene, just run this command in your shell ```bash pip install "graphene-django>=2.0" ``` ### Settings ```python 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. ```python 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: ```python 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: ```python 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: ```python query = ''' query { users { name, lastName } } ''' result = schema.execute(query) ``` To learn more check out the following [examples](examples/): * **Schema with Filtering**: [Cookbook example](examples/cookbook) * **Relay Schema**: [Starwars Relay example](examples/starwars) ## Contributing After cloning this repo, ensure dependencies are installed by running: ```sh pip install -e ".[test]" ``` After developing, the full test suite can be evaluated by running: ```sh py.test graphene_django --cov=graphene_django # Use -v -s for verbose mode ``` ### Documentation The [documentation](http://docs.graphene-python.org/projects/django/en/latest/) is generated using the excellent [Sphinx](http://www.sphinx-doc.org/) and a custom theme. The documentation dependencies are installed by running: ```sh cd docs pip install -r requirements.txt ``` Then to produce a HTML version of the documentation: ```sh make html ```