Mutations
Mutations are transformed into POST requests.
Given the following example:
type Comment {
id: ID
text: String
}
type Mutation {
addComment(text: String!) Comment
}
Sofa will create a POST /add-comment
route that accepts a { text }
body.
curl --header "Content-Type: application/json" \
--request POST \
--data '{"text":"Sofa is awesome!"}' \
http://localhost:3000/api/add-comment
For mutations to properly work with JSON bodies, you will need to have bodyParser.json()
or a similar module as a middleware, else you will have to pass arguments via url paramaters.
Heres an example of without body-parser
:
type Comment {
id: ID
text: String
}
type Mutation {
addComment(text: String!) Comment
}
Will mean that you will have to access it like this:
curl --header "Content-Type: application/json" \
--request POST \
http://localhost:3000/api/add-comment?text=Sofa%20is%20awesome%21
How to enable body-parser
:
npm i body-parser
Then you can simply initialise it like this:
import bodyParser from 'body-parser';
app.use(bodyParser.json());