GraphQL
Il ne laisse pas de REST...
#dev #web #data #api
DATA API
Une histoire de données
Des ressources manipulées : création, lecture, modification et suppression par une
façade générique & interopérable
par le protocole HTTP
API REST
Application
Programming
Interface
Representational
state
transfer
WEB SERVICE SOAP
Simple
Object
Access
Protocol
WEB SERVICE
Une histoire de SERVICE
Des fonctions métiers d'un système exposées par une signature XML (WSDL)
POST /post
API REST
GET /post/1/
PATCH /post/1/
DELETE /post/1
{ title : '...', content: '...' }
{ id: 1, title : '...', content: '...' }
{ id: 1, title : '...', content: '...' }
{ title : 'AAA' }
{ id: 1, title : 'AAA', content: '...'
{ }
GET /post/
[{ id: 1, title : '...', content: '...' }]
REQUEST BODY
URI (endpoint)
RESPONSE
POST /post
API REST
GET /author/1/post
{ author: 1, ... }
{ id: 1, author: 1, ... }
[{ id: 1, author: 1, ... }]
GET /post/1/
{ id: 1, author: 1, ... }
GET /author/1
{ id: 1, name: '...', ... }
Il est nécessaire de faire une requête supplémentaire pour
la récupération des informations de l'auteur
REQUEST BODY
URI (endpoint)
RESPONSE
GRAPH Query LANGUAGE
{
"id": 1,
"name": "Joe",
"posts": [
"id": 1,
"title": "Lorem ipsum"
]
}
type Author {
id: Int!
name: String!
gender: Int!
posts: [Post]
}
type Post{
id: Int!
title: String!
content: String!
}
type Query {
author(id: Int): Author
...
}
query AuthorPosts {
author(id: "1") {
id
name
posts {
id
title
}
}
}
/ QUERY
QUERY
SCHEMA
RESPONSE
GRAPH Query LANGUAGE
{
"id": 1,
"title": "Lorem ipsum",
"votes": 2
}
/ MUTATE
mutation UpVote {
upVote(id: "1") {
id
title
votes
}
}
type Author {
id: Int!
name: String!
gender: Int!
posts: [Post]
}
type Post{
id: Int!
title: String!
content: String!
}
type Mutation {
upVote (id: Int!): Post
...
}
QUERY
SCHEMA
RESPONSE
Comparaison
PLUS | MOINS | |
---|---|---|
API REST Orienté donnée JSON |
Simple (Mise en oeuvre et utilisation) Signature générique Forte testabilité |
Faible typage Structuration non partagé Données brutes en vrac |
SW SOAP Orienté service XML |
Signature claire et typée |
Complexe à mettre en œuvre Services unitaires Formalisé en XML |
GRAPHQL Orienté donnée et service JSON |
Données à la demande Typage fort Schema partagé Par HTTP ou Web Socket |
Sa jeunesse |
GraphQL, il ne laisse pas de reste !
By Michel EDIGHOFFER
GraphQL, il ne laisse pas de reste !
- 418