Welcome to Advanced GraphQL! In order to make the best use of people's time, we ask you to please take the time to set a few things up before the class. NOTE: If your employer-provided laptop uses a proxy, it may block these services. The best solution is to use a personal laptop which has unrestricted access to the internet. If you are blocked on this, please contact us as soon as possible.
You will need one more api (Apollo Engine), but you can start with your .env files from the fundamentals class.
You can see that we have also made a few changes to the project:
- The Create React App structure has been "ejected" (we have a webpack config)
- We are therefore able to use .gql files for queries instead of .js
- We have used fragments to standardize query fields between different client GraphQL operations.
- We have split our schema up into multiple files
These changes form a better foundation for advanced GraphQL patterns.
You will need to get two servers working, one for the GraphQL API, and one for the React UI.
If the api
server is running correctly, you will see the following at localhost:4000:
Detailed instructions can be found here
If the ui
server is running correctly, you will see the following at localhost:3000. Logging in won't work yet
Detailed instructions can be found here
We’ll use Git to complete exercises.
We recommend VS Code with the following packages installed:
- ESLint
- One of:
- GraphQL for VSCode (or)
- GraphQL (newer)
- Prettier - Code formatter
If you prefer to use another editor, please check for corresponding packages.
You’ll need Node.js installed. We recommend the use of NVM. You can also install it from the official website. We’ll use Node 11. The packages are not guaranteed to work with other releases.
Though Node comes with a package manager called npm, we’ll use Yarn, a modern deterministic packager.
We will explore all of this thoroughly during the course, but if you are not comfortable with the following concepts, these links are worth a look.
We won’t cover basic JS syntax. You should know at least how to write a function. If you don’t, please take this free course on Codecademy.
Recent tools are making good use of the newest features in ES2015 and even ES2016 and ES2017. The newest JavaScript is a joy to use. If you haven't tried these, we hope you'll enjoy getting to know the new JS: http://es6-features.org/
Used in this class
- modules with import/export
- const and let
- arrow functions
- destructuring, rest and spread operators
- template literals (everywhere, but a special use in GraphQL)
- async/await - APIs and Apollo
- Array.concat()
We will be using React to render client components.
One nice thing about React is that it is close to base JS, so you should be able to follow even if you are new to it. Nevertheless, some understanding of it will be highly useful. We will implement the GraphQL integration with render props. We'll help you if this is new to you.
Some background on GraphQL: “So what’s this GraphQL thing I keep hearing about?”
We will be using Apollo for client and server GraphQL operations. You can get a head start by reviewing the documentation, but we will cover everything you need to know during the class.
Depending on your current level, you can expect to spend up to several hours on this material. It's worth it, and you will get much more from the class. If anything here is confusing or you want to clarify a fine point, please get in touch. We are happy to answer your questions, before, during, and after the class.
You can email us at [email protected]
We strive to use best practices in this repo, but we prioritize the learning experience where necessary.
This usually just means a simplified file structure, but this app lacks some safety and security features, so please use your judgment when reusing this code.
If you have any questions or concerns about specific code, please ask us; we love to talk about code quality.
You will need to get two servers working, /api
is the GraphQL API, and /ui
is the React UI.
For your convenience, we will provide Google and Darksky API keys for your use during the training because these both require a credit card to set up. NOTE: These will be revoked sometime soon after the training, which means the app will stop working correctly until you replace them with your own. If you prefer you can get your own now instead.
- Google:
AIzaSyA_CSe2Nu2Nry6NinhfMT9OMoBpzz1901Y
- Dark Sky:
ffa903008f2fec70757cd590c50c3756
NOTE for Windows users: This app starts MongoDB automatically when you run the api server, using the mongodb-prebuilt npm package. Currently it seems to be broken on Windows, so you can independently install Mongo and run MongoDB before starting the api server. Then add MONGO_PORT=
(with the correct port number) to api/.env
.
# make a .env file from the example
cp .env.example .env
Update the .env file with the correct API keys. For your convenience, we will provide Google and Darksky API keys for your use during the training – these will be revoked after the training. If you prefer, you can get your own keys:
GOOGLE_API_KEY
– use our temporary one (see above), or get your own: click "Get Started" and choose Places to enable an API key withgeocoding
. Google will collect billing information, but we will not incur any costs during this training.DARKSKY_API_KEY
- use our temporary one (see above), or get your own.ENGINE_API_KEY
- you will need to get your own Apollo Engine key (it's free): sign in and then create a new service.
# install the dependencies
yarn
# run the API server
yarn start
This is not required for setup, but if you end up with a lot of place
s while developing or your data gets corrupted, you can reset the db to the default setup with:
yarn reset-db
This project was bootstrapped with Create React App.
# make a .env file from the example
cp .env.example .env
Update the .env file with your api keys:
- REACT_APP_GOOGLE_API_KEY: use the key you entered in the api folder as GOOGLE_API_KEY
# install the dependencies
yarn
# run the web server
yarn start
If you have issues you can't resolve, please contact us before the class if at all possible. If you resolve your problem, please let us know what you did so we can improve this readme. Here are a some pointers:
- Make sure you are on Node 11. Both earlier and later versions may not work as expected.
- MongoDB errors: This app starts MongoDB automatically when you run the api server. If you get MongoDB errors, start by checking your Node version. If it still doesn't work, you can independently install Mongo and run the database with
mongod
before starting the api server. Then addMONGO_PORT=
(with the correct port number) toapi/.env
. - external API problems:
- Make sure you set up .env files in both
api/
andui/
. You'll need to restart the servers for changes to take effect. - If Google gives you an authorization error, make sure your Google API key includes
geocoding
, and make a new one if not. They key that we provide should have the correct permissions. - Make sure your laptop is not blocking outside api calls via a proxy. You may be able to stop the proxy (e.g., in a Vagrant dev setup), but if you can't, you may want to use a personal laptop instead. Contact us if you think this is a blocker for you.
- Make sure you set up .env files in both