Build powerful, efficient, and flexible GraphQL APIs with seamless Django integration.
Go to file
Tony Angerilli 3e5ae5a3d1 don’t try to access the type until after initialization
this allows for fields in a node (using a DjangoFilterConnectionField) that reference themselves
2016-10-21 17:41:07 -07:00
bin Isolated Graphene Django in a new package 2016-09-17 16:31:17 -07:00
docs Fixes typo in docs 2016-10-18 14:30:15 -07:00
examples Merge pull request #24 from stegben/fix-cookbook-example 2016-10-19 18:40:40 -07:00
graphene_django don’t try to access the type until after initialization 2016-10-21 17:41:07 -07:00
.coveragerc Improved python syntax and sorts (pep8). Improved Readme 2016-09-17 17:09:56 -07:00
.gitignore Moved django-graphql-view and django-graphiql into graphene-django 😎 2016-09-19 22:04:23 -07:00
.travis.yml Force pytest-django verison for testing compatibility with Django 1.6 2016-09-17 18:45:08 -07:00
django_test_settings.py Moved django-graphql-view and django-graphiql into graphene-django 😎 2016-09-19 22:04:23 -07:00
MANIFEST.in Include templates in package. Updated dev version 2016-09-19 23:04:07 -07:00
README.md Fixed install version in README 2016-09-30 09:08:47 -07:00
README.rst Fixed install version in README 2016-09-30 09:08:47 -07:00
setup.cfg Improved python syntax and sorts (pep8). Improved Readme 2016-09-17 17:09:56 -07:00
setup.py Updated graphene-django to 1.0 🎉 2016-09-26 09:26:09 -07:00

Please read UPGRADE-v1.0.md to learn how to upgrade to Graphene 1.0.


Graphene Logo Graphene-Django Build Status PyPI version Coverage Status

A Django integration for Graphene.

Installation

For instaling graphene, just run this command in your shell

pip install "graphene-django>=1.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

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

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

    @graphene.resolve_only_args
    def resolve_users(self):
        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:

python setup.py install

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

python setup.py test # Use --pytest-args="-v -s" for verbose mode