Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/applification/graphql-loader
GraphQL Express Facebook DataLoader
https://github.com/applification/graphql-loader
Last synced: 2 months ago
JSON representation
GraphQL Express Facebook DataLoader
- Host: GitHub
- URL: https://github.com/applification/graphql-loader
- Owner: applification
- Created: 2016-03-11T21:32:26.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2016-03-17T18:52:49.000Z (almost 9 years ago)
- Last Synced: 2024-10-31T18:38:15.380Z (2 months ago)
- Language: JavaScript
- Size: 29.3 KB
- Stars: 52
- Watchers: 2
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-graphql - graphql-loader - Example project to illustrate GraphQL, Express and Facebook DataLoader to connect to third party REST API (Examples / JavaScript Examples)
README
# GraphQL + Express + Facebook DataLoader
> A small project to illustrate using GraphQL Queries with a REST API combined with the Facebook DataLoader library.
#### Project Goals:
* Create a GraphQL + Express + Loader project that is as __simple as possible
* __GraphiQL Integration__ to send Queries / Mutations
* Ability to use __Postman or other REST Client__ to POST GraphQL Queries / Mutations
* Use of __ES6__ (but minimally)
* Use GraphQL queries to make REST API calls using Facebook DataLoader so that the number of API requests is reduced to a minimum## SWAPI REST API
This project makes use of the Star Wars REST API at http://swapi.co/ to demonstrate a GraphQL Server running on Express integrated with Facebook DataLoder to cache and reduce the number of API calls required to return JSON data.## Installation
#### ES6 / Node V4+
This project makes use of ES6 which requires a 4+ version of Node https://nodejs.org/en/download/#### NPM Modules
The following NPM modules are required in package.json:* express
* express-graphql
* graphql
* axios
* dataloader
* babel-cli
* babel-preset-es2015
* nodemonInstall with:
```js
npm install
```#### Run the project
##### Running in Development
npm dev is configured with nodmon so that the server automatically restarts when code files are changes
```js
npm run dev
```##### Running in Production
```js
npm start
```
npm prestart will run first, transpile the ES6 code and save to _dist_ folder. npm start will then run the code directly from the _dist_ folder## Running GraphQL Queries
You can run these queries within GraphiQL, alternatively you can run them within a tool such as Postman. To do so ensure you POST the query / mutation in the body and set the content-type to GraphQL.#### Find a film by Id
```js
query {
film (id:"1") {
title,
director
}
}
```#### Find a vehicle by Id
```js
query {
vehicle(id: "8") {
name
}
}
```#### Find a starship by Id
```js
query {
starship(id:"5") {
name
}
}
```#### Find species by Id
```js
query {
species(id:"1") {
name
}
}
```#### Find planet by Id
```js
query {
planet(id: "1") {
name
}
}
```#### Find character by Id
```js
query {
character (id: "1") {
name,
height,
mass,
hair_color,
skin_color,
eye_color,
birth_year,
gender,
homeworld {
name
rotation_period
orbital_period
diameter
climate
gravity
terrain
surface_water
population
residents {
name
birth_year
gender
}
created
edited
},
films {
title
director
},
species {
name,
classification,
designation,
language,
people {
name
birth_year
gender
},
films {
title
director
}
}
vehicles{
name,
model,
cost_in_credits,
length,
crew,
passengers,
vehicle_class,
pilots {
name
},
films {
title
}
}
starships{
name,
model,
cost_in_credits,
length,
crew,
passengers,
hyperdrive_rating,
starship_class,
pilots {
name
},
films {
title
}
}
created,
edited
}
}
```