You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Syrus Akbary 4e23c3ccf6 Improved python syntax and sorts (pep8). Improved Readme 6 years ago
bin Isolated Graphene Django in a new package 6 years ago
examples Improved python syntax and sorts (pep8). Improved Readme 6 years ago
graphene_django Improved python syntax and sorts (pep8). Improved Readme 6 years ago
.coveragerc Improved python syntax and sorts (pep8). Improved Readme 6 years ago
.gitignore Isolated Graphene Django in a new package 6 years ago
.travis.yml Isolated Graphene Django in a new package 6 years ago
README.md Improved python syntax and sorts (pep8). Improved Readme 6 years ago
django_test_settings.py Improved python syntax and sorts (pep8). Improved Readme 6 years ago
setup.cfg Improved python syntax and sorts (pep8). Improved Readme 6 years ago
setup.py Isolated Graphene Django in a new package 6 years ago

README.md

You are in the next unreleased version of Graphene-Django (1.0.dev). Please read UPGRADE-v1.0.md to learn how to upgrade.


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

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=QueryRoot)

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