Build powerful, efficient, and flexible GraphQL APIs with seamless Django integration.
Go to file
David Beitey ce9d989bcd Update install docs for Django 2.x
This uses the new URL routing syntax introduced in Django 2.0 (https://docs.djangoproject.com/en/2.2/releases/2.0/#simplified-url-routing-syntax).  The older `url()` syntax will deprecated at some point in future https://docs.djangoproject.com/en/2.2/ref/urls/#url
2019-05-13 17:08:26 +10:00
bin Isolated Graphene Django in a new package 2016-09-17 16:31:17 -07:00
docs Update install docs for Django 2.x 2019-05-13 17:08:26 +10:00
examples Fix security issues 2019-05-07 19:26:19 +01:00
graphene_django Bugfix: FormMutation was always causing boolean fields to be required (#613) 2019-05-09 11:47:47 -07: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 Introduce Black formatting, additional tests 2019-05-02 17:46:35 +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 Introduce Black formatting, additional tests 2019-05-02 17:46:35 +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 Rebuild documentation 2019-05-07 19:23:01 +01:00
README.rst Rebuild documentation 2019-05-07 19:23:01 +01:00
setup.cfg Removed duplicate bdist_wheel section 2017-08-31 15:34:22 +02:00
setup.py Introduce Black formatting, additional tests 2019-05-02 17:46:35 +01: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.

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.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

See CONTRIBUTING.md