Skip to content

🔥 A simple game by passing potato to anyone so they fall into Hall of Shame, built on a serverless GraphQL and Vue.js

License

Notifications You must be signed in to change notification settings

AlbertLucianto/hot-potato

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Hot Potato Game logo

Overview

Hot potato is a simple game inpsired (or cloned to be exact) by Google internal tool. Players simply can create and pass potato to anyone for a limited time, otherwise they will drop it.

Dependencies

Server

GraphQL Graphcool Docker TypeScript

Client

VueJS Apollo Client

Database

Database is configured by Graphcool Framework by default

Deployment

Server

If any version of graphcool is installed on your machine, uninstall it using npm uninstall -g graphcool. It's package name is now changed to graphcool-framework.

  1. Install graphcool-cli with npm install -g graphcool-framework.
  2. It is suggested to make an alias of graphcool-framework command to gc. For MacOS, can configure it in ~/.bash_profile.

From here, every command of gc refers to graphcool-framework.

Local

  1. Set server as current working directory.
  2. Ensure docker is installed on the machine. Run it.
  3. Run gc local up --name <any_name_for_cluster>. It will create three docker containers, including MySQL database.
  4. Run gc deploy.
  5. If .graphcoolrc file is not yet there, it will ask you to choose a cluster, and automatically create the file. Else, delete .graphcoolrc file as it may fail the setup

Client

  1. Make sure you have set up the server
  2. Set server as current working directory.
  3. Get the server api url by running gc info, it will print out list of API and Endpoints. Copy the endpoint with Simple API.
  4. Go to client/config as working directory.
  5. Duplicate file apollo.config.template.js and change the name into apollo.config.js
  6. Set the uri to the endpoint just copied.
  7. Run dev server with npm run dev.

Re-Deployment

Some changes in graphql type schema may break something and difficult to fix. You can create a fresh cluster by deleting the old and create the new one.

To delete the containers, run:

# stop all running containers
docker stop $(docker ps -a -q)

# remove all running containers
docker rm $(docker ps -a -q)

But, you may encounter this error when deploying with the same project name: project <project_name> already exists. It was caused by dangling volume in docker.

Thus, to clear them, lastly run: warning: it will also clear other docker containers

# remove all dangling volumes
docker volume rm `docker volume ls -q -f dangling=true`

# or for Graphcool 1.0
gc local nuke

Access MySQL in local deployment

It is not recommended since graphcool uses its own hashing for its database implementation, thus it's not readable.

However you do so by:

  1. List running docker container docker ps. Check for the mysql container ID.
  2. Run docker exec -it <CONTAINER_ID> sh. Then do mysql -u root -p.
  3. Type graphcool when prompted for password.
  4. That's it!

About

🔥 A simple game by passing potato to anyone so they fall into Hall of Shame, built on a serverless GraphQL and Vue.js

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published