Skip to content

Latest commit

 

History

History
151 lines (107 loc) · 5.42 KB

README.md

File metadata and controls

151 lines (107 loc) · 5.42 KB

-quiz-gghlo

How to use this locally

Prerequisites

Our project uses Express.JS with Typescript and Node. These are the versions we're running which can be installed with npm install:

  • Express: 4.17.21
  • Node: 20.12.12
  • Typescript: 5.4.5

Installation

Here are instructions for how to install this locally on the repo:

  1. Clone the repo
git clone https://github.com/fac29/-quiz-gghlo
  1. Install NPM packages
npm install
  1. Enter the following script to create the build/index.js and runs the server.
npm start

API Endpoints

These are our endpoints and how we're using them.

URI HTTP Method POST body Result
/ GET empty Show categories of questions and number of questions in those categories (currently returning whole database)
/questions GET JSON string Submit category and difficulty to filter by
/questions POST JSON string Category, difficulty, questions, options and answer. Timestamp and id are generated automatically
/questions/:id PUT JSON string Update existing question with favouriting?
/questions/:id DELETE JSON string Delete existing question

Using endpoints

To use the endpoints, you will need to install Postman or Bruno and then do the following:

Server path: http://localhost:3210/

  1. GET In order to retrieve questions, you can retrieve the whole database or optionally filter by category, difficulty and number of questions. For example, you can use the following path to find easy Science questions: http://localhost:3210/questions?category=Science&difficulty=easy&questions_number=1

    You should receive the following result:

     [
         {
             "id": 1,
             "category": "Science",
             "difficulty": "easy",
             "question": "What is the chemical symbol for Hydrogen?",
             "options": [
                 "H",
                 "He",
                 "Hy",
                 "Ho"
             ],
             "answer": "H",
             "favourited": true,
             "timestamp": "2023-04-01T10:00:00Z"
         }
     ]
    
  2. POST In order to create/add questions, you should use this endpoint: http://localhost:3210/questions/

Note that id, timestamp and favourited are automatically generated. In future it would be useful to add means to favourite a created question at the point of creation.

Here is an example question object you can submit in the POST body:

{
  		"category": "History",
  		"difficulty": "easy",
  		"question": "When was Princess Diana born?",
  		"options": ["01/07/1998", "07/07/1998", "02/02/1961", "09/09/1990"],
  		"answer": "02/02/1961",
  	}
  1. PUT In order to update existing questions, you should use this endpoint: http://localhost:3210/questions/:id

Here is an example object you can submit in the PUT body:

{
    "id": 31,
    "category": "History",
  		"difficulty": "easy",
  		"question": "When did Princess Diana die?",
  		"options": ["01/07/1998", "07/07/1998", "02/02/1961", "09/09/1990"],
  		"answer": "07/07/1998",
  	}
  1. DELETE In order to delete existing questions, you should use this endpoint: http://localhost:3210/questions/:id

    Here is an example path you can submit on Postman/Bruno: http://localhost:3210/questions/31

    When you check data.json, the question should no longer be there.

Testing our code works

We used Postman to test our endpoints. You can find the local and server tests here.

You will need to set up the following global environment variables:

Local Host: http://localhost:3210/
AWS: https://13.60.83.197:2345/

Prettier configuration

We are using Prettier to ensure our codebase is formatted in the same way and avoid conflicts.

To access Prettier settings on VSCode, go to Settings > Search for 'prettier'

The following are settings we've updated from the default:

Prettier: Jsx Single Quote (ticked) Use single quotes instead of double quotes in JSX.

Prettier: Single Quote (ticked) Use single instead of double quotes

Prettier: Use Tabs (ticked) Indent lines with tabs.

Editor: Default Formatter Defines a default formatter which takes precedence over all other formatter settings. Must be the identifier of an extension contributing a formatter. Set to 'Prettier - Code formatter'

Creating SSL keys to use HTTPS

In order to use HTTPS you will need to create your own SSL keys. You can use the commands below on a Linux terminal:

openssl genrsa -out localhost-key.pem 2048

openssl req -new -x509 -sha256 -key localhost-key.pem -out localhost.pem -days 365

Once these have been installed save them in the build/ folder so the server can access them when it's running.