Please read UPGRADE-v2.0.md to learn how to upgrade to Graphene 2.0
.
A Django integration for Graphene.
Visit the documentation to get started!
For installing graphene, just run this command in your shell
pip install "graphene-neo4j>=2.0"
Use basic graphene_django package in INSTALLED_APPS
INSTALLED_APPS = (
# ...
'django.contrib.staticfiles', # Required for GraphiQL
'graphene_django',
)
GRAPHENE = {
'SCHEMA': 'app.schema.schema' # Where your Graphene schema lives
}
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)),
]
Here is a simple neomodel model:
from neomodel import *
class UserModel(StructuredNode):
name = StringProperty(required=True)
age = IntegerProperty()
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:
# pass yours model here, the fields are define automatically
model = UserModel
class Query(graphene.ObjectType):
users = graphene.List(User)
def resolve_users(self, info):
return UserModel.nodes.all()
schema = graphene.Schema(query=Query)
import graphene
from graphene_django import DjangoObjectType
from graphene_django.filter.fields import DjangoFilterConnectionField
class UserType(DjangoObjectType):
class Meta:
# pass yours model here, the fields are define automatically
model = UserModel
# definition of filter settings
# key - the <field_name>
# value - the list of search instructions
neomodel_filter_fields = {
'name': ['icontains', 'contains', 'exact'],
'age': ['lte', 'gte', 'gt'],
}
interfaces = (
graphene.relay.Node,
)
class Query(graphene.ObjectType):
""" The types resolves automatically
"""
user = graphene.relay.Node.Field(UserType)
users = DjangoFilterConnectionField(UserType)
schema = graphene.Schema(query=Query)
Then you can simply query the schema:
query = '''
query {
users {
name
age
}
}
'''
result = schema.execute(query)
To learn more check out the following examples:
- Schema with Filtering: Cookbook example
- Relay Schema: Starwars Relay example