mirror of
https://github.com/graphql-python/graphene.git
synced 2024-11-29 13:03:56 +03:00
Added example usage code.
This commit is contained in:
parent
1a74ae1ca7
commit
bf4ebbae3e
71
README.md
71
README.md
|
@ -6,6 +6,77 @@ It will map the models/fields to internal GraphQL-py objects without effort.
|
||||||
[![Build Status](https://travis-ci.org/syrusakbary/graphene.svg?branch=master)](https://travis-ci.org/syrusakbary/graphene)
|
[![Build Status](https://travis-ci.org/syrusakbary/graphene.svg?branch=master)](https://travis-ci.org/syrusakbary/graphene)
|
||||||
[![Coverage Status](https://coveralls.io/repos/syrusakbary/graphene/badge.svg?branch=master&service=github)](https://coveralls.io/github/syrusakbary/graphene?branch=master)
|
[![Coverage Status](https://coveralls.io/repos/syrusakbary/graphene/badge.svg?branch=master&service=github)](https://coveralls.io/github/syrusakbary/graphene?branch=master)
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
Example code of a GraphQL schema using Graphene:
|
||||||
|
|
||||||
|
### Schema definition
|
||||||
|
|
||||||
|
```python
|
||||||
|
import graphene
|
||||||
|
# ...
|
||||||
|
|
||||||
|
class Character(graphene.Interface):
|
||||||
|
id = graphene.IDField()
|
||||||
|
name = graphene.StringField()
|
||||||
|
friends = graphene.ListField(graphene.Field('self'))
|
||||||
|
appearsIn = graphene.ListField(Episode)
|
||||||
|
|
||||||
|
def resolve_friends(self, args, *_):
|
||||||
|
return [wrap_character(getCharacter(f)) for f in self.instance.friends]
|
||||||
|
|
||||||
|
class Human(Character):
|
||||||
|
homePlanet = graphene.StringField()
|
||||||
|
|
||||||
|
|
||||||
|
class Droid(Character):
|
||||||
|
primaryFunction = graphene.StringField()
|
||||||
|
|
||||||
|
|
||||||
|
class Query(graphene.ObjectType):
|
||||||
|
hero = graphene.Field(Character,
|
||||||
|
episode = graphene.Argument(Episode)
|
||||||
|
)
|
||||||
|
human = graphene.Field(Human,
|
||||||
|
id = graphene.Argument(graphene.String)
|
||||||
|
)
|
||||||
|
droid = graphene.Field(Droid,
|
||||||
|
id = graphene.Argument(graphene.String)
|
||||||
|
)
|
||||||
|
|
||||||
|
@resolve_only_args
|
||||||
|
def resolve_hero(self, episode):
|
||||||
|
return wrap_character(getHero(episode))
|
||||||
|
|
||||||
|
@resolve_only_args
|
||||||
|
def resolve_human(self, id):
|
||||||
|
return wrap_character(getHuman(id))
|
||||||
|
if human:
|
||||||
|
return Human(human)
|
||||||
|
|
||||||
|
@resolve_only_args
|
||||||
|
def resolve_droid(self, id):
|
||||||
|
return wrap_character(getDroid(id))
|
||||||
|
|
||||||
|
|
||||||
|
Schema = graphene.Schema(query=Query)
|
||||||
|
```
|
||||||
|
|
||||||
|
### Querying
|
||||||
|
|
||||||
|
Querying `graphene.Schema` is as simple as:
|
||||||
|
|
||||||
|
```python
|
||||||
|
query = '''
|
||||||
|
query HeroNameQuery {
|
||||||
|
hero {
|
||||||
|
name
|
||||||
|
}
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
result = Schema.execute(query)
|
||||||
|
```
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
After cloning this repo, ensure dependencies are installed by running:
|
After cloning this repo, ensure dependencies are installed by running:
|
||||||
|
|
Loading…
Reference in New Issue
Block a user