rest in peace {REST} โฐ๏ธ
The rise of GraphQL ๐
{
"Agenda ๐ " : [
}
"About me ๐จโ๐ฌ", "what the talk is, and is not!", "Quick walk-through on REST", "What's wrong with REST ?", "Solution to solve REST issues - GraphQL", "Why GraphQL ?", "About GraphQL & it's building blocks", "How to GraphQL in Python", "E.g.- basic schema and querying using graphene", "Best practices & resources for GraphQL", "Conclusion"
]
data:image/s3,"s3://crabby-images/d3531/d3531f307a8a40c3d2a4f2038ca3b9e6bb5384ce" alt=""
Abhishek
๐จโ๐ป Software Eng. at Saama Research Lab
๐ Pythonista, GDG Chennai & PyCon IN โฅ๏ธ
๐จโ๐ฉโ๐งโ๐ฆ Community first person ๐
data:image/s3,"s3://crabby-images/80443/804432e4e0e029dd0cf9fe4acdef1b6792ab7e1b" alt=""
connect with me:
๐ซ not "10x Engineer"
What this talk is, and is not !
โ Trip around bird's eye view on REST & GraphQL
โ Python Graphene
๐ โโ๏ธ Graphene internals
๐ โโ๏ธ GraphQL tutorial
Let's start with APIs
data:image/s3,"s3://crabby-images/0f500/0f500820e2f8cd159bb349996b3ca718270342af" alt=""
{REST} or "so-called REST"
data:image/s3,"s3://crabby-images/eb37d/eb37d8b47c8abb7d0c4400409e7862f366fb8556" alt=""
data:image/s3,"s3://crabby-images/a0fd6/a0fd6af713475e70db08cd06706eb413e81a6132" alt=""
๐ {REST}
๐ท Focuses on resources through URI's
๐ท Got Methods / Verbs :
- GET
- POST
- PUT
- DELETE
๐ท Gets JSON for you
๐ท Stateless architectural style fo web service development
https://api.saamaconf.com/2021/speakers
GET
[
verb
endpoint
https://api.pyconin.com/2019/speakers
GET
data:image/s3,"s3://crabby-images/54641/546415759bafe6b1d0c196970242a476f1440012" alt=""
REST APIs
return
resources
data:image/s3,"s3://crabby-images/85886/85886fd6818098582035b9fe689e7dfde950b4b7" alt=""
data:image/s3,"s3://crabby-images/89d73/89d73553e44e5d4e4ea8a10954d867987c471f29" alt=""
Multiple endpoints
>
>
>
data:image/s3,"s3://crabby-images/f7280/f72804037bdf797bb6d0fcfb9b87be1630ebe64c" alt=""
data:image/s3,"s3://crabby-images/90608/90608bf7de87913973f3351bbbcffbe7cca1623e" alt=""
Hitting millions* of endpoints......
"RESTful APIs are optimized for servers."
ยฏ\_(ใ)_/ยฏ
data:image/s3,"s3://crabby-images/3d10f/3d10f323b12527fb2c8bf1bcf45e28a3a5c7aa56" alt=""
BFF
data:image/s3,"s3://crabby-images/eb37d/eb37d8b47c8abb7d0c4400409e7862f366fb8556" alt=""
data:image/s3,"s3://crabby-images/eb37d/eb37d8b47c8abb7d0c4400409e7862f366fb8556" alt=""
backends
frontends
data:image/s3,"s3://crabby-images/eb37d/eb37d8b47c8abb7d0c4400409e7862f366fb8556" alt=""
for
data:image/s3,"s3://crabby-images/966da/966da8cb95756d9beadf7cb4dc83ab9b0882a3ac" alt=""
data:image/s3,"s3://crabby-images/89d73/89d73553e44e5d4e4ea8a10954d867987c471f29" alt=""
Netflix's BFF Pattern
>
>
>
data:image/s3,"s3://crabby-images/f7280/f72804037bdf797bb6d0fcfb9b87be1630ebe64c" alt=""
data:image/s3,"s3://crabby-images/74cd3/74cd3bf05c135ff38e3b60464b1ddb759c9b723d" alt=""
REST provides benefits.
...But
comes with
๐ฐ
data:image/s3,"s3://crabby-images/a95d6/a95d6547ab61808082f1c4e4b4e8489a1503b322" alt=""
{REST} ๐
๐ Multiple endpoints (multiple round trips)
๐ Weak typing
๐ Query complexity (n+1)
๐ Over/Under-fetching of data
๐ Tooling & introspection
What's the solution ?
So, there are many !!
๐คนโโ๏ธ
data:image/s3,"s3://crabby-images/40886/40886625b01f4476cb2f7b2ebe61564eed1dbbc1" alt=""
data:image/s3,"s3://crabby-images/d7984/d7984f5c5f4582404fdde8c12fbeeac360fec8cf" alt=""
data:image/s3,"s3://crabby-images/77e6b/77e6b87a190d44cc76a93d2da8d9b49c5ba297b3" alt=""
data:image/s3,"s3://crabby-images/deeb4/deeb48eb7e0aa603abd1646761c38160cb9f154e" alt=""
data:image/s3,"s3://crabby-images/b9c75/b9c75ac191c528a63dc2bf0c5aebd5d54e749dc4" alt=""
โจ
Why GraphQL !?
What makes it different?
๐ค
๐ง
data:image/s3,"s3://crabby-images/eeebb/eeebb8b90b6cedbc15185d67086eee6167c4b1ab" alt=""
Buzz...
"despite the snark,the buzz is important"
RESTaurant
data:image/s3,"s3://crabby-images/aec59/aec591e909ea05403f6fecde1a5af148a596db62" alt=""
data:image/s3,"s3://crabby-images/62442/62442fce0f7e84bf2badc6112236c9eb439d3016" alt=""
data:image/s3,"s3://crabby-images/538d3/538d36cde01dccd319839f49ab1b4db0cdd9fad6" alt=""
data:image/s3,"s3://crabby-images/bff2c/bff2c7689e0b4f03ca0ebba1a26bc047f5fb0e25" alt=""
https://RESTaurant.com/sandwich
data:image/s3,"s3://crabby-images/55bca/55bca343613c447897457d689786f9600bf1ff5a" alt=""
data:image/s3,"s3://crabby-images/55bca/55bca343613c447897457d689786f9600bf1ff5a" alt=""
GraphQL Cafe
data:image/s3,"s3://crabby-images/aec59/aec591e909ea05403f6fecde1a5af148a596db62" alt=""
data:image/s3,"s3://crabby-images/929a3/929a35affb031afe8c32f512fe7e1e5d62ba419a" alt=""
data:image/s3,"s3://crabby-images/bff2c/bff2c7689e0b4f03ca0ebba1a26bc047f5fb0e25" alt=""
data:image/s3,"s3://crabby-images/bff2c/bff2c7689e0b4f03ca0ebba1a26bc047f5fb0e25" alt=""
Query{
Sandwich{
bread
salami
tomato
}
}
data:image/s3,"s3://crabby-images/55bca/55bca343613c447897457d689786f9600bf1ff5a" alt=""
data:image/s3,"s3://crabby-images/55bca/55bca343613c447897457d689786f9600bf1ff5a" alt=""
โ
data:image/s3,"s3://crabby-images/a4f75/a4f75139ed58c167e99b7e75c9dffe6d5ebb10a7" alt=""
โ๏ธ
โ๏ธ
โ๏ธ
โ๏ธ
โ๏ธ
Single request, Single endpoint
Specification...NOT implementation
More control over data
Relational queries
Strongly typed !
๐ฏ
๐
๐บ
๐ฐ
โ
LIFE EASIER
in short
data:image/s3,"s3://crabby-images/38b62/38b625e2934140433b1c6c55f1327240f3898b61" alt=""
enter
GraphQL
data:image/s3,"s3://crabby-images/c057b/c057b0e0b4125432494fdef7cf8532e91267bebf" alt=""
๐ {GraphQL}
DSL on top of your backend data fetching logic
Created by Facebook & went open source in 2015
Query language for your API
data:image/s3,"s3://crabby-images/c057b/c057b0e0b4125432494fdef7cf8532e91267bebf" alt=""
Strongly typed-Schema driven
Self described & introspectable
data:image/s3,"s3://crabby-images/3bf5c/3bf5cb10ab8f893f7bf59ac18ee37cfdd84f709b" alt=""
data:image/s3,"s3://crabby-images/3bf5c/3bf5cb10ab8f893f7bf59ac18ee37cfdd84f709b" alt=""
data:image/s3,"s3://crabby-images/3bf5c/3bf5cb10ab8f893f7bf59ac18ee37cfdd84f709b" alt=""
data:image/s3,"s3://crabby-images/3bf5c/3bf5cb10ab8f893f7bf59ac18ee37cfdd84f709b" alt=""
data:image/s3,"s3://crabby-images/3bf5c/3bf5cb10ab8f893f7bf59ac18ee37cfdd84f709b" alt=""
data:image/s3,"s3://crabby-images/8004e/8004ec9bbd385d53237ceb63229e4c2884907a3b" alt=""
data:image/s3,"s3://crabby-images/1e5af/1e5af4ec157b520bd80484490db5ca90e7ac2cbf" alt=""
data:image/s3,"s3://crabby-images/55e95/55e95fde4dc8089cdd6e213a1c94bd2c60bebfd5" alt=""
data:image/s3,"s3://crabby-images/0cbdb/0cbdb4aeea2964521cc9996c8e45e4c018ac6c70" alt=""
data:image/s3,"s3://crabby-images/4fecb/4fecbc4abaecb5a906ec309bcbaa457915d87467" alt=""
data:image/s3,"s3://crabby-images/f2de9/f2de96137d97a01a86ebad657a9991cf2c9d18b5" alt=""
data:image/s3,"s3://crabby-images/442a6/442a64a1fc5237b2599e2bfc41ea17bd45f69f5c" alt=""
data:image/s3,"s3://crabby-images/29419/2941973c9e99e64169d4c89b8e988f7902258290" alt=""
data:image/s3,"s3://crabby-images/f5a5b/f5a5bbfd667bf3f7596dd028662bdc1bbacaa0d0" alt=""
data:image/s3,"s3://crabby-images/7affa/7affadd523051200fb9f64c292f6dd9c39fafbbe" alt=""
data:image/s3,"s3://crabby-images/e333b/e333b05dbd73846ce88a45927fd96cfbb278844d" alt=""
data:image/s3,"s3://crabby-images/966da/966da8cb95756d9beadf7cb4dc83ab9b0882a3ac" alt=""
data:image/s3,"s3://crabby-images/89d73/89d73553e44e5d4e4ea8a10954d867987c471f29" alt=""
Before GraphQL
data:image/s3,"s3://crabby-images/f7280/f72804037bdf797bb6d0fcfb9b87be1630ebe64c" alt=""
data:image/s3,"s3://crabby-images/74cd3/74cd3bf05c135ff38e3b60464b1ddb759c9b723d" alt=""
data:image/s3,"s3://crabby-images/53c6a/53c6a8f4fbe0bda48345b4338ac1e6a21b38935e" alt=""
After GraphQL
data:image/s3,"s3://crabby-images/c49a0/c49a0a7407147cabcbd6c6e6605cca80bc37235a" alt=""
Front-End Folks
think SQL
not Neo4j
๐ ๏ธ Building blocks of GraphQL ๐๏ธโ๏ธ
-
Schema (types & relation)
-
Query (read)
-
Mutation (write)
-
create
-
update
-
delete
-
-
Subscription (realtime pub-sub)
data:image/s3,"s3://crabby-images/d6c72/d6c72aa1ceae0196bc85eba06e6209bde7e399cd" alt=""
data:image/s3,"s3://crabby-images/d6c72/d6c72aa1ceae0196bc85eba06e6209bde7e399cd" alt=""
Query
Response
Full Schema
Schema ! Schema ! Schema !
- Adds capability for your API to define how client fetch & update data
- Represents contract between client and server
- Collection of GraphQL types with root types
Root Types
type Query {
...
}
type Mutation {
...
}
type Subscription {
...
}
Libraries for GraphQL
data:image/s3,"s3://crabby-images/98892/9889207688354b10ab891e6dbfd7758ebc91ba07" alt=""
Ariadne
data:image/s3,"s3://crabby-images/ffb00/ffb0090d2de732377eb192c946d18d786e55afe4" alt=""
data:image/s3,"s3://crabby-images/46074/460742891227191d2247deba7ad274f8dea8e118" alt=""
Strawberry
data:image/s3,"s3://crabby-images/2e42b/2e42b11db1eb7def5d5fc0760de7d08512c4d049" alt=""
Graphene
data:image/s3,"s3://crabby-images/2e42b/2e42b11db1eb7def5d5fc0760de7d08512c4d049" alt=""
Graphene
- Provides tool to implement a GraphQL API in python using a code-first approach
- Instead of writing GraphQL SDL, we write Python code to describe the data
- Integration with most web frameworks and ORM's
pip install "graphene>=2.0"
Query
Response
from graphene import ObjectType, String, Schema
class Query(ObjectType):
# this defines a Field `hello` in our Schema with a single Argument `name`
hello = String(name=String(default_value="stranger"))
goodbye = String()
# our Resolver method takes the GraphQL context (root, info) as well as
# Argument (name) for the Field and returns data for the query Response
def resolve_hello(root, info, name):
return f'Hello {name}!'
def resolve_goodbye(root, info):
return 'See ya!'
schema = Schema(query=Query)
type Query {
hello(name: String = "stranger"): String
goodbye: String
}
Basic Schema ๐
Code ๐
Querying ๐
# we can query for our field (with the default argument)
query_string = '{ hello }'
result = schema.execute(query_string)
print(result.data['hello'])
# "Hello stranger"
# or passing the argument in the query
query_with_argument = '{ hello(name: "GraphQL") }'
result = schema.execute(query_with_argument)
print(result.data['hello'])
# "Hello GraphQL!"
Hello stranger!
Hello GraphQL!
data:image/s3,"s3://crabby-images/7aba1/7aba1da4788cd36e58f34a74a6be55c5263d3456" alt=""
๐จโ๐ณ ๐ณ
Use cases of GraphQL
- GraphQL with connected DB
- GraphQL with integrated / 3rd party API (REST)
- The Hybrid approach
Conclusion :
- GraphQL is query language for API whereas REST is pattern
- GraphQL is for complex problems - heavy data exchange
- GraphQL is new REST, it's not *Really* end of REST
Depends on your use case and approach
data:image/s3,"s3://crabby-images/aa7df/aa7df12ee00942ff724d65ee0fd9950ae00b1258" alt=""
Resources
*All about API's* -
data:image/s3,"s3://crabby-images/46923/46923739cc1a325e36a9333ab7fa719c7f609a1d" alt=""