GraphQL
REST is just to provide an API, so how do you connect GraphQL to a website?
Relay is the glue
GraphQL provides the API
React is your front end
Relay helps React communicate with GraphQL
GraphQL
queries on matched types (so fb can fetch exact media type resources, like video, so users can watch the video on initial load without having to fetch every resources)
Only allowed to create subgraphs for web3/Ethereum Network
In other words, other blockchains like Cosmos Network is not supported.
More APIs
Star Wars API https://graphql.org/swapi-graphql
Defining a Schema
Resolver
The payload of a GraphQL query (or mutation) consists of a set offields.
In the GraphQL server implementation, each of these fields actually corresponds to exactly one function that’s called a resolver .
The sole purpose of a resolver function is to fetch the data for its field.
When the server receives a query, it will call the functions for the fields that are specified in the query’s payload.
It thus resolves the query and is able to retrieve the correct data for each field.
Once all resolvers returned, the server will package data up in the format that was described by the query and send it back to the client.
Steps
after
create-react-app
, mkdir components and styles(../styles/index.css)
configure ApolloClient in
src/index.js
set up backend
mkdir server with
/prisma
and/src
deploy the Prisma database service
navigate GraphQL playground
queries with Apollo Client
When a query is received by the server, it will resolve it and retrieve the required data from the connected database.
Apollo
apollo-client
where all the magic happens.apollo-cache-memory
recommended cacheapollo-link-http
an apollo link for remote data fetchingapollo-link-error
an apollo link for error handlingapollo-link-state
an apollo link for local state managementgraphql-tag
exports the gql function for your queries & mutationsreact-apollo
contains the bindings to use Apollo Client with Reactqueries:
GET
requestmutations:
POST
request
Prisma
provides the database layer which offers CRUD operations. The second layer is the application layer for business logic and common workflows (like authentication).
Apollo Client
Query, Mutation
ApolloConsumer is similar to React Context API
use the ApolloConsumer component for firing queries manually in response to a user action, like a button click, or for prefetching data.
The declarative way for loading data with React & Apollo is using the <Query />
component and passing GraphQL query as prop
<Mutation />
component allow variables, optimisticResponse, refetchQueries, and update as props
The Graph Explorer
Last updated