mirror of
				https://github.com/graphql-python/graphene.git
				synced 2025-10-24 20:51:28 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			79 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| Mutations
 | |
| =========
 | |
| 
 | |
| A Mutation is a special ObjectType that also defines an Input.
 | |
| 
 | |
| Quick example
 | |
| -------------
 | |
| 
 | |
| This example defines a Mutation:
 | |
| 
 | |
| .. code:: python
 | |
| 
 | |
|     import graphene
 | |
| 
 | |
|     class CreatePerson(graphene.Mutation):
 | |
|         class Input:
 | |
|             name = graphene.String()
 | |
| 
 | |
|         ok = graphene.Boolean()
 | |
|         person = graphene.Field(lambda: Person)
 | |
| 
 | |
|         def mutate(self, args, context, info):
 | |
|             person = Person(name=args.get('name'))
 | |
|             ok = True
 | |
|             return CreatePerson(person=person, ok=ok)
 | |
| 
 | |
| **person** and **ok** are the output fields of the Mutation when is
 | |
| resolved.
 | |
| 
 | |
| **Input** attributes are the arguments that the Mutation
 | |
| ``CreatePerson`` needs for resolving, in this case **name** will be the
 | |
| only argument for the mutation.
 | |
| 
 | |
| **mutate** is the function that will be applied once the mutation is
 | |
| called.
 | |
| 
 | |
| So, we can finish our schema like this:
 | |
| 
 | |
| .. code:: python
 | |
| 
 | |
|     # ... the Mutation Class
 | |
| 
 | |
|     class Person(graphene.ObjectType):
 | |
|         name = graphene.String()
 | |
| 
 | |
|     class MyMutations(graphene.ObjectType):
 | |
|         create_person = CreatePerson.Field()
 | |
| 
 | |
|     schema = graphene.Schema(mutation=MyMutations)
 | |
| 
 | |
| Executing the Mutation
 | |
| ----------------------
 | |
| 
 | |
| Then, if we query (``schema.execute(query_str)``) the following:
 | |
| 
 | |
| .. code:: graphql
 | |
| 
 | |
|     mutation myFirstMutation {
 | |
|         createPerson(name:"Peter") {
 | |
|             person {
 | |
|                 name
 | |
|             }
 | |
|             ok
 | |
|         }
 | |
|     }
 | |
| 
 | |
| We should receive:
 | |
| 
 | |
| .. code:: json
 | |
| 
 | |
|     {
 | |
|         "createPerson": {
 | |
|             "person" : {
 | |
|                 name: "Peter"
 | |
|             },
 | |
|             "ok": true
 | |
|         }
 | |
|     }
 |