Skip to content

c0d-x/apollo-project-starter

Repository files navigation

Apollo project starter

A project starter using Apollo GraphQL that serves as a proxy to TheCatApi

Demos

Requirements

  • node >= 10

  • yarn >= 1.16.0

Setup

Clone the project into your local workspace

$ git clone [email protected]:c0d-x/apollo-project-starter.git

$ cd apollo-project-starter

$ yarn install

Copy .env.dist to .env and fill it with local env configuration.

$ cp .env.dist .env

Launch the server

$ yarn server:start

If you wish to start the demo client as well, you can run the following commands:

$ yarn client:build
$ yarn client:start

GraphQL Playground

Once the server is started you can use the GraphQL Playground to play with the API:

http://localhost:4000/graphql

note: To use another port, update your .env file.

note: When NODE_ENV is set to production the Playground is disabled as a best-practice.

Query samples

List images:

query {
  getImages(limit: 10) {
    id
    url
  }
}

Get breeds:

query {
  getBreeds {
    id
    name
    description
    origin
    mood
    ratings {
      affection
      energy
      intelligence
      sociability
      vocality
    }
  }
}

Mutation samples

Vote for an image

mutation {
  createVote(input: { imageId:"s", vote:UP }) {
    id
    createdAt
    imageId
    value
  }
}

Architecture

This project uses a mono-repo approach using only yarn workspaces.

There are 4 sub-projects:

  • client is a simple client in react for demo (nothing interesting here)

  • datas is where our graphQL data model is

  • server serves an Apolllo GraphQL server

  • datasources contains classes that encapsulate fetching data from external APIs, DB etc

note: We use scripts in the top package.json to call scripts in specific workspace

note: yarn workspace <workspace_name> <script_name>

Resources

TODO

  • Implement a client

  • Implement authentication

  • Use dataloaders as an example

  • Improve exception management

  • Add other types of datasources

  • Add more tests

  • Deploy a demo client

  • Deploy a demo playground