Giter VIP home page Giter VIP logo

snowtooth's Introduction

Snowtooth GraphQL API ๐Ÿ”

Snowtooth Mountain is a fake ski resort, but that shouldn't prevent it from having a real GraphQL API.

You write queries at the project website using GraphQL Playground: http://snowtooth.moonhighway.com. To view a list of all of the available queries, mutations, and subscriptions, click the Schema tab on the right side of the screen.

Running the Project Locally ๐Ÿšก

To run the project locally, follow these instructions:

Basic Setup

  1. Download/clone the repo.
  2. Run npm install or yarn to install the dependencies.
  3. View GraphQL Playground running on http://localhost:4000.

Adding Apollo Engine

Want to integrate with Apollo Engine? Follow these instructions:

  1. Create a free Apollo Engine account.
  2. Get an Apollo Engine Key.
  3. Create a .env file and put it at the root of the project.
  4. In the .env file, add the following line:
ENGINE_API_KEY=<your-apollo-engine-key>

Then shred on some lift and trail data from the greatest fake ski resort on Earth! โ›ท

Caveats ๐Ÿš 

This is a demo app to allow students of Moon Highway or GraphQL Workshop courses to start working with GraphQL. It updates the database (JSON files) each time someone sends a mutation, so some inconsistencies may appear if multiple people are running mutations at the same time.

snowtooth's People

Contributors

eveporcello avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

snowtooth's Issues

Clear Errors

We should throw clear errors from resolvers and add an error handling lesson to this api.

Incorporate Apollo Engine

We need to know who is using this repo and how much it is being used.

TODO

  • Hook production repo up to Apollo Engine
  • Incorporate Apollo Engine schema diffing on all pull requests

running without Apollo Engine causes an error

Error message:

[nodemon] starting 'babel-node -r node_modules/dotenv/config ./src' /moonhighway/snowtooth/node_modules/apollo-server-core/dist/ApolloServer.js:51 else if (typeof engine === 'object' && engine.apiKey) { ^TypeError: Cannot read property 'apiKey' of null

Simple fix, if not using Apollo Engine, is to comment out the engine value in new ApolloServer call in index.js, shown below

const server = new ApolloServer({ typeDefs, resolvers, context, // engine: process.env.ENGINE_API_KEY // ? { apiKey: process.env.ENGINE_API_KEY } // : null });

--

Thanks for the awesome hooks tutorial, very well done

Incorporate Employees

We need to incorporate the Employees schema and resolvers from the Unions and Interfaces example.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.